[ Index ] |
PHP Cross Reference of WordPress |
[Summary view] [Print] [Text view]
1 /******/ (function() { // webpackBootstrap 2 /******/ var __webpack_modules__ = ({ 3 4 /***/ 6411: 5 /***/ (function(module, exports) { 6 7 var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;/*! 8 autosize 4.0.4 9 license: MIT 10 http://www.jacklmoore.com/autosize 11 */ 12 (function (global, factory) { 13 if (true) { 14 !(__WEBPACK_AMD_DEFINE_ARRAY__ = [module, exports], __WEBPACK_AMD_DEFINE_FACTORY__ = (factory), 15 __WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === 'function' ? 16 (__WEBPACK_AMD_DEFINE_FACTORY__.apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__)) : __WEBPACK_AMD_DEFINE_FACTORY__), 17 __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__)); 18 } else { var mod; } 19 })(this, function (module, exports) { 20 'use strict'; 21 22 var map = typeof Map === "function" ? new Map() : function () { 23 var keys = []; 24 var values = []; 25 26 return { 27 has: function has(key) { 28 return keys.indexOf(key) > -1; 29 }, 30 get: function get(key) { 31 return values[keys.indexOf(key)]; 32 }, 33 set: function set(key, value) { 34 if (keys.indexOf(key) === -1) { 35 keys.push(key); 36 values.push(value); 37 } 38 }, 39 delete: function _delete(key) { 40 var index = keys.indexOf(key); 41 if (index > -1) { 42 keys.splice(index, 1); 43 values.splice(index, 1); 44 } 45 } 46 }; 47 }(); 48 49 var createEvent = function createEvent(name) { 50 return new Event(name, { bubbles: true }); 51 }; 52 try { 53 new Event('test'); 54 } catch (e) { 55 // IE does not support `new Event()` 56 createEvent = function createEvent(name) { 57 var evt = document.createEvent('Event'); 58 evt.initEvent(name, true, false); 59 return evt; 60 }; 61 } 62 63 function assign(ta) { 64 if (!ta || !ta.nodeName || ta.nodeName !== 'TEXTAREA' || map.has(ta)) return; 65 66 var heightOffset = null; 67 var clientWidth = null; 68 var cachedHeight = null; 69 70 function init() { 71 var style = window.getComputedStyle(ta, null); 72 73 if (style.resize === 'vertical') { 74 ta.style.resize = 'none'; 75 } else if (style.resize === 'both') { 76 ta.style.resize = 'horizontal'; 77 } 78 79 if (style.boxSizing === 'content-box') { 80 heightOffset = -(parseFloat(style.paddingTop) + parseFloat(style.paddingBottom)); 81 } else { 82 heightOffset = parseFloat(style.borderTopWidth) + parseFloat(style.borderBottomWidth); 83 } 84 // Fix when a textarea is not on document body and heightOffset is Not a Number 85 if (isNaN(heightOffset)) { 86 heightOffset = 0; 87 } 88 89 update(); 90 } 91 92 function changeOverflow(value) { 93 { 94 // Chrome/Safari-specific fix: 95 // When the textarea y-overflow is hidden, Chrome/Safari do not reflow the text to account for the space 96 // made available by removing the scrollbar. The following forces the necessary text reflow. 97 var width = ta.style.width; 98 ta.style.width = '0px'; 99 // Force reflow: 100 /* jshint ignore:start */ 101 ta.offsetWidth; 102 /* jshint ignore:end */ 103 ta.style.width = width; 104 } 105 106 ta.style.overflowY = value; 107 } 108 109 function getParentOverflows(el) { 110 var arr = []; 111 112 while (el && el.parentNode && el.parentNode instanceof Element) { 113 if (el.parentNode.scrollTop) { 114 arr.push({ 115 node: el.parentNode, 116 scrollTop: el.parentNode.scrollTop 117 }); 118 } 119 el = el.parentNode; 120 } 121 122 return arr; 123 } 124 125 function resize() { 126 if (ta.scrollHeight === 0) { 127 // If the scrollHeight is 0, then the element probably has display:none or is detached from the DOM. 128 return; 129 } 130 131 var overflows = getParentOverflows(ta); 132 var docTop = document.documentElement && document.documentElement.scrollTop; // Needed for Mobile IE (ticket #240) 133 134 ta.style.height = ''; 135 ta.style.height = ta.scrollHeight + heightOffset + 'px'; 136 137 // used to check if an update is actually necessary on window.resize 138 clientWidth = ta.clientWidth; 139 140 // prevents scroll-position jumping 141 overflows.forEach(function (el) { 142 el.node.scrollTop = el.scrollTop; 143 }); 144 145 if (docTop) { 146 document.documentElement.scrollTop = docTop; 147 } 148 } 149 150 function update() { 151 resize(); 152 153 var styleHeight = Math.round(parseFloat(ta.style.height)); 154 var computed = window.getComputedStyle(ta, null); 155 156 // Using offsetHeight as a replacement for computed.height in IE, because IE does not account use of border-box 157 var actualHeight = computed.boxSizing === 'content-box' ? Math.round(parseFloat(computed.height)) : ta.offsetHeight; 158 159 // The actual height not matching the style height (set via the resize method) indicates that 160 // the max-height has been exceeded, in which case the overflow should be allowed. 161 if (actualHeight < styleHeight) { 162 if (computed.overflowY === 'hidden') { 163 changeOverflow('scroll'); 164 resize(); 165 actualHeight = computed.boxSizing === 'content-box' ? Math.round(parseFloat(window.getComputedStyle(ta, null).height)) : ta.offsetHeight; 166 } 167 } else { 168 // Normally keep overflow set to hidden, to avoid flash of scrollbar as the textarea expands. 169 if (computed.overflowY !== 'hidden') { 170 changeOverflow('hidden'); 171 resize(); 172 actualHeight = computed.boxSizing === 'content-box' ? Math.round(parseFloat(window.getComputedStyle(ta, null).height)) : ta.offsetHeight; 173 } 174 } 175 176 if (cachedHeight !== actualHeight) { 177 cachedHeight = actualHeight; 178 var evt = createEvent('autosize:resized'); 179 try { 180 ta.dispatchEvent(evt); 181 } catch (err) { 182 // Firefox will throw an error on dispatchEvent for a detached element 183 // https://bugzilla.mozilla.org/show_bug.cgi?id=889376 184 } 185 } 186 } 187 188 var pageResize = function pageResize() { 189 if (ta.clientWidth !== clientWidth) { 190 update(); 191 } 192 }; 193 194 var destroy = function (style) { 195 window.removeEventListener('resize', pageResize, false); 196 ta.removeEventListener('input', update, false); 197 ta.removeEventListener('keyup', update, false); 198 ta.removeEventListener('autosize:destroy', destroy, false); 199 ta.removeEventListener('autosize:update', update, false); 200 201 Object.keys(style).forEach(function (key) { 202 ta.style[key] = style[key]; 203 }); 204 205 map.delete(ta); 206 }.bind(ta, { 207 height: ta.style.height, 208 resize: ta.style.resize, 209 overflowY: ta.style.overflowY, 210 overflowX: ta.style.overflowX, 211 wordWrap: ta.style.wordWrap 212 }); 213 214 ta.addEventListener('autosize:destroy', destroy, false); 215 216 // IE9 does not fire onpropertychange or oninput for deletions, 217 // so binding to onkeyup to catch most of those events. 218 // There is no way that I know of to detect something like 'cut' in IE9. 219 if ('onpropertychange' in ta && 'oninput' in ta) { 220 ta.addEventListener('keyup', update, false); 221 } 222 223 window.addEventListener('resize', pageResize, false); 224 ta.addEventListener('input', update, false); 225 ta.addEventListener('autosize:update', update, false); 226 ta.style.overflowX = 'hidden'; 227 ta.style.wordWrap = 'break-word'; 228 229 map.set(ta, { 230 destroy: destroy, 231 update: update 232 }); 233 234 init(); 235 } 236 237 function destroy(ta) { 238 var methods = map.get(ta); 239 if (methods) { 240 methods.destroy(); 241 } 242 } 243 244 function update(ta) { 245 var methods = map.get(ta); 246 if (methods) { 247 methods.update(); 248 } 249 } 250 251 var autosize = null; 252 253 // Do nothing in Node.js environment and IE8 (or lower) 254 if (typeof window === 'undefined' || typeof window.getComputedStyle !== 'function') { 255 autosize = function autosize(el) { 256 return el; 257 }; 258 autosize.destroy = function (el) { 259 return el; 260 }; 261 autosize.update = function (el) { 262 return el; 263 }; 264 } else { 265 autosize = function autosize(el, options) { 266 if (el) { 267 Array.prototype.forEach.call(el.length ? el : [el], function (x) { 268 return assign(x, options); 269 }); 270 } 271 return el; 272 }; 273 autosize.destroy = function (el) { 274 if (el) { 275 Array.prototype.forEach.call(el.length ? el : [el], destroy); 276 } 277 return el; 278 }; 279 autosize.update = function (el) { 280 if (el) { 281 Array.prototype.forEach.call(el.length ? el : [el], update); 282 } 283 return el; 284 }; 285 } 286 287 exports.default = autosize; 288 module.exports = exports['default']; 289 }); 290 291 /***/ }), 292 293 /***/ 4403: 294 /***/ (function(module, exports) { 295 296 var __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;/*! 297 Copyright (c) 2018 Jed Watson. 298 Licensed under the MIT License (MIT), see 299 http://jedwatson.github.io/classnames 300 */ 301 /* global define */ 302 303 (function () { 304 'use strict'; 305 306 var hasOwn = {}.hasOwnProperty; 307 308 function classNames() { 309 var classes = []; 310 311 for (var i = 0; i < arguments.length; i++) { 312 var arg = arguments[i]; 313 if (!arg) continue; 314 315 var argType = typeof arg; 316 317 if (argType === 'string' || argType === 'number') { 318 classes.push(arg); 319 } else if (Array.isArray(arg)) { 320 if (arg.length) { 321 var inner = classNames.apply(null, arg); 322 if (inner) { 323 classes.push(inner); 324 } 325 } 326 } else if (argType === 'object') { 327 if (arg.toString === Object.prototype.toString) { 328 for (var key in arg) { 329 if (hasOwn.call(arg, key) && arg[key]) { 330 classes.push(key); 331 } 332 } 333 } else { 334 classes.push(arg.toString()); 335 } 336 } 337 } 338 339 return classes.join(' '); 340 } 341 342 if ( true && module.exports) { 343 classNames.default = classNames; 344 module.exports = classNames; 345 } else if (true) { 346 // register as 'classnames', consistent with npm package name 347 !(__WEBPACK_AMD_DEFINE_ARRAY__ = [], __WEBPACK_AMD_DEFINE_RESULT__ = (function () { 348 return classNames; 349 }).apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__), 350 __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__)); 351 } else {} 352 }()); 353 354 355 /***/ }), 356 357 /***/ 4827: 358 /***/ (function(module) { 359 360 // This code has been refactored for 140 bytes 361 // You can see the original here: https://github.com/twolfson/computedStyle/blob/04cd1da2e30fa45844f95f5cb1ac898e9b9ef050/lib/computedStyle.js 362 var computedStyle = function (el, prop, getComputedStyle) { 363 getComputedStyle = window.getComputedStyle; 364 365 // In one fell swoop 366 return ( 367 // If we have getComputedStyle 368 getComputedStyle ? 369 // Query it 370 // TODO: From CSS-Query notes, we might need (node, null) for FF 371 getComputedStyle(el) : 372 373 // Otherwise, we are in IE and use currentStyle 374 el.currentStyle 375 )[ 376 // Switch to camelCase for CSSOM 377 // DEV: Grabbed from jQuery 378 // https://github.com/jquery/jquery/blob/1.9-stable/src/css.js#L191-L194 379 // https://github.com/jquery/jquery/blob/1.9-stable/src/core.js#L593-L597 380 prop.replace(/-(\w)/gi, function (word, letter) { 381 return letter.toUpperCase(); 382 }) 383 ]; 384 }; 385 386 module.exports = computedStyle; 387 388 389 /***/ }), 390 391 /***/ 1198: 392 /***/ (function(__unused_webpack_module, exports) { 393 394 "use strict"; 395 /*istanbul ignore start*/ 396 397 398 Object.defineProperty(exports, "__esModule", ({ 399 value: true 400 })); 401 exports["default"] = Diff; 402 403 /*istanbul ignore end*/ 404 function Diff() {} 405 406 Diff.prototype = { 407 /*istanbul ignore start*/ 408 409 /*istanbul ignore end*/ 410 diff: function diff(oldString, newString) { 411 /*istanbul ignore start*/ 412 var 413 /*istanbul ignore end*/ 414 options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; 415 var callback = options.callback; 416 417 if (typeof options === 'function') { 418 callback = options; 419 options = {}; 420 } 421 422 this.options = options; 423 var self = this; 424 425 function done(value) { 426 if (callback) { 427 setTimeout(function () { 428 callback(undefined, value); 429 }, 0); 430 return true; 431 } else { 432 return value; 433 } 434 } // Allow subclasses to massage the input prior to running 435 436 437 oldString = this.castInput(oldString); 438 newString = this.castInput(newString); 439 oldString = this.removeEmpty(this.tokenize(oldString)); 440 newString = this.removeEmpty(this.tokenize(newString)); 441 var newLen = newString.length, 442 oldLen = oldString.length; 443 var editLength = 1; 444 var maxEditLength = newLen + oldLen; 445 var bestPath = [{ 446 newPos: -1, 447 components: [] 448 }]; // Seed editLength = 0, i.e. the content starts with the same values 449 450 var oldPos = this.extractCommon(bestPath[0], newString, oldString, 0); 451 452 if (bestPath[0].newPos + 1 >= newLen && oldPos + 1 >= oldLen) { 453 // Identity per the equality and tokenizer 454 return done([{ 455 value: this.join(newString), 456 count: newString.length 457 }]); 458 } // Main worker method. checks all permutations of a given edit length for acceptance. 459 460 461 function execEditLength() { 462 for (var diagonalPath = -1 * editLength; diagonalPath <= editLength; diagonalPath += 2) { 463 var basePath = 464 /*istanbul ignore start*/ 465 void 0 466 /*istanbul ignore end*/ 467 ; 468 469 var addPath = bestPath[diagonalPath - 1], 470 removePath = bestPath[diagonalPath + 1], 471 _oldPos = (removePath ? removePath.newPos : 0) - diagonalPath; 472 473 if (addPath) { 474 // No one else is going to attempt to use this value, clear it 475 bestPath[diagonalPath - 1] = undefined; 476 } 477 478 var canAdd = addPath && addPath.newPos + 1 < newLen, 479 canRemove = removePath && 0 <= _oldPos && _oldPos < oldLen; 480 481 if (!canAdd && !canRemove) { 482 // If this path is a terminal then prune 483 bestPath[diagonalPath] = undefined; 484 continue; 485 } // Select the diagonal that we want to branch from. We select the prior 486 // path whose position in the new string is the farthest from the origin 487 // and does not pass the bounds of the diff graph 488 489 490 if (!canAdd || canRemove && addPath.newPos < removePath.newPos) { 491 basePath = clonePath(removePath); 492 self.pushComponent(basePath.components, undefined, true); 493 } else { 494 basePath = addPath; // No need to clone, we've pulled it from the list 495 496 basePath.newPos++; 497 self.pushComponent(basePath.components, true, undefined); 498 } 499 500 _oldPos = self.extractCommon(basePath, newString, oldString, diagonalPath); // If we have hit the end of both strings, then we are done 501 502 if (basePath.newPos + 1 >= newLen && _oldPos + 1 >= oldLen) { 503 return done(buildValues(self, basePath.components, newString, oldString, self.useLongestToken)); 504 } else { 505 // Otherwise track this path as a potential candidate and continue. 506 bestPath[diagonalPath] = basePath; 507 } 508 } 509 510 editLength++; 511 } // Performs the length of edit iteration. Is a bit fugly as this has to support the 512 // sync and async mode which is never fun. Loops over execEditLength until a value 513 // is produced. 514 515 516 if (callback) { 517 (function exec() { 518 setTimeout(function () { 519 // This should not happen, but we want to be safe. 520 521 /* istanbul ignore next */ 522 if (editLength > maxEditLength) { 523 return callback(); 524 } 525 526 if (!execEditLength()) { 527 exec(); 528 } 529 }, 0); 530 })(); 531 } else { 532 while (editLength <= maxEditLength) { 533 var ret = execEditLength(); 534 535 if (ret) { 536 return ret; 537 } 538 } 539 } 540 }, 541 542 /*istanbul ignore start*/ 543 544 /*istanbul ignore end*/ 545 pushComponent: function pushComponent(components, added, removed) { 546 var last = components[components.length - 1]; 547 548 if (last && last.added === added && last.removed === removed) { 549 // We need to clone here as the component clone operation is just 550 // as shallow array clone 551 components[components.length - 1] = { 552 count: last.count + 1, 553 added: added, 554 removed: removed 555 }; 556 } else { 557 components.push({ 558 count: 1, 559 added: added, 560 removed: removed 561 }); 562 } 563 }, 564 565 /*istanbul ignore start*/ 566 567 /*istanbul ignore end*/ 568 extractCommon: function extractCommon(basePath, newString, oldString, diagonalPath) { 569 var newLen = newString.length, 570 oldLen = oldString.length, 571 newPos = basePath.newPos, 572 oldPos = newPos - diagonalPath, 573 commonCount = 0; 574 575 while (newPos + 1 < newLen && oldPos + 1 < oldLen && this.equals(newString[newPos + 1], oldString[oldPos + 1])) { 576 newPos++; 577 oldPos++; 578 commonCount++; 579 } 580 581 if (commonCount) { 582 basePath.components.push({ 583 count: commonCount 584 }); 585 } 586 587 basePath.newPos = newPos; 588 return oldPos; 589 }, 590 591 /*istanbul ignore start*/ 592 593 /*istanbul ignore end*/ 594 equals: function equals(left, right) { 595 if (this.options.comparator) { 596 return this.options.comparator(left, right); 597 } else { 598 return left === right || this.options.ignoreCase && left.toLowerCase() === right.toLowerCase(); 599 } 600 }, 601 602 /*istanbul ignore start*/ 603 604 /*istanbul ignore end*/ 605 removeEmpty: function removeEmpty(array) { 606 var ret = []; 607 608 for (var i = 0; i < array.length; i++) { 609 if (array[i]) { 610 ret.push(array[i]); 611 } 612 } 613 614 return ret; 615 }, 616 617 /*istanbul ignore start*/ 618 619 /*istanbul ignore end*/ 620 castInput: function castInput(value) { 621 return value; 622 }, 623 624 /*istanbul ignore start*/ 625 626 /*istanbul ignore end*/ 627 tokenize: function tokenize(value) { 628 return value.split(''); 629 }, 630 631 /*istanbul ignore start*/ 632 633 /*istanbul ignore end*/ 634 join: function join(chars) { 635 return chars.join(''); 636 } 637 }; 638 639 function buildValues(diff, components, newString, oldString, useLongestToken) { 640 var componentPos = 0, 641 componentLen = components.length, 642 newPos = 0, 643 oldPos = 0; 644 645 for (; componentPos < componentLen; componentPos++) { 646 var component = components[componentPos]; 647 648 if (!component.removed) { 649 if (!component.added && useLongestToken) { 650 var value = newString.slice(newPos, newPos + component.count); 651 value = value.map(function (value, i) { 652 var oldValue = oldString[oldPos + i]; 653 return oldValue.length > value.length ? oldValue : value; 654 }); 655 component.value = diff.join(value); 656 } else { 657 component.value = diff.join(newString.slice(newPos, newPos + component.count)); 658 } 659 660 newPos += component.count; // Common case 661 662 if (!component.added) { 663 oldPos += component.count; 664 } 665 } else { 666 component.value = diff.join(oldString.slice(oldPos, oldPos + component.count)); 667 oldPos += component.count; // Reverse add and remove so removes are output first to match common convention 668 // The diffing algorithm is tied to add then remove output and this is the simplest 669 // route to get the desired output with minimal overhead. 670 671 if (componentPos && components[componentPos - 1].added) { 672 var tmp = components[componentPos - 1]; 673 components[componentPos - 1] = components[componentPos]; 674 components[componentPos] = tmp; 675 } 676 } 677 } // Special case handle for when one terminal is ignored (i.e. whitespace). 678 // For this case we merge the terminal into the prior string and drop the change. 679 // This is only available for string mode. 680 681 682 var lastComponent = components[componentLen - 1]; 683 684 if (componentLen > 1 && typeof lastComponent.value === 'string' && (lastComponent.added || lastComponent.removed) && diff.equals('', lastComponent.value)) { 685 components[componentLen - 2].value += lastComponent.value; 686 components.pop(); 687 } 688 689 return components; 690 } 691 692 function clonePath(path) { 693 return { 694 newPos: path.newPos, 695 components: path.components.slice(0) 696 }; 697 } 698 699 700 /***/ }), 701 702 /***/ 1973: 703 /***/ (function(__unused_webpack_module, exports, __webpack_require__) { 704 705 "use strict"; 706 var __webpack_unused_export__; 707 /*istanbul ignore start*/ 708 709 710 __webpack_unused_export__ = ({ 711 value: true 712 }); 713 exports.Kx = diffChars; 714 __webpack_unused_export__ = void 0; 715 716 /*istanbul ignore end*/ 717 var 718 /*istanbul ignore start*/ 719 _base = _interopRequireDefault(__webpack_require__(1198)) 720 /*istanbul ignore end*/ 721 ; 722 723 /*istanbul ignore start*/ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } 724 725 /*istanbul ignore end*/ 726 var characterDiff = new 727 /*istanbul ignore start*/ 728 _base 729 /*istanbul ignore end*/ 730 . 731 /*istanbul ignore start*/ 732 default 733 /*istanbul ignore end*/ 734 (); 735 736 /*istanbul ignore start*/ 737 __webpack_unused_export__ = characterDiff; 738 739 /*istanbul ignore end*/ 740 function diffChars(oldStr, newStr, options) { 741 return characterDiff.diff(oldStr, newStr, options); 742 } 743 744 745 /***/ }), 746 747 /***/ 1345: 748 /***/ (function(module, __unused_webpack_exports, __webpack_require__) { 749 750 "use strict"; 751 752 753 var util = __webpack_require__(5022); 754 755 function scrollIntoView(elem, container, config) { 756 config = config || {}; 757 // document 归一化到 window 758 if (container.nodeType === 9) { 759 container = util.getWindow(container); 760 } 761 762 var allowHorizontalScroll = config.allowHorizontalScroll; 763 var onlyScrollIfNeeded = config.onlyScrollIfNeeded; 764 var alignWithTop = config.alignWithTop; 765 var alignWithLeft = config.alignWithLeft; 766 var offsetTop = config.offsetTop || 0; 767 var offsetLeft = config.offsetLeft || 0; 768 var offsetBottom = config.offsetBottom || 0; 769 var offsetRight = config.offsetRight || 0; 770 771 allowHorizontalScroll = allowHorizontalScroll === undefined ? true : allowHorizontalScroll; 772 773 var isWin = util.isWindow(container); 774 var elemOffset = util.offset(elem); 775 var eh = util.outerHeight(elem); 776 var ew = util.outerWidth(elem); 777 var containerOffset = undefined; 778 var ch = undefined; 779 var cw = undefined; 780 var containerScroll = undefined; 781 var diffTop = undefined; 782 var diffBottom = undefined; 783 var win = undefined; 784 var winScroll = undefined; 785 var ww = undefined; 786 var wh = undefined; 787 788 if (isWin) { 789 win = container; 790 wh = util.height(win); 791 ww = util.width(win); 792 winScroll = { 793 left: util.scrollLeft(win), 794 top: util.scrollTop(win) 795 }; 796 // elem 相对 container 可视视窗的距离 797 diffTop = { 798 left: elemOffset.left - winScroll.left - offsetLeft, 799 top: elemOffset.top - winScroll.top - offsetTop 800 }; 801 diffBottom = { 802 left: elemOffset.left + ew - (winScroll.left + ww) + offsetRight, 803 top: elemOffset.top + eh - (winScroll.top + wh) + offsetBottom 804 }; 805 containerScroll = winScroll; 806 } else { 807 containerOffset = util.offset(container); 808 ch = container.clientHeight; 809 cw = container.clientWidth; 810 containerScroll = { 811 left: container.scrollLeft, 812 top: container.scrollTop 813 }; 814 // elem 相对 container 可视视窗的距离 815 // 注意边框, offset 是边框到根节点 816 diffTop = { 817 left: elemOffset.left - (containerOffset.left + (parseFloat(util.css(container, 'borderLeftWidth')) || 0)) - offsetLeft, 818 top: elemOffset.top - (containerOffset.top + (parseFloat(util.css(container, 'borderTopWidth')) || 0)) - offsetTop 819 }; 820 diffBottom = { 821 left: elemOffset.left + ew - (containerOffset.left + cw + (parseFloat(util.css(container, 'borderRightWidth')) || 0)) + offsetRight, 822 top: elemOffset.top + eh - (containerOffset.top + ch + (parseFloat(util.css(container, 'borderBottomWidth')) || 0)) + offsetBottom 823 }; 824 } 825 826 if (diffTop.top < 0 || diffBottom.top > 0) { 827 // 强制向上 828 if (alignWithTop === true) { 829 util.scrollTop(container, containerScroll.top + diffTop.top); 830 } else if (alignWithTop === false) { 831 util.scrollTop(container, containerScroll.top + diffBottom.top); 832 } else { 833 // 自动调整 834 if (diffTop.top < 0) { 835 util.scrollTop(container, containerScroll.top + diffTop.top); 836 } else { 837 util.scrollTop(container, containerScroll.top + diffBottom.top); 838 } 839 } 840 } else { 841 if (!onlyScrollIfNeeded) { 842 alignWithTop = alignWithTop === undefined ? true : !!alignWithTop; 843 if (alignWithTop) { 844 util.scrollTop(container, containerScroll.top + diffTop.top); 845 } else { 846 util.scrollTop(container, containerScroll.top + diffBottom.top); 847 } 848 } 849 } 850 851 if (allowHorizontalScroll) { 852 if (diffTop.left < 0 || diffBottom.left > 0) { 853 // 强制向上 854 if (alignWithLeft === true) { 855 util.scrollLeft(container, containerScroll.left + diffTop.left); 856 } else if (alignWithLeft === false) { 857 util.scrollLeft(container, containerScroll.left + diffBottom.left); 858 } else { 859 // 自动调整 860 if (diffTop.left < 0) { 861 util.scrollLeft(container, containerScroll.left + diffTop.left); 862 } else { 863 util.scrollLeft(container, containerScroll.left + diffBottom.left); 864 } 865 } 866 } else { 867 if (!onlyScrollIfNeeded) { 868 alignWithLeft = alignWithLeft === undefined ? true : !!alignWithLeft; 869 if (alignWithLeft) { 870 util.scrollLeft(container, containerScroll.left + diffTop.left); 871 } else { 872 util.scrollLeft(container, containerScroll.left + diffBottom.left); 873 } 874 } 875 } 876 } 877 } 878 879 module.exports = scrollIntoView; 880 881 /***/ }), 882 883 /***/ 5425: 884 /***/ (function(module, __unused_webpack_exports, __webpack_require__) { 885 886 "use strict"; 887 888 889 module.exports = __webpack_require__(1345); 890 891 /***/ }), 892 893 /***/ 5022: 894 /***/ (function(module) { 895 896 "use strict"; 897 898 899 var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; 900 901 var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol ? "symbol" : typeof obj; }; 902 903 var RE_NUM = /[\-+]?(?:\d*\.|)\d+(?:[eE][\-+]?\d+|)/.source; 904 905 function getClientPosition(elem) { 906 var box = undefined; 907 var x = undefined; 908 var y = undefined; 909 var doc = elem.ownerDocument; 910 var body = doc.body; 911 var docElem = doc && doc.documentElement; 912 // 根据 GBS 最新数据,A-Grade Browsers 都已支持 getBoundingClientRect 方法,不用再考虑传统的实现方式 913 box = elem.getBoundingClientRect(); 914 915 // 注:jQuery 还考虑减去 docElem.clientLeft/clientTop 916 // 但测试发现,这样反而会导致当 html 和 body 有边距/边框样式时,获取的值不正确 917 // 此外,ie6 会忽略 html 的 margin 值,幸运地是没有谁会去设置 html 的 margin 918 919 x = box.left; 920 y = box.top; 921 922 // In IE, most of the time, 2 extra pixels are added to the top and left 923 // due to the implicit 2-pixel inset border. In IE6/7 quirks mode and 924 // IE6 standards mode, this border can be overridden by setting the 925 // document element's border to zero -- thus, we cannot rely on the 926 // offset always being 2 pixels. 927 928 // In quirks mode, the offset can be determined by querying the body's 929 // clientLeft/clientTop, but in standards mode, it is found by querying 930 // the document element's clientLeft/clientTop. Since we already called 931 // getClientBoundingRect we have already forced a reflow, so it is not 932 // too expensive just to query them all. 933 934 // ie 下应该减去窗口的边框吧,毕竟默认 absolute 都是相对窗口定位的 935 // 窗口边框标准是设 documentElement ,quirks 时设置 body 936 // 最好禁止在 body 和 html 上边框 ,但 ie < 9 html 默认有 2px ,减去 937 // 但是非 ie 不可能设置窗口边框,body html 也不是窗口 ,ie 可以通过 html,body 设置 938 // 标准 ie 下 docElem.clientTop 就是 border-top 939 // ie7 html 即窗口边框改变不了。永远为 2 940 // 但标准 firefox/chrome/ie9 下 docElem.clientTop 是窗口边框,即使设了 border-top 也为 0 941 942 x -= docElem.clientLeft || body.clientLeft || 0; 943 y -= docElem.clientTop || body.clientTop || 0; 944 945 return { 946 left: x, 947 top: y 948 }; 949 } 950 951 function getScroll(w, top) { 952 var ret = w['page' + (top ? 'Y' : 'X') + 'Offset']; 953 var method = 'scroll' + (top ? 'Top' : 'Left'); 954 if (typeof ret !== 'number') { 955 var d = w.document; 956 // ie6,7,8 standard mode 957 ret = d.documentElement[method]; 958 if (typeof ret !== 'number') { 959 // quirks mode 960 ret = d.body[method]; 961 } 962 } 963 return ret; 964 } 965 966 function getScrollLeft(w) { 967 return getScroll(w); 968 } 969 970 function getScrollTop(w) { 971 return getScroll(w, true); 972 } 973 974 function getOffset(el) { 975 var pos = getClientPosition(el); 976 var doc = el.ownerDocument; 977 var w = doc.defaultView || doc.parentWindow; 978 pos.left += getScrollLeft(w); 979 pos.top += getScrollTop(w); 980 return pos; 981 } 982 function _getComputedStyle(elem, name, computedStyle_) { 983 var val = ''; 984 var d = elem.ownerDocument; 985 var computedStyle = computedStyle_ || d.defaultView.getComputedStyle(elem, null); 986 987 // https://github.com/kissyteam/kissy/issues/61 988 if (computedStyle) { 989 val = computedStyle.getPropertyValue(name) || computedStyle[name]; 990 } 991 992 return val; 993 } 994 995 var _RE_NUM_NO_PX = new RegExp('^(' + RE_NUM + ')(?!px)[a-z%]+$', 'i'); 996 var RE_POS = /^(top|right|bottom|left)$/; 997 var CURRENT_STYLE = 'currentStyle'; 998 var RUNTIME_STYLE = 'runtimeStyle'; 999 var LEFT = 'left'; 1000 var PX = 'px'; 1001 1002 function _getComputedStyleIE(elem, name) { 1003 // currentStyle maybe null 1004 // http://msdn.microsoft.com/en-us/library/ms535231.aspx 1005 var ret = elem[CURRENT_STYLE] && elem[CURRENT_STYLE][name]; 1006 1007 // 当 width/height 设置为百分比时,通过 pixelLeft 方式转换的 width/height 值 1008 // 一开始就处理了! CUSTOM_STYLE.height,CUSTOM_STYLE.width ,cssHook 解决@2011-08-19 1009 // 在 ie 下不对,需要直接用 offset 方式 1010 // borderWidth 等值也有问题,但考虑到 borderWidth 设为百分比的概率很小,这里就不考虑了 1011 1012 // From the awesome hack by Dean Edwards 1013 // http://erik.eae.net/archives/2007/07/27/18.54.15/#comment-102291 1014 // If we're not dealing with a regular pixel number 1015 // but a number that has a weird ending, we need to convert it to pixels 1016 // exclude left right for relativity 1017 if (_RE_NUM_NO_PX.test(ret) && !RE_POS.test(name)) { 1018 // Remember the original values 1019 var style = elem.style; 1020 var left = style[LEFT]; 1021 var rsLeft = elem[RUNTIME_STYLE][LEFT]; 1022 1023 // prevent flashing of content 1024 elem[RUNTIME_STYLE][LEFT] = elem[CURRENT_STYLE][LEFT]; 1025 1026 // Put in the new values to get a computed value out 1027 style[LEFT] = name === 'fontSize' ? '1em' : ret || 0; 1028 ret = style.pixelLeft + PX; 1029 1030 // Revert the changed values 1031 style[LEFT] = left; 1032 1033 elem[RUNTIME_STYLE][LEFT] = rsLeft; 1034 } 1035 return ret === '' ? 'auto' : ret; 1036 } 1037 1038 var getComputedStyleX = undefined; 1039 if (typeof window !== 'undefined') { 1040 getComputedStyleX = window.getComputedStyle ? _getComputedStyle : _getComputedStyleIE; 1041 } 1042 1043 function each(arr, fn) { 1044 for (var i = 0; i < arr.length; i++) { 1045 fn(arr[i]); 1046 } 1047 } 1048 1049 function isBorderBoxFn(elem) { 1050 return getComputedStyleX(elem, 'boxSizing') === 'border-box'; 1051 } 1052 1053 var BOX_MODELS = ['margin', 'border', 'padding']; 1054 var CONTENT_INDEX = -1; 1055 var PADDING_INDEX = 2; 1056 var BORDER_INDEX = 1; 1057 var MARGIN_INDEX = 0; 1058 1059 function swap(elem, options, callback) { 1060 var old = {}; 1061 var style = elem.style; 1062 var name = undefined; 1063 1064 // Remember the old values, and insert the new ones 1065 for (name in options) { 1066 if (options.hasOwnProperty(name)) { 1067 old[name] = style[name]; 1068 style[name] = options[name]; 1069 } 1070 } 1071 1072 callback.call(elem); 1073 1074 // Revert the old values 1075 for (name in options) { 1076 if (options.hasOwnProperty(name)) { 1077 style[name] = old[name]; 1078 } 1079 } 1080 } 1081 1082 function getPBMWidth(elem, props, which) { 1083 var value = 0; 1084 var prop = undefined; 1085 var j = undefined; 1086 var i = undefined; 1087 for (j = 0; j < props.length; j++) { 1088 prop = props[j]; 1089 if (prop) { 1090 for (i = 0; i < which.length; i++) { 1091 var cssProp = undefined; 1092 if (prop === 'border') { 1093 cssProp = prop + which[i] + 'Width'; 1094 } else { 1095 cssProp = prop + which[i]; 1096 } 1097 value += parseFloat(getComputedStyleX(elem, cssProp)) || 0; 1098 } 1099 } 1100 } 1101 return value; 1102 } 1103 1104 /** 1105 * A crude way of determining if an object is a window 1106 * @member util 1107 */ 1108 function isWindow(obj) { 1109 // must use == for ie8 1110 /* eslint eqeqeq:0 */ 1111 return obj != null && obj == obj.window; 1112 } 1113 1114 var domUtils = {}; 1115 1116 each(['Width', 'Height'], function (name) { 1117 domUtils['doc' + name] = function (refWin) { 1118 var d = refWin.document; 1119 return Math.max( 1120 // firefox chrome documentElement.scrollHeight< body.scrollHeight 1121 // ie standard mode : documentElement.scrollHeight> body.scrollHeight 1122 d.documentElement['scroll' + name], 1123 // quirks : documentElement.scrollHeight 最大等于可视窗口多一点? 1124 d.body['scroll' + name], domUtils['viewport' + name](d)); 1125 }; 1126 1127 domUtils['viewport' + name] = function (win) { 1128 // pc browser includes scrollbar in window.innerWidth 1129 var prop = 'client' + name; 1130 var doc = win.document; 1131 var body = doc.body; 1132 var documentElement = doc.documentElement; 1133 var documentElementProp = documentElement[prop]; 1134 // 标准模式取 documentElement 1135 // backcompat 取 body 1136 return doc.compatMode === 'CSS1Compat' && documentElementProp || body && body[prop] || documentElementProp; 1137 }; 1138 }); 1139 1140 /* 1141 得到元素的大小信息 1142 @param elem 1143 @param name 1144 @param {String} [extra] 'padding' : (css width) + padding 1145 'border' : (css width) + padding + border 1146 'margin' : (css width) + padding + border + margin 1147 */ 1148 function getWH(elem, name, extra) { 1149 if (isWindow(elem)) { 1150 return name === 'width' ? domUtils.viewportWidth(elem) : domUtils.viewportHeight(elem); 1151 } else if (elem.nodeType === 9) { 1152 return name === 'width' ? domUtils.docWidth(elem) : domUtils.docHeight(elem); 1153 } 1154 var which = name === 'width' ? ['Left', 'Right'] : ['Top', 'Bottom']; 1155 var borderBoxValue = name === 'width' ? elem.offsetWidth : elem.offsetHeight; 1156 var computedStyle = getComputedStyleX(elem); 1157 var isBorderBox = isBorderBoxFn(elem, computedStyle); 1158 var cssBoxValue = 0; 1159 if (borderBoxValue == null || borderBoxValue <= 0) { 1160 borderBoxValue = undefined; 1161 // Fall back to computed then un computed css if necessary 1162 cssBoxValue = getComputedStyleX(elem, name); 1163 if (cssBoxValue == null || Number(cssBoxValue) < 0) { 1164 cssBoxValue = elem.style[name] || 0; 1165 } 1166 // Normalize '', auto, and prepare for extra 1167 cssBoxValue = parseFloat(cssBoxValue) || 0; 1168 } 1169 if (extra === undefined) { 1170 extra = isBorderBox ? BORDER_INDEX : CONTENT_INDEX; 1171 } 1172 var borderBoxValueOrIsBorderBox = borderBoxValue !== undefined || isBorderBox; 1173 var val = borderBoxValue || cssBoxValue; 1174 if (extra === CONTENT_INDEX) { 1175 if (borderBoxValueOrIsBorderBox) { 1176 return val - getPBMWidth(elem, ['border', 'padding'], which, computedStyle); 1177 } 1178 return cssBoxValue; 1179 } 1180 if (borderBoxValueOrIsBorderBox) { 1181 var padding = extra === PADDING_INDEX ? -getPBMWidth(elem, ['border'], which, computedStyle) : getPBMWidth(elem, ['margin'], which, computedStyle); 1182 return val + (extra === BORDER_INDEX ? 0 : padding); 1183 } 1184 return cssBoxValue + getPBMWidth(elem, BOX_MODELS.slice(extra), which, computedStyle); 1185 } 1186 1187 var cssShow = { 1188 position: 'absolute', 1189 visibility: 'hidden', 1190 display: 'block' 1191 }; 1192 1193 // fix #119 : https://github.com/kissyteam/kissy/issues/119 1194 function getWHIgnoreDisplay(elem) { 1195 var val = undefined; 1196 var args = arguments; 1197 // in case elem is window 1198 // elem.offsetWidth === undefined 1199 if (elem.offsetWidth !== 0) { 1200 val = getWH.apply(undefined, args); 1201 } else { 1202 swap(elem, cssShow, function () { 1203 val = getWH.apply(undefined, args); 1204 }); 1205 } 1206 return val; 1207 } 1208 1209 function css(el, name, v) { 1210 var value = v; 1211 if ((typeof name === 'undefined' ? 'undefined' : _typeof(name)) === 'object') { 1212 for (var i in name) { 1213 if (name.hasOwnProperty(i)) { 1214 css(el, i, name[i]); 1215 } 1216 } 1217 return undefined; 1218 } 1219 if (typeof value !== 'undefined') { 1220 if (typeof value === 'number') { 1221 value += 'px'; 1222 } 1223 el.style[name] = value; 1224 return undefined; 1225 } 1226 return getComputedStyleX(el, name); 1227 } 1228 1229 each(['width', 'height'], function (name) { 1230 var first = name.charAt(0).toUpperCase() + name.slice(1); 1231 domUtils['outer' + first] = function (el, includeMargin) { 1232 return el && getWHIgnoreDisplay(el, name, includeMargin ? MARGIN_INDEX : BORDER_INDEX); 1233 }; 1234 var which = name === 'width' ? ['Left', 'Right'] : ['Top', 'Bottom']; 1235 1236 domUtils[name] = function (elem, val) { 1237 if (val !== undefined) { 1238 if (elem) { 1239 var computedStyle = getComputedStyleX(elem); 1240 var isBorderBox = isBorderBoxFn(elem); 1241 if (isBorderBox) { 1242 val += getPBMWidth(elem, ['padding', 'border'], which, computedStyle); 1243 } 1244 return css(elem, name, val); 1245 } 1246 return undefined; 1247 } 1248 return elem && getWHIgnoreDisplay(elem, name, CONTENT_INDEX); 1249 }; 1250 }); 1251 1252 // 设置 elem 相对 elem.ownerDocument 的坐标 1253 function setOffset(elem, offset) { 1254 // set position first, in-case top/left are set even on static elem 1255 if (css(elem, 'position') === 'static') { 1256 elem.style.position = 'relative'; 1257 } 1258 1259 var old = getOffset(elem); 1260 var ret = {}; 1261 var current = undefined; 1262 var key = undefined; 1263 1264 for (key in offset) { 1265 if (offset.hasOwnProperty(key)) { 1266 current = parseFloat(css(elem, key)) || 0; 1267 ret[key] = current + offset[key] - old[key]; 1268 } 1269 } 1270 css(elem, ret); 1271 } 1272 1273 module.exports = _extends({ 1274 getWindow: function getWindow(node) { 1275 var doc = node.ownerDocument || node; 1276 return doc.defaultView || doc.parentWindow; 1277 }, 1278 offset: function offset(el, value) { 1279 if (typeof value !== 'undefined') { 1280 setOffset(el, value); 1281 } else { 1282 return getOffset(el); 1283 } 1284 }, 1285 1286 isWindow: isWindow, 1287 each: each, 1288 css: css, 1289 clone: function clone(obj) { 1290 var ret = {}; 1291 for (var i in obj) { 1292 if (obj.hasOwnProperty(i)) { 1293 ret[i] = obj[i]; 1294 } 1295 } 1296 var overflow = obj.overflow; 1297 if (overflow) { 1298 for (var i in obj) { 1299 if (obj.hasOwnProperty(i)) { 1300 ret.overflow[i] = obj.overflow[i]; 1301 } 1302 } 1303 } 1304 return ret; 1305 }, 1306 scrollLeft: function scrollLeft(w, v) { 1307 if (isWindow(w)) { 1308 if (v === undefined) { 1309 return getScrollLeft(w); 1310 } 1311 window.scrollTo(v, getScrollTop(w)); 1312 } else { 1313 if (v === undefined) { 1314 return w.scrollLeft; 1315 } 1316 w.scrollLeft = v; 1317 } 1318 }, 1319 scrollTop: function scrollTop(w, v) { 1320 if (isWindow(w)) { 1321 if (v === undefined) { 1322 return getScrollTop(w); 1323 } 1324 window.scrollTo(getScrollLeft(w), v); 1325 } else { 1326 if (v === undefined) { 1327 return w.scrollTop; 1328 } 1329 w.scrollTop = v; 1330 } 1331 }, 1332 1333 viewportWidth: 0, 1334 viewportHeight: 0 1335 }, domUtils); 1336 1337 /***/ }), 1338 1339 /***/ 8575: 1340 /***/ (function(module) { 1341 1342 if (typeof Object.create === 'function') { 1343 // implementation from standard node.js 'util' module 1344 module.exports = function inherits(ctor, superCtor) { 1345 if (superCtor) { 1346 ctor.super_ = superCtor 1347 ctor.prototype = Object.create(superCtor.prototype, { 1348 constructor: { 1349 value: ctor, 1350 enumerable: false, 1351 writable: true, 1352 configurable: true 1353 } 1354 }) 1355 } 1356 }; 1357 } else { 1358 // old school shim for old browsers 1359 module.exports = function inherits(ctor, superCtor) { 1360 if (superCtor) { 1361 ctor.super_ = superCtor 1362 var TempCtor = function () {} 1363 TempCtor.prototype = superCtor.prototype 1364 ctor.prototype = new TempCtor() 1365 ctor.prototype.constructor = ctor 1366 } 1367 } 1368 } 1369 1370 1371 /***/ }), 1372 1373 /***/ 9894: 1374 /***/ (function(module, __unused_webpack_exports, __webpack_require__) { 1375 1376 // Load in dependencies 1377 var computedStyle = __webpack_require__(4827); 1378 1379 /** 1380 * Calculate the `line-height` of a given node 1381 * @param {HTMLElement} node Element to calculate line height of. Must be in the DOM. 1382 * @returns {Number} `line-height` of the element in pixels 1383 */ 1384 function lineHeight(node) { 1385 // Grab the line-height via style 1386 var lnHeightStr = computedStyle(node, 'line-height'); 1387 var lnHeight = parseFloat(lnHeightStr, 10); 1388 1389 // If the lineHeight did not contain a unit (i.e. it was numeric), convert it to ems (e.g. '2.3' === '2.3em') 1390 if (lnHeightStr === lnHeight + '') { 1391 // Save the old lineHeight style and update the em unit to the element 1392 var _lnHeightStyle = node.style.lineHeight; 1393 node.style.lineHeight = lnHeightStr + 'em'; 1394 1395 // Calculate the em based height 1396 lnHeightStr = computedStyle(node, 'line-height'); 1397 lnHeight = parseFloat(lnHeightStr, 10); 1398 1399 // Revert the lineHeight style 1400 if (_lnHeightStyle) { 1401 node.style.lineHeight = _lnHeightStyle; 1402 } else { 1403 delete node.style.lineHeight; 1404 } 1405 } 1406 1407 // If the lineHeight is in `pt`, convert it to pixels (4px for 3pt) 1408 // DEV: `em` units are converted to `pt` in IE6 1409 // Conversion ratio from https://developer.mozilla.org/en-US/docs/Web/CSS/length 1410 if (lnHeightStr.indexOf('pt') !== -1) { 1411 lnHeight *= 4; 1412 lnHeight /= 3; 1413 // Otherwise, if the lineHeight is in `mm`, convert it to pixels (96px for 25.4mm) 1414 } else if (lnHeightStr.indexOf('mm') !== -1) { 1415 lnHeight *= 96; 1416 lnHeight /= 25.4; 1417 // Otherwise, if the lineHeight is in `cm`, convert it to pixels (96px for 2.54cm) 1418 } else if (lnHeightStr.indexOf('cm') !== -1) { 1419 lnHeight *= 96; 1420 lnHeight /= 2.54; 1421 // Otherwise, if the lineHeight is in `in`, convert it to pixels (96px for 1in) 1422 } else if (lnHeightStr.indexOf('in') !== -1) { 1423 lnHeight *= 96; 1424 // Otherwise, if the lineHeight is in `pc`, convert it to pixels (12pt for 1pc) 1425 } else if (lnHeightStr.indexOf('pc') !== -1) { 1426 lnHeight *= 16; 1427 } 1428 1429 // Continue our computation 1430 lnHeight = Math.round(lnHeight); 1431 1432 // If the line-height is "normal", calculate by font-size 1433 if (lnHeightStr === 'normal') { 1434 // Create a temporary node 1435 var nodeName = node.nodeName; 1436 var _node = document.createElement(nodeName); 1437 _node.innerHTML = ' '; 1438 1439 // If we have a text area, reset it to only 1 row 1440 // https://github.com/twolfson/line-height/issues/4 1441 if (nodeName.toUpperCase() === 'TEXTAREA') { 1442 _node.setAttribute('rows', '1'); 1443 } 1444 1445 // Set the font-size of the element 1446 var fontSizeStr = computedStyle(node, 'font-size'); 1447 _node.style.fontSize = fontSizeStr; 1448 1449 // Remove default padding/border which can affect offset height 1450 // https://github.com/twolfson/line-height/issues/4 1451 // https://developer.mozilla.org/en-US/docs/Web/API/HTMLElement/offsetHeight 1452 _node.style.padding = '0px'; 1453 _node.style.border = '0px'; 1454 1455 // Append it to the body 1456 var body = document.body; 1457 body.appendChild(_node); 1458 1459 // Assume the line height of the element is the height 1460 var height = _node.offsetHeight; 1461 lnHeight = height; 1462 1463 // Remove our child from the DOM 1464 body.removeChild(_node); 1465 } 1466 1467 // Return the calculated height 1468 return lnHeight; 1469 } 1470 1471 // Export lineHeight 1472 module.exports = lineHeight; 1473 1474 1475 /***/ }), 1476 1477 /***/ 7970: 1478 /***/ (function(module, __unused_webpack_exports, __webpack_require__) { 1479 1480 module.exports = __webpack_require__(195); 1481 1482 1483 /***/ }), 1484 1485 /***/ 3110: 1486 /***/ (function(module) { 1487 1488 "use strict"; 1489 /** 1490 * Copyright (c) 2015, Facebook, Inc. 1491 * All rights reserved. 1492 * 1493 * This source code is licensed under the BSD-style license found in the 1494 * LICENSE file in the root directory of this source tree. An additional grant 1495 * of patent rights can be found in the PATENTS file in the same directory. 1496 * 1497 * @providesModule ExecutionEnvironment 1498 */ 1499 1500 /*jslint evil: true */ 1501 1502 1503 1504 var canUseDOM = !!( 1505 typeof window !== 'undefined' && 1506 window.document && 1507 window.document.createElement 1508 ); 1509 1510 /** 1511 * Simple, lightweight module assisting with the detection and context of 1512 * Worker. Helps avoid circular dependencies and allows code to reason about 1513 * whether or not they are in a Worker, even if they never include the main 1514 * `ReactWorker` dependency. 1515 */ 1516 var ExecutionEnvironment = { 1517 1518 canUseDOM: canUseDOM, 1519 1520 canUseWorkers: typeof Worker !== 'undefined', 1521 1522 canUseEventListeners: 1523 canUseDOM && !!(window.addEventListener || window.attachEvent), 1524 1525 canUseViewport: canUseDOM && !!window.screen, 1526 1527 isInWorker: !canUseDOM // For now, this is true - might change in the future. 1528 1529 }; 1530 1531 module.exports = ExecutionEnvironment; 1532 1533 1534 /***/ }), 1535 1536 /***/ 3812: 1537 /***/ (function(module) { 1538 1539 /** 1540 * Copyright 2004-present Facebook. All Rights Reserved. 1541 * 1542 * @providesModule UserAgent_DEPRECATED 1543 */ 1544 1545 /** 1546 * Provides entirely client-side User Agent and OS detection. You should prefer 1547 * the non-deprecated UserAgent module when possible, which exposes our 1548 * authoritative server-side PHP-based detection to the client. 1549 * 1550 * Usage is straightforward: 1551 * 1552 * if (UserAgent_DEPRECATED.ie()) { 1553 * // IE 1554 * } 1555 * 1556 * You can also do version checks: 1557 * 1558 * if (UserAgent_DEPRECATED.ie() >= 7) { 1559 * // IE7 or better 1560 * } 1561 * 1562 * The browser functions will return NaN if the browser does not match, so 1563 * you can also do version compares the other way: 1564 * 1565 * if (UserAgent_DEPRECATED.ie() < 7) { 1566 * // IE6 or worse 1567 * } 1568 * 1569 * Note that the version is a float and may include a minor version number, 1570 * so you should always use range operators to perform comparisons, not 1571 * strict equality. 1572 * 1573 * **Note:** You should **strongly** prefer capability detection to browser 1574 * version detection where it's reasonable: 1575 * 1576 * http://www.quirksmode.org/js/support.html 1577 * 1578 * Further, we have a large number of mature wrapper functions and classes 1579 * which abstract away many browser irregularities. Check the documentation, 1580 * grep for things, or ask on javascript@lists.facebook.com before writing yet 1581 * another copy of "event || window.event". 1582 * 1583 */ 1584 1585 var _populated = false; 1586 1587 // Browsers 1588 var _ie, _firefox, _opera, _webkit, _chrome; 1589 1590 // Actual IE browser for compatibility mode 1591 var _ie_real_version; 1592 1593 // Platforms 1594 var _osx, _windows, _linux, _android; 1595 1596 // Architectures 1597 var _win64; 1598 1599 // Devices 1600 var _iphone, _ipad, _native; 1601 1602 var _mobile; 1603 1604 function _populate() { 1605 if (_populated) { 1606 return; 1607 } 1608 1609 _populated = true; 1610 1611 // To work around buggy JS libraries that can't handle multi-digit 1612 // version numbers, Opera 10's user agent string claims it's Opera 1613 // 9, then later includes a Version/X.Y field: 1614 // 1615 // Opera/9.80 (foo) Presto/2.2.15 Version/10.10 1616 var uas = navigator.userAgent; 1617 var agent = /(?:MSIE.(\d+\.\d+))|(?:(?:Firefox|GranParadiso|Iceweasel).(\d+\.\d+))|(?:Opera(?:.+Version.|.)(\d+\.\d+))|(?:AppleWebKit.(\d+(?:\.\d+)?))|(?:Trident\/\d+\.\d+.*rv:(\d+\.\d+))/.exec(uas); 1618 var os = /(Mac OS X)|(Windows)|(Linux)/.exec(uas); 1619 1620 _iphone = /\b(iPhone|iP[ao]d)/.exec(uas); 1621 _ipad = /\b(iP[ao]d)/.exec(uas); 1622 _android = /Android/i.exec(uas); 1623 _native = /FBAN\/\w+;/i.exec(uas); 1624 _mobile = /Mobile/i.exec(uas); 1625 1626 // Note that the IE team blog would have you believe you should be checking 1627 // for 'Win64; x64'. But MSDN then reveals that you can actually be coming 1628 // from either x64 or ia64; so ultimately, you should just check for Win64 1629 // as in indicator of whether you're in 64-bit IE. 32-bit IE on 64-bit 1630 // Windows will send 'WOW64' instead. 1631 _win64 = !!(/Win64/.exec(uas)); 1632 1633 if (agent) { 1634 _ie = agent[1] ? parseFloat(agent[1]) : ( 1635 agent[5] ? parseFloat(agent[5]) : NaN); 1636 // IE compatibility mode 1637 if (_ie && document && document.documentMode) { 1638 _ie = document.documentMode; 1639 } 1640 // grab the "true" ie version from the trident token if available 1641 var trident = /(?:Trident\/(\d+.\d+))/.exec(uas); 1642 _ie_real_version = trident ? parseFloat(trident[1]) + 4 : _ie; 1643 1644 _firefox = agent[2] ? parseFloat(agent[2]) : NaN; 1645 _opera = agent[3] ? parseFloat(agent[3]) : NaN; 1646 _webkit = agent[4] ? parseFloat(agent[4]) : NaN; 1647 if (_webkit) { 1648 // We do not add the regexp to the above test, because it will always 1649 // match 'safari' only since 'AppleWebKit' appears before 'Chrome' in 1650 // the userAgent string. 1651 agent = /(?:Chrome\/(\d+\.\d+))/.exec(uas); 1652 _chrome = agent && agent[1] ? parseFloat(agent[1]) : NaN; 1653 } else { 1654 _chrome = NaN; 1655 } 1656 } else { 1657 _ie = _firefox = _opera = _chrome = _webkit = NaN; 1658 } 1659 1660 if (os) { 1661 if (os[1]) { 1662 // Detect OS X version. If no version number matches, set _osx to true. 1663 // Version examples: 10, 10_6_1, 10.7 1664 // Parses version number as a float, taking only first two sets of 1665 // digits. If only one set of digits is found, returns just the major 1666 // version number. 1667 var ver = /(?:Mac OS X (\d+(?:[._]\d+)?))/.exec(uas); 1668 1669 _osx = ver ? parseFloat(ver[1].replace('_', '.')) : true; 1670 } else { 1671 _osx = false; 1672 } 1673 _windows = !!os[2]; 1674 _linux = !!os[3]; 1675 } else { 1676 _osx = _windows = _linux = false; 1677 } 1678 } 1679 1680 var UserAgent_DEPRECATED = { 1681 1682 /** 1683 * Check if the UA is Internet Explorer. 1684 * 1685 * 1686 * @return float|NaN Version number (if match) or NaN. 1687 */ 1688 ie: function() { 1689 return _populate() || _ie; 1690 }, 1691 1692 /** 1693 * Check if we're in Internet Explorer compatibility mode. 1694 * 1695 * @return bool true if in compatibility mode, false if 1696 * not compatibility mode or not ie 1697 */ 1698 ieCompatibilityMode: function() { 1699 return _populate() || (_ie_real_version > _ie); 1700 }, 1701 1702 1703 /** 1704 * Whether the browser is 64-bit IE. Really, this is kind of weak sauce; we 1705 * only need this because Skype can't handle 64-bit IE yet. We need to remove 1706 * this when we don't need it -- tracked by #601957. 1707 */ 1708 ie64: function() { 1709 return UserAgent_DEPRECATED.ie() && _win64; 1710 }, 1711 1712 /** 1713 * Check if the UA is Firefox. 1714 * 1715 * 1716 * @return float|NaN Version number (if match) or NaN. 1717 */ 1718 firefox: function() { 1719 return _populate() || _firefox; 1720 }, 1721 1722 1723 /** 1724 * Check if the UA is Opera. 1725 * 1726 * 1727 * @return float|NaN Version number (if match) or NaN. 1728 */ 1729 opera: function() { 1730 return _populate() || _opera; 1731 }, 1732 1733 1734 /** 1735 * Check if the UA is WebKit. 1736 * 1737 * 1738 * @return float|NaN Version number (if match) or NaN. 1739 */ 1740 webkit: function() { 1741 return _populate() || _webkit; 1742 }, 1743 1744 /** 1745 * For Push 1746 * WILL BE REMOVED VERY SOON. Use UserAgent_DEPRECATED.webkit 1747 */ 1748 safari: function() { 1749 return UserAgent_DEPRECATED.webkit(); 1750 }, 1751 1752 /** 1753 * Check if the UA is a Chrome browser. 1754 * 1755 * 1756 * @return float|NaN Version number (if match) or NaN. 1757 */ 1758 chrome : function() { 1759 return _populate() || _chrome; 1760 }, 1761 1762 1763 /** 1764 * Check if the user is running Windows. 1765 * 1766 * @return bool `true' if the user's OS is Windows. 1767 */ 1768 windows: function() { 1769 return _populate() || _windows; 1770 }, 1771 1772 1773 /** 1774 * Check if the user is running Mac OS X. 1775 * 1776 * @return float|bool Returns a float if a version number is detected, 1777 * otherwise true/false. 1778 */ 1779 osx: function() { 1780 return _populate() || _osx; 1781 }, 1782 1783 /** 1784 * Check if the user is running Linux. 1785 * 1786 * @return bool `true' if the user's OS is some flavor of Linux. 1787 */ 1788 linux: function() { 1789 return _populate() || _linux; 1790 }, 1791 1792 /** 1793 * Check if the user is running on an iPhone or iPod platform. 1794 * 1795 * @return bool `true' if the user is running some flavor of the 1796 * iPhone OS. 1797 */ 1798 iphone: function() { 1799 return _populate() || _iphone; 1800 }, 1801 1802 mobile: function() { 1803 return _populate() || (_iphone || _ipad || _android || _mobile); 1804 }, 1805 1806 nativeApp: function() { 1807 // webviews inside of the native apps 1808 return _populate() || _native; 1809 }, 1810 1811 android: function() { 1812 return _populate() || _android; 1813 }, 1814 1815 ipad: function() { 1816 return _populate() || _ipad; 1817 } 1818 }; 1819 1820 module.exports = UserAgent_DEPRECATED; 1821 1822 1823 /***/ }), 1824 1825 /***/ 7939: 1826 /***/ (function(module, __unused_webpack_exports, __webpack_require__) { 1827 1828 "use strict"; 1829 /** 1830 * Copyright 2013-2015, Facebook, Inc. 1831 * All rights reserved. 1832 * 1833 * This source code is licensed under the BSD-style license found in the 1834 * LICENSE file in the root directory of this source tree. An additional grant 1835 * of patent rights can be found in the PATENTS file in the same directory. 1836 * 1837 * @providesModule isEventSupported 1838 */ 1839 1840 1841 1842 var ExecutionEnvironment = __webpack_require__(3110); 1843 1844 var useHasFeature; 1845 if (ExecutionEnvironment.canUseDOM) { 1846 useHasFeature = 1847 document.implementation && 1848 document.implementation.hasFeature && 1849 // always returns true in newer browsers as per the standard. 1850 // @see http://dom.spec.whatwg.org/#dom-domimplementation-hasfeature 1851 document.implementation.hasFeature('', '') !== true; 1852 } 1853 1854 /** 1855 * Checks if an event is supported in the current execution environment. 1856 * 1857 * NOTE: This will not work correctly for non-generic events such as `change`, 1858 * `reset`, `load`, `error`, and `select`. 1859 * 1860 * Borrows from Modernizr. 1861 * 1862 * @param {string} eventNameSuffix Event name, e.g. "click". 1863 * @param {?boolean} capture Check if the capture phase is supported. 1864 * @return {boolean} True if the event is supported. 1865 * @internal 1866 * @license Modernizr 3.0.0pre (Custom Build) | MIT 1867 */ 1868 function isEventSupported(eventNameSuffix, capture) { 1869 if (!ExecutionEnvironment.canUseDOM || 1870 capture && !('addEventListener' in document)) { 1871 return false; 1872 } 1873 1874 var eventName = 'on' + eventNameSuffix; 1875 var isSupported = eventName in document; 1876 1877 if (!isSupported) { 1878 var element = document.createElement('div'); 1879 element.setAttribute(eventName, 'return;'); 1880 isSupported = typeof element[eventName] === 'function'; 1881 } 1882 1883 if (!isSupported && useHasFeature && eventNameSuffix === 'wheel') { 1884 // This is the only way to test support for the `wheel` event in IE9+. 1885 isSupported = document.implementation.hasFeature('Events.wheel', '3.0'); 1886 } 1887 1888 return isSupported; 1889 } 1890 1891 module.exports = isEventSupported; 1892 1893 1894 /***/ }), 1895 1896 /***/ 195: 1897 /***/ (function(module, __unused_webpack_exports, __webpack_require__) { 1898 1899 "use strict"; 1900 /** 1901 * Copyright (c) 2015, Facebook, Inc. 1902 * All rights reserved. 1903 * 1904 * This source code is licensed under the BSD-style license found in the 1905 * LICENSE file in the root directory of this source tree. An additional grant 1906 * of patent rights can be found in the PATENTS file in the same directory. 1907 * 1908 * @providesModule normalizeWheel 1909 * @typechecks 1910 */ 1911 1912 1913 1914 var UserAgent_DEPRECATED = __webpack_require__(3812); 1915 1916 var isEventSupported = __webpack_require__(7939); 1917 1918 1919 // Reasonable defaults 1920 var PIXEL_STEP = 10; 1921 var LINE_HEIGHT = 40; 1922 var PAGE_HEIGHT = 800; 1923 1924 /** 1925 * Mouse wheel (and 2-finger trackpad) support on the web sucks. It is 1926 * complicated, thus this doc is long and (hopefully) detailed enough to answer 1927 * your questions. 1928 * 1929 * If you need to react to the mouse wheel in a predictable way, this code is 1930 * like your bestest friend. * hugs * 1931 * 1932 * As of today, there are 4 DOM event types you can listen to: 1933 * 1934 * 'wheel' -- Chrome(31+), FF(17+), IE(9+) 1935 * 'mousewheel' -- Chrome, IE(6+), Opera, Safari 1936 * 'MozMousePixelScroll' -- FF(3.5 only!) (2010-2013) -- don't bother! 1937 * 'DOMMouseScroll' -- FF(0.9.7+) since 2003 1938 * 1939 * So what to do? The is the best: 1940 * 1941 * normalizeWheel.getEventType(); 1942 * 1943 * In your event callback, use this code to get sane interpretation of the 1944 * deltas. This code will return an object with properties: 1945 * 1946 * spinX -- normalized spin speed (use for zoom) - x plane 1947 * spinY -- " - y plane 1948 * pixelX -- normalized distance (to pixels) - x plane 1949 * pixelY -- " - y plane 1950 * 1951 * Wheel values are provided by the browser assuming you are using the wheel to 1952 * scroll a web page by a number of lines or pixels (or pages). Values can vary 1953 * significantly on different platforms and browsers, forgetting that you can 1954 * scroll at different speeds. Some devices (like trackpads) emit more events 1955 * at smaller increments with fine granularity, and some emit massive jumps with 1956 * linear speed or acceleration. 1957 * 1958 * This code does its best to normalize the deltas for you: 1959 * 1960 * - spin is trying to normalize how far the wheel was spun (or trackpad 1961 * dragged). This is super useful for zoom support where you want to 1962 * throw away the chunky scroll steps on the PC and make those equal to 1963 * the slow and smooth tiny steps on the Mac. Key data: This code tries to 1964 * resolve a single slow step on a wheel to 1. 1965 * 1966 * - pixel is normalizing the desired scroll delta in pixel units. You'll 1967 * get the crazy differences between browsers, but at least it'll be in 1968 * pixels! 1969 * 1970 * - positive value indicates scrolling DOWN/RIGHT, negative UP/LEFT. This 1971 * should translate to positive value zooming IN, negative zooming OUT. 1972 * This matches the newer 'wheel' event. 1973 * 1974 * Why are there spinX, spinY (or pixels)? 1975 * 1976 * - spinX is a 2-finger side drag on the trackpad, and a shift + wheel turn 1977 * with a mouse. It results in side-scrolling in the browser by default. 1978 * 1979 * - spinY is what you expect -- it's the classic axis of a mouse wheel. 1980 * 1981 * - I dropped spinZ/pixelZ. It is supported by the DOM 3 'wheel' event and 1982 * probably is by browsers in conjunction with fancy 3D controllers .. but 1983 * you know. 1984 * 1985 * Implementation info: 1986 * 1987 * Examples of 'wheel' event if you scroll slowly (down) by one step with an 1988 * average mouse: 1989 * 1990 * OS X + Chrome (mouse) - 4 pixel delta (wheelDelta -120) 1991 * OS X + Safari (mouse) - N/A pixel delta (wheelDelta -12) 1992 * OS X + Firefox (mouse) - 0.1 line delta (wheelDelta N/A) 1993 * Win8 + Chrome (mouse) - 100 pixel delta (wheelDelta -120) 1994 * Win8 + Firefox (mouse) - 3 line delta (wheelDelta -120) 1995 * 1996 * On the trackpad: 1997 * 1998 * OS X + Chrome (trackpad) - 2 pixel delta (wheelDelta -6) 1999 * OS X + Firefox (trackpad) - 1 pixel delta (wheelDelta N/A) 2000 * 2001 * On other/older browsers.. it's more complicated as there can be multiple and 2002 * also missing delta values. 2003 * 2004 * The 'wheel' event is more standard: 2005 * 2006 * http://www.w3.org/TR/DOM-Level-3-Events/#events-wheelevents 2007 * 2008 * The basics is that it includes a unit, deltaMode (pixels, lines, pages), and 2009 * deltaX, deltaY and deltaZ. Some browsers provide other values to maintain 2010 * backward compatibility with older events. Those other values help us 2011 * better normalize spin speed. Example of what the browsers provide: 2012 * 2013 * | event.wheelDelta | event.detail 2014 * ------------------+------------------+-------------- 2015 * Safari v5/OS X | -120 | 0 2016 * Safari v5/Win7 | -120 | 0 2017 * Chrome v17/OS X | -120 | 0 2018 * Chrome v17/Win7 | -120 | 0 2019 * IE9/Win7 | -120 | undefined 2020 * Firefox v4/OS X | undefined | 1 2021 * Firefox v4/Win7 | undefined | 3 2022 * 2023 */ 2024 function normalizeWheel(/*object*/ event) /*object*/ { 2025 var sX = 0, sY = 0, // spinX, spinY 2026 pX = 0, pY = 0; // pixelX, pixelY 2027 2028 // Legacy 2029 if ('detail' in event) { sY = event.detail; } 2030 if ('wheelDelta' in event) { sY = -event.wheelDelta / 120; } 2031 if ('wheelDeltaY' in event) { sY = -event.wheelDeltaY / 120; } 2032 if ('wheelDeltaX' in event) { sX = -event.wheelDeltaX / 120; } 2033 2034 // side scrolling on FF with DOMMouseScroll 2035 if ( 'axis' in event && event.axis === event.HORIZONTAL_AXIS ) { 2036 sX = sY; 2037 sY = 0; 2038 } 2039 2040 pX = sX * PIXEL_STEP; 2041 pY = sY * PIXEL_STEP; 2042 2043 if ('deltaY' in event) { pY = event.deltaY; } 2044 if ('deltaX' in event) { pX = event.deltaX; } 2045 2046 if ((pX || pY) && event.deltaMode) { 2047 if (event.deltaMode == 1) { // delta in LINE units 2048 pX *= LINE_HEIGHT; 2049 pY *= LINE_HEIGHT; 2050 } else { // delta in PAGE units 2051 pX *= PAGE_HEIGHT; 2052 pY *= PAGE_HEIGHT; 2053 } 2054 } 2055 2056 // Fall-back if spin cannot be determined 2057 if (pX && !sX) { sX = (pX < 1) ? -1 : 1; } 2058 if (pY && !sY) { sY = (pY < 1) ? -1 : 1; } 2059 2060 return { spinX : sX, 2061 spinY : sY, 2062 pixelX : pX, 2063 pixelY : pY }; 2064 } 2065 2066 2067 /** 2068 * The best combination if you prefer spinX + spinY normalization. It favors 2069 * the older DOMMouseScroll for Firefox, as FF does not include wheelDelta with 2070 * 'wheel' event, making spin speed determination impossible. 2071 */ 2072 normalizeWheel.getEventType = function() /*string*/ { 2073 return (UserAgent_DEPRECATED.firefox()) 2074 ? 'DOMMouseScroll' 2075 : (isEventSupported('wheel')) 2076 ? 'wheel' 2077 : 'mousewheel'; 2078 }; 2079 2080 module.exports = normalizeWheel; 2081 2082 2083 /***/ }), 2084 2085 /***/ 5372: 2086 /***/ (function(module, __unused_webpack_exports, __webpack_require__) { 2087 2088 "use strict"; 2089 /** 2090 * Copyright (c) 2013-present, Facebook, Inc. 2091 * 2092 * This source code is licensed under the MIT license found in the 2093 * LICENSE file in the root directory of this source tree. 2094 */ 2095 2096 2097 2098 var ReactPropTypesSecret = __webpack_require__(9567); 2099 2100 function emptyFunction() {} 2101 function emptyFunctionWithReset() {} 2102 emptyFunctionWithReset.resetWarningCache = emptyFunction; 2103 2104 module.exports = function() { 2105 function shim(props, propName, componentName, location, propFullName, secret) { 2106 if (secret === ReactPropTypesSecret) { 2107 // It is still safe when called from React. 2108 return; 2109 } 2110 var err = new Error( 2111 'Calling PropTypes validators directly is not supported by the `prop-types` package. ' + 2112 'Use PropTypes.checkPropTypes() to call them. ' + 2113 'Read more at http://fb.me/use-check-prop-types' 2114 ); 2115 err.name = 'Invariant Violation'; 2116 throw err; 2117 }; 2118 shim.isRequired = shim; 2119 function getShim() { 2120 return shim; 2121 }; 2122 // Important! 2123 // Keep this list in sync with production version in `./factoryWithTypeCheckers.js`. 2124 var ReactPropTypes = { 2125 array: shim, 2126 bigint: shim, 2127 bool: shim, 2128 func: shim, 2129 number: shim, 2130 object: shim, 2131 string: shim, 2132 symbol: shim, 2133 2134 any: shim, 2135 arrayOf: getShim, 2136 element: shim, 2137 elementType: shim, 2138 instanceOf: getShim, 2139 node: shim, 2140 objectOf: getShim, 2141 oneOf: getShim, 2142 oneOfType: getShim, 2143 shape: getShim, 2144 exact: getShim, 2145 2146 checkPropTypes: emptyFunctionWithReset, 2147 resetWarningCache: emptyFunction 2148 }; 2149 2150 ReactPropTypes.PropTypes = ReactPropTypes; 2151 2152 return ReactPropTypes; 2153 }; 2154 2155 2156 /***/ }), 2157 2158 /***/ 2652: 2159 /***/ (function(module, __unused_webpack_exports, __webpack_require__) { 2160 2161 /** 2162 * Copyright (c) 2013-present, Facebook, Inc. 2163 * 2164 * This source code is licensed under the MIT license found in the 2165 * LICENSE file in the root directory of this source tree. 2166 */ 2167 2168 if (false) { var throwOnDirectAccess, ReactIs; } else { 2169 // By explicitly using `prop-types` you are opting into new production behavior. 2170 // http://fb.me/prop-types-in-prod 2171 module.exports = __webpack_require__(5372)(); 2172 } 2173 2174 2175 /***/ }), 2176 2177 /***/ 9567: 2178 /***/ (function(module) { 2179 2180 "use strict"; 2181 /** 2182 * Copyright (c) 2013-present, Facebook, Inc. 2183 * 2184 * This source code is licensed under the MIT license found in the 2185 * LICENSE file in the root directory of this source tree. 2186 */ 2187 2188 2189 2190 var ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED'; 2191 2192 module.exports = ReactPropTypesSecret; 2193 2194 2195 /***/ }), 2196 2197 /***/ 5438: 2198 /***/ (function(__unused_webpack_module, exports, __webpack_require__) { 2199 2200 "use strict"; 2201 2202 var __extends = (this && this.__extends) || (function () { 2203 var extendStatics = Object.setPrototypeOf || 2204 ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || 2205 function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; 2206 return function (d, b) { 2207 extendStatics(d, b); 2208 function __() { this.constructor = d; } 2209 d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); 2210 }; 2211 })(); 2212 var __assign = (this && this.__assign) || Object.assign || function(t) { 2213 for (var s, i = 1, n = arguments.length; i < n; i++) { 2214 s = arguments[i]; 2215 for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) 2216 t[p] = s[p]; 2217 } 2218 return t; 2219 }; 2220 var __rest = (this && this.__rest) || function (s, e) { 2221 var t = {}; 2222 for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) 2223 t[p] = s[p]; 2224 if (s != null && typeof Object.getOwnPropertySymbols === "function") 2225 for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) if (e.indexOf(p[i]) < 0) 2226 t[p[i]] = s[p[i]]; 2227 return t; 2228 }; 2229 exports.__esModule = true; 2230 var React = __webpack_require__(9196); 2231 var PropTypes = __webpack_require__(2652); 2232 var autosize = __webpack_require__(6411); 2233 var _getLineHeight = __webpack_require__(9894); 2234 var getLineHeight = _getLineHeight; 2235 var RESIZED = "autosize:resized"; 2236 /** 2237 * A light replacement for built-in textarea component 2238 * which automaticaly adjusts its height to match the content 2239 */ 2240 var TextareaAutosizeClass = /** @class */ (function (_super) { 2241 __extends(TextareaAutosizeClass, _super); 2242 function TextareaAutosizeClass() { 2243 var _this = _super !== null && _super.apply(this, arguments) || this; 2244 _this.state = { 2245 lineHeight: null 2246 }; 2247 _this.textarea = null; 2248 _this.onResize = function (e) { 2249 if (_this.props.onResize) { 2250 _this.props.onResize(e); 2251 } 2252 }; 2253 _this.updateLineHeight = function () { 2254 if (_this.textarea) { 2255 _this.setState({ 2256 lineHeight: getLineHeight(_this.textarea) 2257 }); 2258 } 2259 }; 2260 _this.onChange = function (e) { 2261 var onChange = _this.props.onChange; 2262 _this.currentValue = e.currentTarget.value; 2263 onChange && onChange(e); 2264 }; 2265 return _this; 2266 } 2267 TextareaAutosizeClass.prototype.componentDidMount = function () { 2268 var _this = this; 2269 var _a = this.props, maxRows = _a.maxRows, async = _a.async; 2270 if (typeof maxRows === "number") { 2271 this.updateLineHeight(); 2272 } 2273 if (typeof maxRows === "number" || async) { 2274 /* 2275 the defer is needed to: 2276 - force "autosize" to activate the scrollbar when this.props.maxRows is passed 2277 - support StyledComponents (see #71) 2278 */ 2279 setTimeout(function () { return _this.textarea && autosize(_this.textarea); }); 2280 } 2281 else { 2282 this.textarea && autosize(this.textarea); 2283 } 2284 if (this.textarea) { 2285 this.textarea.addEventListener(RESIZED, this.onResize); 2286 } 2287 }; 2288 TextareaAutosizeClass.prototype.componentWillUnmount = function () { 2289 if (this.textarea) { 2290 this.textarea.removeEventListener(RESIZED, this.onResize); 2291 autosize.destroy(this.textarea); 2292 } 2293 }; 2294 TextareaAutosizeClass.prototype.render = function () { 2295 var _this = this; 2296 var _a = this, _b = _a.props, onResize = _b.onResize, maxRows = _b.maxRows, onChange = _b.onChange, style = _b.style, innerRef = _b.innerRef, children = _b.children, props = __rest(_b, ["onResize", "maxRows", "onChange", "style", "innerRef", "children"]), lineHeight = _a.state.lineHeight; 2297 var maxHeight = maxRows && lineHeight ? lineHeight * maxRows : null; 2298 return (React.createElement("textarea", __assign({}, props, { onChange: this.onChange, style: maxHeight ? __assign({}, style, { maxHeight: maxHeight }) : style, ref: function (element) { 2299 _this.textarea = element; 2300 if (typeof _this.props.innerRef === 'function') { 2301 _this.props.innerRef(element); 2302 } 2303 else if (_this.props.innerRef) { 2304 _this.props.innerRef.current = element; 2305 } 2306 } }), children)); 2307 }; 2308 TextareaAutosizeClass.prototype.componentDidUpdate = function () { 2309 this.textarea && autosize.update(this.textarea); 2310 }; 2311 TextareaAutosizeClass.defaultProps = { 2312 rows: 1, 2313 async: false 2314 }; 2315 TextareaAutosizeClass.propTypes = { 2316 rows: PropTypes.number, 2317 maxRows: PropTypes.number, 2318 onResize: PropTypes.func, 2319 innerRef: PropTypes.any, 2320 async: PropTypes.bool 2321 }; 2322 return TextareaAutosizeClass; 2323 }(React.Component)); 2324 exports.TextareaAutosize = React.forwardRef(function (props, ref) { 2325 return React.createElement(TextareaAutosizeClass, __assign({}, props, { innerRef: ref })); 2326 }); 2327 2328 2329 /***/ }), 2330 2331 /***/ 773: 2332 /***/ (function(__unused_webpack_module, exports, __webpack_require__) { 2333 2334 "use strict"; 2335 var __webpack_unused_export__; 2336 2337 __webpack_unused_export__ = true; 2338 var TextareaAutosize_1 = __webpack_require__(5438); 2339 exports.Z = TextareaAutosize_1.TextareaAutosize; 2340 2341 2342 /***/ }), 2343 2344 /***/ 3124: 2345 /***/ (function(module) { 2346 2347 var traverse = module.exports = function (obj) { 2348 return new Traverse(obj); 2349 }; 2350 2351 function Traverse (obj) { 2352 this.value = obj; 2353 } 2354 2355 Traverse.prototype.get = function (ps) { 2356 var node = this.value; 2357 for (var i = 0; i < ps.length; i ++) { 2358 var key = ps[i]; 2359 if (!node || !hasOwnProperty.call(node, key)) { 2360 node = undefined; 2361 break; 2362 } 2363 node = node[key]; 2364 } 2365 return node; 2366 }; 2367 2368 Traverse.prototype.has = function (ps) { 2369 var node = this.value; 2370 for (var i = 0; i < ps.length; i ++) { 2371 var key = ps[i]; 2372 if (!node || !hasOwnProperty.call(node, key)) { 2373 return false; 2374 } 2375 node = node[key]; 2376 } 2377 return true; 2378 }; 2379 2380 Traverse.prototype.set = function (ps, value) { 2381 var node = this.value; 2382 for (var i = 0; i < ps.length - 1; i ++) { 2383 var key = ps[i]; 2384 if (!hasOwnProperty.call(node, key)) node[key] = {}; 2385 node = node[key]; 2386 } 2387 node[ps[i]] = value; 2388 return value; 2389 }; 2390 2391 Traverse.prototype.map = function (cb) { 2392 return walk(this.value, cb, true); 2393 }; 2394 2395 Traverse.prototype.forEach = function (cb) { 2396 this.value = walk(this.value, cb, false); 2397 return this.value; 2398 }; 2399 2400 Traverse.prototype.reduce = function (cb, init) { 2401 var skip = arguments.length === 1; 2402 var acc = skip ? this.value : init; 2403 this.forEach(function (x) { 2404 if (!this.isRoot || !skip) { 2405 acc = cb.call(this, acc, x); 2406 } 2407 }); 2408 return acc; 2409 }; 2410 2411 Traverse.prototype.paths = function () { 2412 var acc = []; 2413 this.forEach(function (x) { 2414 acc.push(this.path); 2415 }); 2416 return acc; 2417 }; 2418 2419 Traverse.prototype.nodes = function () { 2420 var acc = []; 2421 this.forEach(function (x) { 2422 acc.push(this.node); 2423 }); 2424 return acc; 2425 }; 2426 2427 Traverse.prototype.clone = function () { 2428 var parents = [], nodes = []; 2429 2430 return (function clone (src) { 2431 for (var i = 0; i < parents.length; i++) { 2432 if (parents[i] === src) { 2433 return nodes[i]; 2434 } 2435 } 2436 2437 if (typeof src === 'object' && src !== null) { 2438 var dst = copy(src); 2439 2440 parents.push(src); 2441 nodes.push(dst); 2442 2443 forEach(objectKeys(src), function (key) { 2444 dst[key] = clone(src[key]); 2445 }); 2446 2447 parents.pop(); 2448 nodes.pop(); 2449 return dst; 2450 } 2451 else { 2452 return src; 2453 } 2454 })(this.value); 2455 }; 2456 2457 function walk (root, cb, immutable) { 2458 var path = []; 2459 var parents = []; 2460 var alive = true; 2461 2462 return (function walker (node_) { 2463 var node = immutable ? copy(node_) : node_; 2464 var modifiers = {}; 2465 2466 var keepGoing = true; 2467 2468 var state = { 2469 node : node, 2470 node_ : node_, 2471 path : [].concat(path), 2472 parent : parents[parents.length - 1], 2473 parents : parents, 2474 key : path.slice(-1)[0], 2475 isRoot : path.length === 0, 2476 level : path.length, 2477 circular : null, 2478 update : function (x, stopHere) { 2479 if (!state.isRoot) { 2480 state.parent.node[state.key] = x; 2481 } 2482 state.node = x; 2483 if (stopHere) keepGoing = false; 2484 }, 2485 'delete' : function (stopHere) { 2486 delete state.parent.node[state.key]; 2487 if (stopHere) keepGoing = false; 2488 }, 2489 remove : function (stopHere) { 2490 if (isArray(state.parent.node)) { 2491 state.parent.node.splice(state.key, 1); 2492 } 2493 else { 2494 delete state.parent.node[state.key]; 2495 } 2496 if (stopHere) keepGoing = false; 2497 }, 2498 keys : null, 2499 before : function (f) { modifiers.before = f }, 2500 after : function (f) { modifiers.after = f }, 2501 pre : function (f) { modifiers.pre = f }, 2502 post : function (f) { modifiers.post = f }, 2503 stop : function () { alive = false }, 2504 block : function () { keepGoing = false } 2505 }; 2506 2507 if (!alive) return state; 2508 2509 function updateState() { 2510 if (typeof state.node === 'object' && state.node !== null) { 2511 if (!state.keys || state.node_ !== state.node) { 2512 state.keys = objectKeys(state.node) 2513 } 2514 2515 state.isLeaf = state.keys.length == 0; 2516 2517 for (var i = 0; i < parents.length; i++) { 2518 if (parents[i].node_ === node_) { 2519 state.circular = parents[i]; 2520 break; 2521 } 2522 } 2523 } 2524 else { 2525 state.isLeaf = true; 2526 state.keys = null; 2527 } 2528 2529 state.notLeaf = !state.isLeaf; 2530 state.notRoot = !state.isRoot; 2531 } 2532 2533 updateState(); 2534 2535 // use return values to update if defined 2536 var ret = cb.call(state, state.node); 2537 if (ret !== undefined && state.update) state.update(ret); 2538 2539 if (modifiers.before) modifiers.before.call(state, state.node); 2540 2541 if (!keepGoing) return state; 2542 2543 if (typeof state.node == 'object' 2544 && state.node !== null && !state.circular) { 2545 parents.push(state); 2546 2547 updateState(); 2548 2549 forEach(state.keys, function (key, i) { 2550 path.push(key); 2551 2552 if (modifiers.pre) modifiers.pre.call(state, state.node[key], key); 2553 2554 var child = walker(state.node[key]); 2555 if (immutable && hasOwnProperty.call(state.node, key)) { 2556 state.node[key] = child.node; 2557 } 2558 2559 child.isLast = i == state.keys.length - 1; 2560 child.isFirst = i == 0; 2561 2562 if (modifiers.post) modifiers.post.call(state, child); 2563 2564 path.pop(); 2565 }); 2566 parents.pop(); 2567 } 2568 2569 if (modifiers.after) modifiers.after.call(state, state.node); 2570 2571 return state; 2572 })(root).node; 2573 } 2574 2575 function copy (src) { 2576 if (typeof src === 'object' && src !== null) { 2577 var dst; 2578 2579 if (isArray(src)) { 2580 dst = []; 2581 } 2582 else if (isDate(src)) { 2583 dst = new Date(src.getTime ? src.getTime() : src); 2584 } 2585 else if (isRegExp(src)) { 2586 dst = new RegExp(src); 2587 } 2588 else if (isError(src)) { 2589 dst = { message: src.message }; 2590 } 2591 else if (isBoolean(src)) { 2592 dst = new Boolean(src); 2593 } 2594 else if (isNumber(src)) { 2595 dst = new Number(src); 2596 } 2597 else if (isString(src)) { 2598 dst = new String(src); 2599 } 2600 else if (Object.create && Object.getPrototypeOf) { 2601 dst = Object.create(Object.getPrototypeOf(src)); 2602 } 2603 else if (src.constructor === Object) { 2604 dst = {}; 2605 } 2606 else { 2607 var proto = 2608 (src.constructor && src.constructor.prototype) 2609 || src.__proto__ 2610 || {} 2611 ; 2612 var T = function () {}; 2613 T.prototype = proto; 2614 dst = new T; 2615 } 2616 2617 forEach(objectKeys(src), function (key) { 2618 dst[key] = src[key]; 2619 }); 2620 return dst; 2621 } 2622 else return src; 2623 } 2624 2625 var objectKeys = Object.keys || function keys (obj) { 2626 var res = []; 2627 for (var key in obj) res.push(key) 2628 return res; 2629 }; 2630 2631 function toS (obj) { return Object.prototype.toString.call(obj) } 2632 function isDate (obj) { return toS(obj) === '[object Date]' } 2633 function isRegExp (obj) { return toS(obj) === '[object RegExp]' } 2634 function isError (obj) { return toS(obj) === '[object Error]' } 2635 function isBoolean (obj) { return toS(obj) === '[object Boolean]' } 2636 function isNumber (obj) { return toS(obj) === '[object Number]' } 2637 function isString (obj) { return toS(obj) === '[object String]' } 2638 2639 var isArray = Array.isArray || function isArray (xs) { 2640 return Object.prototype.toString.call(xs) === '[object Array]'; 2641 }; 2642 2643 var forEach = function (xs, fn) { 2644 if (xs.forEach) return xs.forEach(fn) 2645 else for (var i = 0; i < xs.length; i++) { 2646 fn(xs[i], i, xs); 2647 } 2648 }; 2649 2650 forEach(objectKeys(Traverse.prototype), function (key) { 2651 traverse[key] = function (obj) { 2652 var args = [].slice.call(arguments, 1); 2653 var t = new Traverse(obj); 2654 return t[key].apply(t, args); 2655 }; 2656 }); 2657 2658 var hasOwnProperty = Object.hasOwnProperty || function (obj, key) { 2659 return key in obj; 2660 }; 2661 2662 2663 /***/ }), 2664 2665 /***/ 9196: 2666 /***/ (function(module) { 2667 2668 "use strict"; 2669 module.exports = window["React"]; 2670 2671 /***/ }) 2672 2673 /******/ }); 2674 /************************************************************************/ 2675 /******/ // The module cache 2676 /******/ var __webpack_module_cache__ = {}; 2677 /******/ 2678 /******/ // The require function 2679 /******/ function __webpack_require__(moduleId) { 2680 /******/ // Check if module is in cache 2681 /******/ var cachedModule = __webpack_module_cache__[moduleId]; 2682 /******/ if (cachedModule !== undefined) { 2683 /******/ return cachedModule.exports; 2684 /******/ } 2685 /******/ // Create a new module (and put it into the cache) 2686 /******/ var module = __webpack_module_cache__[moduleId] = { 2687 /******/ // no module.id needed 2688 /******/ // no module.loaded needed 2689 /******/ exports: {} 2690 /******/ }; 2691 /******/ 2692 /******/ // Execute the module function 2693 /******/ __webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__); 2694 /******/ 2695 /******/ // Return the exports of the module 2696 /******/ return module.exports; 2697 /******/ } 2698 /******/ 2699 /************************************************************************/ 2700 /******/ /* webpack/runtime/compat get default export */ 2701 /******/ !function() { 2702 /******/ // getDefaultExport function for compatibility with non-harmony modules 2703 /******/ __webpack_require__.n = function(module) { 2704 /******/ var getter = module && module.__esModule ? 2705 /******/ function() { return module['default']; } : 2706 /******/ function() { return module; }; 2707 /******/ __webpack_require__.d(getter, { a: getter }); 2708 /******/ return getter; 2709 /******/ }; 2710 /******/ }(); 2711 /******/ 2712 /******/ /* webpack/runtime/define property getters */ 2713 /******/ !function() { 2714 /******/ // define getter functions for harmony exports 2715 /******/ __webpack_require__.d = function(exports, definition) { 2716 /******/ for(var key in definition) { 2717 /******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { 2718 /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); 2719 /******/ } 2720 /******/ } 2721 /******/ }; 2722 /******/ }(); 2723 /******/ 2724 /******/ /* webpack/runtime/hasOwnProperty shorthand */ 2725 /******/ !function() { 2726 /******/ __webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); } 2727 /******/ }(); 2728 /******/ 2729 /******/ /* webpack/runtime/make namespace object */ 2730 /******/ !function() { 2731 /******/ // define __esModule on exports 2732 /******/ __webpack_require__.r = function(exports) { 2733 /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { 2734 /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); 2735 /******/ } 2736 /******/ Object.defineProperty(exports, '__esModule', { value: true }); 2737 /******/ }; 2738 /******/ }(); 2739 /******/ 2740 /************************************************************************/ 2741 var __webpack_exports__ = {}; 2742 // This entry need to be wrapped in an IIFE because it need to be in strict mode. 2743 !function() { 2744 "use strict"; 2745 // ESM COMPAT FLAG 2746 __webpack_require__.r(__webpack_exports__); 2747 2748 // EXPORTS 2749 __webpack_require__.d(__webpack_exports__, { 2750 "AlignmentControl": function() { return /* reexport */ AlignmentControl; }, 2751 "AlignmentToolbar": function() { return /* reexport */ AlignmentToolbar; }, 2752 "Autocomplete": function() { return /* reexport */ autocomplete; }, 2753 "BlockAlignmentControl": function() { return /* reexport */ BlockAlignmentControl; }, 2754 "BlockAlignmentToolbar": function() { return /* reexport */ BlockAlignmentToolbar; }, 2755 "BlockBreadcrumb": function() { return /* reexport */ block_breadcrumb; }, 2756 "BlockColorsStyleSelector": function() { return /* reexport */ color_style_selector; }, 2757 "BlockContextProvider": function() { return /* reexport */ BlockContextProvider; }, 2758 "BlockControls": function() { return /* reexport */ block_controls; }, 2759 "BlockEdit": function() { return /* reexport */ BlockEdit; }, 2760 "BlockEditorKeyboardShortcuts": function() { return /* reexport */ keyboard_shortcuts; }, 2761 "BlockEditorProvider": function() { return /* reexport */ provider; }, 2762 "BlockFormatControls": function() { return /* reexport */ BlockFormatControls; }, 2763 "BlockIcon": function() { return /* reexport */ block_icon; }, 2764 "BlockInspector": function() { return /* reexport */ block_inspector; }, 2765 "BlockList": function() { return /* reexport */ BlockList; }, 2766 "BlockMover": function() { return /* reexport */ block_mover; }, 2767 "BlockNavigationDropdown": function() { return /* reexport */ dropdown; }, 2768 "BlockPreview": function() { return /* reexport */ block_preview; }, 2769 "BlockSelectionClearer": function() { return /* reexport */ BlockSelectionClearer; }, 2770 "BlockSettingsMenu": function() { return /* reexport */ block_settings_menu; }, 2771 "BlockSettingsMenuControls": function() { return /* reexport */ block_settings_menu_controls; }, 2772 "BlockStyles": function() { return /* reexport */ block_styles; }, 2773 "BlockTitle": function() { return /* reexport */ BlockTitle; }, 2774 "BlockToolbar": function() { return /* reexport */ block_toolbar; }, 2775 "BlockTools": function() { return /* reexport */ BlockTools; }, 2776 "BlockVerticalAlignmentControl": function() { return /* reexport */ BlockVerticalAlignmentControl; }, 2777 "BlockVerticalAlignmentToolbar": function() { return /* reexport */ BlockVerticalAlignmentToolbar; }, 2778 "ButtonBlockAppender": function() { return /* reexport */ button_block_appender; }, 2779 "ButtonBlockerAppender": function() { return /* reexport */ ButtonBlockerAppender; }, 2780 "ColorPalette": function() { return /* reexport */ color_palette; }, 2781 "ColorPaletteControl": function() { return /* reexport */ ColorPaletteControl; }, 2782 "ContrastChecker": function() { return /* reexport */ contrast_checker; }, 2783 "CopyHandler": function() { return /* reexport */ copy_handler; }, 2784 "DefaultBlockAppender": function() { return /* reexport */ default_block_appender; }, 2785 "FontSizePicker": function() { return /* reexport */ font_size_picker; }, 2786 "InnerBlocks": function() { return /* reexport */ inner_blocks; }, 2787 "Inserter": function() { return /* reexport */ inserter; }, 2788 "InspectorAdvancedControls": function() { return /* reexport */ InspectorAdvancedControls; }, 2789 "InspectorControls": function() { return /* reexport */ inspector_controls; }, 2790 "JustifyContentControl": function() { return /* reexport */ JustifyContentControl; }, 2791 "JustifyToolbar": function() { return /* reexport */ JustifyToolbar; }, 2792 "LineHeightControl": function() { return /* reexport */ line_height_control; }, 2793 "MediaPlaceholder": function() { return /* reexport */ media_placeholder; }, 2794 "MediaReplaceFlow": function() { return /* reexport */ media_replace_flow; }, 2795 "MediaUpload": function() { return /* reexport */ media_upload; }, 2796 "MediaUploadCheck": function() { return /* reexport */ media_upload_check; }, 2797 "MultiSelectScrollIntoView": function() { return /* reexport */ MultiSelectScrollIntoView; }, 2798 "NavigableToolbar": function() { return /* reexport */ navigable_toolbar; }, 2799 "ObserveTyping": function() { return /* reexport */ observe_typing; }, 2800 "PanelColorSettings": function() { return /* reexport */ panel_color_settings; }, 2801 "PlainText": function() { return /* reexport */ plain_text; }, 2802 "RichText": function() { return /* reexport */ rich_text; }, 2803 "RichTextShortcut": function() { return /* reexport */ RichTextShortcut; }, 2804 "RichTextToolbarButton": function() { return /* reexport */ RichTextToolbarButton; }, 2805 "SETTINGS_DEFAULTS": function() { return /* reexport */ SETTINGS_DEFAULTS; }, 2806 "SkipToSelectedBlock": function() { return /* reexport */ skip_to_selected_block; }, 2807 "ToolSelector": function() { return /* reexport */ tool_selector; }, 2808 "Typewriter": function() { return /* reexport */ typewriter; }, 2809 "URLInput": function() { return /* reexport */ url_input; }, 2810 "URLInputButton": function() { return /* reexport */ url_input_button; }, 2811 "URLPopover": function() { return /* reexport */ url_popover; }, 2812 "Warning": function() { return /* reexport */ warning; }, 2813 "WritingFlow": function() { return /* reexport */ writing_flow; }, 2814 "__experimentalBlockAlignmentMatrixControl": function() { return /* reexport */ block_alignment_matrix_control; }, 2815 "__experimentalBlockContentOverlay": function() { return /* reexport */ BlockContentOverlay; }, 2816 "__experimentalBlockFullHeightAligmentControl": function() { return /* reexport */ block_full_height_alignment_control; }, 2817 "__experimentalBlockPatternSetup": function() { return /* reexport */ block_pattern_setup; }, 2818 "__experimentalBlockPatternsList": function() { return /* reexport */ block_patterns_list; }, 2819 "__experimentalBlockVariationPicker": function() { return /* reexport */ block_variation_picker; }, 2820 "__experimentalBlockVariationTransforms": function() { return /* reexport */ block_variation_transforms; }, 2821 "__experimentalBorderRadiusControl": function() { return /* reexport */ BorderRadiusControl; }, 2822 "__experimentalBorderStyleControl": function() { return /* reexport */ BorderStyleControl; }, 2823 "__experimentalColorGradientControl": function() { return /* reexport */ control; }, 2824 "__experimentalColorGradientSettingsDropdown": function() { return /* reexport */ ColorGradientSettingsDropdown; }, 2825 "__experimentalDateFormatPicker": function() { return /* reexport */ DateFormatPicker; }, 2826 "__experimentalDuotoneControl": function() { return /* reexport */ duotone_control; }, 2827 "__experimentalFontAppearanceControl": function() { return /* reexport */ FontAppearanceControl; }, 2828 "__experimentalFontFamilyControl": function() { return /* reexport */ FontFamilyControl; }, 2829 "__experimentalGetBorderClassesAndStyles": function() { return /* reexport */ getBorderClassesAndStyles; }, 2830 "__experimentalGetColorClassesAndStyles": function() { return /* reexport */ getColorClassesAndStyles; }, 2831 "__experimentalGetGradientClass": function() { return /* reexport */ __experimentalGetGradientClass; }, 2832 "__experimentalGetGradientObjectByGradientValue": function() { return /* reexport */ __experimentalGetGradientObjectByGradientValue; }, 2833 "__experimentalGetMatchingVariation": function() { return /* reexport */ __experimentalGetMatchingVariation; }, 2834 "__experimentalGetSpacingClassesAndStyles": function() { return /* reexport */ getSpacingClassesAndStyles; }, 2835 "__experimentalImageEditingProvider": function() { return /* reexport */ ImageEditingProvider; }, 2836 "__experimentalImageEditor": function() { return /* reexport */ ImageEditor; }, 2837 "__experimentalImageSizeControl": function() { return /* reexport */ ImageSizeControl; }, 2838 "__experimentalImageURLInputUI": function() { return /* reexport */ ImageURLInputUI; }, 2839 "__experimentalLayoutStyle": function() { return /* reexport */ LayoutStyle; }, 2840 "__experimentalLetterSpacingControl": function() { return /* reexport */ LetterSpacingControl; }, 2841 "__experimentalLibrary": function() { return /* reexport */ library; }, 2842 "__experimentalLinkControl": function() { return /* reexport */ link_control; }, 2843 "__experimentalLinkControlSearchInput": function() { return /* reexport */ search_input; }, 2844 "__experimentalLinkControlSearchItem": function() { return /* reexport */ search_item; }, 2845 "__experimentalLinkControlSearchResults": function() { return /* reexport */ LinkControlSearchResults; }, 2846 "__experimentalListView": function() { return /* reexport */ components_list_view; }, 2847 "__experimentalPanelColorGradientSettings": function() { return /* reexport */ panel_color_gradient_settings; }, 2848 "__experimentalPreviewOptions": function() { return /* reexport */ PreviewOptions; }, 2849 "__experimentalResponsiveBlockControl": function() { return /* reexport */ responsive_block_control; }, 2850 "__experimentalTextDecorationControl": function() { return /* reexport */ TextDecorationControl; }, 2851 "__experimentalTextTransformControl": function() { return /* reexport */ TextTransformControl; }, 2852 "__experimentalToolsPanelColorDropdown": function() { return /* reexport */ ToolsPanelColorDropdown; }, 2853 "__experimentalUnitControl": function() { return /* reexport */ UnitControl; }, 2854 "__experimentalUseBlockPreview": function() { return /* reexport */ useBlockPreview; }, 2855 "__experimentalUseBorderProps": function() { return /* reexport */ useBorderProps; }, 2856 "__experimentalUseColorProps": function() { return /* reexport */ useColorProps; }, 2857 "__experimentalUseCustomSides": function() { return /* reexport */ useCustomSides; }, 2858 "__experimentalUseGradient": function() { return /* reexport */ __experimentalUseGradient; }, 2859 "__experimentalUseNoRecursiveRenders": function() { return /* reexport */ useNoRecursiveRenders; }, 2860 "__experimentalUseResizeCanvas": function() { return /* reexport */ useResizeCanvas; }, 2861 "__unstableBlockNameContext": function() { return /* reexport */ block_name_context; }, 2862 "__unstableBlockSettingsMenuFirstItem": function() { return /* reexport */ block_settings_menu_first_item; }, 2863 "__unstableBlockToolbarLastItem": function() { return /* reexport */ block_toolbar_last_item; }, 2864 "__unstableEditorStyles": function() { return /* reexport */ EditorStyles; }, 2865 "__unstableIframe": function() { return /* reexport */ iframe; }, 2866 "__unstableInserterMenuExtension": function() { return /* reexport */ inserter_menu_extension; }, 2867 "__unstablePresetDuotoneFilter": function() { return /* reexport */ PresetDuotoneFilter; }, 2868 "__unstableRichTextInputEvent": function() { return /* reexport */ __unstableRichTextInputEvent; }, 2869 "__unstableUseBlockSelectionClearer": function() { return /* reexport */ useBlockSelectionClearer; }, 2870 "__unstableUseClipboardHandler": function() { return /* reexport */ useClipboardHandler; }, 2871 "__unstableUseMouseMoveTypingReset": function() { return /* reexport */ useMouseMoveTypingReset; }, 2872 "__unstableUseTypewriter": function() { return /* reexport */ useTypewriter; }, 2873 "__unstableUseTypingObserver": function() { return /* reexport */ useTypingObserver; }, 2874 "createCustomColorsHOC": function() { return /* reexport */ createCustomColorsHOC; }, 2875 "getColorClassName": function() { return /* reexport */ getColorClassName; }, 2876 "getColorObjectByAttributeValues": function() { return /* reexport */ getColorObjectByAttributeValues; }, 2877 "getColorObjectByColorValue": function() { return /* reexport */ getColorObjectByColorValue; }, 2878 "getFontSize": function() { return /* reexport */ getFontSize; }, 2879 "getFontSizeClass": function() { return /* reexport */ getFontSizeClass; }, 2880 "getFontSizeObjectByValue": function() { return /* reexport */ getFontSizeObjectByValue; }, 2881 "getGradientSlugByValue": function() { return /* reexport */ getGradientSlugByValue; }, 2882 "getGradientValueBySlug": function() { return /* reexport */ getGradientValueBySlug; }, 2883 "getPxFromCssUnit": function() { return /* reexport */ parse_css_unit_to_px; }, 2884 "store": function() { return /* reexport */ store; }, 2885 "storeConfig": function() { return /* reexport */ storeConfig; }, 2886 "transformStyles": function() { return /* reexport */ transform_styles; }, 2887 "useBlockDisplayInformation": function() { return /* reexport */ useBlockDisplayInformation; }, 2888 "useBlockEditContext": function() { return /* reexport */ useBlockEditContext; }, 2889 "useBlockProps": function() { return /* reexport */ useBlockProps; }, 2890 "useCachedTruthy": function() { return /* reexport */ useCachedTruthy; }, 2891 "useInnerBlocksProps": function() { return /* reexport */ useInnerBlocksProps; }, 2892 "useSetting": function() { return /* reexport */ useSetting; }, 2893 "withColorContext": function() { return /* reexport */ with_color_context; }, 2894 "withColors": function() { return /* reexport */ withColors; }, 2895 "withFontSizes": function() { return /* reexport */ with_font_sizes; } 2896 }); 2897 2898 // NAMESPACE OBJECT: ./node_modules/@wordpress/block-editor/build-module/store/selectors.js 2899 var selectors_namespaceObject = {}; 2900 __webpack_require__.r(selectors_namespaceObject); 2901 __webpack_require__.d(selectors_namespaceObject, { 2902 "__experimentalGetActiveBlockIdByBlockNames": function() { return __experimentalGetActiveBlockIdByBlockNames; }, 2903 "__experimentalGetAllowedBlocks": function() { return __experimentalGetAllowedBlocks; }, 2904 "__experimentalGetAllowedPatterns": function() { return __experimentalGetAllowedPatterns; }, 2905 "__experimentalGetBlockListSettingsForBlocks": function() { return __experimentalGetBlockListSettingsForBlocks; }, 2906 "__experimentalGetDirectInsertBlock": function() { return __experimentalGetDirectInsertBlock; }, 2907 "__experimentalGetGlobalBlocksByName": function() { return __experimentalGetGlobalBlocksByName; }, 2908 "__experimentalGetLastBlockAttributeChanges": function() { return __experimentalGetLastBlockAttributeChanges; }, 2909 "__experimentalGetParsedPattern": function() { return __experimentalGetParsedPattern; }, 2910 "__experimentalGetPatternTransformItems": function() { return __experimentalGetPatternTransformItems; }, 2911 "__experimentalGetPatternsByBlockTypes": function() { return __experimentalGetPatternsByBlockTypes; }, 2912 "__experimentalGetReusableBlockTitle": function() { return __experimentalGetReusableBlockTitle; }, 2913 "__unstableGetBlockWithoutInnerBlocks": function() { return __unstableGetBlockWithoutInnerBlocks; }, 2914 "__unstableGetClientIdWithClientIdsTree": function() { return __unstableGetClientIdWithClientIdsTree; }, 2915 "__unstableGetClientIdsTree": function() { return __unstableGetClientIdsTree; }, 2916 "__unstableGetSelectedBlocksWithPartialSelection": function() { return __unstableGetSelectedBlocksWithPartialSelection; }, 2917 "__unstableIsFullySelected": function() { return __unstableIsFullySelected; }, 2918 "__unstableIsLastBlockChangeIgnored": function() { return __unstableIsLastBlockChangeIgnored; }, 2919 "__unstableIsSelectionCollapsed": function() { return __unstableIsSelectionCollapsed; }, 2920 "__unstableIsSelectionMergeable": function() { return __unstableIsSelectionMergeable; }, 2921 "areInnerBlocksControlled": function() { return areInnerBlocksControlled; }, 2922 "canInsertBlockType": function() { return canInsertBlockType; }, 2923 "canInsertBlocks": function() { return canInsertBlocks; }, 2924 "canLockBlockType": function() { return canLockBlockType; }, 2925 "canMoveBlock": function() { return canMoveBlock; }, 2926 "canMoveBlocks": function() { return canMoveBlocks; }, 2927 "canRemoveBlock": function() { return canRemoveBlock; }, 2928 "canRemoveBlocks": function() { return canRemoveBlocks; }, 2929 "didAutomaticChange": function() { return didAutomaticChange; }, 2930 "getAdjacentBlockClientId": function() { return getAdjacentBlockClientId; }, 2931 "getBlock": function() { return getBlock; }, 2932 "getBlockAttributes": function() { return getBlockAttributes; }, 2933 "getBlockCount": function() { return getBlockCount; }, 2934 "getBlockHierarchyRootClientId": function() { return getBlockHierarchyRootClientId; }, 2935 "getBlockIndex": function() { return getBlockIndex; }, 2936 "getBlockInsertionPoint": function() { return getBlockInsertionPoint; }, 2937 "getBlockListSettings": function() { return getBlockListSettings; }, 2938 "getBlockMode": function() { return getBlockMode; }, 2939 "getBlockName": function() { return getBlockName; }, 2940 "getBlockOrder": function() { return getBlockOrder; }, 2941 "getBlockParents": function() { return getBlockParents; }, 2942 "getBlockParentsByBlockName": function() { return getBlockParentsByBlockName; }, 2943 "getBlockRootClientId": function() { return getBlockRootClientId; }, 2944 "getBlockSelectionEnd": function() { return getBlockSelectionEnd; }, 2945 "getBlockSelectionStart": function() { return getBlockSelectionStart; }, 2946 "getBlockTransformItems": function() { return getBlockTransformItems; }, 2947 "getBlocks": function() { return getBlocks; }, 2948 "getBlocksByClientId": function() { return getBlocksByClientId; }, 2949 "getClientIdsOfDescendants": function() { return getClientIdsOfDescendants; }, 2950 "getClientIdsWithDescendants": function() { return getClientIdsWithDescendants; }, 2951 "getDraggedBlockClientIds": function() { return getDraggedBlockClientIds; }, 2952 "getFirstMultiSelectedBlockClientId": function() { return getFirstMultiSelectedBlockClientId; }, 2953 "getGlobalBlockCount": function() { return getGlobalBlockCount; }, 2954 "getInserterItems": function() { return getInserterItems; }, 2955 "getLastMultiSelectedBlockClientId": function() { return getLastMultiSelectedBlockClientId; }, 2956 "getLowestCommonAncestorWithSelectedBlock": function() { return getLowestCommonAncestorWithSelectedBlock; }, 2957 "getMultiSelectedBlockClientIds": function() { return getMultiSelectedBlockClientIds; }, 2958 "getMultiSelectedBlocks": function() { return getMultiSelectedBlocks; }, 2959 "getMultiSelectedBlocksEndClientId": function() { return getMultiSelectedBlocksEndClientId; }, 2960 "getMultiSelectedBlocksStartClientId": function() { return getMultiSelectedBlocksStartClientId; }, 2961 "getNextBlockClientId": function() { return getNextBlockClientId; }, 2962 "getPreviousBlockClientId": function() { return getPreviousBlockClientId; }, 2963 "getSelectedBlock": function() { return getSelectedBlock; }, 2964 "getSelectedBlockClientId": function() { return getSelectedBlockClientId; }, 2965 "getSelectedBlockClientIds": function() { return getSelectedBlockClientIds; }, 2966 "getSelectedBlockCount": function() { return getSelectedBlockCount; }, 2967 "getSelectedBlocksInitialCaretPosition": function() { return getSelectedBlocksInitialCaretPosition; }, 2968 "getSelectionEnd": function() { return getSelectionEnd; }, 2969 "getSelectionStart": function() { return getSelectionStart; }, 2970 "getSettings": function() { return getSettings; }, 2971 "getTemplate": function() { return getTemplate; }, 2972 "getTemplateLock": function() { return getTemplateLock; }, 2973 "hasBlockMovingClientId": function() { return selectors_hasBlockMovingClientId; }, 2974 "hasInserterItems": function() { return hasInserterItems; }, 2975 "hasMultiSelection": function() { return hasMultiSelection; }, 2976 "hasSelectedBlock": function() { return hasSelectedBlock; }, 2977 "hasSelectedInnerBlock": function() { return hasSelectedInnerBlock; }, 2978 "isAncestorBeingDragged": function() { return isAncestorBeingDragged; }, 2979 "isAncestorMultiSelected": function() { return isAncestorMultiSelected; }, 2980 "isBlockBeingDragged": function() { return isBlockBeingDragged; }, 2981 "isBlockHighlighted": function() { return isBlockHighlighted; }, 2982 "isBlockInsertionPointVisible": function() { return isBlockInsertionPointVisible; }, 2983 "isBlockMultiSelected": function() { return isBlockMultiSelected; }, 2984 "isBlockSelected": function() { return isBlockSelected; }, 2985 "isBlockValid": function() { return isBlockValid; }, 2986 "isBlockWithinSelection": function() { return isBlockWithinSelection; }, 2987 "isCaretWithinFormattedText": function() { return selectors_isCaretWithinFormattedText; }, 2988 "isDraggingBlocks": function() { return isDraggingBlocks; }, 2989 "isFirstMultiSelectedBlock": function() { return isFirstMultiSelectedBlock; }, 2990 "isLastBlockChangePersistent": function() { return isLastBlockChangePersistent; }, 2991 "isMultiSelecting": function() { return selectors_isMultiSelecting; }, 2992 "isNavigationMode": function() { return selectors_isNavigationMode; }, 2993 "isSelectionEnabled": function() { return selectors_isSelectionEnabled; }, 2994 "isTyping": function() { return selectors_isTyping; }, 2995 "isValidTemplate": function() { return isValidTemplate; }, 2996 "wasBlockJustInserted": function() { return wasBlockJustInserted; } 2997 }); 2998 2999 // NAMESPACE OBJECT: ./node_modules/@wordpress/block-editor/build-module/store/actions.js 3000 var actions_namespaceObject = {}; 3001 __webpack_require__.r(actions_namespaceObject); 3002 __webpack_require__.d(actions_namespaceObject, { 3003 "__unstableDeleteSelection": function() { return __unstableDeleteSelection; }, 3004 "__unstableExpandSelection": function() { return __unstableExpandSelection; }, 3005 "__unstableMarkAutomaticChange": function() { return __unstableMarkAutomaticChange; }, 3006 "__unstableMarkLastChangeAsPersistent": function() { return __unstableMarkLastChangeAsPersistent; }, 3007 "__unstableMarkNextChangeAsNotPersistent": function() { return __unstableMarkNextChangeAsNotPersistent; }, 3008 "__unstableSaveReusableBlock": function() { return __unstableSaveReusableBlock; }, 3009 "__unstableSplitSelection": function() { return __unstableSplitSelection; }, 3010 "clearSelectedBlock": function() { return clearSelectedBlock; }, 3011 "duplicateBlocks": function() { return duplicateBlocks; }, 3012 "enterFormattedText": function() { return enterFormattedText; }, 3013 "exitFormattedText": function() { return exitFormattedText; }, 3014 "flashBlock": function() { return flashBlock; }, 3015 "hideInsertionPoint": function() { return hideInsertionPoint; }, 3016 "insertAfterBlock": function() { return insertAfterBlock; }, 3017 "insertBeforeBlock": function() { return insertBeforeBlock; }, 3018 "insertBlock": function() { return insertBlock; }, 3019 "insertBlocks": function() { return insertBlocks; }, 3020 "insertDefaultBlock": function() { return insertDefaultBlock; }, 3021 "mergeBlocks": function() { return mergeBlocks; }, 3022 "moveBlockToPosition": function() { return moveBlockToPosition; }, 3023 "moveBlocksDown": function() { return moveBlocksDown; }, 3024 "moveBlocksToPosition": function() { return moveBlocksToPosition; }, 3025 "moveBlocksUp": function() { return moveBlocksUp; }, 3026 "multiSelect": function() { return multiSelect; }, 3027 "receiveBlocks": function() { return receiveBlocks; }, 3028 "removeBlock": function() { return removeBlock; }, 3029 "removeBlocks": function() { return removeBlocks; }, 3030 "replaceBlock": function() { return replaceBlock; }, 3031 "replaceBlocks": function() { return replaceBlocks; }, 3032 "replaceInnerBlocks": function() { return replaceInnerBlocks; }, 3033 "resetBlocks": function() { return resetBlocks; }, 3034 "resetSelection": function() { return resetSelection; }, 3035 "selectBlock": function() { return selectBlock; }, 3036 "selectNextBlock": function() { return selectNextBlock; }, 3037 "selectPreviousBlock": function() { return selectPreviousBlock; }, 3038 "selectionChange": function() { return selectionChange; }, 3039 "setBlockMovingClientId": function() { return setBlockMovingClientId; }, 3040 "setHasControlledInnerBlocks": function() { return setHasControlledInnerBlocks; }, 3041 "setNavigationMode": function() { return setNavigationMode; }, 3042 "setTemplateValidity": function() { return setTemplateValidity; }, 3043 "showInsertionPoint": function() { return showInsertionPoint; }, 3044 "startDraggingBlocks": function() { return startDraggingBlocks; }, 3045 "startMultiSelect": function() { return startMultiSelect; }, 3046 "startTyping": function() { return startTyping; }, 3047 "stopDraggingBlocks": function() { return stopDraggingBlocks; }, 3048 "stopMultiSelect": function() { return stopMultiSelect; }, 3049 "stopTyping": function() { return stopTyping; }, 3050 "synchronizeTemplate": function() { return synchronizeTemplate; }, 3051 "toggleBlockHighlight": function() { return toggleBlockHighlight; }, 3052 "toggleBlockMode": function() { return toggleBlockMode; }, 3053 "toggleSelection": function() { return toggleSelection; }, 3054 "updateBlock": function() { return updateBlock; }, 3055 "updateBlockAttributes": function() { return updateBlockAttributes; }, 3056 "updateBlockListSettings": function() { return updateBlockListSettings; }, 3057 "updateSettings": function() { return updateSettings; }, 3058 "validateBlocksToTemplate": function() { return validateBlocksToTemplate; } 3059 }); 3060 3061 ;// CONCATENATED MODULE: external ["wp","blocks"] 3062 var external_wp_blocks_namespaceObject = window["wp"]["blocks"]; 3063 ;// CONCATENATED MODULE: external ["wp","hooks"] 3064 var external_wp_hooks_namespaceObject = window["wp"]["hooks"]; 3065 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/hooks/compat.js 3066 /** 3067 * WordPress dependencies 3068 */ 3069 3070 3071 3072 function migrateLightBlockWrapper(settings) { 3073 const { 3074 apiVersion = 1 3075 } = settings; 3076 3077 if (apiVersion < 2 && (0,external_wp_blocks_namespaceObject.hasBlockSupport)(settings, 'lightBlockWrapper', false)) { 3078 settings.apiVersion = 2; 3079 } 3080 3081 return settings; 3082 } 3083 3084 (0,external_wp_hooks_namespaceObject.addFilter)('blocks.registerBlockType', 'core/compat/migrateLightBlockWrapper', migrateLightBlockWrapper); 3085 3086 ;// CONCATENATED MODULE: ./node_modules/@babel/runtime/helpers/esm/extends.js 3087 function _extends() { 3088 _extends = Object.assign || function (target) { 3089 for (var i = 1; i < arguments.length; i++) { 3090 var source = arguments[i]; 3091 3092 for (var key in source) { 3093 if (Object.prototype.hasOwnProperty.call(source, key)) { 3094 target[key] = source[key]; 3095 } 3096 } 3097 } 3098 3099 return target; 3100 }; 3101 3102 return _extends.apply(this, arguments); 3103 } 3104 ;// CONCATENATED MODULE: external ["wp","element"] 3105 var external_wp_element_namespaceObject = window["wp"]["element"]; 3106 // EXTERNAL MODULE: ./node_modules/classnames/index.js 3107 var classnames = __webpack_require__(4403); 3108 var classnames_default = /*#__PURE__*/__webpack_require__.n(classnames); 3109 ;// CONCATENATED MODULE: external "lodash" 3110 var external_lodash_namespaceObject = window["lodash"]; 3111 ;// CONCATENATED MODULE: external ["wp","compose"] 3112 var external_wp_compose_namespaceObject = window["wp"]["compose"]; 3113 ;// CONCATENATED MODULE: external ["wp","components"] 3114 var external_wp_components_namespaceObject = window["wp"]["components"]; 3115 ;// CONCATENATED MODULE: external ["wp","data"] 3116 var external_wp_data_namespaceObject = window["wp"]["data"]; 3117 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-controls/groups.js 3118 /** 3119 * WordPress dependencies 3120 */ 3121 3122 const BlockControlsDefault = (0,external_wp_components_namespaceObject.createSlotFill)('BlockControls'); 3123 const BlockControlsBlock = (0,external_wp_components_namespaceObject.createSlotFill)('BlockControlsBlock'); 3124 const BlockControlsInline = (0,external_wp_components_namespaceObject.createSlotFill)('BlockFormatControls'); 3125 const BlockControlsOther = (0,external_wp_components_namespaceObject.createSlotFill)('BlockControlsOther'); 3126 const BlockControlsParent = (0,external_wp_components_namespaceObject.createSlotFill)('BlockControlsParent'); 3127 const groups = { 3128 default: BlockControlsDefault, 3129 block: BlockControlsBlock, 3130 inline: BlockControlsInline, 3131 other: BlockControlsOther, 3132 parent: BlockControlsParent 3133 }; 3134 /* harmony default export */ var block_controls_groups = (groups); 3135 3136 ;// CONCATENATED MODULE: external ["wp","i18n"] 3137 var external_wp_i18n_namespaceObject = window["wp"]["i18n"]; 3138 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/store/defaults.js 3139 /** 3140 * WordPress dependencies 3141 */ 3142 3143 const PREFERENCES_DEFAULTS = { 3144 insertUsage: {} 3145 }; 3146 /** 3147 * The default editor settings 3148 * 3149 * @typedef {Object} SETTINGS_DEFAULT 3150 * @property {boolean} alignWide Enable/Disable Wide/Full Alignments 3151 * @property {boolean} supportsLayout Enable/disable layouts support in container blocks. 3152 * @property {boolean} imageEditing Image Editing settings set to false to disable. 3153 * @property {Array} imageSizes Available image sizes 3154 * @property {number} maxWidth Max width to constraint resizing 3155 * @property {boolean|Array} allowedBlockTypes Allowed block types 3156 * @property {boolean} hasFixedToolbar Whether or not the editor toolbar is fixed 3157 * @property {boolean} focusMode Whether the focus mode is enabled or not 3158 * @property {Array} styles Editor Styles 3159 * @property {boolean} keepCaretInsideBlock Whether caret should move between blocks in edit mode 3160 * @property {string} bodyPlaceholder Empty post placeholder 3161 * @property {string} titlePlaceholder Empty title placeholder 3162 * @property {boolean} canLockBlocks Whether the user can manage Block Lock state 3163 * @property {boolean} codeEditingEnabled Whether or not the user can switch to the code editor 3164 * @property {boolean} generateAnchors Enable/Disable auto anchor generation for Heading blocks 3165 * @property {boolean} __experimentalCanUserUseUnfilteredHTML Whether the user should be able to use unfiltered HTML or the HTML should be filtered e.g., to remove elements considered insecure like iframes. 3166 * @property {boolean} __experimentalBlockDirectory Whether the user has enabled the Block Directory 3167 * @property {Array} __experimentalBlockPatterns Array of objects representing the block patterns 3168 * @property {Array} __experimentalBlockPatternCategories Array of objects representing the block pattern categories 3169 * @property {boolean} __unstableGalleryWithImageBlocks Whether the user has enabled the refactored gallery block which uses InnerBlocks 3170 */ 3171 3172 const SETTINGS_DEFAULTS = { 3173 alignWide: false, 3174 supportsLayout: true, 3175 // colors setting is not used anymore now defaults are passed from theme.json on the server and core has its own defaults. 3176 // The setting is only kept for backward compatibility purposes. 3177 colors: [{ 3178 name: (0,external_wp_i18n_namespaceObject.__)('Black'), 3179 slug: 'black', 3180 color: '#000000' 3181 }, { 3182 name: (0,external_wp_i18n_namespaceObject.__)('Cyan bluish gray'), 3183 slug: 'cyan-bluish-gray', 3184 color: '#abb8c3' 3185 }, { 3186 name: (0,external_wp_i18n_namespaceObject.__)('White'), 3187 slug: 'white', 3188 color: '#ffffff' 3189 }, { 3190 name: (0,external_wp_i18n_namespaceObject.__)('Pale pink'), 3191 slug: 'pale-pink', 3192 color: '#f78da7' 3193 }, { 3194 name: (0,external_wp_i18n_namespaceObject.__)('Vivid red'), 3195 slug: 'vivid-red', 3196 color: '#cf2e2e' 3197 }, { 3198 name: (0,external_wp_i18n_namespaceObject.__)('Luminous vivid orange'), 3199 slug: 'luminous-vivid-orange', 3200 color: '#ff6900' 3201 }, { 3202 name: (0,external_wp_i18n_namespaceObject.__)('Luminous vivid amber'), 3203 slug: 'luminous-vivid-amber', 3204 color: '#fcb900' 3205 }, { 3206 name: (0,external_wp_i18n_namespaceObject.__)('Light green cyan'), 3207 slug: 'light-green-cyan', 3208 color: '#7bdcb5' 3209 }, { 3210 name: (0,external_wp_i18n_namespaceObject.__)('Vivid green cyan'), 3211 slug: 'vivid-green-cyan', 3212 color: '#00d084' 3213 }, { 3214 name: (0,external_wp_i18n_namespaceObject.__)('Pale cyan blue'), 3215 slug: 'pale-cyan-blue', 3216 color: '#8ed1fc' 3217 }, { 3218 name: (0,external_wp_i18n_namespaceObject.__)('Vivid cyan blue'), 3219 slug: 'vivid-cyan-blue', 3220 color: '#0693e3' 3221 }, { 3222 name: (0,external_wp_i18n_namespaceObject.__)('Vivid purple'), 3223 slug: 'vivid-purple', 3224 color: '#9b51e0' 3225 }], 3226 // fontSizes setting is not used anymore now defaults are passed from theme.json on the server and core has its own defaults. 3227 // The setting is only kept for backward compatibility purposes. 3228 fontSizes: [{ 3229 name: (0,external_wp_i18n_namespaceObject._x)('Small', 'font size name'), 3230 size: 13, 3231 slug: 'small' 3232 }, { 3233 name: (0,external_wp_i18n_namespaceObject._x)('Normal', 'font size name'), 3234 size: 16, 3235 slug: 'normal' 3236 }, { 3237 name: (0,external_wp_i18n_namespaceObject._x)('Medium', 'font size name'), 3238 size: 20, 3239 slug: 'medium' 3240 }, { 3241 name: (0,external_wp_i18n_namespaceObject._x)('Large', 'font size name'), 3242 size: 36, 3243 slug: 'large' 3244 }, { 3245 name: (0,external_wp_i18n_namespaceObject._x)('Huge', 'font size name'), 3246 size: 42, 3247 slug: 'huge' 3248 }], 3249 // Image default size slug. 3250 imageDefaultSize: 'large', 3251 imageSizes: [{ 3252 slug: 'thumbnail', 3253 name: (0,external_wp_i18n_namespaceObject.__)('Thumbnail') 3254 }, { 3255 slug: 'medium', 3256 name: (0,external_wp_i18n_namespaceObject.__)('Medium') 3257 }, { 3258 slug: 'large', 3259 name: (0,external_wp_i18n_namespaceObject.__)('Large') 3260 }, { 3261 slug: 'full', 3262 name: (0,external_wp_i18n_namespaceObject.__)('Full Size') 3263 }], 3264 // Allow plugin to disable Image Editor if need be. 3265 imageEditing: true, 3266 // This is current max width of the block inner area 3267 // It's used to constraint image resizing and this value could be overridden later by themes 3268 maxWidth: 580, 3269 // Allowed block types for the editor, defaulting to true (all supported). 3270 allowedBlockTypes: true, 3271 // Maximum upload size in bytes allowed for the site. 3272 maxUploadFileSize: 0, 3273 // List of allowed mime types and file extensions. 3274 allowedMimeTypes: null, 3275 // Allows to disable block locking interface. 3276 canLockBlocks: true, 3277 __experimentalCanUserUseUnfilteredHTML: false, 3278 __experimentalBlockDirectory: false, 3279 __mobileEnablePageTemplates: false, 3280 __experimentalBlockPatterns: [], 3281 __experimentalBlockPatternCategories: [], 3282 __experimentalSpotlightEntityBlocks: [], 3283 __unstableGalleryWithImageBlocks: false, 3284 generateAnchors: false, 3285 // gradients setting is not used anymore now defaults are passed from theme.json on the server and core has its own defaults. 3286 // The setting is only kept for backward compatibility purposes. 3287 gradients: [{ 3288 name: (0,external_wp_i18n_namespaceObject.__)('Vivid cyan blue to vivid purple'), 3289 gradient: 'linear-gradient(135deg,rgba(6,147,227,1) 0%,rgb(155,81,224) 100%)', 3290 slug: 'vivid-cyan-blue-to-vivid-purple' 3291 }, { 3292 name: (0,external_wp_i18n_namespaceObject.__)('Light green cyan to vivid green cyan'), 3293 gradient: 'linear-gradient(135deg,rgb(122,220,180) 0%,rgb(0,208,130) 100%)', 3294 slug: 'light-green-cyan-to-vivid-green-cyan' 3295 }, { 3296 name: (0,external_wp_i18n_namespaceObject.__)('Luminous vivid amber to luminous vivid orange'), 3297 gradient: 'linear-gradient(135deg,rgba(252,185,0,1) 0%,rgba(255,105,0,1) 100%)', 3298 slug: 'luminous-vivid-amber-to-luminous-vivid-orange' 3299 }, { 3300 name: (0,external_wp_i18n_namespaceObject.__)('Luminous vivid orange to vivid red'), 3301 gradient: 'linear-gradient(135deg,rgba(255,105,0,1) 0%,rgb(207,46,46) 100%)', 3302 slug: 'luminous-vivid-orange-to-vivid-red' 3303 }, { 3304 name: (0,external_wp_i18n_namespaceObject.__)('Very light gray to cyan bluish gray'), 3305 gradient: 'linear-gradient(135deg,rgb(238,238,238) 0%,rgb(169,184,195) 100%)', 3306 slug: 'very-light-gray-to-cyan-bluish-gray' 3307 }, { 3308 name: (0,external_wp_i18n_namespaceObject.__)('Cool to warm spectrum'), 3309 gradient: 'linear-gradient(135deg,rgb(74,234,220) 0%,rgb(151,120,209) 20%,rgb(207,42,186) 40%,rgb(238,44,130) 60%,rgb(251,105,98) 80%,rgb(254,248,76) 100%)', 3310 slug: 'cool-to-warm-spectrum' 3311 }, { 3312 name: (0,external_wp_i18n_namespaceObject.__)('Blush light purple'), 3313 gradient: 'linear-gradient(135deg,rgb(255,206,236) 0%,rgb(152,150,240) 100%)', 3314 slug: 'blush-light-purple' 3315 }, { 3316 name: (0,external_wp_i18n_namespaceObject.__)('Blush bordeaux'), 3317 gradient: 'linear-gradient(135deg,rgb(254,205,165) 0%,rgb(254,45,45) 50%,rgb(107,0,62) 100%)', 3318 slug: 'blush-bordeaux' 3319 }, { 3320 name: (0,external_wp_i18n_namespaceObject.__)('Luminous dusk'), 3321 gradient: 'linear-gradient(135deg,rgb(255,203,112) 0%,rgb(199,81,192) 50%,rgb(65,88,208) 100%)', 3322 slug: 'luminous-dusk' 3323 }, { 3324 name: (0,external_wp_i18n_namespaceObject.__)('Pale ocean'), 3325 gradient: 'linear-gradient(135deg,rgb(255,245,203) 0%,rgb(182,227,212) 50%,rgb(51,167,181) 100%)', 3326 slug: 'pale-ocean' 3327 }, { 3328 name: (0,external_wp_i18n_namespaceObject.__)('Electric grass'), 3329 gradient: 'linear-gradient(135deg,rgb(202,248,128) 0%,rgb(113,206,126) 100%)', 3330 slug: 'electric-grass' 3331 }, { 3332 name: (0,external_wp_i18n_namespaceObject.__)('Midnight'), 3333 gradient: 'linear-gradient(135deg,rgb(2,3,129) 0%,rgb(40,116,252) 100%)', 3334 slug: 'midnight' 3335 }], 3336 __unstableResolvedAssets: { 3337 styles: [], 3338 scripts: [] 3339 } 3340 }; 3341 3342 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/store/array.js 3343 /** 3344 * External dependencies 3345 */ 3346 3347 /** 3348 * Insert one or multiple elements into a given position of an array. 3349 * 3350 * @param {Array} array Source array. 3351 * @param {*} elements Elements to insert. 3352 * @param {number} index Insert Position. 3353 * 3354 * @return {Array} Result. 3355 */ 3356 3357 function insertAt(array, elements, index) { 3358 return [...array.slice(0, index), ...(0,external_lodash_namespaceObject.castArray)(elements), ...array.slice(index)]; 3359 } 3360 /** 3361 * Moves an element in an array. 3362 * 3363 * @param {Array} array Source array. 3364 * @param {number} from Source index. 3365 * @param {number} to Destination index. 3366 * @param {number} count Number of elements to move. 3367 * 3368 * @return {Array} Result. 3369 */ 3370 3371 function moveTo(array, from, to) { 3372 let count = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 1; 3373 const withoutMovedElements = [...array]; 3374 withoutMovedElements.splice(from, count); 3375 return insertAt(withoutMovedElements, array.slice(from, from + count), to); 3376 } 3377 3378 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/store/reducer.js 3379 /** 3380 * External dependencies 3381 */ 3382 3383 /** 3384 * WordPress dependencies 3385 */ 3386 3387 3388 3389 /** 3390 * Internal dependencies 3391 */ 3392 3393 3394 3395 /** 3396 * Given an array of blocks, returns an object where each key is a nesting 3397 * context, the value of which is an array of block client IDs existing within 3398 * that nesting context. 3399 * 3400 * @param {Array} blocks Blocks to map. 3401 * @param {?string} rootClientId Assumed root client ID. 3402 * 3403 * @return {Object} Block order map object. 3404 */ 3405 3406 function mapBlockOrder(blocks) { 3407 let rootClientId = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : ''; 3408 const result = { 3409 [rootClientId]: [] 3410 }; 3411 blocks.forEach(block => { 3412 const { 3413 clientId, 3414 innerBlocks 3415 } = block; 3416 result[rootClientId].push(clientId); 3417 Object.assign(result, mapBlockOrder(innerBlocks, clientId)); 3418 }); 3419 return result; 3420 } 3421 /** 3422 * Given an array of blocks, returns an object where each key contains 3423 * the clientId of the block and the value is the parent of the block. 3424 * 3425 * @param {Array} blocks Blocks to map. 3426 * @param {?string} rootClientId Assumed root client ID. 3427 * 3428 * @return {Object} Block order map object. 3429 */ 3430 3431 3432 function mapBlockParents(blocks) { 3433 let rootClientId = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : ''; 3434 return blocks.reduce((result, block) => Object.assign(result, { 3435 [block.clientId]: rootClientId 3436 }, mapBlockParents(block.innerBlocks, block.clientId)), {}); 3437 } 3438 /** 3439 * Helper method to iterate through all blocks, recursing into inner blocks, 3440 * applying a transformation function to each one. 3441 * Returns a flattened object with the transformed blocks. 3442 * 3443 * @param {Array} blocks Blocks to flatten. 3444 * @param {Function} transform Transforming function to be applied to each block. 3445 * 3446 * @return {Object} Flattened object. 3447 */ 3448 3449 3450 function flattenBlocks(blocks) { 3451 let transform = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : external_lodash_namespaceObject.identity; 3452 const result = {}; 3453 const stack = [...blocks]; 3454 3455 while (stack.length) { 3456 const { 3457 innerBlocks, 3458 ...block 3459 } = stack.shift(); 3460 stack.push(...innerBlocks); 3461 result[block.clientId] = transform(block); 3462 } 3463 3464 return result; 3465 } 3466 /** 3467 * Given an array of blocks, returns an object containing all blocks, without 3468 * attributes, recursing into inner blocks. Keys correspond to the block client 3469 * ID, the value of which is the attributes object. 3470 * 3471 * @param {Array} blocks Blocks to flatten. 3472 * 3473 * @return {Object} Flattened block attributes object. 3474 */ 3475 3476 3477 function getFlattenedBlocksWithoutAttributes(blocks) { 3478 return flattenBlocks(blocks, block => (0,external_lodash_namespaceObject.omit)(block, 'attributes')); 3479 } 3480 /** 3481 * Given an array of blocks, returns an object containing all block attributes, 3482 * recursing into inner blocks. Keys correspond to the block client ID, the 3483 * value of which is the attributes object. 3484 * 3485 * @param {Array} blocks Blocks to flatten. 3486 * 3487 * @return {Object} Flattened block attributes object. 3488 */ 3489 3490 3491 function getFlattenedBlockAttributes(blocks) { 3492 return flattenBlocks(blocks, block => block.attributes); 3493 } 3494 /** 3495 * Returns an object against which it is safe to perform mutating operations, 3496 * given the original object and its current working copy. 3497 * 3498 * @param {Object} original Original object. 3499 * @param {Object} working Working object. 3500 * 3501 * @return {Object} Mutation-safe object. 3502 */ 3503 3504 3505 function getMutateSafeObject(original, working) { 3506 if (original === working) { 3507 return { ...original 3508 }; 3509 } 3510 3511 return working; 3512 } 3513 /** 3514 * Returns true if the two object arguments have the same keys, or false 3515 * otherwise. 3516 * 3517 * @param {Object} a First object. 3518 * @param {Object} b Second object. 3519 * 3520 * @return {boolean} Whether the two objects have the same keys. 3521 */ 3522 3523 3524 function hasSameKeys(a, b) { 3525 return (0,external_lodash_namespaceObject.isEqual)((0,external_lodash_namespaceObject.keys)(a), (0,external_lodash_namespaceObject.keys)(b)); 3526 } 3527 /** 3528 * Returns true if, given the currently dispatching action and the previously 3529 * dispatched action, the two actions are updating the same block attribute, or 3530 * false otherwise. 3531 * 3532 * @param {Object} action Currently dispatching action. 3533 * @param {Object} lastAction Previously dispatched action. 3534 * 3535 * @return {boolean} Whether actions are updating the same block attribute. 3536 */ 3537 3538 function isUpdatingSameBlockAttribute(action, lastAction) { 3539 return action.type === 'UPDATE_BLOCK_ATTRIBUTES' && lastAction !== undefined && lastAction.type === 'UPDATE_BLOCK_ATTRIBUTES' && (0,external_lodash_namespaceObject.isEqual)(action.clientIds, lastAction.clientIds) && hasSameKeys(action.attributes, lastAction.attributes); 3540 } 3541 3542 function buildBlockTree(state, blocks) { 3543 const result = {}; 3544 const stack = [...blocks]; 3545 const flattenedBlocks = [...blocks]; 3546 3547 while (stack.length) { 3548 const block = stack.shift(); 3549 stack.push(...block.innerBlocks); 3550 flattenedBlocks.push(...block.innerBlocks); 3551 } // Create objects before mutating them, that way it's always defined. 3552 3553 3554 for (const block of flattenedBlocks) { 3555 result[block.clientId] = {}; 3556 } 3557 3558 for (const block of flattenedBlocks) { 3559 result[block.clientId] = Object.assign(result[block.clientId], { ...state.byClientId[block.clientId], 3560 attributes: state.attributes[block.clientId], 3561 innerBlocks: block.innerBlocks.map(subBlock => result[subBlock.clientId]) 3562 }); 3563 } 3564 3565 return result; 3566 } 3567 3568 function updateParentInnerBlocksInTree(state, tree, updatedClientIds) { 3569 let updateChildrenOfUpdatedClientIds = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false; 3570 const uncontrolledParents = new Set([]); 3571 const controlledParents = new Set(); 3572 3573 for (const clientId of updatedClientIds) { 3574 let current = updateChildrenOfUpdatedClientIds ? clientId : state.parents[clientId]; 3575 3576 do { 3577 if (state.controlledInnerBlocks[current]) { 3578 // Should stop on controlled blocks. 3579 // If we reach a controlled parent, break out of the loop. 3580 controlledParents.add(current); 3581 break; 3582 } else { 3583 // Else continue traversing up through parents. 3584 uncontrolledParents.add(current); 3585 current = state.parents[current]; 3586 } 3587 } while (current !== undefined); 3588 } // To make sure the order of assignments doesn't matter, 3589 // we first create empty objects and mutates the inner blocks later. 3590 3591 3592 for (const clientId of uncontrolledParents) { 3593 tree[clientId] = { ...tree[clientId] 3594 }; 3595 } 3596 3597 for (const clientId of uncontrolledParents) { 3598 tree[clientId].innerBlocks = (state.order[clientId] || []).map(subClientId => tree[subClientId]); 3599 } // Controlled parent blocks, need a dedicated key for their inner blocks 3600 // to be used when doing getBlocks( controlledBlockClientId ). 3601 3602 3603 for (const clientId of controlledParents) { 3604 tree['controlled||' + clientId] = { 3605 innerBlocks: (state.order[clientId] || []).map(subClientId => tree[subClientId]) 3606 }; 3607 } 3608 3609 return tree; 3610 } 3611 /** 3612 * Higher-order reducer intended to compute full block objects key for each block in the post. 3613 * This is a denormalization to optimize the performance of the getBlock selectors and avoid 3614 * recomputing the block objects and avoid heavy memoization. 3615 * 3616 * @param {Function} reducer Original reducer function. 3617 * 3618 * @return {Function} Enhanced reducer function. 3619 */ 3620 3621 3622 const withBlockTree = reducer => function () { 3623 let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; 3624 let action = arguments.length > 1 ? arguments[1] : undefined; 3625 const newState = reducer(state, action); 3626 3627 if (newState === state) { 3628 return state; 3629 } 3630 3631 newState.tree = state.tree ? state.tree : {}; 3632 3633 switch (action.type) { 3634 case 'RECEIVE_BLOCKS': 3635 case 'INSERT_BLOCKS': 3636 { 3637 const subTree = buildBlockTree(newState, action.blocks); 3638 newState.tree = updateParentInnerBlocksInTree(newState, { ...newState.tree, 3639 ...subTree 3640 }, action.rootClientId ? [action.rootClientId] : [''], true); 3641 break; 3642 } 3643 3644 case 'UPDATE_BLOCK': 3645 newState.tree = updateParentInnerBlocksInTree(newState, { ...newState.tree, 3646 [action.clientId]: { ...newState.tree[action.clientId], 3647 ...newState.byClientId[action.clientId], 3648 attributes: newState.attributes[action.clientId] 3649 } 3650 }, [action.clientId], false); 3651 break; 3652 3653 case 'UPDATE_BLOCK_ATTRIBUTES': 3654 { 3655 const newSubTree = action.clientIds.reduce((result, clientId) => { 3656 result[clientId] = { ...newState.tree[clientId], 3657 attributes: newState.attributes[clientId] 3658 }; 3659 return result; 3660 }, {}); 3661 newState.tree = updateParentInnerBlocksInTree(newState, { ...newState.tree, 3662 ...newSubTree 3663 }, action.clientIds, false); 3664 break; 3665 } 3666 3667 case 'REPLACE_BLOCKS_AUGMENTED_WITH_CHILDREN': 3668 { 3669 const subTree = buildBlockTree(newState, action.blocks); 3670 newState.tree = updateParentInnerBlocksInTree(newState, { ...(0,external_lodash_namespaceObject.omit)(newState.tree, action.replacedClientIds.concat( // Controlled inner blocks are only removed 3671 // if the block doesn't move to another position 3672 // otherwise their content will be lost. 3673 action.replacedClientIds.filter(clientId => !subTree[clientId]).map(clientId => 'controlled||' + clientId))), 3674 ...subTree 3675 }, action.blocks.map(b => b.clientId), false); // If there are no replaced blocks, it means we're removing blocks so we need to update their parent. 3676 3677 const parentsOfRemovedBlocks = []; 3678 3679 for (const clientId of action.clientIds) { 3680 if (state.parents[clientId] !== undefined && (state.parents[clientId] === '' || newState.byClientId[state.parents[clientId]])) { 3681 parentsOfRemovedBlocks.push(state.parents[clientId]); 3682 } 3683 } 3684 3685 newState.tree = updateParentInnerBlocksInTree(newState, newState.tree, parentsOfRemovedBlocks, true); 3686 break; 3687 } 3688 3689 case 'REMOVE_BLOCKS_AUGMENTED_WITH_CHILDREN': 3690 const parentsOfRemovedBlocks = []; 3691 3692 for (const clientId of action.clientIds) { 3693 if (state.parents[clientId] !== undefined && (state.parents[clientId] === '' || newState.byClientId[state.parents[clientId]])) { 3694 parentsOfRemovedBlocks.push(state.parents[clientId]); 3695 } 3696 } 3697 3698 newState.tree = updateParentInnerBlocksInTree(newState, (0,external_lodash_namespaceObject.omit)(newState.tree, action.removedClientIds.concat(action.removedClientIds.map(clientId => 'controlled||' + clientId))), parentsOfRemovedBlocks, true); 3699 break; 3700 3701 case 'MOVE_BLOCKS_TO_POSITION': 3702 { 3703 const updatedBlockUids = []; 3704 3705 if (action.fromRootClientId) { 3706 updatedBlockUids.push(action.fromRootClientId); 3707 } 3708 3709 if (action.toRootClientId) { 3710 updatedBlockUids.push(action.toRootClientId); 3711 } 3712 3713 if (!action.fromRootClientId || !action.fromRootClientId) { 3714 updatedBlockUids.push(''); 3715 } 3716 3717 newState.tree = updateParentInnerBlocksInTree(newState, newState.tree, updatedBlockUids, true); 3718 break; 3719 } 3720 3721 case 'MOVE_BLOCKS_UP': 3722 case 'MOVE_BLOCKS_DOWN': 3723 { 3724 const updatedBlockUids = [action.rootClientId ? action.rootClientId : '']; 3725 newState.tree = updateParentInnerBlocksInTree(newState, newState.tree, updatedBlockUids, true); 3726 break; 3727 } 3728 3729 case 'SAVE_REUSABLE_BLOCK_SUCCESS': 3730 { 3731 const updatedBlockUids = (0,external_lodash_namespaceObject.keys)((0,external_lodash_namespaceObject.omitBy)(newState.attributes, (attributes, clientId) => { 3732 return newState.byClientId[clientId].name !== 'core/block' || attributes.ref !== action.updatedId; 3733 })); 3734 newState.tree = updateParentInnerBlocksInTree(newState, { ...newState.tree, 3735 ...updatedBlockUids.reduce((result, clientId) => { 3736 result[clientId] = { ...newState.byClientId[clientId], 3737 attributes: newState.attributes[clientId], 3738 innerBlocks: newState.tree[clientId].innerBlocks 3739 }; 3740 return result; 3741 }, {}) 3742 }, updatedBlockUids, false); 3743 } 3744 } 3745 3746 return newState; 3747 }; 3748 /** 3749 * Higher-order reducer intended to augment the blocks reducer, assigning an 3750 * `isPersistentChange` property value corresponding to whether a change in 3751 * state can be considered as persistent. All changes are considered persistent 3752 * except when updating the same block attribute as in the previous action. 3753 * 3754 * @param {Function} reducer Original reducer function. 3755 * 3756 * @return {Function} Enhanced reducer function. 3757 */ 3758 3759 3760 function withPersistentBlockChange(reducer) { 3761 let lastAction; 3762 let markNextChangeAsNotPersistent = false; 3763 return (state, action) => { 3764 let nextState = reducer(state, action); 3765 const isExplicitPersistentChange = action.type === 'MARK_LAST_CHANGE_AS_PERSISTENT' || markNextChangeAsNotPersistent; // Defer to previous state value (or default) unless changing or 3766 // explicitly marking as persistent. 3767 3768 if (state === nextState && !isExplicitPersistentChange) { 3769 var _state$isPersistentCh; 3770 3771 markNextChangeAsNotPersistent = action.type === 'MARK_NEXT_CHANGE_AS_NOT_PERSISTENT'; 3772 const nextIsPersistentChange = (_state$isPersistentCh = state === null || state === void 0 ? void 0 : state.isPersistentChange) !== null && _state$isPersistentCh !== void 0 ? _state$isPersistentCh : true; 3773 3774 if (state.isPersistentChange === nextIsPersistentChange) { 3775 return state; 3776 } 3777 3778 return { ...nextState, 3779 isPersistentChange: nextIsPersistentChange 3780 }; 3781 } 3782 3783 nextState = { ...nextState, 3784 isPersistentChange: isExplicitPersistentChange ? !markNextChangeAsNotPersistent : !isUpdatingSameBlockAttribute(action, lastAction) 3785 }; // In comparing against the previous action, consider only those which 3786 // would have qualified as one which would have been ignored or not 3787 // have resulted in a changed state. 3788 3789 lastAction = action; 3790 markNextChangeAsNotPersistent = action.type === 'MARK_NEXT_CHANGE_AS_NOT_PERSISTENT'; 3791 return nextState; 3792 }; 3793 } 3794 /** 3795 * Higher-order reducer intended to augment the blocks reducer, assigning an 3796 * `isIgnoredChange` property value corresponding to whether a change in state 3797 * can be considered as ignored. A change is considered ignored when the result 3798 * of an action not incurred by direct user interaction. 3799 * 3800 * @param {Function} reducer Original reducer function. 3801 * 3802 * @return {Function} Enhanced reducer function. 3803 */ 3804 3805 3806 function withIgnoredBlockChange(reducer) { 3807 /** 3808 * Set of action types for which a blocks state change should be ignored. 3809 * 3810 * @type {Set} 3811 */ 3812 const IGNORED_ACTION_TYPES = new Set(['RECEIVE_BLOCKS']); 3813 return (state, action) => { 3814 const nextState = reducer(state, action); 3815 3816 if (nextState !== state) { 3817 nextState.isIgnoredChange = IGNORED_ACTION_TYPES.has(action.type); 3818 } 3819 3820 return nextState; 3821 }; 3822 } 3823 /** 3824 * Higher-order reducer targeting the combined blocks reducer, augmenting 3825 * block client IDs in remove action to include cascade of inner blocks. 3826 * 3827 * @param {Function} reducer Original reducer function. 3828 * 3829 * @return {Function} Enhanced reducer function. 3830 */ 3831 3832 3833 const withInnerBlocksRemoveCascade = reducer => (state, action) => { 3834 // Gets all children which need to be removed. 3835 const getAllChildren = clientIds => { 3836 let result = clientIds; 3837 3838 for (let i = 0; i < result.length; i++) { 3839 if (!state.order[result[i]] || action.keepControlledInnerBlocks && action.keepControlledInnerBlocks[result[i]]) { 3840 continue; 3841 } 3842 3843 if (result === clientIds) { 3844 result = [...result]; 3845 } 3846 3847 result.push(...state.order[result[i]]); 3848 } 3849 3850 return result; 3851 }; 3852 3853 if (state) { 3854 switch (action.type) { 3855 case 'REMOVE_BLOCKS': 3856 action = { ...action, 3857 type: 'REMOVE_BLOCKS_AUGMENTED_WITH_CHILDREN', 3858 removedClientIds: getAllChildren(action.clientIds) 3859 }; 3860 break; 3861 3862 case 'REPLACE_BLOCKS': 3863 action = { ...action, 3864 type: 'REPLACE_BLOCKS_AUGMENTED_WITH_CHILDREN', 3865 replacedClientIds: getAllChildren(action.clientIds) 3866 }; 3867 break; 3868 } 3869 } 3870 3871 return reducer(state, action); 3872 }; 3873 /** 3874 * Higher-order reducer which targets the combined blocks reducer and handles 3875 * the `RESET_BLOCKS` action. When dispatched, this action will replace all 3876 * blocks that exist in the post, leaving blocks that exist only in state (e.g. 3877 * reusable blocks and blocks controlled by inner blocks controllers) alone. 3878 * 3879 * @param {Function} reducer Original reducer function. 3880 * 3881 * @return {Function} Enhanced reducer function. 3882 */ 3883 3884 3885 const withBlockReset = reducer => (state, action) => { 3886 if (action.type === 'RESET_BLOCKS') { 3887 const newState = { ...state, 3888 byClientId: getFlattenedBlocksWithoutAttributes(action.blocks), 3889 attributes: getFlattenedBlockAttributes(action.blocks), 3890 order: mapBlockOrder(action.blocks), 3891 parents: mapBlockParents(action.blocks), 3892 controlledInnerBlocks: {} 3893 }; 3894 const subTree = buildBlockTree(newState, action.blocks); 3895 newState.tree = { ...subTree, 3896 // Root. 3897 '': { 3898 innerBlocks: action.blocks.map(subBlock => subTree[subBlock.clientId]) 3899 } 3900 }; 3901 return newState; 3902 } 3903 3904 return reducer(state, action); 3905 }; 3906 /** 3907 * Higher-order reducer which targets the combined blocks reducer and handles 3908 * the `REPLACE_INNER_BLOCKS` action. When dispatched, this action the state 3909 * should become equivalent to the execution of a `REMOVE_BLOCKS` action 3910 * containing all the child's of the root block followed by the execution of 3911 * `INSERT_BLOCKS` with the new blocks. 3912 * 3913 * @param {Function} reducer Original reducer function. 3914 * 3915 * @return {Function} Enhanced reducer function. 3916 */ 3917 3918 3919 const withReplaceInnerBlocks = reducer => (state, action) => { 3920 if (action.type !== 'REPLACE_INNER_BLOCKS') { 3921 return reducer(state, action); 3922 } // Finds every nested inner block controller. We must check the action blocks 3923 // and not just the block parent state because some inner block controllers 3924 // should be deleted if specified, whereas others should not be deleted. If 3925 // a controlled should not be deleted, then we need to avoid deleting its 3926 // inner blocks from the block state because its inner blocks will not be 3927 // attached to the block in the action. 3928 3929 3930 const nestedControllers = {}; 3931 3932 if (Object.keys(state.controlledInnerBlocks).length) { 3933 const stack = [...action.blocks]; 3934 3935 while (stack.length) { 3936 const { 3937 innerBlocks, 3938 ...block 3939 } = stack.shift(); 3940 stack.push(...innerBlocks); 3941 3942 if (!!state.controlledInnerBlocks[block.clientId]) { 3943 nestedControllers[block.clientId] = true; 3944 } 3945 } 3946 } // The `keepControlledInnerBlocks` prop will keep the inner blocks of the 3947 // marked block in the block state so that they can be reattached to the 3948 // marked block when we re-insert everything a few lines below. 3949 3950 3951 let stateAfterBlocksRemoval = state; 3952 3953 if (state.order[action.rootClientId]) { 3954 stateAfterBlocksRemoval = reducer(stateAfterBlocksRemoval, { 3955 type: 'REMOVE_BLOCKS', 3956 keepControlledInnerBlocks: nestedControllers, 3957 clientIds: state.order[action.rootClientId] 3958 }); 3959 } 3960 3961 let stateAfterInsert = stateAfterBlocksRemoval; 3962 3963 if (action.blocks.length) { 3964 stateAfterInsert = reducer(stateAfterInsert, { ...action, 3965 type: 'INSERT_BLOCKS', 3966 index: 0 3967 }); // We need to re-attach the block order of the controlled inner blocks. 3968 // Otherwise, an inner block controller's blocks will be deleted entirely 3969 // from its entity.. 3970 3971 stateAfterInsert.order = { ...stateAfterInsert.order, 3972 ...(0,external_lodash_namespaceObject.reduce)(nestedControllers, (result, value, key) => { 3973 if (state.order[key]) { 3974 result[key] = state.order[key]; 3975 } 3976 3977 return result; 3978 }, {}) 3979 }; 3980 } 3981 3982 return stateAfterInsert; 3983 }; 3984 /** 3985 * Higher-order reducer which targets the combined blocks reducer and handles 3986 * the `SAVE_REUSABLE_BLOCK_SUCCESS` action. This action can't be handled by 3987 * regular reducers and needs a higher-order reducer since it needs access to 3988 * both `byClientId` and `attributes` simultaneously. 3989 * 3990 * @param {Function} reducer Original reducer function. 3991 * 3992 * @return {Function} Enhanced reducer function. 3993 */ 3994 3995 3996 const withSaveReusableBlock = reducer => (state, action) => { 3997 if (state && action.type === 'SAVE_REUSABLE_BLOCK_SUCCESS') { 3998 const { 3999 id, 4000 updatedId 4001 } = action; // If a temporary reusable block is saved, we swap the temporary id with the final one. 4002 4003 if (id === updatedId) { 4004 return state; 4005 } 4006 4007 state = { ...state 4008 }; 4009 state.attributes = (0,external_lodash_namespaceObject.mapValues)(state.attributes, (attributes, clientId) => { 4010 const { 4011 name 4012 } = state.byClientId[clientId]; 4013 4014 if (name === 'core/block' && attributes.ref === id) { 4015 return { ...attributes, 4016 ref: updatedId 4017 }; 4018 } 4019 4020 return attributes; 4021 }); 4022 } 4023 4024 return reducer(state, action); 4025 }; 4026 /** 4027 * Higher-order reducer which removes blocks from state when switching parent block controlled state. 4028 * 4029 * @param {Function} reducer Original reducer function. 4030 * 4031 * @return {Function} Enhanced reducer function. 4032 */ 4033 4034 4035 const withResetControlledBlocks = reducer => (state, action) => { 4036 if (action.type === 'SET_HAS_CONTROLLED_INNER_BLOCKS') { 4037 // when switching a block from controlled to uncontrolled or inverse, 4038 // we need to remove its content first. 4039 const tempState = reducer(state, { 4040 type: 'REPLACE_INNER_BLOCKS', 4041 rootClientId: action.clientId, 4042 blocks: [] 4043 }); 4044 return reducer(tempState, action); 4045 } 4046 4047 return reducer(state, action); 4048 }; 4049 /** 4050 * Reducer returning the blocks state. 4051 * 4052 * @param {Object} state Current state. 4053 * @param {Object} action Dispatched action. 4054 * 4055 * @return {Object} Updated state. 4056 */ 4057 4058 4059 const blocks = (0,external_lodash_namespaceObject.flow)(external_wp_data_namespaceObject.combineReducers, withSaveReusableBlock, // Needs to be before withBlockCache. 4060 withBlockTree, // Needs to be before withInnerBlocksRemoveCascade. 4061 withInnerBlocksRemoveCascade, withReplaceInnerBlocks, // Needs to be after withInnerBlocksRemoveCascade. 4062 withBlockReset, withPersistentBlockChange, withIgnoredBlockChange, withResetControlledBlocks)({ 4063 byClientId() { 4064 let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; 4065 let action = arguments.length > 1 ? arguments[1] : undefined; 4066 4067 switch (action.type) { 4068 case 'RECEIVE_BLOCKS': 4069 case 'INSERT_BLOCKS': 4070 return { ...state, 4071 ...getFlattenedBlocksWithoutAttributes(action.blocks) 4072 }; 4073 4074 case 'UPDATE_BLOCK': 4075 // Ignore updates if block isn't known. 4076 if (!state[action.clientId]) { 4077 return state; 4078 } // Do nothing if only attributes change. 4079 4080 4081 const changes = (0,external_lodash_namespaceObject.omit)(action.updates, 'attributes'); 4082 4083 if ((0,external_lodash_namespaceObject.isEmpty)(changes)) { 4084 return state; 4085 } 4086 4087 return { ...state, 4088 [action.clientId]: { ...state[action.clientId], 4089 ...changes 4090 } 4091 }; 4092 4093 case 'REPLACE_BLOCKS_AUGMENTED_WITH_CHILDREN': 4094 if (!action.blocks) { 4095 return state; 4096 } 4097 4098 return { ...(0,external_lodash_namespaceObject.omit)(state, action.replacedClientIds), 4099 ...getFlattenedBlocksWithoutAttributes(action.blocks) 4100 }; 4101 4102 case 'REMOVE_BLOCKS_AUGMENTED_WITH_CHILDREN': 4103 return (0,external_lodash_namespaceObject.omit)(state, action.removedClientIds); 4104 } 4105 4106 return state; 4107 }, 4108 4109 attributes() { 4110 let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; 4111 let action = arguments.length > 1 ? arguments[1] : undefined; 4112 4113 switch (action.type) { 4114 case 'RECEIVE_BLOCKS': 4115 case 'INSERT_BLOCKS': 4116 return { ...state, 4117 ...getFlattenedBlockAttributes(action.blocks) 4118 }; 4119 4120 case 'UPDATE_BLOCK': 4121 // Ignore updates if block isn't known or there are no attribute changes. 4122 if (!state[action.clientId] || !action.updates.attributes) { 4123 return state; 4124 } 4125 4126 return { ...state, 4127 [action.clientId]: { ...state[action.clientId], 4128 ...action.updates.attributes 4129 } 4130 }; 4131 4132 case 'UPDATE_BLOCK_ATTRIBUTES': 4133 { 4134 // Avoid a state change if none of the block IDs are known. 4135 if (action.clientIds.every(id => !state[id])) { 4136 return state; 4137 } 4138 4139 const next = action.clientIds.reduce((accumulator, id) => ({ ...accumulator, 4140 [id]: (0,external_lodash_namespaceObject.reduce)(action.uniqueByBlock ? action.attributes[id] : action.attributes, (result, value, key) => { 4141 // Consider as updates only changed values. 4142 if (value !== result[key]) { 4143 result = getMutateSafeObject(state[id], result); 4144 result[key] = value; 4145 } 4146 4147 return result; 4148 }, state[id]) 4149 }), {}); 4150 4151 if (action.clientIds.every(id => next[id] === state[id])) { 4152 return state; 4153 } 4154 4155 return { ...state, 4156 ...next 4157 }; 4158 } 4159 4160 case 'REPLACE_BLOCKS_AUGMENTED_WITH_CHILDREN': 4161 if (!action.blocks) { 4162 return state; 4163 } 4164 4165 return { ...(0,external_lodash_namespaceObject.omit)(state, action.replacedClientIds), 4166 ...getFlattenedBlockAttributes(action.blocks) 4167 }; 4168 4169 case 'REMOVE_BLOCKS_AUGMENTED_WITH_CHILDREN': 4170 return (0,external_lodash_namespaceObject.omit)(state, action.removedClientIds); 4171 } 4172 4173 return state; 4174 }, 4175 4176 order() { 4177 let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; 4178 let action = arguments.length > 1 ? arguments[1] : undefined; 4179 4180 switch (action.type) { 4181 case 'RECEIVE_BLOCKS': 4182 { 4183 const blockOrder = mapBlockOrder(action.blocks); 4184 return { ...state, 4185 ...(0,external_lodash_namespaceObject.omit)(blockOrder, ''), 4186 '': ((state === null || state === void 0 ? void 0 : state['']) || []).concat(blockOrder['']) 4187 }; 4188 } 4189 4190 case 'INSERT_BLOCKS': 4191 { 4192 const { 4193 rootClientId = '' 4194 } = action; 4195 const subState = state[rootClientId] || []; 4196 const mappedBlocks = mapBlockOrder(action.blocks, rootClientId); 4197 const { 4198 index = subState.length 4199 } = action; 4200 return { ...state, 4201 ...mappedBlocks, 4202 [rootClientId]: insertAt(subState, mappedBlocks[rootClientId], index) 4203 }; 4204 } 4205 4206 case 'MOVE_BLOCKS_TO_POSITION': 4207 { 4208 const { 4209 fromRootClientId = '', 4210 toRootClientId = '', 4211 clientIds 4212 } = action; 4213 const { 4214 index = state[toRootClientId].length 4215 } = action; // Moving inside the same parent block. 4216 4217 if (fromRootClientId === toRootClientId) { 4218 const subState = state[toRootClientId]; 4219 const fromIndex = subState.indexOf(clientIds[0]); 4220 return { ...state, 4221 [toRootClientId]: moveTo(state[toRootClientId], fromIndex, index, clientIds.length) 4222 }; 4223 } // Moving from a parent block to another. 4224 4225 4226 return { ...state, 4227 [fromRootClientId]: (0,external_lodash_namespaceObject.without)(state[fromRootClientId], ...clientIds), 4228 [toRootClientId]: insertAt(state[toRootClientId], clientIds, index) 4229 }; 4230 } 4231 4232 case 'MOVE_BLOCKS_UP': 4233 { 4234 const { 4235 clientIds, 4236 rootClientId = '' 4237 } = action; 4238 const firstClientId = (0,external_lodash_namespaceObject.first)(clientIds); 4239 const subState = state[rootClientId]; 4240 4241 if (!subState.length || firstClientId === (0,external_lodash_namespaceObject.first)(subState)) { 4242 return state; 4243 } 4244 4245 const firstIndex = subState.indexOf(firstClientId); 4246 return { ...state, 4247 [rootClientId]: moveTo(subState, firstIndex, firstIndex - 1, clientIds.length) 4248 }; 4249 } 4250 4251 case 'MOVE_BLOCKS_DOWN': 4252 { 4253 const { 4254 clientIds, 4255 rootClientId = '' 4256 } = action; 4257 const firstClientId = (0,external_lodash_namespaceObject.first)(clientIds); 4258 const lastClientId = (0,external_lodash_namespaceObject.last)(clientIds); 4259 const subState = state[rootClientId]; 4260 4261 if (!subState.length || lastClientId === (0,external_lodash_namespaceObject.last)(subState)) { 4262 return state; 4263 } 4264 4265 const firstIndex = subState.indexOf(firstClientId); 4266 return { ...state, 4267 [rootClientId]: moveTo(subState, firstIndex, firstIndex + 1, clientIds.length) 4268 }; 4269 } 4270 4271 case 'REPLACE_BLOCKS_AUGMENTED_WITH_CHILDREN': 4272 { 4273 const { 4274 clientIds 4275 } = action; 4276 4277 if (!action.blocks) { 4278 return state; 4279 } 4280 4281 const mappedBlocks = mapBlockOrder(action.blocks); 4282 return (0,external_lodash_namespaceObject.flow)([nextState => (0,external_lodash_namespaceObject.omit)(nextState, action.replacedClientIds), nextState => ({ ...nextState, 4283 ...(0,external_lodash_namespaceObject.omit)(mappedBlocks, '') 4284 }), nextState => (0,external_lodash_namespaceObject.mapValues)(nextState, subState => (0,external_lodash_namespaceObject.reduce)(subState, (result, clientId) => { 4285 if (clientId === clientIds[0]) { 4286 return [...result, ...mappedBlocks['']]; 4287 } 4288 4289 if (clientIds.indexOf(clientId) === -1) { 4290 result.push(clientId); 4291 } 4292 4293 return result; 4294 }, []))])(state); 4295 } 4296 4297 case 'REMOVE_BLOCKS_AUGMENTED_WITH_CHILDREN': 4298 return (0,external_lodash_namespaceObject.flow)([// Remove inner block ordering for removed blocks. 4299 nextState => (0,external_lodash_namespaceObject.omit)(nextState, action.removedClientIds), // Remove deleted blocks from other blocks' orderings. 4300 nextState => (0,external_lodash_namespaceObject.mapValues)(nextState, subState => (0,external_lodash_namespaceObject.without)(subState, ...action.removedClientIds))])(state); 4301 } 4302 4303 return state; 4304 }, 4305 4306 // While technically redundant data as the inverse of `order`, it serves as 4307 // an optimization for the selectors which derive the ancestry of a block. 4308 parents() { 4309 let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; 4310 let action = arguments.length > 1 ? arguments[1] : undefined; 4311 4312 switch (action.type) { 4313 case 'RECEIVE_BLOCKS': 4314 return { ...state, 4315 ...mapBlockParents(action.blocks) 4316 }; 4317 4318 case 'INSERT_BLOCKS': 4319 return { ...state, 4320 ...mapBlockParents(action.blocks, action.rootClientId || '') 4321 }; 4322 4323 case 'MOVE_BLOCKS_TO_POSITION': 4324 { 4325 return { ...state, 4326 ...action.clientIds.reduce((accumulator, id) => { 4327 accumulator[id] = action.toRootClientId || ''; 4328 return accumulator; 4329 }, {}) 4330 }; 4331 } 4332 4333 case 'REPLACE_BLOCKS_AUGMENTED_WITH_CHILDREN': 4334 return { ...(0,external_lodash_namespaceObject.omit)(state, action.replacedClientIds), 4335 ...mapBlockParents(action.blocks, state[action.clientIds[0]]) 4336 }; 4337 4338 case 'REMOVE_BLOCKS_AUGMENTED_WITH_CHILDREN': 4339 return (0,external_lodash_namespaceObject.omit)(state, action.removedClientIds); 4340 } 4341 4342 return state; 4343 }, 4344 4345 controlledInnerBlocks() { 4346 let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; 4347 let { 4348 type, 4349 clientId, 4350 hasControlledInnerBlocks 4351 } = arguments.length > 1 ? arguments[1] : undefined; 4352 4353 if (type === 'SET_HAS_CONTROLLED_INNER_BLOCKS') { 4354 return { ...state, 4355 [clientId]: hasControlledInnerBlocks 4356 }; 4357 } 4358 4359 return state; 4360 } 4361 4362 }); 4363 /** 4364 * Reducer returning typing state. 4365 * 4366 * @param {boolean} state Current state. 4367 * @param {Object} action Dispatched action. 4368 * 4369 * @return {boolean} Updated state. 4370 */ 4371 4372 function isTyping() { 4373 let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false; 4374 let action = arguments.length > 1 ? arguments[1] : undefined; 4375 4376 switch (action.type) { 4377 case 'START_TYPING': 4378 return true; 4379 4380 case 'STOP_TYPING': 4381 return false; 4382 } 4383 4384 return state; 4385 } 4386 /** 4387 * Reducer returning dragged block client id. 4388 * 4389 * @param {string[]} state Current state. 4390 * @param {Object} action Dispatched action. 4391 * 4392 * @return {string[]} Updated state. 4393 */ 4394 4395 function draggedBlocks() { 4396 let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : []; 4397 let action = arguments.length > 1 ? arguments[1] : undefined; 4398 4399 switch (action.type) { 4400 case 'START_DRAGGING_BLOCKS': 4401 return action.clientIds; 4402 4403 case 'STOP_DRAGGING_BLOCKS': 4404 return []; 4405 } 4406 4407 return state; 4408 } 4409 /** 4410 * Reducer returning whether the caret is within formatted text. 4411 * 4412 * @param {boolean} state Current state. 4413 * @param {Object} action Dispatched action. 4414 * 4415 * @return {boolean} Updated state. 4416 */ 4417 4418 function isCaretWithinFormattedText() { 4419 let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false; 4420 let action = arguments.length > 1 ? arguments[1] : undefined; 4421 4422 switch (action.type) { 4423 case 'ENTER_FORMATTED_TEXT': 4424 return true; 4425 4426 case 'EXIT_FORMATTED_TEXT': 4427 return false; 4428 } 4429 4430 return state; 4431 } 4432 /** 4433 * Internal helper reducer for selectionStart and selectionEnd. Can hold a block 4434 * selection, represented by an object with property clientId. 4435 * 4436 * @param {Object} state Current state. 4437 * @param {Object} action Dispatched action. 4438 * 4439 * @return {Object} Updated state. 4440 */ 4441 4442 function selectionHelper() { 4443 let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; 4444 let action = arguments.length > 1 ? arguments[1] : undefined; 4445 4446 switch (action.type) { 4447 case 'CLEAR_SELECTED_BLOCK': 4448 { 4449 if (state.clientId) { 4450 return {}; 4451 } 4452 4453 return state; 4454 } 4455 4456 case 'SELECT_BLOCK': 4457 if (action.clientId === state.clientId) { 4458 return state; 4459 } 4460 4461 return { 4462 clientId: action.clientId 4463 }; 4464 4465 case 'REPLACE_INNER_BLOCKS': 4466 case 'INSERT_BLOCKS': 4467 { 4468 if (!action.updateSelection || !action.blocks.length) { 4469 return state; 4470 } 4471 4472 return { 4473 clientId: action.blocks[0].clientId 4474 }; 4475 } 4476 4477 case 'REMOVE_BLOCKS': 4478 if (!action.clientIds || !action.clientIds.length || action.clientIds.indexOf(state.clientId) === -1) { 4479 return state; 4480 } 4481 4482 return {}; 4483 4484 case 'REPLACE_BLOCKS': 4485 { 4486 if (action.clientIds.indexOf(state.clientId) === -1) { 4487 return state; 4488 } 4489 4490 const blockToSelect = action.blocks[action.indexToSelect] || action.blocks[action.blocks.length - 1]; 4491 4492 if (!blockToSelect) { 4493 return {}; 4494 } 4495 4496 if (blockToSelect.clientId === state.clientId) { 4497 return state; 4498 } 4499 4500 return { 4501 clientId: blockToSelect.clientId 4502 }; 4503 } 4504 } 4505 4506 return state; 4507 } 4508 /** 4509 * Reducer returning the selection state. 4510 * 4511 * @param {boolean} state Current state. 4512 * @param {Object} action Dispatched action. 4513 * 4514 * @return {boolean} Updated state. 4515 */ 4516 4517 4518 function selection() { 4519 var _state$selectionStart, _state$selectionEnd, _state$selectionStart2, _state$selectionEnd2; 4520 4521 let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; 4522 let action = arguments.length > 1 ? arguments[1] : undefined; 4523 4524 switch (action.type) { 4525 case 'SELECTION_CHANGE': 4526 if (action.clientId) { 4527 return { 4528 selectionStart: { 4529 clientId: action.clientId, 4530 attributeKey: action.attributeKey, 4531 offset: action.startOffset 4532 }, 4533 selectionEnd: { 4534 clientId: action.clientId, 4535 attributeKey: action.attributeKey, 4536 offset: action.endOffset 4537 } 4538 }; 4539 } 4540 4541 return { 4542 selectionStart: action.start || state.selectionStart, 4543 selectionEnd: action.end || state.selectionEnd 4544 }; 4545 4546 case 'RESET_SELECTION': 4547 const { 4548 selectionStart, 4549 selectionEnd 4550 } = action; 4551 return { 4552 selectionStart, 4553 selectionEnd 4554 }; 4555 4556 case 'MULTI_SELECT': 4557 const { 4558 start, 4559 end 4560 } = action; 4561 4562 if (start === ((_state$selectionStart = state.selectionStart) === null || _state$selectionStart === void 0 ? void 0 : _state$selectionStart.clientId) && end === ((_state$selectionEnd = state.selectionEnd) === null || _state$selectionEnd === void 0 ? void 0 : _state$selectionEnd.clientId)) { 4563 return state; 4564 } 4565 4566 return { 4567 selectionStart: { 4568 clientId: start 4569 }, 4570 selectionEnd: { 4571 clientId: end 4572 } 4573 }; 4574 4575 case 'RESET_BLOCKS': 4576 const startClientId = state === null || state === void 0 ? void 0 : (_state$selectionStart2 = state.selectionStart) === null || _state$selectionStart2 === void 0 ? void 0 : _state$selectionStart2.clientId; 4577 const endClientId = state === null || state === void 0 ? void 0 : (_state$selectionEnd2 = state.selectionEnd) === null || _state$selectionEnd2 === void 0 ? void 0 : _state$selectionEnd2.clientId; // Do nothing if there's no selected block. 4578 4579 if (!startClientId && !endClientId) { 4580 return state; 4581 } // If the start of the selection won't exist after reset, remove selection. 4582 4583 4584 if (!action.blocks.some(block => block.clientId === startClientId)) { 4585 return { 4586 selectionStart: {}, 4587 selectionEnd: {} 4588 }; 4589 } // If the end of the selection won't exist after reset, collapse selection. 4590 4591 4592 if (!action.blocks.some(block => block.clientId === endClientId)) { 4593 return { ...state, 4594 selectionEnd: state.selectionStart 4595 }; 4596 } 4597 4598 } 4599 4600 return { 4601 selectionStart: selectionHelper(state.selectionStart, action), 4602 selectionEnd: selectionHelper(state.selectionEnd, action) 4603 }; 4604 } 4605 /** 4606 * Reducer returning whether the user is multi-selecting. 4607 * 4608 * @param {boolean} state Current state. 4609 * @param {Object} action Dispatched action. 4610 * 4611 * @return {boolean} Updated state. 4612 */ 4613 4614 function isMultiSelecting() { 4615 let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false; 4616 let action = arguments.length > 1 ? arguments[1] : undefined; 4617 4618 switch (action.type) { 4619 case 'START_MULTI_SELECT': 4620 return true; 4621 4622 case 'STOP_MULTI_SELECT': 4623 return false; 4624 } 4625 4626 return state; 4627 } 4628 /** 4629 * Reducer returning whether selection is enabled. 4630 * 4631 * @param {boolean} state Current state. 4632 * @param {Object} action Dispatched action. 4633 * 4634 * @return {boolean} Updated state. 4635 */ 4636 4637 function isSelectionEnabled() { 4638 let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true; 4639 let action = arguments.length > 1 ? arguments[1] : undefined; 4640 4641 switch (action.type) { 4642 case 'TOGGLE_SELECTION': 4643 return action.isSelectionEnabled; 4644 } 4645 4646 return state; 4647 } 4648 /** 4649 * Reducer returning the initial block selection. 4650 * 4651 * Currently this in only used to restore the selection after block deletion and 4652 * pasting new content.This reducer should eventually be removed in favour of setting 4653 * selection directly. 4654 * 4655 * @param {boolean} state Current state. 4656 * @param {Object} action Dispatched action. 4657 * 4658 * @return {number|null} Initial position: 0, -1 or null. 4659 */ 4660 4661 function initialPosition() { 4662 let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null; 4663 let action = arguments.length > 1 ? arguments[1] : undefined; 4664 4665 if (action.type === 'REPLACE_BLOCKS' && action.initialPosition !== undefined) { 4666 return action.initialPosition; 4667 } else if (['MULTI_SELECT', 'SELECT_BLOCK', 'RESET_SELECTION', 'INSERT_BLOCKS', 'REPLACE_INNER_BLOCKS'].includes(action.type)) { 4668 return action.initialPosition; 4669 } 4670 4671 return state; 4672 } 4673 function blocksMode() { 4674 let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; 4675 let action = arguments.length > 1 ? arguments[1] : undefined; 4676 4677 if (action.type === 'TOGGLE_BLOCK_MODE') { 4678 const { 4679 clientId 4680 } = action; 4681 return { ...state, 4682 [clientId]: state[clientId] && state[clientId] === 'html' ? 'visual' : 'html' 4683 }; 4684 } 4685 4686 return state; 4687 } 4688 /** 4689 * Reducer returning the block insertion point visibility, either null if there 4690 * is not an explicit insertion point assigned, or an object of its `index` and 4691 * `rootClientId`. 4692 * 4693 * @param {Object} state Current state. 4694 * @param {Object} action Dispatched action. 4695 * 4696 * @return {Object} Updated state. 4697 */ 4698 4699 function insertionPoint() { 4700 let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null; 4701 let action = arguments.length > 1 ? arguments[1] : undefined; 4702 4703 switch (action.type) { 4704 case 'SHOW_INSERTION_POINT': 4705 const { 4706 rootClientId, 4707 index, 4708 __unstableWithInserter 4709 } = action; 4710 return { 4711 rootClientId, 4712 index, 4713 __unstableWithInserter 4714 }; 4715 4716 case 'HIDE_INSERTION_POINT': 4717 return null; 4718 } 4719 4720 return state; 4721 } 4722 /** 4723 * Reducer returning whether the post blocks match the defined template or not. 4724 * 4725 * @param {Object} state Current state. 4726 * @param {Object} action Dispatched action. 4727 * 4728 * @return {boolean} Updated state. 4729 */ 4730 4731 function template() { 4732 let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : { 4733 isValid: true 4734 }; 4735 let action = arguments.length > 1 ? arguments[1] : undefined; 4736 4737 switch (action.type) { 4738 case 'SET_TEMPLATE_VALIDITY': 4739 return { ...state, 4740 isValid: action.isValid 4741 }; 4742 } 4743 4744 return state; 4745 } 4746 /** 4747 * Reducer returning the editor setting. 4748 * 4749 * @param {Object} state Current state. 4750 * @param {Object} action Dispatched action. 4751 * 4752 * @return {Object} Updated state. 4753 */ 4754 4755 function settings() { 4756 let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : SETTINGS_DEFAULTS; 4757 let action = arguments.length > 1 ? arguments[1] : undefined; 4758 4759 switch (action.type) { 4760 case 'UPDATE_SETTINGS': 4761 return { ...state, 4762 ...action.settings 4763 }; 4764 } 4765 4766 return state; 4767 } 4768 /** 4769 * Reducer returning the user preferences. 4770 * 4771 * @param {Object} state Current state. 4772 * @param {Object} action Dispatched action. 4773 * 4774 * @return {string} Updated state. 4775 */ 4776 4777 function preferences() { 4778 let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : PREFERENCES_DEFAULTS; 4779 let action = arguments.length > 1 ? arguments[1] : undefined; 4780 4781 switch (action.type) { 4782 case 'INSERT_BLOCKS': 4783 case 'REPLACE_BLOCKS': 4784 return action.blocks.reduce((prevState, block) => { 4785 const { 4786 attributes, 4787 name: blockName 4788 } = block; 4789 const match = (0,external_wp_data_namespaceObject.select)(external_wp_blocks_namespaceObject.store).getActiveBlockVariation(blockName, attributes); // If a block variation match is found change the name to be the same with the 4790 // one that is used for block variations in the Inserter (`getItemFromVariation`). 4791 4792 let id = match !== null && match !== void 0 && match.name ? `$blockName}/$match.name}` : blockName; 4793 const insert = { 4794 name: id 4795 }; 4796 4797 if (blockName === 'core/block') { 4798 insert.ref = attributes.ref; 4799 id += '/' + attributes.ref; 4800 } 4801 4802 return { ...prevState, 4803 insertUsage: { ...prevState.insertUsage, 4804 [id]: { 4805 time: action.time, 4806 count: prevState.insertUsage[id] ? prevState.insertUsage[id].count + 1 : 1, 4807 insert 4808 } 4809 } 4810 }; 4811 }, state); 4812 } 4813 4814 return state; 4815 } 4816 /** 4817 * Reducer returning an object where each key is a block client ID, its value 4818 * representing the settings for its nested blocks. 4819 * 4820 * @param {Object} state Current state. 4821 * @param {Object} action Dispatched action. 4822 * 4823 * @return {Object} Updated state. 4824 */ 4825 4826 const blockListSettings = function () { 4827 let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; 4828 let action = arguments.length > 1 ? arguments[1] : undefined; 4829 4830 switch (action.type) { 4831 // Even if the replaced blocks have the same client ID, our logic 4832 // should correct the state. 4833 case 'REPLACE_BLOCKS': 4834 case 'REMOVE_BLOCKS': 4835 { 4836 return (0,external_lodash_namespaceObject.omit)(state, action.clientIds); 4837 } 4838 4839 case 'UPDATE_BLOCK_LIST_SETTINGS': 4840 { 4841 const { 4842 clientId 4843 } = action; 4844 4845 if (!action.settings) { 4846 if (state.hasOwnProperty(clientId)) { 4847 return (0,external_lodash_namespaceObject.omit)(state, clientId); 4848 } 4849 4850 return state; 4851 } 4852 4853 if ((0,external_lodash_namespaceObject.isEqual)(state[clientId], action.settings)) { 4854 return state; 4855 } 4856 4857 return { ...state, 4858 [clientId]: action.settings 4859 }; 4860 } 4861 } 4862 4863 return state; 4864 }; 4865 /** 4866 * Reducer returning whether the navigation mode is enabled or not. 4867 * 4868 * @param {string} state Current state. 4869 * @param {Object} action Dispatched action. 4870 * 4871 * @return {string} Updated state. 4872 */ 4873 4874 function isNavigationMode() { 4875 let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false; 4876 let action = arguments.length > 1 ? arguments[1] : undefined; 4877 4878 // Let inserting block always trigger Edit mode. 4879 if (action.type === 'INSERT_BLOCKS') { 4880 return false; 4881 } 4882 4883 if (action.type === 'SET_NAVIGATION_MODE') { 4884 return action.isNavigationMode; 4885 } 4886 4887 return state; 4888 } 4889 /** 4890 * Reducer returning whether the block moving mode is enabled or not. 4891 * 4892 * @param {string|null} state Current state. 4893 * @param {Object} action Dispatched action. 4894 * 4895 * @return {string|null} Updated state. 4896 */ 4897 4898 function hasBlockMovingClientId() { 4899 let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null; 4900 let action = arguments.length > 1 ? arguments[1] : undefined; 4901 4902 // Let inserting block always trigger Edit mode. 4903 if (action.type === 'SET_BLOCK_MOVING_MODE') { 4904 return action.hasBlockMovingClientId; 4905 } 4906 4907 if (action.type === 'SET_NAVIGATION_MODE') { 4908 return null; 4909 } 4910 4911 return state; 4912 } 4913 /** 4914 * Reducer return an updated state representing the most recent block attribute 4915 * update. The state is structured as an object where the keys represent the 4916 * client IDs of blocks, the values a subset of attributes from the most recent 4917 * block update. The state is always reset to null if the last action is 4918 * anything other than an attributes update. 4919 * 4920 * @param {Object<string,Object>} state Current state. 4921 * @param {Object} action Action object. 4922 * 4923 * @return {[string,Object]} Updated state. 4924 */ 4925 4926 function lastBlockAttributesChange(state, action) { 4927 switch (action.type) { 4928 case 'UPDATE_BLOCK': 4929 if (!action.updates.attributes) { 4930 break; 4931 } 4932 4933 return { 4934 [action.clientId]: action.updates.attributes 4935 }; 4936 4937 case 'UPDATE_BLOCK_ATTRIBUTES': 4938 return action.clientIds.reduce((accumulator, id) => ({ ...accumulator, 4939 [id]: action.uniqueByBlock ? action.attributes[id] : action.attributes 4940 }), {}); 4941 } 4942 4943 return null; 4944 } 4945 /** 4946 * Reducer returning automatic change state. 4947 * 4948 * @param {boolean} state Current state. 4949 * @param {Object} action Dispatched action. 4950 * 4951 * @return {string} Updated state. 4952 */ 4953 4954 function automaticChangeStatus(state, action) { 4955 switch (action.type) { 4956 case 'MARK_AUTOMATIC_CHANGE': 4957 return 'pending'; 4958 4959 case 'MARK_AUTOMATIC_CHANGE_FINAL': 4960 if (state === 'pending') { 4961 return 'final'; 4962 } 4963 4964 return; 4965 4966 case 'SELECTION_CHANGE': 4967 // As long as the state is not final, ignore any selection changes. 4968 if (state !== 'final') { 4969 return state; 4970 } 4971 4972 return; 4973 // Undoing an automatic change should still be possible after mouse 4974 // move. 4975 4976 case 'START_TYPING': 4977 case 'STOP_TYPING': 4978 return state; 4979 } // Reset the state by default (for any action not handled). 4980 4981 } 4982 /** 4983 * Reducer returning current highlighted block. 4984 * 4985 * @param {boolean} state Current highlighted block. 4986 * @param {Object} action Dispatched action. 4987 * 4988 * @return {string} Updated state. 4989 */ 4990 4991 function highlightedBlock(state, action) { 4992 switch (action.type) { 4993 case 'TOGGLE_BLOCK_HIGHLIGHT': 4994 const { 4995 clientId, 4996 isHighlighted 4997 } = action; 4998 4999 if (isHighlighted) { 5000 return clientId; 5001 } else if (state === clientId) { 5002 return null; 5003 } 5004 5005 return state; 5006 5007 case 'SELECT_BLOCK': 5008 if (action.clientId !== state) { 5009 return null; 5010 } 5011 5012 } 5013 5014 return state; 5015 } 5016 /** 5017 * Reducer returning the block insertion event list state. 5018 * 5019 * @param {Object} state Current state. 5020 * @param {Object} action Dispatched action. 5021 * 5022 * @return {Object} Updated state. 5023 */ 5024 5025 function lastBlockInserted() { 5026 var _action$meta; 5027 5028 let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; 5029 let action = arguments.length > 1 ? arguments[1] : undefined; 5030 5031 switch (action.type) { 5032 case 'INSERT_BLOCKS': 5033 if (!action.blocks.length) { 5034 return state; 5035 } 5036 5037 const clientId = action.blocks[0].clientId; 5038 const source = (_action$meta = action.meta) === null || _action$meta === void 0 ? void 0 : _action$meta.source; 5039 return { 5040 clientId, 5041 source 5042 }; 5043 5044 case 'RESET_BLOCKS': 5045 return {}; 5046 } 5047 5048 return state; 5049 } 5050 /* harmony default export */ var reducer = ((0,external_wp_data_namespaceObject.combineReducers)({ 5051 blocks, 5052 isTyping, 5053 draggedBlocks, 5054 isCaretWithinFormattedText, 5055 selection, 5056 isMultiSelecting, 5057 isSelectionEnabled, 5058 initialPosition, 5059 blocksMode, 5060 blockListSettings, 5061 insertionPoint, 5062 template, 5063 settings, 5064 preferences, 5065 lastBlockAttributesChange, 5066 isNavigationMode, 5067 hasBlockMovingClientId, 5068 automaticChangeStatus, 5069 highlightedBlock, 5070 lastBlockInserted 5071 })); 5072 5073 ;// CONCATENATED MODULE: ./node_modules/rememo/es/rememo.js 5074 5075 5076 var LEAF_KEY, hasWeakMap; 5077 5078 /** 5079 * Arbitrary value used as key for referencing cache object in WeakMap tree. 5080 * 5081 * @type {Object} 5082 */ 5083 LEAF_KEY = {}; 5084 5085 /** 5086 * Whether environment supports WeakMap. 5087 * 5088 * @type {boolean} 5089 */ 5090 hasWeakMap = typeof WeakMap !== 'undefined'; 5091 5092 /** 5093 * Returns the first argument as the sole entry in an array. 5094 * 5095 * @param {*} value Value to return. 5096 * 5097 * @return {Array} Value returned as entry in array. 5098 */ 5099 function arrayOf( value ) { 5100 return [ value ]; 5101 } 5102 5103 /** 5104 * Returns true if the value passed is object-like, or false otherwise. A value 5105 * is object-like if it can support property assignment, e.g. object or array. 5106 * 5107 * @param {*} value Value to test. 5108 * 5109 * @return {boolean} Whether value is object-like. 5110 */ 5111 function isObjectLike( value ) { 5112 return !! value && 'object' === typeof value; 5113 } 5114 5115 /** 5116 * Creates and returns a new cache object. 5117 * 5118 * @return {Object} Cache object. 5119 */ 5120 function createCache() { 5121 var cache = { 5122 clear: function() { 5123 cache.head = null; 5124 }, 5125 }; 5126 5127 return cache; 5128 } 5129 5130 /** 5131 * Returns true if entries within the two arrays are strictly equal by 5132 * reference from a starting index. 5133 * 5134 * @param {Array} a First array. 5135 * @param {Array} b Second array. 5136 * @param {number} fromIndex Index from which to start comparison. 5137 * 5138 * @return {boolean} Whether arrays are shallowly equal. 5139 */ 5140 function isShallowEqual( a, b, fromIndex ) { 5141 var i; 5142 5143 if ( a.length !== b.length ) { 5144 return false; 5145 } 5146 5147 for ( i = fromIndex; i < a.length; i++ ) { 5148 if ( a[ i ] !== b[ i ] ) { 5149 return false; 5150 } 5151 } 5152 5153 return true; 5154 } 5155 5156 /** 5157 * Returns a memoized selector function. The getDependants function argument is 5158 * called before the memoized selector and is expected to return an immutable 5159 * reference or array of references on which the selector depends for computing 5160 * its own return value. The memoize cache is preserved only as long as those 5161 * dependant references remain the same. If getDependants returns a different 5162 * reference(s), the cache is cleared and the selector value regenerated. 5163 * 5164 * @param {Function} selector Selector function. 5165 * @param {Function} getDependants Dependant getter returning an immutable 5166 * reference or array of reference used in 5167 * cache bust consideration. 5168 * 5169 * @return {Function} Memoized selector. 5170 */ 5171 /* harmony default export */ function rememo(selector, getDependants ) { 5172 var rootCache, getCache; 5173 5174 // Use object source as dependant if getter not provided 5175 if ( ! getDependants ) { 5176 getDependants = arrayOf; 5177 } 5178 5179 /** 5180 * Returns the root cache. If WeakMap is supported, this is assigned to the 5181 * root WeakMap cache set, otherwise it is a shared instance of the default 5182 * cache object. 5183 * 5184 * @return {(WeakMap|Object)} Root cache object. 5185 */ 5186 function getRootCache() { 5187 return rootCache; 5188 } 5189 5190 /** 5191 * Returns the cache for a given dependants array. When possible, a WeakMap 5192 * will be used to create a unique cache for each set of dependants. This 5193 * is feasible due to the nature of WeakMap in allowing garbage collection 5194 * to occur on entries where the key object is no longer referenced. Since 5195 * WeakMap requires the key to be an object, this is only possible when the 5196 * dependant is object-like. The root cache is created as a hierarchy where 5197 * each top-level key is the first entry in a dependants set, the value a 5198 * WeakMap where each key is the next dependant, and so on. This continues 5199 * so long as the dependants are object-like. If no dependants are object- 5200 * like, then the cache is shared across all invocations. 5201 * 5202 * @see isObjectLike 5203 * 5204 * @param {Array} dependants Selector dependants. 5205 * 5206 * @return {Object} Cache object. 5207 */ 5208 function getWeakMapCache( dependants ) { 5209 var caches = rootCache, 5210 isUniqueByDependants = true, 5211 i, dependant, map, cache; 5212 5213 for ( i = 0; i < dependants.length; i++ ) { 5214 dependant = dependants[ i ]; 5215 5216 // Can only compose WeakMap from object-like key. 5217 if ( ! isObjectLike( dependant ) ) { 5218 isUniqueByDependants = false; 5219 break; 5220 } 5221 5222 // Does current segment of cache already have a WeakMap? 5223 if ( caches.has( dependant ) ) { 5224 // Traverse into nested WeakMap. 5225 caches = caches.get( dependant ); 5226 } else { 5227 // Create, set, and traverse into a new one. 5228 map = new WeakMap(); 5229 caches.set( dependant, map ); 5230 caches = map; 5231 } 5232 } 5233 5234 // We use an arbitrary (but consistent) object as key for the last item 5235 // in the WeakMap to serve as our running cache. 5236 if ( ! caches.has( LEAF_KEY ) ) { 5237 cache = createCache(); 5238 cache.isUniqueByDependants = isUniqueByDependants; 5239 caches.set( LEAF_KEY, cache ); 5240 } 5241 5242 return caches.get( LEAF_KEY ); 5243 } 5244 5245 // Assign cache handler by availability of WeakMap 5246 getCache = hasWeakMap ? getWeakMapCache : getRootCache; 5247 5248 /** 5249 * Resets root memoization cache. 5250 */ 5251 function clear() { 5252 rootCache = hasWeakMap ? new WeakMap() : createCache(); 5253 } 5254 5255 // eslint-disable-next-line jsdoc/check-param-names 5256 /** 5257 * The augmented selector call, considering first whether dependants have 5258 * changed before passing it to underlying memoize function. 5259 * 5260 * @param {Object} source Source object for derivation. 5261 * @param {...*} extraArgs Additional arguments to pass to selector. 5262 * 5263 * @return {*} Selector result. 5264 */ 5265 function callSelector( /* source, ...extraArgs */ ) { 5266 var len = arguments.length, 5267 cache, node, i, args, dependants; 5268 5269 // Create copy of arguments (avoid leaking deoptimization). 5270 args = new Array( len ); 5271 for ( i = 0; i < len; i++ ) { 5272 args[ i ] = arguments[ i ]; 5273 } 5274 5275 dependants = getDependants.apply( null, args ); 5276 cache = getCache( dependants ); 5277 5278 // If not guaranteed uniqueness by dependants (primitive type or lack 5279 // of WeakMap support), shallow compare against last dependants and, if 5280 // references have changed, destroy cache to recalculate result. 5281 if ( ! cache.isUniqueByDependants ) { 5282 if ( cache.lastDependants && ! isShallowEqual( dependants, cache.lastDependants, 0 ) ) { 5283 cache.clear(); 5284 } 5285 5286 cache.lastDependants = dependants; 5287 } 5288 5289 node = cache.head; 5290 while ( node ) { 5291 // Check whether node arguments match arguments 5292 if ( ! isShallowEqual( node.args, args, 1 ) ) { 5293 node = node.next; 5294 continue; 5295 } 5296 5297 // At this point we can assume we've found a match 5298 5299 // Surface matched node to head if not already 5300 if ( node !== cache.head ) { 5301 // Adjust siblings to point to each other. 5302 node.prev.next = node.next; 5303 if ( node.next ) { 5304 node.next.prev = node.prev; 5305 } 5306 5307 node.next = cache.head; 5308 node.prev = null; 5309 cache.head.prev = node; 5310 cache.head = node; 5311 } 5312 5313 // Return immediately 5314 return node.val; 5315 } 5316 5317 // No cached value found. Continue to insertion phase: 5318 5319 node = { 5320 // Generate the result from original function 5321 val: selector.apply( null, args ), 5322 }; 5323 5324 // Avoid including the source object in the cache. 5325 args[ 0 ] = null; 5326 node.args = args; 5327 5328 // Don't need to check whether node is already head, since it would 5329 // have been returned above already if it was 5330 5331 // Shift existing head down list 5332 if ( cache.head ) { 5333 cache.head.prev = node; 5334 node.next = cache.head; 5335 } 5336 5337 cache.head = node; 5338 5339 return node.val; 5340 } 5341 5342 callSelector.getDependants = getDependants; 5343 callSelector.clear = clear; 5344 clear(); 5345 5346 return callSelector; 5347 } 5348 5349 ;// CONCATENATED MODULE: external ["wp","primitives"] 5350 var external_wp_primitives_namespaceObject = window["wp"]["primitives"]; 5351 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/symbol.js 5352 5353 5354 /** 5355 * WordPress dependencies 5356 */ 5357 5358 const symbol = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 5359 xmlns: "http://www.w3.org/2000/svg", 5360 viewBox: "0 0 24 24" 5361 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 5362 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" 5363 })); 5364 /* harmony default export */ var library_symbol = (symbol); 5365 5366 ;// CONCATENATED MODULE: external ["wp","richText"] 5367 var external_wp_richText_namespaceObject = window["wp"]["richText"]; 5368 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/store/utils.js 5369 /** 5370 * Helper function that maps attribute definition properties to the 5371 * ones used by RichText utils like `create, toHTMLString, etc..`. 5372 * 5373 * @param {Object} attributeDefinition A block's attribute definition object. 5374 * @return {Object} The mapped object. 5375 */ 5376 function mapRichTextSettings(attributeDefinition) { 5377 const { 5378 multiline: multilineTag, 5379 __unstableMultilineWrapperTags: multilineWrapperTags, 5380 __unstablePreserveWhiteSpace: preserveWhiteSpace 5381 } = attributeDefinition; 5382 return { 5383 multilineTag, 5384 multilineWrapperTags, 5385 preserveWhiteSpace 5386 }; 5387 } 5388 5389 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/store/selectors.js 5390 /** 5391 * External dependencies 5392 */ 5393 5394 5395 /** 5396 * WordPress dependencies 5397 */ 5398 5399 5400 5401 5402 5403 5404 5405 /** 5406 * Internal dependencies 5407 */ 5408 5409 5410 /** 5411 * A block selection object. 5412 * 5413 * @typedef {Object} WPBlockSelection 5414 * 5415 * @property {string} clientId A block client ID. 5416 * @property {string} attributeKey A block attribute key. 5417 * @property {number} offset An attribute value offset, based on the rich 5418 * text value. See `wp.richText.create`. 5419 */ 5420 // Module constants. 5421 5422 const MILLISECONDS_PER_HOUR = 3600 * 1000; 5423 const MILLISECONDS_PER_DAY = 24 * 3600 * 1000; 5424 const MILLISECONDS_PER_WEEK = 7 * 24 * 3600 * 1000; 5425 /** 5426 * Shared reference to an empty array for cases where it is important to avoid 5427 * returning a new array reference on every invocation, as in a connected or 5428 * other pure component which performs `shouldComponentUpdate` check on props. 5429 * This should be used as a last resort, since the normalized data should be 5430 * maintained by the reducer result in state. 5431 * 5432 * @type {Array} 5433 */ 5434 5435 const EMPTY_ARRAY = []; 5436 /** 5437 * Returns a block's name given its client ID, or null if no block exists with 5438 * the client ID. 5439 * 5440 * @param {Object} state Editor state. 5441 * @param {string} clientId Block client ID. 5442 * 5443 * @return {string} Block name. 5444 */ 5445 5446 function getBlockName(state, clientId) { 5447 const block = state.blocks.byClientId[clientId]; 5448 const socialLinkName = 'core/social-link'; 5449 5450 if (external_wp_element_namespaceObject.Platform.OS !== 'web' && (block === null || block === void 0 ? void 0 : block.name) === socialLinkName) { 5451 const attributes = state.blocks.attributes[clientId]; 5452 const { 5453 service 5454 } = attributes; 5455 return service ? `$socialLinkName}-$service}` : socialLinkName; 5456 } 5457 5458 return block ? block.name : null; 5459 } 5460 /** 5461 * Returns whether a block is valid or not. 5462 * 5463 * @param {Object} state Editor state. 5464 * @param {string} clientId Block client ID. 5465 * 5466 * @return {boolean} Is Valid. 5467 */ 5468 5469 function isBlockValid(state, clientId) { 5470 const block = state.blocks.byClientId[clientId]; 5471 return !!block && block.isValid; 5472 } 5473 /** 5474 * Returns a block's attributes given its client ID, or null if no block exists with 5475 * the client ID. 5476 * 5477 * @param {Object} state Editor state. 5478 * @param {string} clientId Block client ID. 5479 * 5480 * @return {Object?} Block attributes. 5481 */ 5482 5483 function getBlockAttributes(state, clientId) { 5484 const block = state.blocks.byClientId[clientId]; 5485 5486 if (!block) { 5487 return null; 5488 } 5489 5490 return state.blocks.attributes[clientId]; 5491 } 5492 /** 5493 * Returns a block given its client ID. This is a parsed copy of the block, 5494 * containing its `blockName`, `clientId`, and current `attributes` state. This 5495 * is not the block's registration settings, which must be retrieved from the 5496 * blocks module registration store. 5497 * 5498 * getBlock recurses through its inner blocks until all its children blocks have 5499 * been retrieved. Note that getBlock will not return the child inner blocks of 5500 * an inner block controller. This is because an inner block controller syncs 5501 * itself with its own entity, and should therefore not be included with the 5502 * blocks of a different entity. For example, say you call `getBlocks( TP )` to 5503 * get the blocks of a template part. If another template part is a child of TP, 5504 * then the nested template part's child blocks will not be returned. This way, 5505 * the template block itself is considered part of the parent, but the children 5506 * are not. 5507 * 5508 * @param {Object} state Editor state. 5509 * @param {string} clientId Block client ID. 5510 * 5511 * @return {Object} Parsed block object. 5512 */ 5513 5514 function getBlock(state, clientId) { 5515 const block = state.blocks.byClientId[clientId]; 5516 5517 if (!block) { 5518 return null; 5519 } 5520 5521 return state.blocks.tree[clientId]; 5522 } 5523 const __unstableGetBlockWithoutInnerBlocks = rememo((state, clientId) => { 5524 const block = state.blocks.byClientId[clientId]; 5525 5526 if (!block) { 5527 return null; 5528 } 5529 5530 return { ...block, 5531 attributes: getBlockAttributes(state, clientId) 5532 }; 5533 }, (state, clientId) => [state.blocks.byClientId[clientId], state.blocks.attributes[clientId]]); 5534 /** 5535 * Returns all block objects for the current post being edited as an array in 5536 * the order they appear in the post. Note that this will exclude child blocks 5537 * of nested inner block controllers. 5538 * 5539 * @param {Object} state Editor state. 5540 * @param {?string} rootClientId Optional root client ID of block list. 5541 * 5542 * @return {Object[]} Post blocks. 5543 */ 5544 5545 function getBlocks(state, rootClientId) { 5546 var _state$blocks$tree$tr; 5547 5548 const treeKey = !rootClientId || !areInnerBlocksControlled(state, rootClientId) ? rootClientId || '' : 'controlled||' + rootClientId; 5549 return ((_state$blocks$tree$tr = state.blocks.tree[treeKey]) === null || _state$blocks$tree$tr === void 0 ? void 0 : _state$blocks$tree$tr.innerBlocks) || EMPTY_ARRAY; 5550 } 5551 /** 5552 * Returns a stripped down block object containing only its client ID, 5553 * and its inner blocks' client IDs. 5554 * 5555 * @param {Object} state Editor state. 5556 * @param {string} clientId Client ID of the block to get. 5557 * 5558 * @return {Object} Client IDs of the post blocks. 5559 */ 5560 5561 const __unstableGetClientIdWithClientIdsTree = rememo((state, clientId) => ({ 5562 clientId, 5563 innerBlocks: __unstableGetClientIdsTree(state, clientId) 5564 }), state => [state.blocks.order]); 5565 /** 5566 * Returns the block tree represented in the block-editor store from the 5567 * given root, consisting of stripped down block objects containing only 5568 * their client IDs, and their inner blocks' client IDs. 5569 * 5570 * @param {Object} state Editor state. 5571 * @param {?string} rootClientId Optional root client ID of block list. 5572 * 5573 * @return {Object[]} Client IDs of the post blocks. 5574 */ 5575 5576 const __unstableGetClientIdsTree = rememo(function (state) { 5577 let rootClientId = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : ''; 5578 return (0,external_lodash_namespaceObject.map)(getBlockOrder(state, rootClientId), clientId => __unstableGetClientIdWithClientIdsTree(state, clientId)); 5579 }, state => [state.blocks.order]); 5580 /** 5581 * Returns an array containing the clientIds of all descendants of the blocks 5582 * given. Returned ids are ordered first by the order of the ids given, then 5583 * by the order that they appear in the editor. 5584 * 5585 * @param {Object} state Global application state. 5586 * @param {Array} clientIds Array of blocks to inspect. 5587 * 5588 * @return {Array} ids of descendants. 5589 */ 5590 5591 const getClientIdsOfDescendants = rememo((state, clientIds) => { 5592 const collectedIds = []; 5593 5594 for (const givenId of clientIds) { 5595 for (const descendantId of getBlockOrder(state, givenId)) { 5596 collectedIds.push(descendantId, ...getClientIdsOfDescendants(state, [descendantId])); 5597 } 5598 } 5599 5600 return collectedIds; 5601 }, state => [state.blocks.order]); 5602 /** 5603 * Returns an array containing the clientIds of the top-level blocks and 5604 * their descendants of any depth (for nested blocks). Ids are returned 5605 * in the same order that they appear in the editor. 5606 * 5607 * @param {Object} state Global application state. 5608 * 5609 * @return {Array} ids of top-level and descendant blocks. 5610 */ 5611 5612 const getClientIdsWithDescendants = rememo(state => { 5613 const collectedIds = []; 5614 5615 for (const topLevelId of getBlockOrder(state)) { 5616 collectedIds.push(topLevelId, ...getClientIdsOfDescendants(state, [topLevelId])); 5617 } 5618 5619 return collectedIds; 5620 }, state => [state.blocks.order]); 5621 /** 5622 * Returns the total number of blocks, or the total number of blocks with a specific name in a post. 5623 * The number returned includes nested blocks. 5624 * 5625 * @param {Object} state Global application state. 5626 * @param {?string} blockName Optional block name, if specified only blocks of that type will be counted. 5627 * 5628 * @return {number} Number of blocks in the post, or number of blocks with name equal to blockName. 5629 */ 5630 5631 const getGlobalBlockCount = rememo((state, blockName) => { 5632 const clientIds = getClientIdsWithDescendants(state); 5633 5634 if (!blockName) { 5635 return clientIds.length; 5636 } 5637 5638 return (0,external_lodash_namespaceObject.reduce)(clientIds, (accumulator, clientId) => { 5639 const block = state.blocks.byClientId[clientId]; 5640 return block.name === blockName ? accumulator + 1 : accumulator; 5641 }, 0); 5642 }, state => [state.blocks.order, state.blocks.byClientId]); 5643 /** 5644 * Returns all global blocks that match a blockName. Results include nested blocks. 5645 * 5646 * @param {Object} state Global application state. 5647 * @param {?string} blockName Optional block name, if not specified, returns an empty array. 5648 * 5649 * @return {Array} Array of clientIds of blocks with name equal to blockName. 5650 */ 5651 5652 const __experimentalGetGlobalBlocksByName = rememo((state, blockName) => { 5653 if (!blockName) { 5654 return EMPTY_ARRAY; 5655 } 5656 5657 const clientIds = getClientIdsWithDescendants(state); 5658 const foundBlocks = clientIds.filter(clientId => { 5659 const block = state.blocks.byClientId[clientId]; 5660 return block.name === blockName; 5661 }); 5662 return foundBlocks.length > 0 ? foundBlocks : EMPTY_ARRAY; 5663 }, state => [state.blocks.order, state.blocks.byClientId]); 5664 /** 5665 * Given an array of block client IDs, returns the corresponding array of block 5666 * objects. 5667 * 5668 * @param {Object} state Editor state. 5669 * @param {string[]} clientIds Client IDs for which blocks are to be returned. 5670 * 5671 * @return {WPBlock[]} Block objects. 5672 */ 5673 5674 const getBlocksByClientId = rememo((state, clientIds) => (0,external_lodash_namespaceObject.map)((0,external_lodash_namespaceObject.castArray)(clientIds), clientId => getBlock(state, clientId)), (state, clientIds) => (0,external_lodash_namespaceObject.map)((0,external_lodash_namespaceObject.castArray)(clientIds), clientId => state.blocks.tree[clientId])); 5675 /** 5676 * Returns the number of blocks currently present in the post. 5677 * 5678 * @param {Object} state Editor state. 5679 * @param {?string} rootClientId Optional root client ID of block list. 5680 * 5681 * @return {number} Number of blocks in the post. 5682 */ 5683 5684 function getBlockCount(state, rootClientId) { 5685 return getBlockOrder(state, rootClientId).length; 5686 } 5687 /** 5688 * Returns the current selection start block client ID, attribute key and text 5689 * offset. 5690 * 5691 * @param {Object} state Block editor state. 5692 * 5693 * @return {WPBlockSelection} Selection start information. 5694 */ 5695 5696 function getSelectionStart(state) { 5697 return state.selection.selectionStart; 5698 } 5699 /** 5700 * Returns the current selection end block client ID, attribute key and text 5701 * offset. 5702 * 5703 * @param {Object} state Block editor state. 5704 * 5705 * @return {WPBlockSelection} Selection end information. 5706 */ 5707 5708 function getSelectionEnd(state) { 5709 return state.selection.selectionEnd; 5710 } 5711 /** 5712 * Returns the current block selection start. This value may be null, and it 5713 * may represent either a singular block selection or multi-selection start. 5714 * A selection is singular if its start and end match. 5715 * 5716 * @param {Object} state Global application state. 5717 * 5718 * @return {?string} Client ID of block selection start. 5719 */ 5720 5721 function getBlockSelectionStart(state) { 5722 return state.selection.selectionStart.clientId; 5723 } 5724 /** 5725 * Returns the current block selection end. This value may be null, and it 5726 * may represent either a singular block selection or multi-selection end. 5727 * A selection is singular if its start and end match. 5728 * 5729 * @param {Object} state Global application state. 5730 * 5731 * @return {?string} Client ID of block selection end. 5732 */ 5733 5734 function getBlockSelectionEnd(state) { 5735 return state.selection.selectionEnd.clientId; 5736 } 5737 /** 5738 * Returns the number of blocks currently selected in the post. 5739 * 5740 * @param {Object} state Global application state. 5741 * 5742 * @return {number} Number of blocks selected in the post. 5743 */ 5744 5745 function getSelectedBlockCount(state) { 5746 const multiSelectedBlockCount = getMultiSelectedBlockClientIds(state).length; 5747 5748 if (multiSelectedBlockCount) { 5749 return multiSelectedBlockCount; 5750 } 5751 5752 return state.selection.selectionStart.clientId ? 1 : 0; 5753 } 5754 /** 5755 * Returns true if there is a single selected block, or false otherwise. 5756 * 5757 * @param {Object} state Editor state. 5758 * 5759 * @return {boolean} Whether a single block is selected. 5760 */ 5761 5762 function hasSelectedBlock(state) { 5763 const { 5764 selectionStart, 5765 selectionEnd 5766 } = state.selection; 5767 return !!selectionStart.clientId && selectionStart.clientId === selectionEnd.clientId; 5768 } 5769 /** 5770 * Returns the currently selected block client ID, or null if there is no 5771 * selected block. 5772 * 5773 * @param {Object} state Editor state. 5774 * 5775 * @return {?string} Selected block client ID. 5776 */ 5777 5778 function getSelectedBlockClientId(state) { 5779 const { 5780 selectionStart, 5781 selectionEnd 5782 } = state.selection; 5783 const { 5784 clientId 5785 } = selectionStart; 5786 5787 if (!clientId || clientId !== selectionEnd.clientId) { 5788 return null; 5789 } 5790 5791 return clientId; 5792 } 5793 /** 5794 * Returns the currently selected block, or null if there is no selected block. 5795 * 5796 * @param {Object} state Global application state. 5797 * 5798 * @return {?Object} Selected block. 5799 */ 5800 5801 function getSelectedBlock(state) { 5802 const clientId = getSelectedBlockClientId(state); 5803 return clientId ? getBlock(state, clientId) : null; 5804 } 5805 /** 5806 * Given a block client ID, returns the root block from which the block is 5807 * nested, an empty string for top-level blocks, or null if the block does not 5808 * exist. 5809 * 5810 * @param {Object} state Editor state. 5811 * @param {string} clientId Block from which to find root client ID. 5812 * 5813 * @return {?string} Root client ID, if exists 5814 */ 5815 5816 function getBlockRootClientId(state, clientId) { 5817 return state.blocks.parents[clientId] !== undefined ? state.blocks.parents[clientId] : null; 5818 } 5819 /** 5820 * Given a block client ID, returns the list of all its parents from top to bottom. 5821 * 5822 * @param {Object} state Editor state. 5823 * @param {string} clientId Block from which to find root client ID. 5824 * @param {boolean} ascending Order results from bottom to top (true) or top to bottom (false). 5825 * 5826 * @return {Array} ClientIDs of the parent blocks. 5827 */ 5828 5829 const getBlockParents = rememo(function (state, clientId) { 5830 let ascending = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; 5831 const parents = []; 5832 let current = clientId; 5833 5834 while (!!state.blocks.parents[current]) { 5835 current = state.blocks.parents[current]; 5836 parents.push(current); 5837 } 5838 5839 return ascending ? parents : parents.reverse(); 5840 }, state => [state.blocks.parents]); 5841 /** 5842 * Given a block client ID and a block name, returns the list of all its parents 5843 * from top to bottom, filtered by the given name(s). For example, if passed 5844 * 'core/group' as the blockName, it will only return parents which are group 5845 * blocks. If passed `[ 'core/group', 'core/cover']`, as the blockName, it will 5846 * return parents which are group blocks and parents which are cover blocks. 5847 * 5848 * @param {Object} state Editor state. 5849 * @param {string} clientId Block from which to find root client ID. 5850 * @param {string|string[]} blockName Block name(s) to filter. 5851 * @param {boolean} ascending Order results from bottom to top (true) or top to bottom (false). 5852 * 5853 * @return {Array} ClientIDs of the parent blocks. 5854 */ 5855 5856 const getBlockParentsByBlockName = rememo(function (state, clientId, blockName) { 5857 let ascending = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false; 5858 const parents = getBlockParents(state, clientId, ascending); 5859 return (0,external_lodash_namespaceObject.map)((0,external_lodash_namespaceObject.filter)((0,external_lodash_namespaceObject.map)(parents, id => ({ 5860 id, 5861 name: getBlockName(state, id) 5862 })), _ref => { 5863 let { 5864 name 5865 } = _ref; 5866 5867 if (Array.isArray(blockName)) { 5868 return blockName.includes(name); 5869 } 5870 5871 return name === blockName; 5872 }), _ref2 => { 5873 let { 5874 id 5875 } = _ref2; 5876 return id; 5877 }); 5878 }, state => [state.blocks.parents]); 5879 /** 5880 * Given a block client ID, returns the root of the hierarchy from which the block is nested, return the block itself for root level blocks. 5881 * 5882 * @param {Object} state Editor state. 5883 * @param {string} clientId Block from which to find root client ID. 5884 * 5885 * @return {string} Root client ID 5886 */ 5887 5888 function getBlockHierarchyRootClientId(state, clientId) { 5889 let current = clientId; 5890 let parent; 5891 5892 do { 5893 parent = current; 5894 current = state.blocks.parents[current]; 5895 } while (current); 5896 5897 return parent; 5898 } 5899 /** 5900 * Given a block client ID, returns the lowest common ancestor with selected client ID. 5901 * 5902 * @param {Object} state Editor state. 5903 * @param {string} clientId Block from which to find common ancestor client ID. 5904 * 5905 * @return {string} Common ancestor client ID or undefined 5906 */ 5907 5908 function getLowestCommonAncestorWithSelectedBlock(state, clientId) { 5909 const selectedId = getSelectedBlockClientId(state); 5910 const clientParents = [...getBlockParents(state, clientId), clientId]; 5911 const selectedParents = [...getBlockParents(state, selectedId), selectedId]; 5912 let lowestCommonAncestor; 5913 const maxDepth = Math.min(clientParents.length, selectedParents.length); 5914 5915 for (let index = 0; index < maxDepth; index++) { 5916 if (clientParents[index] === selectedParents[index]) { 5917 lowestCommonAncestor = clientParents[index]; 5918 } else { 5919 break; 5920 } 5921 } 5922 5923 return lowestCommonAncestor; 5924 } 5925 /** 5926 * Returns the client ID of the block adjacent one at the given reference 5927 * startClientId and modifier directionality. Defaults start startClientId to 5928 * the selected block, and direction as next block. Returns null if there is no 5929 * adjacent block. 5930 * 5931 * @param {Object} state Editor state. 5932 * @param {?string} startClientId Optional client ID of block from which to 5933 * search. 5934 * @param {?number} modifier Directionality multiplier (1 next, -1 5935 * previous). 5936 * 5937 * @return {?string} Return the client ID of the block, or null if none exists. 5938 */ 5939 5940 function getAdjacentBlockClientId(state, startClientId) { 5941 let modifier = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 1; 5942 5943 // Default to selected block. 5944 if (startClientId === undefined) { 5945 startClientId = getSelectedBlockClientId(state); 5946 } // Try multi-selection starting at extent based on modifier. 5947 5948 5949 if (startClientId === undefined) { 5950 if (modifier < 0) { 5951 startClientId = getFirstMultiSelectedBlockClientId(state); 5952 } else { 5953 startClientId = getLastMultiSelectedBlockClientId(state); 5954 } 5955 } // Validate working start client ID. 5956 5957 5958 if (!startClientId) { 5959 return null; 5960 } // Retrieve start block root client ID, being careful to allow the falsey 5961 // empty string top-level root by explicitly testing against null. 5962 5963 5964 const rootClientId = getBlockRootClientId(state, startClientId); 5965 5966 if (rootClientId === null) { 5967 return null; 5968 } 5969 5970 const { 5971 order 5972 } = state.blocks; 5973 const orderSet = order[rootClientId]; 5974 const index = orderSet.indexOf(startClientId); 5975 const nextIndex = index + 1 * modifier; // Block was first in set and we're attempting to get previous. 5976 5977 if (nextIndex < 0) { 5978 return null; 5979 } // Block was last in set and we're attempting to get next. 5980 5981 5982 if (nextIndex === orderSet.length) { 5983 return null; 5984 } // Assume incremented index is within the set. 5985 5986 5987 return orderSet[nextIndex]; 5988 } 5989 /** 5990 * Returns the previous block's client ID from the given reference start ID. 5991 * Defaults start to the selected block. Returns null if there is no previous 5992 * block. 5993 * 5994 * @param {Object} state Editor state. 5995 * @param {?string} startClientId Optional client ID of block from which to 5996 * search. 5997 * 5998 * @return {?string} Adjacent block's client ID, or null if none exists. 5999 */ 6000 6001 function getPreviousBlockClientId(state, startClientId) { 6002 return getAdjacentBlockClientId(state, startClientId, -1); 6003 } 6004 /** 6005 * Returns the next block's client ID from the given reference start ID. 6006 * Defaults start to the selected block. Returns null if there is no next 6007 * block. 6008 * 6009 * @param {Object} state Editor state. 6010 * @param {?string} startClientId Optional client ID of block from which to 6011 * search. 6012 * 6013 * @return {?string} Adjacent block's client ID, or null if none exists. 6014 */ 6015 6016 function getNextBlockClientId(state, startClientId) { 6017 return getAdjacentBlockClientId(state, startClientId, 1); 6018 } 6019 /* eslint-disable jsdoc/valid-types */ 6020 6021 /** 6022 * Returns the initial caret position for the selected block. 6023 * This position is to used to position the caret properly when the selected block changes. 6024 * If the current block is not a RichText, having initial position set to 0 means "focus block" 6025 * 6026 * @param {Object} state Global application state. 6027 * 6028 * @return {0|-1|null} Initial position. 6029 */ 6030 6031 function getSelectedBlocksInitialCaretPosition(state) { 6032 /* eslint-enable jsdoc/valid-types */ 6033 return state.initialPosition; 6034 } 6035 /** 6036 * Returns the current selection set of block client IDs (multiselection or single selection). 6037 * 6038 * @param {Object} state Editor state. 6039 * 6040 * @return {Array} Multi-selected block client IDs. 6041 */ 6042 6043 const getSelectedBlockClientIds = rememo(state => { 6044 const { 6045 selectionStart, 6046 selectionEnd 6047 } = state.selection; 6048 6049 if (selectionStart.clientId === undefined || selectionEnd.clientId === undefined) { 6050 return EMPTY_ARRAY; 6051 } 6052 6053 if (selectionStart.clientId === selectionEnd.clientId) { 6054 return [selectionStart.clientId]; 6055 } // Retrieve root client ID to aid in retrieving relevant nested block 6056 // order, being careful to allow the falsey empty string top-level root 6057 // by explicitly testing against null. 6058 6059 6060 const rootClientId = getBlockRootClientId(state, selectionStart.clientId); 6061 6062 if (rootClientId === null) { 6063 return EMPTY_ARRAY; 6064 } 6065 6066 const blockOrder = getBlockOrder(state, rootClientId); 6067 const startIndex = blockOrder.indexOf(selectionStart.clientId); 6068 const endIndex = blockOrder.indexOf(selectionEnd.clientId); 6069 6070 if (startIndex > endIndex) { 6071 return blockOrder.slice(endIndex, startIndex + 1); 6072 } 6073 6074 return blockOrder.slice(startIndex, endIndex + 1); 6075 }, state => [state.blocks.order, state.selection.selectionStart.clientId, state.selection.selectionEnd.clientId]); 6076 /** 6077 * Returns the current multi-selection set of block client IDs, or an empty 6078 * array if there is no multi-selection. 6079 * 6080 * @param {Object} state Editor state. 6081 * 6082 * @return {Array} Multi-selected block client IDs. 6083 */ 6084 6085 function getMultiSelectedBlockClientIds(state) { 6086 const { 6087 selectionStart, 6088 selectionEnd 6089 } = state.selection; 6090 6091 if (selectionStart.clientId === selectionEnd.clientId) { 6092 return EMPTY_ARRAY; 6093 } 6094 6095 return getSelectedBlockClientIds(state); 6096 } 6097 /** 6098 * Returns the current multi-selection set of blocks, or an empty array if 6099 * there is no multi-selection. 6100 * 6101 * @param {Object} state Editor state. 6102 * 6103 * @return {Array} Multi-selected block objects. 6104 */ 6105 6106 const getMultiSelectedBlocks = rememo(state => { 6107 const multiSelectedBlockClientIds = getMultiSelectedBlockClientIds(state); 6108 6109 if (!multiSelectedBlockClientIds.length) { 6110 return EMPTY_ARRAY; 6111 } 6112 6113 return multiSelectedBlockClientIds.map(clientId => getBlock(state, clientId)); 6114 }, state => [...getSelectedBlockClientIds.getDependants(state), state.blocks.byClientId, state.blocks.order, state.blocks.attributes]); 6115 /** 6116 * Returns the client ID of the first block in the multi-selection set, or null 6117 * if there is no multi-selection. 6118 * 6119 * @param {Object} state Editor state. 6120 * 6121 * @return {?string} First block client ID in the multi-selection set. 6122 */ 6123 6124 function getFirstMultiSelectedBlockClientId(state) { 6125 return (0,external_lodash_namespaceObject.first)(getMultiSelectedBlockClientIds(state)) || null; 6126 } 6127 /** 6128 * Returns the client ID of the last block in the multi-selection set, or null 6129 * if there is no multi-selection. 6130 * 6131 * @param {Object} state Editor state. 6132 * 6133 * @return {?string} Last block client ID in the multi-selection set. 6134 */ 6135 6136 function getLastMultiSelectedBlockClientId(state) { 6137 return (0,external_lodash_namespaceObject.last)(getMultiSelectedBlockClientIds(state)) || null; 6138 } 6139 /** 6140 * Returns true if a multi-selection exists, and the block corresponding to the 6141 * specified client ID is the first block of the multi-selection set, or false 6142 * otherwise. 6143 * 6144 * @param {Object} state Editor state. 6145 * @param {string} clientId Block client ID. 6146 * 6147 * @return {boolean} Whether block is first in multi-selection. 6148 */ 6149 6150 function isFirstMultiSelectedBlock(state, clientId) { 6151 return getFirstMultiSelectedBlockClientId(state) === clientId; 6152 } 6153 /** 6154 * Returns true if the client ID occurs within the block multi-selection, or 6155 * false otherwise. 6156 * 6157 * @param {Object} state Editor state. 6158 * @param {string} clientId Block client ID. 6159 * 6160 * @return {boolean} Whether block is in multi-selection set. 6161 */ 6162 6163 function isBlockMultiSelected(state, clientId) { 6164 return getMultiSelectedBlockClientIds(state).indexOf(clientId) !== -1; 6165 } 6166 /** 6167 * Returns true if an ancestor of the block is multi-selected, or false 6168 * otherwise. 6169 * 6170 * @param {Object} state Editor state. 6171 * @param {string} clientId Block client ID. 6172 * 6173 * @return {boolean} Whether an ancestor of the block is in multi-selection 6174 * set. 6175 */ 6176 6177 const isAncestorMultiSelected = rememo((state, clientId) => { 6178 let ancestorClientId = clientId; 6179 let isMultiSelected = false; 6180 6181 while (ancestorClientId && !isMultiSelected) { 6182 ancestorClientId = getBlockRootClientId(state, ancestorClientId); 6183 isMultiSelected = isBlockMultiSelected(state, ancestorClientId); 6184 } 6185 6186 return isMultiSelected; 6187 }, state => [state.blocks.order, state.selection.selectionStart.clientId, state.selection.selectionEnd.clientId]); 6188 /** 6189 * Returns the client ID of the block which begins the multi-selection set, or 6190 * null if there is no multi-selection. 6191 * 6192 * This is not necessarily the first client ID in the selection. 6193 * 6194 * @see getFirstMultiSelectedBlockClientId 6195 * 6196 * @param {Object} state Editor state. 6197 * 6198 * @return {?string} Client ID of block beginning multi-selection. 6199 */ 6200 6201 function getMultiSelectedBlocksStartClientId(state) { 6202 const { 6203 selectionStart, 6204 selectionEnd 6205 } = state.selection; 6206 6207 if (selectionStart.clientId === selectionEnd.clientId) { 6208 return null; 6209 } 6210 6211 return selectionStart.clientId || null; 6212 } 6213 /** 6214 * Returns the client ID of the block which ends the multi-selection set, or 6215 * null if there is no multi-selection. 6216 * 6217 * This is not necessarily the last client ID in the selection. 6218 * 6219 * @see getLastMultiSelectedBlockClientId 6220 * 6221 * @param {Object} state Editor state. 6222 * 6223 * @return {?string} Client ID of block ending multi-selection. 6224 */ 6225 6226 function getMultiSelectedBlocksEndClientId(state) { 6227 const { 6228 selectionStart, 6229 selectionEnd 6230 } = state.selection; 6231 6232 if (selectionStart.clientId === selectionEnd.clientId) { 6233 return null; 6234 } 6235 6236 return selectionEnd.clientId || null; 6237 } 6238 /** 6239 * Returns true if the selection is not partial. 6240 * 6241 * @param {Object} state Editor state. 6242 * 6243 * @return {boolean} Whether the selection is mergeable. 6244 */ 6245 6246 function __unstableIsFullySelected(state) { 6247 const selectionAnchor = getSelectionStart(state); 6248 const selectionFocus = getSelectionEnd(state); 6249 return !selectionAnchor.attributeKey && !selectionFocus.attributeKey && typeof selectionAnchor.offset === 'undefined' && typeof selectionFocus.offset === 'undefined'; 6250 } 6251 /** 6252 * Returns true if the selection is collapsed. 6253 * 6254 * @param {Object} state Editor state. 6255 * 6256 * @return {boolean} Whether the selection is collapsed. 6257 */ 6258 6259 function __unstableIsSelectionCollapsed(state) { 6260 const selectionAnchor = getSelectionStart(state); 6261 const selectionFocus = getSelectionEnd(state); 6262 return !!selectionAnchor && !!selectionFocus && selectionAnchor.clientId === selectionFocus.clientId && selectionAnchor.attributeKey === selectionFocus.attributeKey && selectionAnchor.offset === selectionFocus.offset; 6263 } 6264 /** 6265 * Check whether the selection is mergeable. 6266 * 6267 * @param {Object} state Editor state. 6268 * @param {boolean} isForward Whether to merge forwards. 6269 * 6270 * @return {boolean} Whether the selection is mergeable. 6271 */ 6272 6273 function __unstableIsSelectionMergeable(state, isForward) { 6274 const selectionAnchor = getSelectionStart(state); 6275 const selectionFocus = getSelectionEnd(state); // It's not mergeable if the start and end are within the same block. 6276 6277 if (selectionAnchor.clientId === selectionFocus.clientId) return false; // It's not mergeable if there's no rich text selection. 6278 6279 if (!selectionAnchor.attributeKey || !selectionFocus.attributeKey || typeof selectionAnchor.offset === 'undefined' || typeof selectionFocus.offset === 'undefined') return false; 6280 const anchorRootClientId = getBlockRootClientId(state, selectionAnchor.clientId); 6281 const focusRootClientId = getBlockRootClientId(state, selectionFocus.clientId); // It's not mergeable if the selection doesn't start and end in the same 6282 // block list. Maybe in the future it should be allowed. 6283 6284 if (anchorRootClientId !== focusRootClientId) { 6285 return false; 6286 } 6287 6288 const blockOrder = getBlockOrder(state, anchorRootClientId); 6289 const anchorIndex = blockOrder.indexOf(selectionAnchor.clientId); 6290 const focusIndex = blockOrder.indexOf(selectionFocus.clientId); // Reassign selection start and end based on order. 6291 6292 let selectionStart, selectionEnd; 6293 6294 if (anchorIndex > focusIndex) { 6295 selectionStart = selectionFocus; 6296 selectionEnd = selectionAnchor; 6297 } else { 6298 selectionStart = selectionAnchor; 6299 selectionEnd = selectionFocus; 6300 } 6301 6302 const targetBlockClientId = isForward ? selectionEnd.clientId : selectionStart.clientId; 6303 const blockToMergeClientId = isForward ? selectionStart.clientId : selectionEnd.clientId; 6304 const targetBlock = getBlock(state, targetBlockClientId); 6305 const targetBlockType = (0,external_wp_blocks_namespaceObject.getBlockType)(targetBlock.name); 6306 if (!targetBlockType.merge) return false; 6307 const blockToMerge = getBlock(state, blockToMergeClientId); // It's mergeable if the blocks are of the same type. 6308 6309 if (blockToMerge.name === targetBlock.name) return true; // If the blocks are of a different type, try to transform the block being 6310 // merged into the same type of block. 6311 6312 const blocksToMerge = (0,external_wp_blocks_namespaceObject.switchToBlockType)(blockToMerge, targetBlock.name); 6313 return blocksToMerge && blocksToMerge.length; 6314 } 6315 /** 6316 * Get partial selected blocks with their content updated 6317 * based on the selection. 6318 * 6319 * @param {Object} state Editor state. 6320 * 6321 * @return {Object[]} Updated partial selected blocks. 6322 */ 6323 6324 const __unstableGetSelectedBlocksWithPartialSelection = state => { 6325 const selectionAnchor = getSelectionStart(state); 6326 const selectionFocus = getSelectionEnd(state); 6327 6328 if (selectionAnchor.clientId === selectionFocus.clientId) { 6329 return EMPTY_ARRAY; 6330 } // Can't split if the selection is not set. 6331 6332 6333 if (!selectionAnchor.attributeKey || !selectionFocus.attributeKey || typeof selectionAnchor.offset === 'undefined' || typeof selectionFocus.offset === 'undefined') { 6334 return EMPTY_ARRAY; 6335 } 6336 6337 const anchorRootClientId = getBlockRootClientId(state, selectionAnchor.clientId); 6338 const focusRootClientId = getBlockRootClientId(state, selectionFocus.clientId); // It's not splittable if the selection doesn't start and end in the same 6339 // block list. Maybe in the future it should be allowed. 6340 6341 if (anchorRootClientId !== focusRootClientId) { 6342 return EMPTY_ARRAY; 6343 } 6344 6345 const blockOrder = getBlockOrder(state, anchorRootClientId); 6346 const anchorIndex = blockOrder.indexOf(selectionAnchor.clientId); 6347 const focusIndex = blockOrder.indexOf(selectionFocus.clientId); // Reassign selection start and end based on order. 6348 6349 const [selectionStart, selectionEnd] = anchorIndex > focusIndex ? [selectionFocus, selectionAnchor] : [selectionAnchor, selectionFocus]; 6350 const blockA = getBlock(state, selectionStart.clientId); 6351 const blockAType = (0,external_wp_blocks_namespaceObject.getBlockType)(blockA.name); 6352 const blockB = getBlock(state, selectionEnd.clientId); 6353 const blockBType = (0,external_wp_blocks_namespaceObject.getBlockType)(blockB.name); 6354 const htmlA = blockA.attributes[selectionStart.attributeKey]; 6355 const htmlB = blockB.attributes[selectionEnd.attributeKey]; 6356 const attributeDefinitionA = blockAType.attributes[selectionStart.attributeKey]; 6357 const attributeDefinitionB = blockBType.attributes[selectionEnd.attributeKey]; 6358 let valueA = (0,external_wp_richText_namespaceObject.create)({ 6359 html: htmlA, 6360 ...mapRichTextSettings(attributeDefinitionA) 6361 }); 6362 let valueB = (0,external_wp_richText_namespaceObject.create)({ 6363 html: htmlB, 6364 ...mapRichTextSettings(attributeDefinitionB) 6365 }); 6366 valueA = (0,external_wp_richText_namespaceObject.remove)(valueA, 0, selectionStart.offset); 6367 valueB = (0,external_wp_richText_namespaceObject.remove)(valueB, selectionEnd.offset, valueB.text.length); 6368 return [{ ...blockA, 6369 attributes: { ...blockA.attributes, 6370 [selectionStart.attributeKey]: (0,external_wp_richText_namespaceObject.toHTMLString)({ 6371 value: valueA, 6372 ...mapRichTextSettings(attributeDefinitionA) 6373 }) 6374 } 6375 }, { ...blockB, 6376 attributes: { ...blockB.attributes, 6377 [selectionEnd.attributeKey]: (0,external_wp_richText_namespaceObject.toHTMLString)({ 6378 value: valueB, 6379 ...mapRichTextSettings(attributeDefinitionB) 6380 }) 6381 } 6382 }]; 6383 }; 6384 /** 6385 * Returns an array containing all block client IDs in the editor in the order 6386 * they appear. Optionally accepts a root client ID of the block list for which 6387 * the order should be returned, defaulting to the top-level block order. 6388 * 6389 * @param {Object} state Editor state. 6390 * @param {?string} rootClientId Optional root client ID of block list. 6391 * 6392 * @return {Array} Ordered client IDs of editor blocks. 6393 */ 6394 6395 function getBlockOrder(state, rootClientId) { 6396 return state.blocks.order[rootClientId || ''] || EMPTY_ARRAY; 6397 } 6398 /** 6399 * Returns the index at which the block corresponding to the specified client 6400 * ID occurs within the block order, or `-1` if the block does not exist. 6401 * 6402 * @param {Object} state Editor state. 6403 * @param {string} clientId Block client ID. 6404 * 6405 * @return {number} Index at which block exists in order. 6406 */ 6407 6408 function getBlockIndex(state, clientId) { 6409 const rootClientId = getBlockRootClientId(state, clientId); 6410 return getBlockOrder(state, rootClientId).indexOf(clientId); 6411 } 6412 /** 6413 * Returns true if the block corresponding to the specified client ID is 6414 * currently selected and no multi-selection exists, or false otherwise. 6415 * 6416 * @param {Object} state Editor state. 6417 * @param {string} clientId Block client ID. 6418 * 6419 * @return {boolean} Whether block is selected and multi-selection exists. 6420 */ 6421 6422 function isBlockSelected(state, clientId) { 6423 const { 6424 selectionStart, 6425 selectionEnd 6426 } = state.selection; 6427 6428 if (selectionStart.clientId !== selectionEnd.clientId) { 6429 return false; 6430 } 6431 6432 return selectionStart.clientId === clientId; 6433 } 6434 /** 6435 * Returns true if one of the block's inner blocks is selected. 6436 * 6437 * @param {Object} state Editor state. 6438 * @param {string} clientId Block client ID. 6439 * @param {boolean} deep Perform a deep check. 6440 * 6441 * @return {boolean} Whether the block as an inner block selected 6442 */ 6443 6444 function hasSelectedInnerBlock(state, clientId) { 6445 let deep = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; 6446 return (0,external_lodash_namespaceObject.some)(getBlockOrder(state, clientId), innerClientId => isBlockSelected(state, innerClientId) || isBlockMultiSelected(state, innerClientId) || deep && hasSelectedInnerBlock(state, innerClientId, deep)); 6447 } 6448 /** 6449 * Returns true if the block corresponding to the specified client ID is 6450 * currently selected but isn't the last of the selected blocks. Here "last" 6451 * refers to the block sequence in the document, _not_ the sequence of 6452 * multi-selection, which is why `state.selectionEnd` isn't used. 6453 * 6454 * @param {Object} state Editor state. 6455 * @param {string} clientId Block client ID. 6456 * 6457 * @return {boolean} Whether block is selected and not the last in the 6458 * selection. 6459 */ 6460 6461 function isBlockWithinSelection(state, clientId) { 6462 if (!clientId) { 6463 return false; 6464 } 6465 6466 const clientIds = getMultiSelectedBlockClientIds(state); 6467 const index = clientIds.indexOf(clientId); 6468 return index > -1 && index < clientIds.length - 1; 6469 } 6470 /** 6471 * Returns true if a multi-selection has been made, or false otherwise. 6472 * 6473 * @param {Object} state Editor state. 6474 * 6475 * @return {boolean} Whether multi-selection has been made. 6476 */ 6477 6478 function hasMultiSelection(state) { 6479 const { 6480 selectionStart, 6481 selectionEnd 6482 } = state.selection; 6483 return selectionStart.clientId !== selectionEnd.clientId; 6484 } 6485 /** 6486 * Whether in the process of multi-selecting or not. This flag is only true 6487 * while the multi-selection is being selected (by mouse move), and is false 6488 * once the multi-selection has been settled. 6489 * 6490 * @see hasMultiSelection 6491 * 6492 * @param {Object} state Global application state. 6493 * 6494 * @return {boolean} True if multi-selecting, false if not. 6495 */ 6496 6497 function selectors_isMultiSelecting(state) { 6498 return state.isMultiSelecting; 6499 } 6500 /** 6501 * Selector that returns if multi-selection is enabled or not. 6502 * 6503 * @param {Object} state Global application state. 6504 * 6505 * @return {boolean} True if it should be possible to multi-select blocks, false if multi-selection is disabled. 6506 */ 6507 6508 function selectors_isSelectionEnabled(state) { 6509 return state.isSelectionEnabled; 6510 } 6511 /** 6512 * Returns the block's editing mode, defaulting to "visual" if not explicitly 6513 * assigned. 6514 * 6515 * @param {Object} state Editor state. 6516 * @param {string} clientId Block client ID. 6517 * 6518 * @return {Object} Block editing mode. 6519 */ 6520 6521 function getBlockMode(state, clientId) { 6522 return state.blocksMode[clientId] || 'visual'; 6523 } 6524 /** 6525 * Returns true if the user is typing, or false otherwise. 6526 * 6527 * @param {Object} state Global application state. 6528 * 6529 * @return {boolean} Whether user is typing. 6530 */ 6531 6532 function selectors_isTyping(state) { 6533 return state.isTyping; 6534 } 6535 /** 6536 * Returns true if the user is dragging blocks, or false otherwise. 6537 * 6538 * @param {Object} state Global application state. 6539 * 6540 * @return {boolean} Whether user is dragging blocks. 6541 */ 6542 6543 function isDraggingBlocks(state) { 6544 return !!state.draggedBlocks.length; 6545 } 6546 /** 6547 * Returns the client ids of any blocks being directly dragged. 6548 * 6549 * This does not include children of a parent being dragged. 6550 * 6551 * @param {Object} state Global application state. 6552 * 6553 * @return {string[]} Array of dragged block client ids. 6554 */ 6555 6556 function getDraggedBlockClientIds(state) { 6557 return state.draggedBlocks; 6558 } 6559 /** 6560 * Returns whether the block is being dragged. 6561 * 6562 * Only returns true if the block is being directly dragged, 6563 * not if the block is a child of a parent being dragged. 6564 * See `isAncestorBeingDragged` for child blocks. 6565 * 6566 * @param {Object} state Global application state. 6567 * @param {string} clientId Client id for block to check. 6568 * 6569 * @return {boolean} Whether the block is being dragged. 6570 */ 6571 6572 function isBlockBeingDragged(state, clientId) { 6573 return state.draggedBlocks.includes(clientId); 6574 } 6575 /** 6576 * Returns whether a parent/ancestor of the block is being dragged. 6577 * 6578 * @param {Object} state Global application state. 6579 * @param {string} clientId Client id for block to check. 6580 * 6581 * @return {boolean} Whether the block's ancestor is being dragged. 6582 */ 6583 6584 function isAncestorBeingDragged(state, clientId) { 6585 // Return early if no blocks are being dragged rather than 6586 // the more expensive check for parents. 6587 if (!isDraggingBlocks(state)) { 6588 return false; 6589 } 6590 6591 const parents = getBlockParents(state, clientId); 6592 return (0,external_lodash_namespaceObject.some)(parents, parentClientId => isBlockBeingDragged(state, parentClientId)); 6593 } 6594 /** 6595 * Returns true if the caret is within formatted text, or false otherwise. 6596 * 6597 * @param {Object} state Global application state. 6598 * 6599 * @return {boolean} Whether the caret is within formatted text. 6600 */ 6601 6602 function selectors_isCaretWithinFormattedText(state) { 6603 return state.isCaretWithinFormattedText; 6604 } 6605 /** 6606 * Returns the insertion point, the index at which the new inserted block would 6607 * be placed. Defaults to the last index. 6608 * 6609 * @param {Object} state Editor state. 6610 * 6611 * @return {Object} Insertion point object with `rootClientId`, `index`. 6612 */ 6613 6614 function getBlockInsertionPoint(state) { 6615 let rootClientId, index; 6616 const { 6617 insertionPoint, 6618 selection: { 6619 selectionEnd 6620 } 6621 } = state; 6622 6623 if (insertionPoint !== null) { 6624 return insertionPoint; 6625 } 6626 6627 const { 6628 clientId 6629 } = selectionEnd; 6630 6631 if (clientId) { 6632 rootClientId = getBlockRootClientId(state, clientId) || undefined; 6633 index = getBlockIndex(state, selectionEnd.clientId, rootClientId) + 1; 6634 } else { 6635 index = getBlockOrder(state).length; 6636 } 6637 6638 return { 6639 rootClientId, 6640 index 6641 }; 6642 } 6643 /** 6644 * Returns true if we should show the block insertion point. 6645 * 6646 * @param {Object} state Global application state. 6647 * 6648 * @return {?boolean} Whether the insertion point is visible or not. 6649 */ 6650 6651 function isBlockInsertionPointVisible(state) { 6652 return state.insertionPoint !== null; 6653 } 6654 /** 6655 * Returns whether the blocks matches the template or not. 6656 * 6657 * @param {boolean} state 6658 * @return {?boolean} Whether the template is valid or not. 6659 */ 6660 6661 function isValidTemplate(state) { 6662 return state.template.isValid; 6663 } 6664 /** 6665 * Returns the defined block template 6666 * 6667 * @param {boolean} state 6668 * 6669 * @return {?Array} Block Template. 6670 */ 6671 6672 function getTemplate(state) { 6673 return state.settings.template; 6674 } 6675 /** 6676 * Returns the defined block template lock. Optionally accepts a root block 6677 * client ID as context, otherwise defaulting to the global context. 6678 * 6679 * @param {Object} state Editor state. 6680 * @param {?string} rootClientId Optional block root client ID. 6681 * 6682 * @return {?string} Block Template Lock 6683 */ 6684 6685 function getTemplateLock(state, rootClientId) { 6686 if (!rootClientId) { 6687 return state.settings.templateLock; 6688 } 6689 6690 const blockListSettings = getBlockListSettings(state, rootClientId); 6691 6692 if (!blockListSettings) { 6693 return null; 6694 } 6695 6696 return blockListSettings.templateLock; 6697 } 6698 6699 const checkAllowList = function (list, item) { 6700 let defaultResult = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null; 6701 6702 if ((0,external_lodash_namespaceObject.isBoolean)(list)) { 6703 return list; 6704 } 6705 6706 if ((0,external_lodash_namespaceObject.isArray)(list)) { 6707 // TODO: when there is a canonical way to detect that we are editing a post 6708 // the following check should be changed to something like: 6709 // if ( list.includes( 'core/post-content' ) && getEditorMode() === 'post-content' && item === null ) 6710 if (list.includes('core/post-content') && item === null) { 6711 return true; 6712 } 6713 6714 return list.includes(item); 6715 } 6716 6717 return defaultResult; 6718 }; 6719 /** 6720 * Determines if the given block type is allowed to be inserted into the block list. 6721 * This function is not exported and not memoized because using a memoized selector 6722 * inside another memoized selector is just a waste of time. 6723 * 6724 * @param {Object} state Editor state. 6725 * @param {string|Object} blockName The block type object, e.g., the response 6726 * from the block directory; or a string name of 6727 * an installed block type, e.g.' core/paragraph'. 6728 * @param {?string} rootClientId Optional root client ID of block list. 6729 * 6730 * @return {boolean} Whether the given block type is allowed to be inserted. 6731 */ 6732 6733 6734 const canInsertBlockTypeUnmemoized = function (state, blockName) { 6735 let rootClientId = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null; 6736 let blockType; 6737 6738 if (blockName && 'object' === typeof blockName) { 6739 blockType = blockName; 6740 blockName = blockType.name; 6741 } else { 6742 blockType = (0,external_wp_blocks_namespaceObject.getBlockType)(blockName); 6743 } 6744 6745 if (!blockType) { 6746 return false; 6747 } 6748 6749 const { 6750 allowedBlockTypes 6751 } = getSettings(state); 6752 const isBlockAllowedInEditor = checkAllowList(allowedBlockTypes, blockName, true); 6753 6754 if (!isBlockAllowedInEditor) { 6755 return false; 6756 } 6757 6758 const isLocked = !!getTemplateLock(state, rootClientId); 6759 6760 if (isLocked) { 6761 return false; 6762 } 6763 6764 const parentBlockListSettings = getBlockListSettings(state, rootClientId); // The parent block doesn't have settings indicating it doesn't support 6765 // inner blocks, return false. 6766 6767 if (rootClientId && parentBlockListSettings === undefined) { 6768 return false; 6769 } 6770 6771 const parentAllowedBlocks = parentBlockListSettings === null || parentBlockListSettings === void 0 ? void 0 : parentBlockListSettings.allowedBlocks; 6772 const hasParentAllowedBlock = checkAllowList(parentAllowedBlocks, blockName); 6773 const blockAllowedParentBlocks = blockType.parent; 6774 const parentName = getBlockName(state, rootClientId); 6775 const hasBlockAllowedParent = checkAllowList(blockAllowedParentBlocks, parentName); 6776 let hasBlockAllowedAncestor = true; 6777 const blockAllowedAncestorBlocks = blockType.ancestor; 6778 6779 if (blockAllowedAncestorBlocks) { 6780 const ancestors = [rootClientId, ...getBlockParents(state, rootClientId)]; 6781 hasBlockAllowedAncestor = (0,external_lodash_namespaceObject.some)(ancestors, ancestorClientId => checkAllowList(blockAllowedAncestorBlocks, getBlockName(state, ancestorClientId))); 6782 } 6783 6784 const canInsert = hasBlockAllowedAncestor && (hasParentAllowedBlock === null && hasBlockAllowedParent === null || hasParentAllowedBlock === true || hasBlockAllowedParent === true); 6785 6786 if (!canInsert) { 6787 return canInsert; 6788 } 6789 /** 6790 * This filter is an ad-hoc solution to prevent adding template parts inside post content. 6791 * Conceptually, having a filter inside a selector is bad pattern so this code will be 6792 * replaced by a declarative API that doesn't the following drawbacks: 6793 * 6794 * Filters are not reactive: Upon switching between "template mode" and non "template mode", 6795 * the filter and selector won't necessarily be executed again. For now, it doesn't matter much 6796 * because you can't switch between the two modes while the inserter stays open. 6797 * 6798 * Filters are global: Once they're defined, they will affect all editor instances and all registries. 6799 * An ideal API would only affect specific editor instances. 6800 */ 6801 6802 6803 return (0,external_wp_hooks_namespaceObject.applyFilters)('blockEditor.__unstableCanInsertBlockType', canInsert, blockType, rootClientId, { 6804 // Pass bound selectors of the current registry. If we're in a nested 6805 // context, the data will differ from the one selected from the root 6806 // registry. 6807 getBlock: getBlock.bind(null, state), 6808 getBlockParentsByBlockName: getBlockParentsByBlockName.bind(null, state) 6809 }); 6810 }; 6811 /** 6812 * Determines if the given block type is allowed to be inserted into the block list. 6813 * 6814 * @param {Object} state Editor state. 6815 * @param {string} blockName The name of the block type, e.g.' core/paragraph'. 6816 * @param {?string} rootClientId Optional root client ID of block list. 6817 * 6818 * @return {boolean} Whether the given block type is allowed to be inserted. 6819 */ 6820 6821 6822 const canInsertBlockType = rememo(canInsertBlockTypeUnmemoized, (state, blockName, rootClientId) => [state.blockListSettings[rootClientId], state.blocks.byClientId[rootClientId], state.settings.allowedBlockTypes, state.settings.templateLock]); 6823 /** 6824 * Determines if the given blocks are allowed to be inserted into the block 6825 * list. 6826 * 6827 * @param {Object} state Editor state. 6828 * @param {string} clientIds The block client IDs to be inserted. 6829 * @param {?string} rootClientId Optional root client ID of block list. 6830 * 6831 * @return {boolean} Whether the given blocks are allowed to be inserted. 6832 */ 6833 6834 function canInsertBlocks(state, clientIds) { 6835 let rootClientId = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null; 6836 return clientIds.every(id => canInsertBlockType(state, getBlockName(state, id), rootClientId)); 6837 } 6838 /** 6839 * Determines if the given block is allowed to be deleted. 6840 * 6841 * @param {Object} state Editor state. 6842 * @param {string} clientId The block client Id. 6843 * @param {?string} rootClientId Optional root client ID of block list. 6844 * 6845 * @return {boolean} Whether the given block is allowed to be removed. 6846 */ 6847 6848 function canRemoveBlock(state, clientId) { 6849 let rootClientId = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null; 6850 const attributes = getBlockAttributes(state, clientId); // attributes can be null if the block is already deleted. 6851 6852 if (attributes === null) { 6853 return true; 6854 } 6855 6856 const { 6857 lock 6858 } = attributes; 6859 const parentIsLocked = !!getTemplateLock(state, rootClientId); // If we don't have a lock on the blockType level, we defer to the parent templateLock. 6860 6861 if (lock === undefined || (lock === null || lock === void 0 ? void 0 : lock.remove) === undefined) { 6862 return !parentIsLocked; 6863 } // When remove is true, it means we cannot remove it. 6864 6865 6866 return !(lock !== null && lock !== void 0 && lock.remove); 6867 } 6868 /** 6869 * Determines if the given blocks are allowed to be removed. 6870 * 6871 * @param {Object} state Editor state. 6872 * @param {string} clientIds The block client IDs to be removed. 6873 * @param {?string} rootClientId Optional root client ID of block list. 6874 * 6875 * @return {boolean} Whether the given blocks are allowed to be removed. 6876 */ 6877 6878 function canRemoveBlocks(state, clientIds) { 6879 let rootClientId = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null; 6880 return clientIds.every(clientId => canRemoveBlock(state, clientId, rootClientId)); 6881 } 6882 /** 6883 * Determines if the given block is allowed to be moved. 6884 * 6885 * @param {Object} state Editor state. 6886 * @param {string} clientId The block client Id. 6887 * @param {?string} rootClientId Optional root client ID of block list. 6888 * 6889 * @return {boolean} Whether the given block is allowed to be moved. 6890 */ 6891 6892 function canMoveBlock(state, clientId) { 6893 let rootClientId = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null; 6894 const attributes = getBlockAttributes(state, clientId); 6895 6896 if (attributes === null) { 6897 return; 6898 } 6899 6900 const { 6901 lock 6902 } = attributes; 6903 const parentIsLocked = getTemplateLock(state, rootClientId) === 'all'; // If we don't have a lock on the blockType level, we defer to the parent templateLock. 6904 6905 if (lock === undefined || (lock === null || lock === void 0 ? void 0 : lock.move) === undefined) { 6906 return !parentIsLocked; 6907 } // When move is true, it means we cannot move it. 6908 6909 6910 return !(lock !== null && lock !== void 0 && lock.move); 6911 } 6912 /** 6913 * Determines if the given blocks are allowed to be moved. 6914 * 6915 * @param {Object} state Editor state. 6916 * @param {string} clientIds The block client IDs to be moved. 6917 * @param {?string} rootClientId Optional root client ID of block list. 6918 * 6919 * @return {boolean} Whether the given blocks are allowed to be moved. 6920 */ 6921 6922 function canMoveBlocks(state, clientIds) { 6923 let rootClientId = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null; 6924 return clientIds.every(clientId => canMoveBlock(state, clientId, rootClientId)); 6925 } 6926 /** 6927 * Determines if the given block type can be locked/unlocked by a user. 6928 * 6929 * @param {Object} state Editor state. 6930 * @param {(string|Object)} nameOrType Block name or type object. 6931 * 6932 * @return {boolean} Whether a given block type can be locked/unlocked. 6933 */ 6934 6935 function canLockBlockType(state, nameOrType) { 6936 var _state$settings; 6937 6938 if (!(0,external_wp_blocks_namespaceObject.hasBlockSupport)(nameOrType, 'lock', true)) { 6939 return false; 6940 } // Use block editor settings as the default value. 6941 6942 6943 return !!((_state$settings = state.settings) !== null && _state$settings !== void 0 && _state$settings.canLockBlocks); 6944 } 6945 /** 6946 * Returns information about how recently and frequently a block has been inserted. 6947 * 6948 * @param {Object} state Global application state. 6949 * @param {string} id A string which identifies the insert, e.g. 'core/block/12' 6950 * 6951 * @return {?{ time: number, count: number }} An object containing `time` which is when the last 6952 * insert occurred as a UNIX epoch, and `count` which is 6953 * the number of inserts that have occurred. 6954 */ 6955 6956 function getInsertUsage(state, id) { 6957 var _state$preferences$in, _state$preferences$in2; 6958 6959 return (_state$preferences$in = (_state$preferences$in2 = state.preferences.insertUsage) === null || _state$preferences$in2 === void 0 ? void 0 : _state$preferences$in2[id]) !== null && _state$preferences$in !== void 0 ? _state$preferences$in : null; 6960 } 6961 /** 6962 * Returns whether we can show a block type in the inserter 6963 * 6964 * @param {Object} state Global State 6965 * @param {Object} blockType BlockType 6966 * @param {?string} rootClientId Optional root client ID of block list. 6967 * 6968 * @return {boolean} Whether the given block type is allowed to be shown in the inserter. 6969 */ 6970 6971 6972 const canIncludeBlockTypeInInserter = (state, blockType, rootClientId) => { 6973 if (!(0,external_wp_blocks_namespaceObject.hasBlockSupport)(blockType, 'inserter', true)) { 6974 return false; 6975 } 6976 6977 return canInsertBlockTypeUnmemoized(state, blockType.name, rootClientId); 6978 }; 6979 /** 6980 * Return a function to be used to tranform a block variation to an inserter item 6981 * 6982 * @param {Object} state Global State 6983 * @param {Object} item Denormalized inserter item 6984 * @return {Function} Function to transform a block variation to inserter item 6985 */ 6986 6987 6988 const getItemFromVariation = (state, item) => variation => { 6989 const variationId = `$item.id}/$variation.name}`; 6990 const { 6991 time, 6992 count = 0 6993 } = getInsertUsage(state, variationId) || {}; 6994 return { ...item, 6995 id: variationId, 6996 icon: variation.icon || item.icon, 6997 title: variation.title || item.title, 6998 description: variation.description || item.description, 6999 category: variation.category || item.category, 7000 // If `example` is explicitly undefined for the variation, the preview will not be shown. 7001 example: variation.hasOwnProperty('example') ? variation.example : item.example, 7002 initialAttributes: { ...item.initialAttributes, 7003 ...variation.attributes 7004 }, 7005 innerBlocks: variation.innerBlocks, 7006 keywords: variation.keywords || item.keywords, 7007 frecency: calculateFrecency(time, count) 7008 }; 7009 }; 7010 /** 7011 * Returns the calculated frecency. 7012 * 7013 * 'frecency' is a heuristic (https://en.wikipedia.org/wiki/Frecency) 7014 * that combines block usage frequenty and recency. 7015 * 7016 * @param {number} time When the last insert occurred as a UNIX epoch 7017 * @param {number} count The number of inserts that have occurred. 7018 * 7019 * @return {number} The calculated frecency. 7020 */ 7021 7022 7023 const calculateFrecency = (time, count) => { 7024 if (!time) { 7025 return count; 7026 } // The selector is cached, which means Date.now() is the last time that the 7027 // relevant state changed. This suits our needs. 7028 7029 7030 const duration = Date.now() - time; 7031 7032 switch (true) { 7033 case duration < MILLISECONDS_PER_HOUR: 7034 return count * 4; 7035 7036 case duration < MILLISECONDS_PER_DAY: 7037 return count * 2; 7038 7039 case duration < MILLISECONDS_PER_WEEK: 7040 return count / 2; 7041 7042 default: 7043 return count / 4; 7044 } 7045 }; 7046 /** 7047 * Returns a function that accepts a block type and builds an item to be shown 7048 * in a specific context. It's used for building items for Inserter and available 7049 * block Transfroms list. 7050 * 7051 * @param {Object} state Editor state. 7052 * @param {Object} options Options object for handling the building of a block type. 7053 * @param {string} options.buildScope The scope for which the item is going to be used. 7054 * @return {Function} Function returns an item to be shown in a specific context (Inserter|Transforms list). 7055 */ 7056 7057 7058 const buildBlockTypeItem = (state, _ref3) => { 7059 let { 7060 buildScope = 'inserter' 7061 } = _ref3; 7062 return blockType => { 7063 const id = blockType.name; 7064 let isDisabled = false; 7065 7066 if (!(0,external_wp_blocks_namespaceObject.hasBlockSupport)(blockType.name, 'multiple', true)) { 7067 isDisabled = (0,external_lodash_namespaceObject.some)(getBlocksByClientId(state, getClientIdsWithDescendants(state)), { 7068 name: blockType.name 7069 }); 7070 } 7071 7072 const { 7073 time, 7074 count = 0 7075 } = getInsertUsage(state, id) || {}; 7076 const blockItemBase = { 7077 id, 7078 name: blockType.name, 7079 title: blockType.title, 7080 icon: blockType.icon, 7081 isDisabled, 7082 frecency: calculateFrecency(time, count) 7083 }; 7084 if (buildScope === 'transform') return blockItemBase; 7085 const inserterVariations = (0,external_wp_blocks_namespaceObject.getBlockVariations)(blockType.name, 'inserter'); 7086 return { ...blockItemBase, 7087 initialAttributes: {}, 7088 description: blockType.description, 7089 category: blockType.category, 7090 keywords: blockType.keywords, 7091 variations: inserterVariations, 7092 example: blockType.example, 7093 utility: 1 // Deprecated. 7094 7095 }; 7096 }; 7097 }; 7098 /** 7099 * Determines the items that appear in the inserter. Includes both static 7100 * items (e.g. a regular block type) and dynamic items (e.g. a reusable block). 7101 * 7102 * Each item object contains what's necessary to display a button in the 7103 * inserter and handle its selection. 7104 * 7105 * The 'frecency' property is a heuristic (https://en.wikipedia.org/wiki/Frecency) 7106 * that combines block usage frequenty and recency. 7107 * 7108 * Items are returned ordered descendingly by their 'utility' and 'frecency'. 7109 * 7110 * @param {Object} state Editor state. 7111 * @param {?string} rootClientId Optional root client ID of block list. 7112 * 7113 * @return {WPEditorInserterItem[]} Items that appear in inserter. 7114 * 7115 * @typedef {Object} WPEditorInserterItem 7116 * @property {string} id Unique identifier for the item. 7117 * @property {string} name The type of block to create. 7118 * @property {Object} initialAttributes Attributes to pass to the newly created block. 7119 * @property {string} title Title of the item, as it appears in the inserter. 7120 * @property {string} icon Dashicon for the item, as it appears in the inserter. 7121 * @property {string} category Block category that the item is associated with. 7122 * @property {string[]} keywords Keywords that can be searched to find this item. 7123 * @property {boolean} isDisabled Whether or not the user should be prevented from inserting 7124 * this item. 7125 * @property {number} frecency Heuristic that combines frequency and recency. 7126 */ 7127 7128 7129 const getInserterItems = rememo(function (state) { 7130 let rootClientId = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null; 7131 const buildBlockTypeInserterItem = buildBlockTypeItem(state, { 7132 buildScope: 'inserter' 7133 }); 7134 /* 7135 * Matches block comment delimiters amid serialized content. 7136 * 7137 * @see `tokenizer` in `@wordpress/block-serialization-default-parser` 7138 * package 7139 * 7140 * blockParserTokenizer differs from the original tokenizer in the 7141 * following ways: 7142 * 7143 * - removed global flag (/g) 7144 * - prepended ^\s* 7145 * 7146 */ 7147 7148 const blockParserTokenizer = /^\s*<!--\s+(\/)?wp:([a-z][a-z0-9_-]*\/)?([a-z][a-z0-9_-]*)\s+({(?:(?=([^}]+|}+(?=})|(?!}\s+\/?-->)[^])*)\5|[^]*?)}\s+)?(\/)?-->/; 7149 7150 const buildReusableBlockInserterItem = reusableBlock => { 7151 let icon = library_symbol; 7152 /* 7153 * Instead of always displaying a generic "symbol" icon for every 7154 * reusable block, try to use an icon that represents the first 7155 * outermost block contained in the reusable block. This requires 7156 * scanning the serialized form of the reusable block to find its 7157 * first block delimiter, then looking up the corresponding block 7158 * type, if available. 7159 */ 7160 7161 if (external_wp_element_namespaceObject.Platform.OS === 'web') { 7162 const content = typeof reusableBlock.content.raw === 'string' ? reusableBlock.content.raw : reusableBlock.content; 7163 const rawBlockMatch = content.match(blockParserTokenizer); 7164 7165 if (rawBlockMatch) { 7166 const [,, namespace = 'core/', blockName] = rawBlockMatch; 7167 const referencedBlockType = (0,external_wp_blocks_namespaceObject.getBlockType)(namespace + blockName); 7168 7169 if (referencedBlockType) { 7170 icon = referencedBlockType.icon; 7171 } 7172 } 7173 } 7174 7175 const id = `core/block/$reusableBlock.id}`; 7176 const { 7177 time, 7178 count = 0 7179 } = getInsertUsage(state, id) || {}; 7180 const frecency = calculateFrecency(time, count); 7181 return { 7182 id, 7183 name: 'core/block', 7184 initialAttributes: { 7185 ref: reusableBlock.id 7186 }, 7187 title: reusableBlock.title.raw, 7188 icon, 7189 category: 'reusable', 7190 keywords: [], 7191 isDisabled: false, 7192 utility: 1, 7193 // Deprecated. 7194 frecency 7195 }; 7196 }; 7197 7198 const blockTypeInserterItems = (0,external_wp_blocks_namespaceObject.getBlockTypes)().filter(blockType => canIncludeBlockTypeInInserter(state, blockType, rootClientId)).map(buildBlockTypeInserterItem); 7199 const reusableBlockInserterItems = canInsertBlockTypeUnmemoized(state, 'core/block', rootClientId) ? getReusableBlocks(state).map(buildReusableBlockInserterItem) : []; 7200 const items = blockTypeInserterItems.reduce((accumulator, item) => { 7201 const { 7202 variations = [] 7203 } = item; // Exclude any block type item that is to be replaced by a default variation. 7204 7205 if (!variations.some(_ref4 => { 7206 let { 7207 isDefault 7208 } = _ref4; 7209 return isDefault; 7210 })) { 7211 accumulator.push(item); 7212 } 7213 7214 if (variations.length) { 7215 const variationMapper = getItemFromVariation(state, item); 7216 accumulator.push(...variations.map(variationMapper)); 7217 } 7218 7219 return accumulator; 7220 }, []); // Ensure core blocks are prioritized in the returned results, 7221 // because third party blocks can be registered earlier than 7222 // the core blocks (usually by using the `init` action), 7223 // thus affecting the display order. 7224 // We don't sort reusable blocks as they are handled differently. 7225 7226 const groupByType = (blocks, block) => { 7227 const { 7228 core, 7229 noncore 7230 } = blocks; 7231 const type = block.name.startsWith('core/') ? core : noncore; 7232 type.push(block); 7233 return blocks; 7234 }; 7235 7236 const { 7237 core: coreItems, 7238 noncore: nonCoreItems 7239 } = items.reduce(groupByType, { 7240 core: [], 7241 noncore: [] 7242 }); 7243 const sortedBlockTypes = [...coreItems, ...nonCoreItems]; 7244 return [...sortedBlockTypes, ...reusableBlockInserterItems]; 7245 }, (state, rootClientId) => [state.blockListSettings[rootClientId], state.blocks.byClientId, state.blocks.order, state.preferences.insertUsage, state.settings.allowedBlockTypes, state.settings.templateLock, getReusableBlocks(state), (0,external_wp_blocks_namespaceObject.getBlockTypes)()]); 7246 /** 7247 * Determines the items that appear in the available block transforms list. 7248 * 7249 * Each item object contains what's necessary to display a menu item in the 7250 * transform list and handle its selection. 7251 * 7252 * The 'frecency' property is a heuristic (https://en.wikipedia.org/wiki/Frecency) 7253 * that combines block usage frequenty and recency. 7254 * 7255 * Items are returned ordered descendingly by their 'frecency'. 7256 * 7257 * @param {Object} state Editor state. 7258 * @param {?string} rootClientId Optional root client ID of block list. 7259 * 7260 * @return {WPEditorTransformItem[]} Items that appear in inserter. 7261 * 7262 * @typedef {Object} WPEditorTransformItem 7263 * @property {string} id Unique identifier for the item. 7264 * @property {string} name The type of block to create. 7265 * @property {string} title Title of the item, as it appears in the inserter. 7266 * @property {string} icon Dashicon for the item, as it appears in the inserter. 7267 * @property {boolean} isDisabled Whether or not the user should be prevented from inserting 7268 * this item. 7269 * @property {number} frecency Heuristic that combines frequency and recency. 7270 */ 7271 7272 const getBlockTransformItems = rememo(function (state, blocks) { 7273 var _itemsByName$sourceBl; 7274 7275 let rootClientId = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null; 7276 const [sourceBlock] = blocks; 7277 const buildBlockTypeTransformItem = buildBlockTypeItem(state, { 7278 buildScope: 'transform' 7279 }); 7280 const blockTypeTransformItems = (0,external_wp_blocks_namespaceObject.getBlockTypes)().filter(blockType => canIncludeBlockTypeInInserter(state, blockType, rootClientId)).map(buildBlockTypeTransformItem); 7281 const itemsByName = (0,external_lodash_namespaceObject.mapKeys)(blockTypeTransformItems, _ref5 => { 7282 let { 7283 name 7284 } = _ref5; 7285 return name; 7286 }); // Consider unwraping the highest priority. 7287 7288 itemsByName['*'] = { 7289 frecency: +Infinity, 7290 id: '*', 7291 isDisabled: false, 7292 name: '*', 7293 title: (0,external_wp_i18n_namespaceObject.__)('Unwrap'), 7294 icon: (_itemsByName$sourceBl = itemsByName[sourceBlock.name]) === null || _itemsByName$sourceBl === void 0 ? void 0 : _itemsByName$sourceBl.icon 7295 }; 7296 const possibleTransforms = (0,external_wp_blocks_namespaceObject.getPossibleBlockTransformations)(blocks).reduce((accumulator, block) => { 7297 if (block === '*') { 7298 accumulator.push(itemsByName['*']); 7299 } else if (itemsByName[block === null || block === void 0 ? void 0 : block.name]) { 7300 accumulator.push(itemsByName[block.name]); 7301 } 7302 7303 return accumulator; 7304 }, []); 7305 return (0,external_lodash_namespaceObject.orderBy)(possibleTransforms, block => itemsByName[block.name].frecency, 'desc'); 7306 }, (state, rootClientId) => [state.blockListSettings[rootClientId], state.blocks.byClientId, state.preferences.insertUsage, state.settings.allowedBlockTypes, state.settings.templateLock, (0,external_wp_blocks_namespaceObject.getBlockTypes)()]); 7307 /** 7308 * Determines whether there are items to show in the inserter. 7309 * 7310 * @param {Object} state Editor state. 7311 * @param {?string} rootClientId Optional root client ID of block list. 7312 * 7313 * @return {boolean} Items that appear in inserter. 7314 */ 7315 7316 const hasInserterItems = rememo(function (state) { 7317 let rootClientId = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null; 7318 const hasBlockType = (0,external_lodash_namespaceObject.some)((0,external_wp_blocks_namespaceObject.getBlockTypes)(), blockType => canIncludeBlockTypeInInserter(state, blockType, rootClientId)); 7319 7320 if (hasBlockType) { 7321 return true; 7322 } 7323 7324 const hasReusableBlock = canInsertBlockTypeUnmemoized(state, 'core/block', rootClientId) && getReusableBlocks(state).length > 0; 7325 return hasReusableBlock; 7326 }, (state, rootClientId) => [state.blockListSettings[rootClientId], state.blocks.byClientId, state.settings.allowedBlockTypes, state.settings.templateLock, getReusableBlocks(state), (0,external_wp_blocks_namespaceObject.getBlockTypes)()]); 7327 /** 7328 * Returns the list of allowed inserter blocks for inner blocks children 7329 * 7330 * @param {Object} state Editor state. 7331 * @param {?string} rootClientId Optional root client ID of block list. 7332 * 7333 * @return {Array?} The list of allowed block types. 7334 */ 7335 7336 const __experimentalGetAllowedBlocks = rememo(function (state) { 7337 let rootClientId = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null; 7338 7339 if (!rootClientId) { 7340 return; 7341 } 7342 7343 return (0,external_lodash_namespaceObject.filter)((0,external_wp_blocks_namespaceObject.getBlockTypes)(), blockType => canIncludeBlockTypeInInserter(state, blockType, rootClientId)); 7344 }, (state, rootClientId) => [state.blockListSettings[rootClientId], state.blocks.byClientId, state.settings.allowedBlockTypes, state.settings.templateLock, (0,external_wp_blocks_namespaceObject.getBlockTypes)()]); 7345 /** 7346 * Returns the block to be directly inserted by the block appender. 7347 * 7348 * @param {Object} state Editor state. 7349 * @param {?string} rootClientId Optional root client ID of block list. 7350 * 7351 * @return {?WPDirectInsertBlock} The block type to be directly inserted. 7352 * 7353 * @typedef {Object} WPDirectInsertBlock 7354 * @property {string} name The type of block. 7355 * @property {?Object} attributes Attributes to pass to the newly created block. 7356 * @property {?Array<string>} attributesToCopy Attributes to be copied from adjecent blocks when inserted. 7357 */ 7358 7359 const __experimentalGetDirectInsertBlock = rememo(function (state) { 7360 var _state$blockListSetti, _state$blockListSetti2; 7361 7362 let rootClientId = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null; 7363 7364 if (!rootClientId) { 7365 return; 7366 } 7367 7368 const defaultBlock = (_state$blockListSetti = state.blockListSettings[rootClientId]) === null || _state$blockListSetti === void 0 ? void 0 : _state$blockListSetti.__experimentalDefaultBlock; 7369 const directInsert = (_state$blockListSetti2 = state.blockListSettings[rootClientId]) === null || _state$blockListSetti2 === void 0 ? void 0 : _state$blockListSetti2.__experimentalDirectInsert; 7370 7371 if (!defaultBlock || !directInsert) { 7372 return; 7373 } 7374 7375 if (typeof directInsert === 'function') { 7376 return directInsert(getBlock(state, rootClientId)) ? defaultBlock : null; 7377 } 7378 7379 return defaultBlock; 7380 }, (state, rootClientId) => [state.blockListSettings[rootClientId], state.blocks.tree[rootClientId]]); 7381 7382 const checkAllowListRecursive = (blocks, allowedBlockTypes) => { 7383 if ((0,external_lodash_namespaceObject.isBoolean)(allowedBlockTypes)) { 7384 return allowedBlockTypes; 7385 } 7386 7387 const blocksQueue = [...blocks]; 7388 7389 while (blocksQueue.length > 0) { 7390 var _block$innerBlocks; 7391 7392 const block = blocksQueue.shift(); 7393 const isAllowed = checkAllowList(allowedBlockTypes, block.name || block.blockName, true); 7394 7395 if (!isAllowed) { 7396 return false; 7397 } 7398 7399 (_block$innerBlocks = block.innerBlocks) === null || _block$innerBlocks === void 0 ? void 0 : _block$innerBlocks.forEach(innerBlock => { 7400 blocksQueue.push(innerBlock); 7401 }); 7402 } 7403 7404 return true; 7405 }; 7406 7407 const __experimentalGetParsedPattern = rememo((state, patternName) => { 7408 const patterns = state.settings.__experimentalBlockPatterns; 7409 const pattern = patterns.find(_ref6 => { 7410 let { 7411 name 7412 } = _ref6; 7413 return name === patternName; 7414 }); 7415 7416 if (!pattern) { 7417 return null; 7418 } 7419 7420 return { ...pattern, 7421 blocks: (0,external_wp_blocks_namespaceObject.parse)(pattern.content, { 7422 __unstableSkipMigrationLogs: true 7423 }) 7424 }; 7425 }, state => [state.settings.__experimentalBlockPatterns]); 7426 const getAllAllowedPatterns = rememo(state => { 7427 const patterns = state.settings.__experimentalBlockPatterns; 7428 const { 7429 allowedBlockTypes 7430 } = getSettings(state); 7431 const parsedPatterns = patterns.filter(_ref7 => { 7432 let { 7433 inserter = true 7434 } = _ref7; 7435 return !!inserter; 7436 }).map(_ref8 => { 7437 let { 7438 name 7439 } = _ref8; 7440 return __experimentalGetParsedPattern(state, name); 7441 }); 7442 const allowedPatterns = parsedPatterns.filter(_ref9 => { 7443 let { 7444 blocks 7445 } = _ref9; 7446 return checkAllowListRecursive(blocks, allowedBlockTypes); 7447 }); 7448 return allowedPatterns; 7449 }, state => [state.settings.__experimentalBlockPatterns, state.settings.allowedBlockTypes]); 7450 /** 7451 * Returns the list of allowed patterns for inner blocks children. 7452 * 7453 * @param {Object} state Editor state. 7454 * @param {?string} rootClientId Optional target root client ID. 7455 * 7456 * @return {Array?} The list of allowed patterns. 7457 */ 7458 7459 const __experimentalGetAllowedPatterns = rememo(function (state) { 7460 let rootClientId = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null; 7461 const availableParsedPatterns = getAllAllowedPatterns(state); 7462 const patternsAllowed = (0,external_lodash_namespaceObject.filter)(availableParsedPatterns, _ref10 => { 7463 let { 7464 blocks 7465 } = _ref10; 7466 return blocks.every(_ref11 => { 7467 let { 7468 name 7469 } = _ref11; 7470 return canInsertBlockType(state, name, rootClientId); 7471 }); 7472 }); 7473 return patternsAllowed; 7474 }, (state, rootClientId) => [state.settings.__experimentalBlockPatterns, state.settings.allowedBlockTypes, state.settings.templateLock, state.blockListSettings[rootClientId], state.blocks.byClientId[rootClientId]]); 7475 /** 7476 * Returns the list of patterns based on their declared `blockTypes` 7477 * and a block's name. 7478 * Patterns can use `blockTypes` to integrate in work flows like 7479 * suggesting appropriate patterns in a Placeholder state(during insertion) 7480 * or blocks transformations. 7481 * 7482 * @param {Object} state Editor state. 7483 * @param {string|string[]} blockNames Block's name or array of block names to find matching pattens. 7484 * @param {?string} rootClientId Optional target root client ID. 7485 * 7486 * @return {Array} The list of matched block patterns based on declared `blockTypes` and block name. 7487 */ 7488 7489 const __experimentalGetPatternsByBlockTypes = rememo(function (state, blockNames) { 7490 let rootClientId = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null; 7491 if (!blockNames) return EMPTY_ARRAY; 7492 7493 const patterns = __experimentalGetAllowedPatterns(state, rootClientId); 7494 7495 const normalizedBlockNames = Array.isArray(blockNames) ? blockNames : [blockNames]; 7496 return patterns.filter(pattern => { 7497 var _pattern$blockTypes, _pattern$blockTypes$s; 7498 7499 return pattern === null || pattern === void 0 ? void 0 : (_pattern$blockTypes = pattern.blockTypes) === null || _pattern$blockTypes === void 0 ? void 0 : (_pattern$blockTypes$s = _pattern$blockTypes.some) === null || _pattern$blockTypes$s === void 0 ? void 0 : _pattern$blockTypes$s.call(_pattern$blockTypes, blockName => normalizedBlockNames.includes(blockName)); 7500 }); 7501 }, (state, rootClientId) => [...__experimentalGetAllowedPatterns.getDependants(state, rootClientId)]); 7502 /** 7503 * Determines the items that appear in the available pattern transforms list. 7504 * 7505 * For now we only handle blocks without InnerBlocks and take into account 7506 * the `__experimentalRole` property of blocks' attributes for the transformation. 7507 * 7508 * We return the first set of possible eligible block patterns, 7509 * by checking the `blockTypes` property. We still have to recurse through 7510 * block pattern's blocks and try to find matches from the selected blocks. 7511 * Now this happens in the consumer to avoid heavy operations in the selector. 7512 * 7513 * @param {Object} state Editor state. 7514 * @param {Object[]} blocks The selected blocks. 7515 * @param {?string} rootClientId Optional root client ID of block list. 7516 * 7517 * @return {WPBlockPattern[]} Items that are eligible for a pattern transformation. 7518 */ 7519 7520 const __experimentalGetPatternTransformItems = rememo(function (state, blocks) { 7521 let rootClientId = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null; 7522 if (!blocks) return EMPTY_ARRAY; 7523 /** 7524 * For now we only handle blocks without InnerBlocks and take into account 7525 * the `__experimentalRole` property of blocks' attributes for the transformation. 7526 * Note that the blocks have been retrieved through `getBlock`, which doesn't 7527 * return the inner blocks of an inner block controller, so we still need 7528 * to check for this case too. 7529 */ 7530 7531 if (blocks.some(_ref12 => { 7532 let { 7533 clientId, 7534 innerBlocks 7535 } = _ref12; 7536 return innerBlocks.length || areInnerBlocksControlled(state, clientId); 7537 })) { 7538 return EMPTY_ARRAY; 7539 } // Create a Set of the selected block names that is used in patterns filtering. 7540 7541 7542 const selectedBlockNames = Array.from(new Set(blocks.map(_ref13 => { 7543 let { 7544 name 7545 } = _ref13; 7546 return name; 7547 }))); 7548 /** 7549 * Here we will return first set of possible eligible block patterns, 7550 * by checking the `blockTypes` property. We still have to recurse through 7551 * block pattern's blocks and try to find matches from the selected blocks. 7552 * Now this happens in the consumer to avoid heavy operations in the selector. 7553 */ 7554 7555 return __experimentalGetPatternsByBlockTypes(state, selectedBlockNames, rootClientId); 7556 }, (state, rootClientId) => [...__experimentalGetPatternsByBlockTypes.getDependants(state, rootClientId)]); 7557 /** 7558 * Returns the Block List settings of a block, if any exist. 7559 * 7560 * @param {Object} state Editor state. 7561 * @param {?string} clientId Block client ID. 7562 * 7563 * @return {?Object} Block settings of the block if set. 7564 */ 7565 7566 function getBlockListSettings(state, clientId) { 7567 return state.blockListSettings[clientId]; 7568 } 7569 /** 7570 * Returns the editor settings. 7571 * 7572 * @param {Object} state Editor state. 7573 * 7574 * @return {Object} The editor settings object. 7575 */ 7576 7577 function getSettings(state) { 7578 return state.settings; 7579 } 7580 /** 7581 * Returns true if the most recent block change is be considered persistent, or 7582 * false otherwise. A persistent change is one committed by BlockEditorProvider 7583 * via its `onChange` callback, in addition to `onInput`. 7584 * 7585 * @param {Object} state Block editor state. 7586 * 7587 * @return {boolean} Whether the most recent block change was persistent. 7588 */ 7589 7590 function isLastBlockChangePersistent(state) { 7591 return state.blocks.isPersistentChange; 7592 } 7593 /** 7594 * Returns the block list settings for an array of blocks, if any exist. 7595 * 7596 * @param {Object} state Editor state. 7597 * @param {Array} clientIds Block client IDs. 7598 * 7599 * @return {Object} An object where the keys are client ids and the values are 7600 * a block list setting object. 7601 */ 7602 7603 const __experimentalGetBlockListSettingsForBlocks = rememo(function (state) { 7604 let clientIds = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : []; 7605 return clientIds.reduce((blockListSettingsForBlocks, clientId) => { 7606 if (!state.blockListSettings[clientId]) { 7607 return blockListSettingsForBlocks; 7608 } 7609 7610 return { ...blockListSettingsForBlocks, 7611 [clientId]: state.blockListSettings[clientId] 7612 }; 7613 }, {}); 7614 }, state => [state.blockListSettings]); 7615 /** 7616 * Returns the title of a given reusable block 7617 * 7618 * @param {Object} state Global application state. 7619 * @param {number|string} ref The shared block's ID. 7620 * 7621 * @return {string} The reusable block saved title. 7622 */ 7623 7624 const __experimentalGetReusableBlockTitle = rememo((state, ref) => { 7625 var _reusableBlock$title; 7626 7627 const reusableBlock = (0,external_lodash_namespaceObject.find)(getReusableBlocks(state), block => block.id === ref); 7628 7629 if (!reusableBlock) { 7630 return null; 7631 } 7632 7633 return (_reusableBlock$title = reusableBlock.title) === null || _reusableBlock$title === void 0 ? void 0 : _reusableBlock$title.raw; 7634 }, state => [getReusableBlocks(state)]); 7635 /** 7636 * Returns true if the most recent block change is be considered ignored, or 7637 * false otherwise. An ignored change is one not to be committed by 7638 * BlockEditorProvider, neither via `onChange` nor `onInput`. 7639 * 7640 * @param {Object} state Block editor state. 7641 * 7642 * @return {boolean} Whether the most recent block change was ignored. 7643 */ 7644 7645 function __unstableIsLastBlockChangeIgnored(state) { 7646 // TODO: Removal Plan: Changes incurred by RECEIVE_BLOCKS should not be 7647 // ignored if in-fact they result in a change in blocks state. The current 7648 // need to ignore changes not a result of user interaction should be 7649 // accounted for in the refactoring of reusable blocks as occurring within 7650 // their own separate block editor / state (#7119). 7651 return state.blocks.isIgnoredChange; 7652 } 7653 /** 7654 * Returns the block attributes changed as a result of the last dispatched 7655 * action. 7656 * 7657 * @param {Object} state Block editor state. 7658 * 7659 * @return {Object<string,Object>} Subsets of block attributes changed, keyed 7660 * by block client ID. 7661 */ 7662 7663 function __experimentalGetLastBlockAttributeChanges(state) { 7664 return state.lastBlockAttributesChange; 7665 } 7666 /** 7667 * Returns the available reusable blocks 7668 * 7669 * @param {Object} state Global application state. 7670 * 7671 * @return {Array} Reusable blocks 7672 */ 7673 7674 function getReusableBlocks(state) { 7675 var _state$settings$__exp, _state$settings2; 7676 7677 return (_state$settings$__exp = state === null || state === void 0 ? void 0 : (_state$settings2 = state.settings) === null || _state$settings2 === void 0 ? void 0 : _state$settings2.__experimentalReusableBlocks) !== null && _state$settings$__exp !== void 0 ? _state$settings$__exp : EMPTY_ARRAY; 7678 } 7679 /** 7680 * Returns whether the navigation mode is enabled. 7681 * 7682 * @param {Object} state Editor state. 7683 * 7684 * @return {boolean} Is navigation mode enabled. 7685 */ 7686 7687 7688 function selectors_isNavigationMode(state) { 7689 return state.isNavigationMode; 7690 } 7691 /** 7692 * Returns whether block moving mode is enabled. 7693 * 7694 * @param {Object} state Editor state. 7695 * 7696 * @return {string} Client Id of moving block. 7697 */ 7698 7699 function selectors_hasBlockMovingClientId(state) { 7700 return state.hasBlockMovingClientId; 7701 } 7702 /** 7703 * Returns true if the last change was an automatic change, false otherwise. 7704 * 7705 * @param {Object} state Global application state. 7706 * 7707 * @return {boolean} Whether the last change was automatic. 7708 */ 7709 7710 function didAutomaticChange(state) { 7711 return !!state.automaticChangeStatus; 7712 } 7713 /** 7714 * Returns true if the current highlighted block matches the block clientId. 7715 * 7716 * @param {Object} state Global application state. 7717 * @param {string} clientId The block to check. 7718 * 7719 * @return {boolean} Whether the block is currently highlighted. 7720 */ 7721 7722 function isBlockHighlighted(state, clientId) { 7723 return state.highlightedBlock === clientId; 7724 } 7725 /** 7726 * Checks if a given block has controlled inner blocks. 7727 * 7728 * @param {Object} state Global application state. 7729 * @param {string} clientId The block to check. 7730 * 7731 * @return {boolean} True if the block has controlled inner blocks. 7732 */ 7733 7734 function areInnerBlocksControlled(state, clientId) { 7735 return !!state.blocks.controlledInnerBlocks[clientId]; 7736 } 7737 /** 7738 * Returns the clientId for the first 'active' block of a given array of block names. 7739 * A block is 'active' if it (or a child) is the selected block. 7740 * Returns the first match moving up the DOM from the selected block. 7741 * 7742 * @param {Object} state Global application state. 7743 * @param {string[]} validBlocksNames The names of block types to check for. 7744 * 7745 * @return {string} The matching block's clientId. 7746 */ 7747 7748 const __experimentalGetActiveBlockIdByBlockNames = rememo((state, validBlockNames) => { 7749 if (!validBlockNames.length) { 7750 return null; 7751 } // Check if selected block is a valid entity area. 7752 7753 7754 const selectedBlockClientId = getSelectedBlockClientId(state); 7755 7756 if (validBlockNames.includes(getBlockName(state, selectedBlockClientId))) { 7757 return selectedBlockClientId; 7758 } // Check if first selected block is a child of a valid entity area. 7759 7760 7761 const multiSelectedBlockClientIds = getMultiSelectedBlockClientIds(state); 7762 const entityAreaParents = getBlockParentsByBlockName(state, selectedBlockClientId || multiSelectedBlockClientIds[0], validBlockNames); 7763 7764 if (entityAreaParents) { 7765 // Last parent closest/most interior. 7766 return (0,external_lodash_namespaceObject.last)(entityAreaParents); 7767 } 7768 7769 return null; 7770 }, (state, validBlockNames) => [state.selection.selectionStart.clientId, state.selection.selectionEnd.clientId, validBlockNames]); 7771 /** 7772 * Tells if the block with the passed clientId was just inserted. 7773 * 7774 * @param {Object} state Global application state. 7775 * @param {Object} clientId Client Id of the block. 7776 * @param {?string} source Optional insertion source of the block. 7777 * @return {boolean} True if the block matches the last block inserted from the specified source. 7778 */ 7779 7780 function wasBlockJustInserted(state, clientId, source) { 7781 const { 7782 lastBlockInserted 7783 } = state; 7784 return lastBlockInserted.clientId === clientId && lastBlockInserted.source === source; 7785 } 7786 7787 ;// CONCATENATED MODULE: external ["wp","a11y"] 7788 var external_wp_a11y_namespaceObject = window["wp"]["a11y"]; 7789 ;// CONCATENATED MODULE: external ["wp","deprecated"] 7790 var external_wp_deprecated_namespaceObject = window["wp"]["deprecated"]; 7791 var external_wp_deprecated_default = /*#__PURE__*/__webpack_require__.n(external_wp_deprecated_namespaceObject); 7792 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/store/actions.js 7793 /** 7794 * External dependencies 7795 */ 7796 7797 /** 7798 * WordPress dependencies 7799 */ 7800 7801 7802 7803 7804 7805 7806 /** 7807 * Internal dependencies 7808 */ 7809 7810 7811 /** 7812 * Action which will insert a default block insert action if there 7813 * are no other blocks at the root of the editor. This action should be used 7814 * in actions which may result in no blocks remaining in the editor (removal, 7815 * replacement, etc). 7816 */ 7817 7818 const ensureDefaultBlock = () => _ref => { 7819 let { 7820 select, 7821 dispatch 7822 } = _ref; 7823 // To avoid a focus loss when removing the last block, assure there is 7824 // always a default block if the last of the blocks have been removed. 7825 const count = select.getBlockCount(); 7826 7827 if (count > 0) { 7828 return; 7829 } // If there's an custom appender, don't insert default block. 7830 // We have to remember to manually move the focus elsewhere to 7831 // prevent it from being lost though. 7832 7833 7834 const { 7835 __unstableHasCustomAppender 7836 } = select.getSettings(); 7837 7838 if (__unstableHasCustomAppender) { 7839 return; 7840 } 7841 7842 dispatch.insertDefaultBlock(); 7843 }; 7844 /** 7845 * Action that resets blocks state to the specified array of blocks, taking precedence 7846 * over any other content reflected as an edit in state. 7847 * 7848 * @param {Array} blocks Array of blocks. 7849 */ 7850 7851 7852 const resetBlocks = blocks => _ref2 => { 7853 let { 7854 dispatch 7855 } = _ref2; 7856 dispatch({ 7857 type: 'RESET_BLOCKS', 7858 blocks 7859 }); 7860 dispatch(validateBlocksToTemplate(blocks)); 7861 }; 7862 /** 7863 * Block validity is a function of blocks state (at the point of a 7864 * reset) and the template setting. As a compromise to its placement 7865 * across distinct parts of state, it is implemented here as a side- 7866 * effect of the block reset action. 7867 * 7868 * @param {Array} blocks Array of blocks. 7869 */ 7870 7871 const validateBlocksToTemplate = blocks => _ref3 => { 7872 let { 7873 select, 7874 dispatch 7875 } = _ref3; 7876 const template = select.getTemplate(); 7877 const templateLock = select.getTemplateLock(); // Unlocked templates are considered always valid because they act 7878 // as default values only. 7879 7880 const isBlocksValidToTemplate = !template || templateLock !== 'all' || (0,external_wp_blocks_namespaceObject.doBlocksMatchTemplate)(blocks, template); // Update if validity has changed. 7881 7882 const isValidTemplate = select.isValidTemplate(); 7883 7884 if (isBlocksValidToTemplate !== isValidTemplate) { 7885 dispatch.setTemplateValidity(isBlocksValidToTemplate); 7886 return isBlocksValidToTemplate; 7887 } 7888 }; 7889 /** 7890 * A block selection object. 7891 * 7892 * @typedef {Object} WPBlockSelection 7893 * 7894 * @property {string} clientId A block client ID. 7895 * @property {string} attributeKey A block attribute key. 7896 * @property {number} offset An attribute value offset, based on the rich 7897 * text value. See `wp.richText.create`. 7898 */ 7899 7900 /** 7901 * A selection object. 7902 * 7903 * @typedef {Object} WPSelection 7904 * 7905 * @property {WPBlockSelection} start The selection start. 7906 * @property {WPBlockSelection} end The selection end. 7907 */ 7908 7909 /* eslint-disable jsdoc/valid-types */ 7910 7911 /** 7912 * Returns an action object used in signalling that selection state should be 7913 * reset to the specified selection. 7914 * 7915 * @param {WPBlockSelection} selectionStart The selection start. 7916 * @param {WPBlockSelection} selectionEnd The selection end. 7917 * @param {0|-1|null} initialPosition Initial block position. 7918 * 7919 * @return {Object} Action object. 7920 */ 7921 7922 function resetSelection(selectionStart, selectionEnd, initialPosition) { 7923 /* eslint-enable jsdoc/valid-types */ 7924 return { 7925 type: 'RESET_SELECTION', 7926 selectionStart, 7927 selectionEnd, 7928 initialPosition 7929 }; 7930 } 7931 /** 7932 * Returns an action object used in signalling that blocks have been received. 7933 * Unlike resetBlocks, these should be appended to the existing known set, not 7934 * replacing. 7935 * 7936 * @deprecated 7937 * 7938 * @param {Object[]} blocks Array of block objects. 7939 * 7940 * @return {Object} Action object. 7941 */ 7942 7943 function receiveBlocks(blocks) { 7944 external_wp_deprecated_default()('wp.data.dispatch( "core/block-editor" ).receiveBlocks', { 7945 since: '5.9', 7946 alternative: 'resetBlocks or insertBlocks' 7947 }); 7948 return { 7949 type: 'RECEIVE_BLOCKS', 7950 blocks 7951 }; 7952 } 7953 /** 7954 * Action that updates attributes of multiple blocks with the specified client IDs. 7955 * 7956 * @param {string|string[]} clientIds Block client IDs. 7957 * @param {Object} attributes Block attributes to be merged. Should be keyed by clientIds if 7958 * uniqueByBlock is true. 7959 * @param {boolean} uniqueByBlock true if each block in clientIds array has a unique set of attributes 7960 * @return {Object} Action object. 7961 */ 7962 7963 function updateBlockAttributes(clientIds, attributes) { 7964 let uniqueByBlock = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; 7965 return { 7966 type: 'UPDATE_BLOCK_ATTRIBUTES', 7967 clientIds: (0,external_lodash_namespaceObject.castArray)(clientIds), 7968 attributes, 7969 uniqueByBlock 7970 }; 7971 } 7972 /** 7973 * Action that updates the block with the specified client ID. 7974 * 7975 * @param {string} clientId Block client ID. 7976 * @param {Object} updates Block attributes to be merged. 7977 * 7978 * @return {Object} Action object. 7979 */ 7980 7981 function updateBlock(clientId, updates) { 7982 return { 7983 type: 'UPDATE_BLOCK', 7984 clientId, 7985 updates 7986 }; 7987 } 7988 /* eslint-disable jsdoc/valid-types */ 7989 7990 /** 7991 * Returns an action object used in signalling that the block with the 7992 * specified client ID has been selected, optionally accepting a position 7993 * value reflecting its selection directionality. An initialPosition of -1 7994 * reflects a reverse selection. 7995 * 7996 * @param {string} clientId Block client ID. 7997 * @param {0|-1|null} initialPosition Optional initial position. Pass as -1 to 7998 * reflect reverse selection. 7999 * 8000 * @return {Object} Action object. 8001 */ 8002 8003 function selectBlock(clientId) { 8004 let initialPosition = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0; 8005 8006 /* eslint-enable jsdoc/valid-types */ 8007 return { 8008 type: 'SELECT_BLOCK', 8009 initialPosition, 8010 clientId 8011 }; 8012 } 8013 /** 8014 * Yields action objects used in signalling that the block preceding the given 8015 * clientId should be selected. 8016 * 8017 * @param {string} clientId Block client ID. 8018 */ 8019 8020 const selectPreviousBlock = clientId => _ref4 => { 8021 let { 8022 select, 8023 dispatch 8024 } = _ref4; 8025 const previousBlockClientId = select.getPreviousBlockClientId(clientId); 8026 8027 if (previousBlockClientId) { 8028 dispatch.selectBlock(previousBlockClientId, -1); 8029 } 8030 }; 8031 /** 8032 * Yields action objects used in signalling that the block following the given 8033 * clientId should be selected. 8034 * 8035 * @param {string} clientId Block client ID. 8036 */ 8037 8038 const selectNextBlock = clientId => _ref5 => { 8039 let { 8040 select, 8041 dispatch 8042 } = _ref5; 8043 const nextBlockClientId = select.getNextBlockClientId(clientId); 8044 8045 if (nextBlockClientId) { 8046 dispatch.selectBlock(nextBlockClientId); 8047 } 8048 }; 8049 /** 8050 * Action that starts block multi-selection. 8051 * 8052 * @return {Object} Action object. 8053 */ 8054 8055 function startMultiSelect() { 8056 return { 8057 type: 'START_MULTI_SELECT' 8058 }; 8059 } 8060 /** 8061 * Action that stops block multi-selection. 8062 * 8063 * @return {Object} Action object. 8064 */ 8065 8066 function stopMultiSelect() { 8067 return { 8068 type: 'STOP_MULTI_SELECT' 8069 }; 8070 } 8071 /** 8072 * Action that changes block multi-selection. 8073 * 8074 * @param {string} start First block of the multi selection. 8075 * @param {string} end Last block of the multiselection. 8076 * @param {number|null} __experimentalInitialPosition Optional initial position. Pass as null to skip focus within editor canvas. 8077 */ 8078 8079 const multiSelect = function (start, end) { 8080 let __experimentalInitialPosition = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0; 8081 8082 return _ref6 => { 8083 let { 8084 select, 8085 dispatch 8086 } = _ref6; 8087 const startBlockRootClientId = select.getBlockRootClientId(start); 8088 const endBlockRootClientId = select.getBlockRootClientId(end); // Only allow block multi-selections at the same level. 8089 8090 if (startBlockRootClientId !== endBlockRootClientId) { 8091 return; 8092 } 8093 8094 dispatch({ 8095 type: 'MULTI_SELECT', 8096 start, 8097 end, 8098 initialPosition: __experimentalInitialPosition 8099 }); 8100 const blockCount = select.getSelectedBlockCount(); 8101 (0,external_wp_a11y_namespaceObject.speak)((0,external_wp_i18n_namespaceObject.sprintf)( 8102 /* translators: %s: number of selected blocks */ 8103 (0,external_wp_i18n_namespaceObject._n)('%s block selected.', '%s blocks selected.', blockCount), blockCount), 'assertive'); 8104 }; 8105 }; 8106 /** 8107 * Action that clears the block selection. 8108 * 8109 * @return {Object} Action object. 8110 */ 8111 8112 function clearSelectedBlock() { 8113 return { 8114 type: 'CLEAR_SELECTED_BLOCK' 8115 }; 8116 } 8117 /** 8118 * Action that enables or disables block selection. 8119 * 8120 * @param {boolean} [isSelectionEnabled=true] Whether block selection should 8121 * be enabled. 8122 * 8123 * @return {Object} Action object. 8124 */ 8125 8126 function toggleSelection() { 8127 let isSelectionEnabled = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true; 8128 return { 8129 type: 'TOGGLE_SELECTION', 8130 isSelectionEnabled 8131 }; 8132 } 8133 8134 function getBlocksWithDefaultStylesApplied(blocks, blockEditorSettings) { 8135 var _blockEditorSettings$, _blockEditorSettings$2; 8136 8137 const preferredStyleVariations = (_blockEditorSettings$ = blockEditorSettings === null || blockEditorSettings === void 0 ? void 0 : (_blockEditorSettings$2 = blockEditorSettings.__experimentalPreferredStyleVariations) === null || _blockEditorSettings$2 === void 0 ? void 0 : _blockEditorSettings$2.value) !== null && _blockEditorSettings$ !== void 0 ? _blockEditorSettings$ : {}; 8138 return blocks.map(block => { 8139 var _block$attributes; 8140 8141 const blockName = block.name; 8142 8143 if (!(0,external_wp_blocks_namespaceObject.hasBlockSupport)(blockName, 'defaultStylePicker', true)) { 8144 return block; 8145 } 8146 8147 if (!preferredStyleVariations[blockName]) { 8148 return block; 8149 } 8150 8151 const className = (_block$attributes = block.attributes) === null || _block$attributes === void 0 ? void 0 : _block$attributes.className; 8152 8153 if (className !== null && className !== void 0 && className.includes('is-style-')) { 8154 return block; 8155 } 8156 8157 const { 8158 attributes = {} 8159 } = block; 8160 const blockStyle = preferredStyleVariations[blockName]; 8161 return { ...block, 8162 attributes: { ...attributes, 8163 className: `$className || ''} is-style-$blockStyle}`.trim() 8164 } 8165 }; 8166 }); 8167 } 8168 /* eslint-disable jsdoc/valid-types */ 8169 8170 /** 8171 * Action that replaces given blocks with one or more replacement blocks. 8172 * 8173 * @param {(string|string[])} clientIds Block client ID(s) to replace. 8174 * @param {(Object|Object[])} blocks Replacement block(s). 8175 * @param {number} indexToSelect Index of replacement block to select. 8176 * @param {0|-1|null} initialPosition Index of caret after in the selected block after the operation. 8177 * @param {?Object} meta Optional Meta values to be passed to the action object. 8178 * 8179 * @return {Object} Action object. 8180 */ 8181 8182 8183 const replaceBlocks = function (clientIds, blocks, indexToSelect) { 8184 let initialPosition = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 0; 8185 let meta = arguments.length > 4 ? arguments[4] : undefined; 8186 return _ref7 => { 8187 let { 8188 select, 8189 dispatch 8190 } = _ref7; 8191 8192 /* eslint-enable jsdoc/valid-types */ 8193 clientIds = (0,external_lodash_namespaceObject.castArray)(clientIds); 8194 blocks = getBlocksWithDefaultStylesApplied((0,external_lodash_namespaceObject.castArray)(blocks), select.getSettings()); 8195 const rootClientId = select.getBlockRootClientId((0,external_lodash_namespaceObject.first)(clientIds)); // Replace is valid if the new blocks can be inserted in the root block. 8196 8197 for (let index = 0; index < blocks.length; index++) { 8198 const block = blocks[index]; 8199 const canInsertBlock = select.canInsertBlockType(block.name, rootClientId); 8200 8201 if (!canInsertBlock) { 8202 return; 8203 } 8204 } 8205 8206 dispatch({ 8207 type: 'REPLACE_BLOCKS', 8208 clientIds, 8209 blocks, 8210 time: Date.now(), 8211 indexToSelect, 8212 initialPosition, 8213 meta 8214 }); 8215 dispatch(ensureDefaultBlock()); 8216 }; 8217 }; 8218 /** 8219 * Action that replaces a single block with one or more replacement blocks. 8220 * 8221 * @param {(string|string[])} clientId Block client ID to replace. 8222 * @param {(Object|Object[])} block Replacement block(s). 8223 * 8224 * @return {Object} Action object. 8225 */ 8226 8227 function replaceBlock(clientId, block) { 8228 return replaceBlocks(clientId, block); 8229 } 8230 /** 8231 * Higher-order action creator which, given the action type to dispatch creates 8232 * an action creator for managing block movement. 8233 * 8234 * @param {string} type Action type to dispatch. 8235 * 8236 * @return {Function} Action creator. 8237 */ 8238 8239 const createOnMove = type => (clientIds, rootClientId) => _ref8 => { 8240 let { 8241 select, 8242 dispatch 8243 } = _ref8; 8244 // If one of the blocks is locked or the parent is locked, we cannot move any block. 8245 const canMoveBlocks = select.canMoveBlocks(clientIds, rootClientId); 8246 8247 if (!canMoveBlocks) { 8248 return; 8249 } 8250 8251 dispatch({ 8252 type, 8253 clientIds: (0,external_lodash_namespaceObject.castArray)(clientIds), 8254 rootClientId 8255 }); 8256 }; 8257 8258 const moveBlocksDown = createOnMove('MOVE_BLOCKS_DOWN'); 8259 const moveBlocksUp = createOnMove('MOVE_BLOCKS_UP'); 8260 /** 8261 * Action that moves given blocks to a new position. 8262 * 8263 * @param {?string} clientIds The client IDs of the blocks. 8264 * @param {?string} fromRootClientId Root client ID source. 8265 * @param {?string} toRootClientId Root client ID destination. 8266 * @param {number} index The index to move the blocks to. 8267 */ 8268 8269 const moveBlocksToPosition = function (clientIds) { 8270 let fromRootClientId = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : ''; 8271 let toRootClientId = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : ''; 8272 let index = arguments.length > 3 ? arguments[3] : undefined; 8273 return _ref9 => { 8274 let { 8275 select, 8276 dispatch 8277 } = _ref9; 8278 const canMoveBlocks = select.canMoveBlocks(clientIds, fromRootClientId); // If one of the blocks is locked or the parent is locked, we cannot move any block. 8279 8280 if (!canMoveBlocks) { 8281 return; 8282 } // If moving inside the same root block the move is always possible. 8283 8284 8285 if (fromRootClientId !== toRootClientId) { 8286 const canRemoveBlocks = select.canRemoveBlocks(clientIds, fromRootClientId); // If we're moving to another block, it means we're deleting blocks from 8287 // the original block, so we need to check if removing is possible. 8288 8289 if (!canRemoveBlocks) { 8290 return; 8291 } 8292 8293 const canInsertBlocks = select.canInsertBlocks(clientIds, toRootClientId); // If moving to other parent block, the move is possible if we can insert a block of the same type inside the new parent block. 8294 8295 if (!canInsertBlocks) { 8296 return; 8297 } 8298 } 8299 8300 dispatch({ 8301 type: 'MOVE_BLOCKS_TO_POSITION', 8302 fromRootClientId, 8303 toRootClientId, 8304 clientIds, 8305 index 8306 }); 8307 }; 8308 }; 8309 /** 8310 * Action that moves given block to a new position. 8311 * 8312 * @param {?string} clientId The client ID of the block. 8313 * @param {?string} fromRootClientId Root client ID source. 8314 * @param {?string} toRootClientId Root client ID destination. 8315 * @param {number} index The index to move the block to. 8316 */ 8317 8318 function moveBlockToPosition(clientId) { 8319 let fromRootClientId = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : ''; 8320 let toRootClientId = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : ''; 8321 let index = arguments.length > 3 ? arguments[3] : undefined; 8322 return moveBlocksToPosition([clientId], fromRootClientId, toRootClientId, index); 8323 } 8324 /** 8325 * Action that inserts a single block, optionally at a specific index respective a root block list. 8326 * 8327 * @param {Object} block Block object to insert. 8328 * @param {?number} index Index at which block should be inserted. 8329 * @param {?string} rootClientId Optional root client ID of block list on which to insert. 8330 * @param {?boolean} updateSelection If true block selection will be updated. If false, block selection will not change. Defaults to true. 8331 * @param {?Object} meta Optional Meta values to be passed to the action object. 8332 * 8333 * @return {Object} Action object. 8334 */ 8335 8336 function insertBlock(block, index, rootClientId, updateSelection, meta) { 8337 return insertBlocks([block], index, rootClientId, updateSelection, 0, meta); 8338 } 8339 /* eslint-disable jsdoc/valid-types */ 8340 8341 /** 8342 * Action that inserts an array of blocks, optionally at a specific index respective a root block list. 8343 * 8344 * @param {Object[]} blocks Block objects to insert. 8345 * @param {?number} index Index at which block should be inserted. 8346 * @param {?string} rootClientId Optional root client ID of block list on which to insert. 8347 * @param {?boolean} updateSelection If true block selection will be updated. If false, block selection will not change. Defaults to true. 8348 * @param {0|-1|null} initialPosition Initial focus position. Setting it to null prevent focusing the inserted block. 8349 * @param {?Object} meta Optional Meta values to be passed to the action object. 8350 * @return {Object} Action object. 8351 */ 8352 8353 const insertBlocks = function (blocks, index, rootClientId) { 8354 let updateSelection = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : true; 8355 let initialPosition = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : 0; 8356 let meta = arguments.length > 5 ? arguments[5] : undefined; 8357 return _ref10 => { 8358 let { 8359 select, 8360 dispatch 8361 } = _ref10; 8362 8363 /* eslint-enable jsdoc/valid-types */ 8364 if ((0,external_lodash_namespaceObject.isObject)(initialPosition)) { 8365 meta = initialPosition; 8366 initialPosition = 0; 8367 external_wp_deprecated_default()("meta argument in wp.data.dispatch('core/block-editor')", { 8368 since: '5.8', 8369 hint: 'The meta argument is now the 6th argument of the function' 8370 }); 8371 } 8372 8373 blocks = getBlocksWithDefaultStylesApplied((0,external_lodash_namespaceObject.castArray)(blocks), select.getSettings()); 8374 const allowedBlocks = []; 8375 8376 for (const block of blocks) { 8377 const isValid = select.canInsertBlockType(block.name, rootClientId); 8378 8379 if (isValid) { 8380 allowedBlocks.push(block); 8381 } 8382 } 8383 8384 if (allowedBlocks.length) { 8385 dispatch({ 8386 type: 'INSERT_BLOCKS', 8387 blocks: allowedBlocks, 8388 index, 8389 rootClientId, 8390 time: Date.now(), 8391 updateSelection, 8392 initialPosition: updateSelection ? initialPosition : null, 8393 meta 8394 }); 8395 } 8396 }; 8397 }; 8398 /** 8399 * Action that shows the insertion point. 8400 * 8401 * @param {?string} rootClientId Optional root client ID of block list on 8402 * which to insert. 8403 * @param {?number} index Index at which block should be inserted. 8404 * @param {Object} __unstableOptions Whether or not to show an inserter button. 8405 * 8406 * @return {Object} Action object. 8407 */ 8408 8409 function showInsertionPoint(rootClientId, index) { 8410 let __unstableOptions = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; 8411 8412 const { 8413 __unstableWithInserter 8414 } = __unstableOptions; 8415 return { 8416 type: 'SHOW_INSERTION_POINT', 8417 rootClientId, 8418 index, 8419 __unstableWithInserter 8420 }; 8421 } 8422 /** 8423 * Action that hides the insertion point. 8424 * 8425 * @return {Object} Action object. 8426 */ 8427 8428 function hideInsertionPoint() { 8429 return { 8430 type: 'HIDE_INSERTION_POINT' 8431 }; 8432 } 8433 /** 8434 * Action that resets the template validity. 8435 * 8436 * @param {boolean} isValid template validity flag. 8437 * 8438 * @return {Object} Action object. 8439 */ 8440 8441 function setTemplateValidity(isValid) { 8442 return { 8443 type: 'SET_TEMPLATE_VALIDITY', 8444 isValid 8445 }; 8446 } 8447 /** 8448 * Action that synchronizes the template with the list of blocks. 8449 * 8450 * @return {Object} Action object. 8451 */ 8452 8453 const synchronizeTemplate = () => _ref11 => { 8454 let { 8455 select, 8456 dispatch 8457 } = _ref11; 8458 dispatch({ 8459 type: 'SYNCHRONIZE_TEMPLATE' 8460 }); 8461 const blocks = select.getBlocks(); 8462 const template = select.getTemplate(); 8463 const updatedBlockList = (0,external_wp_blocks_namespaceObject.synchronizeBlocksWithTemplate)(blocks, template); 8464 dispatch.resetBlocks(updatedBlockList); 8465 }; 8466 /** 8467 * Delete the current selection. 8468 * 8469 * @param {boolean} isForward 8470 */ 8471 8472 const __unstableDeleteSelection = isForward => _ref12 => { 8473 let { 8474 registry, 8475 select, 8476 dispatch 8477 } = _ref12; 8478 const selectionAnchor = select.getSelectionStart(); 8479 const selectionFocus = select.getSelectionEnd(); 8480 if (selectionAnchor.clientId === selectionFocus.clientId) return; // It's not mergeable if there's no rich text selection. 8481 8482 if (!selectionAnchor.attributeKey || !selectionFocus.attributeKey || typeof selectionAnchor.offset === 'undefined' || typeof selectionFocus.offset === 'undefined') return false; 8483 const anchorRootClientId = select.getBlockRootClientId(selectionAnchor.clientId); 8484 const focusRootClientId = select.getBlockRootClientId(selectionFocus.clientId); // It's not mergeable if the selection doesn't start and end in the same 8485 // block list. Maybe in the future it should be allowed. 8486 8487 if (anchorRootClientId !== focusRootClientId) { 8488 return; 8489 } 8490 8491 const blockOrder = select.getBlockOrder(anchorRootClientId); 8492 const anchorIndex = blockOrder.indexOf(selectionAnchor.clientId); 8493 const focusIndex = blockOrder.indexOf(selectionFocus.clientId); // Reassign selection start and end based on order. 8494 8495 let selectionStart, selectionEnd; 8496 8497 if (anchorIndex > focusIndex) { 8498 selectionStart = selectionFocus; 8499 selectionEnd = selectionAnchor; 8500 } else { 8501 selectionStart = selectionAnchor; 8502 selectionEnd = selectionFocus; 8503 } 8504 8505 const targetSelection = isForward ? selectionEnd : selectionStart; 8506 const targetBlock = select.getBlock(targetSelection.clientId); 8507 const targetBlockType = (0,external_wp_blocks_namespaceObject.getBlockType)(targetBlock.name); 8508 8509 if (!targetBlockType.merge) { 8510 return; 8511 } 8512 8513 const selectionA = selectionStart; 8514 const selectionB = selectionEnd; 8515 const blockA = select.getBlock(selectionA.clientId); 8516 const blockAType = (0,external_wp_blocks_namespaceObject.getBlockType)(blockA.name); 8517 const blockB = select.getBlock(selectionB.clientId); 8518 const blockBType = (0,external_wp_blocks_namespaceObject.getBlockType)(blockB.name); 8519 const htmlA = blockA.attributes[selectionA.attributeKey]; 8520 const htmlB = blockB.attributes[selectionB.attributeKey]; 8521 const attributeDefinitionA = blockAType.attributes[selectionA.attributeKey]; 8522 const attributeDefinitionB = blockBType.attributes[selectionB.attributeKey]; 8523 let valueA = (0,external_wp_richText_namespaceObject.create)({ 8524 html: htmlA, 8525 ...mapRichTextSettings(attributeDefinitionA) 8526 }); 8527 let valueB = (0,external_wp_richText_namespaceObject.create)({ 8528 html: htmlB, 8529 ...mapRichTextSettings(attributeDefinitionB) 8530 }); // A robust way to retain selection position through various transforms 8531 // is to insert a special character at the position and then recover it. 8532 8533 const START_OF_SELECTED_AREA = '\u0086'; 8534 valueA = (0,external_wp_richText_namespaceObject.remove)(valueA, selectionA.offset, valueA.text.length); 8535 valueB = (0,external_wp_richText_namespaceObject.insert)(valueB, START_OF_SELECTED_AREA, 0, selectionB.offset); // Clone the blocks so we don't manipulate the original. 8536 8537 const cloneA = (0,external_wp_blocks_namespaceObject.cloneBlock)(blockA, { 8538 [selectionA.attributeKey]: (0,external_wp_richText_namespaceObject.toHTMLString)({ 8539 value: valueA, 8540 ...mapRichTextSettings(attributeDefinitionA) 8541 }) 8542 }); 8543 const cloneB = (0,external_wp_blocks_namespaceObject.cloneBlock)(blockB, { 8544 [selectionB.attributeKey]: (0,external_wp_richText_namespaceObject.toHTMLString)({ 8545 value: valueB, 8546 ...mapRichTextSettings(attributeDefinitionB) 8547 }) 8548 }); 8549 const followingBlock = isForward ? cloneA : cloneB; // We can only merge blocks with similar types 8550 // thus, we transform the block to merge first 8551 8552 const blocksWithTheSameType = blockA.name === blockB.name ? [followingBlock] : (0,external_wp_blocks_namespaceObject.switchToBlockType)(followingBlock, targetBlockType.name); // If the block types can not match, do nothing 8553 8554 if (!blocksWithTheSameType || !blocksWithTheSameType.length) { 8555 return; 8556 } 8557 8558 let updatedAttributes; 8559 8560 if (isForward) { 8561 const blockToMerge = blocksWithTheSameType.pop(); 8562 updatedAttributes = targetBlockType.merge(blockToMerge.attributes, cloneB.attributes); 8563 } else { 8564 const blockToMerge = blocksWithTheSameType.shift(); 8565 updatedAttributes = targetBlockType.merge(cloneA.attributes, blockToMerge.attributes); 8566 } 8567 8568 const newAttributeKey = (0,external_lodash_namespaceObject.findKey)(updatedAttributes, v => typeof v === 'string' && v.indexOf(START_OF_SELECTED_AREA) !== -1); 8569 const convertedHtml = updatedAttributes[newAttributeKey]; 8570 const convertedValue = (0,external_wp_richText_namespaceObject.create)({ 8571 html: convertedHtml, 8572 ...mapRichTextSettings(targetBlockType.attributes[newAttributeKey]) 8573 }); 8574 const newOffset = convertedValue.text.indexOf(START_OF_SELECTED_AREA); 8575 const newValue = (0,external_wp_richText_namespaceObject.remove)(convertedValue, newOffset, newOffset + 1); 8576 const newHtml = (0,external_wp_richText_namespaceObject.toHTMLString)({ 8577 value: newValue, 8578 ...mapRichTextSettings(targetBlockType.attributes[newAttributeKey]) 8579 }); 8580 updatedAttributes[newAttributeKey] = newHtml; 8581 const selectedBlockClientIds = select.getSelectedBlockClientIds(); 8582 const replacement = [...(isForward ? blocksWithTheSameType : []), { // Preserve the original client ID. 8583 ...targetBlock, 8584 attributes: { ...targetBlock.attributes, 8585 ...updatedAttributes 8586 } 8587 }, ...(isForward ? [] : blocksWithTheSameType)]; 8588 registry.batch(() => { 8589 dispatch.selectionChange(targetBlock.clientId, newAttributeKey, newOffset, newOffset); 8590 dispatch.replaceBlocks(selectedBlockClientIds, replacement, 0, // If we don't pass the `indexToSelect` it will default to the last block. 8591 select.getSelectedBlocksInitialCaretPosition()); 8592 }); 8593 }; 8594 /** 8595 * Split the current selection. 8596 */ 8597 8598 const __unstableSplitSelection = () => _ref13 => { 8599 let { 8600 select, 8601 dispatch 8602 } = _ref13; 8603 const selectionAnchor = select.getSelectionStart(); 8604 const selectionFocus = select.getSelectionEnd(); 8605 if (selectionAnchor.clientId === selectionFocus.clientId) return; // Can't split if the selection is not set. 8606 8607 if (!selectionAnchor.attributeKey || !selectionFocus.attributeKey || typeof selectionAnchor.offset === 'undefined' || typeof selectionFocus.offset === 'undefined') return; 8608 const anchorRootClientId = select.getBlockRootClientId(selectionAnchor.clientId); 8609 const focusRootClientId = select.getBlockRootClientId(selectionFocus.clientId); // It's not splittable if the selection doesn't start and end in the same 8610 // block list. Maybe in the future it should be allowed. 8611 8612 if (anchorRootClientId !== focusRootClientId) { 8613 return; 8614 } 8615 8616 const blockOrder = select.getBlockOrder(anchorRootClientId); 8617 const anchorIndex = blockOrder.indexOf(selectionAnchor.clientId); 8618 const focusIndex = blockOrder.indexOf(selectionFocus.clientId); // Reassign selection start and end based on order. 8619 8620 let selectionStart, selectionEnd; 8621 8622 if (anchorIndex > focusIndex) { 8623 selectionStart = selectionFocus; 8624 selectionEnd = selectionAnchor; 8625 } else { 8626 selectionStart = selectionAnchor; 8627 selectionEnd = selectionFocus; 8628 } 8629 8630 const selectionA = selectionStart; 8631 const selectionB = selectionEnd; 8632 const blockA = select.getBlock(selectionA.clientId); 8633 const blockAType = (0,external_wp_blocks_namespaceObject.getBlockType)(blockA.name); 8634 const blockB = select.getBlock(selectionB.clientId); 8635 const blockBType = (0,external_wp_blocks_namespaceObject.getBlockType)(blockB.name); 8636 const htmlA = blockA.attributes[selectionA.attributeKey]; 8637 const htmlB = blockB.attributes[selectionB.attributeKey]; 8638 const attributeDefinitionA = blockAType.attributes[selectionA.attributeKey]; 8639 const attributeDefinitionB = blockBType.attributes[selectionB.attributeKey]; 8640 let valueA = (0,external_wp_richText_namespaceObject.create)({ 8641 html: htmlA, 8642 ...mapRichTextSettings(attributeDefinitionA) 8643 }); 8644 let valueB = (0,external_wp_richText_namespaceObject.create)({ 8645 html: htmlB, 8646 ...mapRichTextSettings(attributeDefinitionB) 8647 }); 8648 valueA = (0,external_wp_richText_namespaceObject.remove)(valueA, selectionA.offset, valueA.text.length); 8649 valueB = (0,external_wp_richText_namespaceObject.remove)(valueB, 0, selectionB.offset); 8650 dispatch.replaceBlocks(select.getSelectedBlockClientIds(), [{ // Preserve the original client ID. 8651 ...blockA, 8652 attributes: { ...blockA.attributes, 8653 [selectionA.attributeKey]: (0,external_wp_richText_namespaceObject.toHTMLString)({ 8654 value: valueA, 8655 ...mapRichTextSettings(attributeDefinitionA) 8656 }) 8657 } 8658 }, (0,external_wp_blocks_namespaceObject.createBlock)((0,external_wp_blocks_namespaceObject.getDefaultBlockName)()), { // Preserve the original client ID. 8659 ...blockB, 8660 attributes: { ...blockB.attributes, 8661 [selectionB.attributeKey]: (0,external_wp_richText_namespaceObject.toHTMLString)({ 8662 value: valueB, 8663 ...mapRichTextSettings(attributeDefinitionB) 8664 }) 8665 } 8666 }], 1, // If we don't pass the `indexToSelect` it will default to the last block. 8667 select.getSelectedBlocksInitialCaretPosition()); 8668 }; 8669 /** 8670 * Expand the selection to cover the entire blocks, removing partial selection. 8671 */ 8672 8673 const __unstableExpandSelection = () => _ref14 => { 8674 let { 8675 select, 8676 dispatch 8677 } = _ref14; 8678 const selectionAnchor = select.getSelectionStart(); 8679 const selectionFocus = select.getSelectionEnd(); 8680 dispatch.selectionChange({ 8681 start: { 8682 clientId: selectionAnchor.clientId 8683 }, 8684 end: { 8685 clientId: selectionFocus.clientId 8686 } 8687 }); 8688 }; 8689 /** 8690 * Action that merges two blocks. 8691 * 8692 * @param {string} firstBlockClientId Client ID of the first block to merge. 8693 * @param {string} secondBlockClientId Client ID of the second block to merge. 8694 */ 8695 8696 const mergeBlocks = (firstBlockClientId, secondBlockClientId) => _ref15 => { 8697 let { 8698 select, 8699 dispatch 8700 } = _ref15; 8701 const blocks = [firstBlockClientId, secondBlockClientId]; 8702 dispatch({ 8703 type: 'MERGE_BLOCKS', 8704 blocks 8705 }); 8706 const [clientIdA, clientIdB] = blocks; 8707 const blockA = select.getBlock(clientIdA); 8708 const blockAType = (0,external_wp_blocks_namespaceObject.getBlockType)(blockA.name); // Only focus the previous block if it's not mergeable. 8709 8710 if (blockAType && !blockAType.merge) { 8711 dispatch.selectBlock(blockA.clientId); 8712 return; 8713 } 8714 8715 const blockB = select.getBlock(clientIdB); 8716 const blockBType = (0,external_wp_blocks_namespaceObject.getBlockType)(blockB.name); 8717 const { 8718 clientId, 8719 attributeKey, 8720 offset 8721 } = select.getSelectionStart(); 8722 const selectedBlockType = clientId === clientIdA ? blockAType : blockBType; 8723 const attributeDefinition = selectedBlockType.attributes[attributeKey]; 8724 const canRestoreTextSelection = (clientId === clientIdA || clientId === clientIdB) && attributeKey !== undefined && offset !== undefined && // We cannot restore text selection if the RichText identifier 8725 // is not a defined block attribute key. This can be the case if the 8726 // fallback intance ID is used to store selection (and no RichText 8727 // identifier is set), or when the identifier is wrong. 8728 !!attributeDefinition; 8729 8730 if (!attributeDefinition) { 8731 if (typeof attributeKey === 'number') { 8732 window.console.error(`RichText needs an identifier prop that is the block attribute key of the attribute it controls. Its type is expected to be a string, but was $typeof attributeKey}`); 8733 } else { 8734 window.console.error('The RichText identifier prop does not match any attributes defined by the block.'); 8735 } 8736 } // A robust way to retain selection position through various transforms 8737 // is to insert a special character at the position and then recover it. 8738 8739 8740 const START_OF_SELECTED_AREA = '\u0086'; // Clone the blocks so we don't insert the character in a "live" block. 8741 8742 const cloneA = (0,external_wp_blocks_namespaceObject.cloneBlock)(blockA); 8743 const cloneB = (0,external_wp_blocks_namespaceObject.cloneBlock)(blockB); 8744 8745 if (canRestoreTextSelection) { 8746 const selectedBlock = clientId === clientIdA ? cloneA : cloneB; 8747 const html = selectedBlock.attributes[attributeKey]; 8748 const value = (0,external_wp_richText_namespaceObject.insert)((0,external_wp_richText_namespaceObject.create)({ 8749 html, 8750 ...mapRichTextSettings(attributeDefinition) 8751 }), START_OF_SELECTED_AREA, offset, offset); 8752 selectedBlock.attributes[attributeKey] = (0,external_wp_richText_namespaceObject.toHTMLString)({ 8753 value, 8754 ...mapRichTextSettings(attributeDefinition) 8755 }); 8756 } // We can only merge blocks with similar types 8757 // thus, we transform the block to merge first. 8758 8759 8760 const blocksWithTheSameType = blockA.name === blockB.name ? [cloneB] : (0,external_wp_blocks_namespaceObject.switchToBlockType)(cloneB, blockA.name); // If the block types can not match, do nothing. 8761 8762 if (!blocksWithTheSameType || !blocksWithTheSameType.length) { 8763 return; 8764 } // Calling the merge to update the attributes and remove the block to be merged. 8765 8766 8767 const updatedAttributes = blockAType.merge(cloneA.attributes, blocksWithTheSameType[0].attributes); 8768 8769 if (canRestoreTextSelection) { 8770 const newAttributeKey = (0,external_lodash_namespaceObject.findKey)(updatedAttributes, v => typeof v === 'string' && v.indexOf(START_OF_SELECTED_AREA) !== -1); 8771 const convertedHtml = updatedAttributes[newAttributeKey]; 8772 const convertedValue = (0,external_wp_richText_namespaceObject.create)({ 8773 html: convertedHtml, 8774 ...mapRichTextSettings(blockAType.attributes[newAttributeKey]) 8775 }); 8776 const newOffset = convertedValue.text.indexOf(START_OF_SELECTED_AREA); 8777 const newValue = (0,external_wp_richText_namespaceObject.remove)(convertedValue, newOffset, newOffset + 1); 8778 const newHtml = (0,external_wp_richText_namespaceObject.toHTMLString)({ 8779 value: newValue, 8780 ...mapRichTextSettings(blockAType.attributes[newAttributeKey]) 8781 }); 8782 updatedAttributes[newAttributeKey] = newHtml; 8783 dispatch.selectionChange(blockA.clientId, newAttributeKey, newOffset, newOffset); 8784 } 8785 8786 dispatch.replaceBlocks([blockA.clientId, blockB.clientId], [{ ...blockA, 8787 attributes: { ...blockA.attributes, 8788 ...updatedAttributes 8789 } 8790 }, ...blocksWithTheSameType.slice(1)], 0 // If we don't pass the `indexToSelect` it will default to the last block. 8791 ); 8792 }; 8793 /** 8794 * Yields action objects used in signalling that the blocks corresponding to 8795 * the set of specified client IDs are to be removed. 8796 * 8797 * @param {string|string[]} clientIds Client IDs of blocks to remove. 8798 * @param {boolean} selectPrevious True if the previous block should be 8799 * selected when a block is removed. 8800 */ 8801 8802 const removeBlocks = function (clientIds) { 8803 let selectPrevious = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true; 8804 return _ref16 => { 8805 let { 8806 select, 8807 dispatch 8808 } = _ref16; 8809 8810 if (!clientIds || !clientIds.length) { 8811 return; 8812 } 8813 8814 clientIds = (0,external_lodash_namespaceObject.castArray)(clientIds); 8815 const rootClientId = select.getBlockRootClientId(clientIds[0]); 8816 const canRemoveBlocks = select.canRemoveBlocks(clientIds, rootClientId); 8817 8818 if (!canRemoveBlocks) { 8819 return; 8820 } 8821 8822 if (selectPrevious) { 8823 dispatch.selectPreviousBlock(clientIds[0]); 8824 } 8825 8826 dispatch({ 8827 type: 'REMOVE_BLOCKS', 8828 clientIds 8829 }); // To avoid a focus loss when removing the last block, assure there is 8830 // always a default block if the last of the blocks have been removed. 8831 8832 dispatch(ensureDefaultBlock()); 8833 }; 8834 }; 8835 /** 8836 * Returns an action object used in signalling that the block with the 8837 * specified client ID is to be removed. 8838 * 8839 * @param {string} clientId Client ID of block to remove. 8840 * @param {boolean} selectPrevious True if the previous block should be 8841 * selected when a block is removed. 8842 * 8843 * @return {Object} Action object. 8844 */ 8845 8846 function removeBlock(clientId, selectPrevious) { 8847 return removeBlocks([clientId], selectPrevious); 8848 } 8849 /* eslint-disable jsdoc/valid-types */ 8850 8851 /** 8852 * Returns an action object used in signalling that the inner blocks with the 8853 * specified client ID should be replaced. 8854 * 8855 * @param {string} rootClientId Client ID of the block whose InnerBlocks will re replaced. 8856 * @param {Object[]} blocks Block objects to insert as new InnerBlocks 8857 * @param {?boolean} updateSelection If true block selection will be updated. If false, block selection will not change. Defaults to false. 8858 * @param {0|-1|null} initialPosition Initial block position. 8859 * @return {Object} Action object. 8860 */ 8861 8862 function replaceInnerBlocks(rootClientId, blocks) { 8863 let updateSelection = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; 8864 let initialPosition = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 0; 8865 8866 /* eslint-enable jsdoc/valid-types */ 8867 return { 8868 type: 'REPLACE_INNER_BLOCKS', 8869 rootClientId, 8870 blocks, 8871 updateSelection, 8872 initialPosition: updateSelection ? initialPosition : null, 8873 time: Date.now() 8874 }; 8875 } 8876 /** 8877 * Returns an action object used to toggle the block editing mode between 8878 * visual and HTML modes. 8879 * 8880 * @param {string} clientId Block client ID. 8881 * 8882 * @return {Object} Action object. 8883 */ 8884 8885 function toggleBlockMode(clientId) { 8886 return { 8887 type: 'TOGGLE_BLOCK_MODE', 8888 clientId 8889 }; 8890 } 8891 /** 8892 * Returns an action object used in signalling that the user has begun to type. 8893 * 8894 * @return {Object} Action object. 8895 */ 8896 8897 function startTyping() { 8898 return { 8899 type: 'START_TYPING' 8900 }; 8901 } 8902 /** 8903 * Returns an action object used in signalling that the user has stopped typing. 8904 * 8905 * @return {Object} Action object. 8906 */ 8907 8908 function stopTyping() { 8909 return { 8910 type: 'STOP_TYPING' 8911 }; 8912 } 8913 /** 8914 * Returns an action object used in signalling that the user has begun to drag blocks. 8915 * 8916 * @param {string[]} clientIds An array of client ids being dragged 8917 * 8918 * @return {Object} Action object. 8919 */ 8920 8921 function startDraggingBlocks() { 8922 let clientIds = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : []; 8923 return { 8924 type: 'START_DRAGGING_BLOCKS', 8925 clientIds 8926 }; 8927 } 8928 /** 8929 * Returns an action object used in signalling that the user has stopped dragging blocks. 8930 * 8931 * @return {Object} Action object. 8932 */ 8933 8934 function stopDraggingBlocks() { 8935 return { 8936 type: 'STOP_DRAGGING_BLOCKS' 8937 }; 8938 } 8939 /** 8940 * Returns an action object used in signalling that the caret has entered formatted text. 8941 * 8942 * @return {Object} Action object. 8943 */ 8944 8945 function enterFormattedText() { 8946 return { 8947 type: 'ENTER_FORMATTED_TEXT' 8948 }; 8949 } 8950 /** 8951 * Returns an action object used in signalling that the user caret has exited formatted text. 8952 * 8953 * @return {Object} Action object. 8954 */ 8955 8956 function exitFormattedText() { 8957 return { 8958 type: 'EXIT_FORMATTED_TEXT' 8959 }; 8960 } 8961 /** 8962 * Action that changes the position of the user caret. 8963 * 8964 * @param {string|WPSelection} clientId The selected block client ID. 8965 * @param {string} attributeKey The selected block attribute key. 8966 * @param {number} startOffset The start offset. 8967 * @param {number} endOffset The end offset. 8968 * 8969 * @return {Object} Action object. 8970 */ 8971 8972 function selectionChange(clientId, attributeKey, startOffset, endOffset) { 8973 if (typeof clientId === 'string') { 8974 return { 8975 type: 'SELECTION_CHANGE', 8976 clientId, 8977 attributeKey, 8978 startOffset, 8979 endOffset 8980 }; 8981 } 8982 8983 return { 8984 type: 'SELECTION_CHANGE', 8985 ...clientId 8986 }; 8987 } 8988 /** 8989 * Action that adds a new block of the default type to the block list. 8990 * 8991 * @param {?Object} attributes Optional attributes of the block to assign. 8992 * @param {?string} rootClientId Optional root client ID of block list on which 8993 * to append. 8994 * @param {?number} index Optional index where to insert the default block. 8995 */ 8996 8997 const insertDefaultBlock = (attributes, rootClientId, index) => _ref17 => { 8998 let { 8999 dispatch 9000 } = _ref17; 9001 // Abort if there is no default block type (if it has been unregistered). 9002 const defaultBlockName = (0,external_wp_blocks_namespaceObject.getDefaultBlockName)(); 9003 9004 if (!defaultBlockName) { 9005 return; 9006 } 9007 9008 const block = (0,external_wp_blocks_namespaceObject.createBlock)(defaultBlockName, attributes); 9009 return dispatch.insertBlock(block, index, rootClientId); 9010 }; 9011 /** 9012 * Action that changes the nested settings of a given block. 9013 * 9014 * @param {string} clientId Client ID of the block whose nested setting are 9015 * being received. 9016 * @param {Object} settings Object with the new settings for the nested block. 9017 * 9018 * @return {Object} Action object 9019 */ 9020 9021 function updateBlockListSettings(clientId, settings) { 9022 return { 9023 type: 'UPDATE_BLOCK_LIST_SETTINGS', 9024 clientId, 9025 settings 9026 }; 9027 } 9028 /** 9029 * Action that updates the block editor settings. 9030 * 9031 * @param {Object} settings Updated settings 9032 * 9033 * @return {Object} Action object 9034 */ 9035 9036 function updateSettings(settings) { 9037 return { 9038 type: 'UPDATE_SETTINGS', 9039 settings 9040 }; 9041 } 9042 /** 9043 * Action that signals that a temporary reusable block has been saved 9044 * in order to switch its temporary id with the real id. 9045 * 9046 * @param {string} id Reusable block's id. 9047 * @param {string} updatedId Updated block's id. 9048 * 9049 * @return {Object} Action object. 9050 */ 9051 9052 function __unstableSaveReusableBlock(id, updatedId) { 9053 return { 9054 type: 'SAVE_REUSABLE_BLOCK_SUCCESS', 9055 id, 9056 updatedId 9057 }; 9058 } 9059 /** 9060 * Action that marks the last block change explicitly as persistent. 9061 * 9062 * @return {Object} Action object. 9063 */ 9064 9065 function __unstableMarkLastChangeAsPersistent() { 9066 return { 9067 type: 'MARK_LAST_CHANGE_AS_PERSISTENT' 9068 }; 9069 } 9070 /** 9071 * Action that signals that the next block change should be marked explicitly as not persistent. 9072 * 9073 * @return {Object} Action object. 9074 */ 9075 9076 function __unstableMarkNextChangeAsNotPersistent() { 9077 return { 9078 type: 'MARK_NEXT_CHANGE_AS_NOT_PERSISTENT' 9079 }; 9080 } 9081 /** 9082 * Action that marks the last block change as an automatic change, meaning it was not 9083 * performed by the user, and can be undone using the `Escape` and `Backspace` keys. 9084 * This action must be called after the change was made, and any actions that are a 9085 * consequence of it, so it is recommended to be called at the next idle period to ensure all 9086 * selection changes have been recorded. 9087 */ 9088 9089 const __unstableMarkAutomaticChange = () => _ref18 => { 9090 let { 9091 dispatch 9092 } = _ref18; 9093 dispatch({ 9094 type: 'MARK_AUTOMATIC_CHANGE' 9095 }); 9096 const { 9097 requestIdleCallback = cb => setTimeout(cb, 100) 9098 } = window; 9099 requestIdleCallback(() => { 9100 dispatch({ 9101 type: 'MARK_AUTOMATIC_CHANGE_FINAL' 9102 }); 9103 }); 9104 }; 9105 /** 9106 * Action that enables or disables the navigation mode. 9107 * 9108 * @param {string} isNavigationMode Enable/Disable navigation mode. 9109 */ 9110 9111 const setNavigationMode = function () { 9112 let isNavigationMode = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true; 9113 return _ref19 => { 9114 let { 9115 dispatch 9116 } = _ref19; 9117 dispatch({ 9118 type: 'SET_NAVIGATION_MODE', 9119 isNavigationMode 9120 }); 9121 9122 if (isNavigationMode) { 9123 (0,external_wp_a11y_namespaceObject.speak)((0,external_wp_i18n_namespaceObject.__)('You are currently in navigation mode. Navigate blocks using the Tab key and Arrow keys. Use Left and Right Arrow keys to move between nesting levels. To exit navigation mode and edit the selected block, press Enter.')); 9124 } else { 9125 (0,external_wp_a11y_namespaceObject.speak)((0,external_wp_i18n_namespaceObject.__)('You are currently in edit mode. To return to the navigation mode, press Escape.')); 9126 } 9127 }; 9128 }; 9129 /** 9130 * Action that enables or disables the block moving mode. 9131 * 9132 * @param {string|null} hasBlockMovingClientId Enable/Disable block moving mode. 9133 */ 9134 9135 const setBlockMovingClientId = function () { 9136 let hasBlockMovingClientId = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null; 9137 return _ref20 => { 9138 let { 9139 dispatch 9140 } = _ref20; 9141 dispatch({ 9142 type: 'SET_BLOCK_MOVING_MODE', 9143 hasBlockMovingClientId 9144 }); 9145 9146 if (hasBlockMovingClientId) { 9147 (0,external_wp_a11y_namespaceObject.speak)((0,external_wp_i18n_namespaceObject.__)('Use the Tab key and Arrow keys to choose new block location. Use Left and Right Arrow keys to move between nesting levels. Once location is selected press Enter or Space to move the block.')); 9148 } 9149 }; 9150 }; 9151 /** 9152 * Action that duplicates a list of blocks. 9153 * 9154 * @param {string[]} clientIds 9155 * @param {boolean} updateSelection 9156 */ 9157 9158 const duplicateBlocks = function (clientIds) { 9159 let updateSelection = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true; 9160 return _ref21 => { 9161 let { 9162 select, 9163 dispatch 9164 } = _ref21; 9165 9166 if (!clientIds || !clientIds.length) { 9167 return; 9168 } // Return early if blocks don't exist. 9169 9170 9171 const blocks = select.getBlocksByClientId(clientIds); 9172 9173 if ((0,external_lodash_namespaceObject.some)(blocks, block => !block)) { 9174 return; 9175 } // Return early if blocks don't support multiple usage. 9176 9177 9178 const blockNames = blocks.map(block => block.name); 9179 9180 if (blockNames.some(blockName => !(0,external_wp_blocks_namespaceObject.hasBlockSupport)(blockName, 'multiple', true))) { 9181 return; 9182 } 9183 9184 const rootClientId = select.getBlockRootClientId(clientIds[0]); 9185 const lastSelectedIndex = select.getBlockIndex((0,external_lodash_namespaceObject.last)((0,external_lodash_namespaceObject.castArray)(clientIds))); 9186 const clonedBlocks = blocks.map(block => (0,external_wp_blocks_namespaceObject.__experimentalCloneSanitizedBlock)(block)); 9187 dispatch.insertBlocks(clonedBlocks, lastSelectedIndex + 1, rootClientId, updateSelection); 9188 9189 if (clonedBlocks.length > 1 && updateSelection) { 9190 dispatch.multiSelect((0,external_lodash_namespaceObject.first)(clonedBlocks).clientId, (0,external_lodash_namespaceObject.last)(clonedBlocks).clientId); 9191 } 9192 9193 return clonedBlocks.map(block => block.clientId); 9194 }; 9195 }; 9196 /** 9197 * Action that inserts an empty block before a given block. 9198 * 9199 * @param {string} clientId 9200 */ 9201 9202 const insertBeforeBlock = clientId => _ref22 => { 9203 let { 9204 select, 9205 dispatch 9206 } = _ref22; 9207 9208 if (!clientId) { 9209 return; 9210 } 9211 9212 const rootClientId = select.getBlockRootClientId(clientId); 9213 const isLocked = select.getTemplateLock(rootClientId); 9214 9215 if (isLocked) { 9216 return; 9217 } 9218 9219 const firstSelectedIndex = select.getBlockIndex(clientId); 9220 return dispatch.insertDefaultBlock({}, rootClientId, firstSelectedIndex); 9221 }; 9222 /** 9223 * Action that inserts an empty block after a given block. 9224 * 9225 * @param {string} clientId 9226 */ 9227 9228 const insertAfterBlock = clientId => _ref23 => { 9229 let { 9230 select, 9231 dispatch 9232 } = _ref23; 9233 9234 if (!clientId) { 9235 return; 9236 } 9237 9238 const rootClientId = select.getBlockRootClientId(clientId); 9239 const isLocked = select.getTemplateLock(rootClientId); 9240 9241 if (isLocked) { 9242 return; 9243 } 9244 9245 const firstSelectedIndex = select.getBlockIndex(clientId); 9246 return dispatch.insertDefaultBlock({}, rootClientId, firstSelectedIndex + 1); 9247 }; 9248 /** 9249 * Action that toggles the highlighted block state. 9250 * 9251 * @param {string} clientId The block's clientId. 9252 * @param {boolean} isHighlighted The highlight state. 9253 */ 9254 9255 function toggleBlockHighlight(clientId, isHighlighted) { 9256 return { 9257 type: 'TOGGLE_BLOCK_HIGHLIGHT', 9258 clientId, 9259 isHighlighted 9260 }; 9261 } 9262 /** 9263 * Action that "flashes" the block with a given `clientId` by rhythmically highlighting it. 9264 * 9265 * @param {string} clientId Target block client ID. 9266 */ 9267 9268 const flashBlock = clientId => async _ref24 => { 9269 let { 9270 dispatch 9271 } = _ref24; 9272 dispatch(toggleBlockHighlight(clientId, true)); 9273 await new Promise(resolve => setTimeout(resolve, 150)); 9274 dispatch(toggleBlockHighlight(clientId, false)); 9275 }; 9276 /** 9277 * Action that sets whether a block has controlled inner blocks. 9278 * 9279 * @param {string} clientId The block's clientId. 9280 * @param {boolean} hasControlledInnerBlocks True if the block's inner blocks are controlled. 9281 */ 9282 9283 function setHasControlledInnerBlocks(clientId, hasControlledInnerBlocks) { 9284 return { 9285 type: 'SET_HAS_CONTROLLED_INNER_BLOCKS', 9286 hasControlledInnerBlocks, 9287 clientId 9288 }; 9289 } 9290 9291 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/store/constants.js 9292 const STORE_NAME = 'core/block-editor'; 9293 9294 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/store/index.js 9295 /** 9296 * WordPress dependencies 9297 */ 9298 9299 /** 9300 * Internal dependencies 9301 */ 9302 9303 9304 9305 9306 9307 /** 9308 * Block editor data store configuration. 9309 * 9310 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/data/README.md#registerStore 9311 * 9312 * @type {Object} 9313 */ 9314 9315 const storeConfig = { 9316 reducer: reducer, 9317 selectors: selectors_namespaceObject, 9318 actions: actions_namespaceObject 9319 }; 9320 /** 9321 * Store definition for the block editor namespace. 9322 * 9323 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/data/README.md#createReduxStore 9324 * 9325 * @type {Object} 9326 */ 9327 9328 const store = (0,external_wp_data_namespaceObject.createReduxStore)(STORE_NAME, { ...storeConfig, 9329 persist: ['preferences'] 9330 }); // Ideally we'd use register instead of register stores. 9331 9332 (0,external_wp_data_namespaceObject.registerStore)(STORE_NAME, { ...storeConfig, 9333 persist: ['preferences'] 9334 }); 9335 9336 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-edit/context.js 9337 /** 9338 * WordPress dependencies 9339 */ 9340 9341 const DEFAULT_BLOCK_EDIT_CONTEXT = { 9342 name: '', 9343 isSelected: false 9344 }; 9345 const Context = (0,external_wp_element_namespaceObject.createContext)(DEFAULT_BLOCK_EDIT_CONTEXT); 9346 const { 9347 Provider 9348 } = Context; 9349 9350 /** 9351 * A hook that returns the block edit context. 9352 * 9353 * @return {Object} Block edit context 9354 */ 9355 9356 function useBlockEditContext() { 9357 return (0,external_wp_element_namespaceObject.useContext)(Context); 9358 } 9359 9360 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/use-display-block-controls/index.js 9361 /** 9362 * WordPress dependencies 9363 */ 9364 9365 /** 9366 * Internal dependencies 9367 */ 9368 9369 9370 9371 function useDisplayBlockControls() { 9372 const { 9373 isSelected, 9374 clientId, 9375 name 9376 } = useBlockEditContext(); 9377 return (0,external_wp_data_namespaceObject.useSelect)(select => { 9378 if (isSelected) { 9379 return true; 9380 } 9381 9382 const { 9383 getBlockName, 9384 isFirstMultiSelectedBlock, 9385 getMultiSelectedBlockClientIds 9386 } = select(store); 9387 9388 if (isFirstMultiSelectedBlock(clientId)) { 9389 return getMultiSelectedBlockClientIds().every(id => getBlockName(id) === name); 9390 } 9391 9392 return false; 9393 }, [clientId, isSelected, name]); 9394 } 9395 9396 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-controls/hook.js 9397 /** 9398 * WordPress dependencies 9399 */ 9400 9401 9402 /** 9403 * Internal dependencies 9404 */ 9405 9406 9407 9408 9409 9410 function useBlockControlsFill(group, shareWithChildBlocks) { 9411 const isDisplayed = useDisplayBlockControls(); 9412 const { 9413 clientId 9414 } = useBlockEditContext(); 9415 const isParentDisplayed = (0,external_wp_data_namespaceObject.useSelect)(select => { 9416 const { 9417 getBlockName, 9418 hasSelectedInnerBlock 9419 } = select(store); 9420 const { 9421 hasBlockSupport 9422 } = select(external_wp_blocks_namespaceObject.store); 9423 return shareWithChildBlocks && hasBlockSupport(getBlockName(clientId), '__experimentalExposeControlsToChildren', false) && hasSelectedInnerBlock(clientId); 9424 }, [shareWithChildBlocks, clientId]); 9425 9426 if (isDisplayed) { 9427 var _groups$group; 9428 9429 return (_groups$group = block_controls_groups[group]) === null || _groups$group === void 0 ? void 0 : _groups$group.Fill; 9430 } 9431 9432 if (isParentDisplayed) { 9433 return block_controls_groups.parent.Fill; 9434 } 9435 9436 return null; 9437 } 9438 9439 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-controls/fill.js 9440 9441 9442 /** 9443 * External dependencies 9444 */ 9445 9446 /** 9447 * WordPress dependencies 9448 */ 9449 9450 9451 /** 9452 * Internal dependencies 9453 */ 9454 9455 9456 function BlockControlsFill(_ref) { 9457 let { 9458 group = 'default', 9459 controls, 9460 children, 9461 __experimentalShareWithChildBlocks = false 9462 } = _ref; 9463 const Fill = useBlockControlsFill(group, __experimentalShareWithChildBlocks); 9464 9465 if (!Fill) { 9466 return null; 9467 } 9468 9469 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalStyleProvider, { 9470 document: document 9471 }, (0,external_wp_element_namespaceObject.createElement)(Fill, null, fillProps => { 9472 // Children passed to BlockControlsFill will not have access to any 9473 // React Context whose Provider is part of the BlockControlsSlot tree. 9474 // So we re-create the Provider in this subtree. 9475 const value = !(0,external_lodash_namespaceObject.isEmpty)(fillProps) ? fillProps : null; 9476 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToolbarContext.Provider, { 9477 value: value 9478 }, group === 'default' && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarGroup, { 9479 controls: controls 9480 }), children); 9481 })); 9482 } 9483 9484 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-controls/slot.js 9485 9486 9487 9488 /** 9489 * WordPress dependencies 9490 */ 9491 9492 9493 /** 9494 * Internal dependencies 9495 */ 9496 9497 9498 function BlockControlsSlot(_ref) { 9499 let { 9500 group = 'default', 9501 ...props 9502 } = _ref; 9503 const accessibleToolbarState = (0,external_wp_element_namespaceObject.useContext)(external_wp_components_namespaceObject.__experimentalToolbarContext); 9504 const Slot = block_controls_groups[group].Slot; 9505 const slot = (0,external_wp_components_namespaceObject.__experimentalUseSlot)(Slot.__unstableName); 9506 const hasFills = Boolean(slot.fills && slot.fills.length); 9507 9508 if (!hasFills) { 9509 return null; 9510 } 9511 9512 if (group === 'default') { 9513 return (0,external_wp_element_namespaceObject.createElement)(Slot, _extends({}, props, { 9514 bubblesVirtually: true, 9515 fillProps: accessibleToolbarState 9516 })); 9517 } 9518 9519 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarGroup, null, (0,external_wp_element_namespaceObject.createElement)(Slot, _extends({}, props, { 9520 bubblesVirtually: true, 9521 fillProps: accessibleToolbarState 9522 }))); 9523 } 9524 9525 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-controls/index.js 9526 9527 9528 9529 /** 9530 * Internal dependencies 9531 */ 9532 9533 9534 const BlockControls = BlockControlsFill; 9535 BlockControls.Slot = BlockControlsSlot; // This is just here for backward compatibility. 9536 9537 const BlockFormatControls = props => { 9538 return (0,external_wp_element_namespaceObject.createElement)(BlockControlsFill, _extends({ 9539 group: "inline" 9540 }, props)); 9541 }; 9542 9543 BlockFormatControls.Slot = props => { 9544 return (0,external_wp_element_namespaceObject.createElement)(BlockControlsSlot, _extends({ 9545 group: "inline" 9546 }, props)); 9547 }; 9548 9549 /* harmony default export */ var block_controls = (BlockControls); 9550 9551 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/align-none.js 9552 9553 9554 /** 9555 * WordPress dependencies 9556 */ 9557 9558 const alignNone = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 9559 xmlns: "http://www.w3.org/2000/svg", 9560 viewBox: "0 0 24 24" 9561 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 9562 d: "M5 15h14V9H5v6zm0 4.8h14v-1.5H5v1.5zM5 4.2v1.5h14V4.2H5z" 9563 })); 9564 /* harmony default export */ var align_none = (alignNone); 9565 9566 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/position-left.js 9567 9568 9569 /** 9570 * WordPress dependencies 9571 */ 9572 9573 const positionLeft = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 9574 xmlns: "http://www.w3.org/2000/svg", 9575 viewBox: "0 0 24 24" 9576 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 9577 d: "M4 9v6h14V9H4zm8-4.8H4v1.5h8V4.2zM4 19.8h8v-1.5H4v1.5z" 9578 })); 9579 /* harmony default export */ var position_left = (positionLeft); 9580 9581 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/position-center.js 9582 9583 9584 /** 9585 * WordPress dependencies 9586 */ 9587 9588 const positionCenter = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 9589 xmlns: "http://www.w3.org/2000/svg", 9590 viewBox: "0 0 24 24" 9591 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 9592 d: "M7 9v6h10V9H7zM5 19.8h14v-1.5H5v1.5zM5 4.3v1.5h14V4.3H5z" 9593 })); 9594 /* harmony default export */ var position_center = (positionCenter); 9595 9596 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/position-right.js 9597 9598 9599 /** 9600 * WordPress dependencies 9601 */ 9602 9603 const positionRight = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 9604 xmlns: "http://www.w3.org/2000/svg", 9605 viewBox: "0 0 24 24" 9606 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 9607 d: "M6 15h14V9H6v6zm6-10.8v1.5h8V4.2h-8zm0 15.6h8v-1.5h-8v1.5z" 9608 })); 9609 /* harmony default export */ var position_right = (positionRight); 9610 9611 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/stretch-wide.js 9612 9613 9614 /** 9615 * WordPress dependencies 9616 */ 9617 9618 const stretchWide = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 9619 xmlns: "http://www.w3.org/2000/svg", 9620 viewBox: "0 0 24 24" 9621 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 9622 d: "M5 9v6h14V9H5zm11-4.8H8v1.5h8V4.2zM8 19.8h8v-1.5H8v1.5z" 9623 })); 9624 /* harmony default export */ var stretch_wide = (stretchWide); 9625 9626 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/stretch-full-width.js 9627 9628 9629 /** 9630 * WordPress dependencies 9631 */ 9632 9633 const stretchFullWidth = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 9634 xmlns: "http://www.w3.org/2000/svg", 9635 viewBox: "0 0 24 24" 9636 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 9637 d: "M5 4v11h14V4H5zm3 15.8h8v-1.5H8v1.5z" 9638 })); 9639 /* harmony default export */ var stretch_full_width = (stretchFullWidth); 9640 9641 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/justify-left.js 9642 9643 9644 /** 9645 * WordPress dependencies 9646 */ 9647 9648 const justifyLeft = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 9649 xmlns: "http://www.w3.org/2000/svg", 9650 viewBox: "0 0 24 24" 9651 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 9652 d: "M9 9v6h11V9H9zM4 20h1.5V4H4v16z" 9653 })); 9654 /* harmony default export */ var justify_left = (justifyLeft); 9655 9656 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/justify-center.js 9657 9658 9659 /** 9660 * WordPress dependencies 9661 */ 9662 9663 const justifyCenter = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 9664 xmlns: "http://www.w3.org/2000/svg", 9665 viewBox: "0 0 24 24" 9666 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 9667 d: "M20 9h-7.2V4h-1.6v5H4v6h7.2v5h1.6v-5H20z" 9668 })); 9669 /* harmony default export */ var justify_center = (justifyCenter); 9670 9671 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/justify-right.js 9672 9673 9674 /** 9675 * WordPress dependencies 9676 */ 9677 9678 const justifyRight = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 9679 xmlns: "http://www.w3.org/2000/svg", 9680 viewBox: "0 0 24 24" 9681 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 9682 d: "M4 15h11V9H4v6zM18.5 4v16H20V4h-1.5z" 9683 })); 9684 /* harmony default export */ var justify_right = (justifyRight); 9685 9686 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/justify-space-between.js 9687 9688 9689 /** 9690 * WordPress dependencies 9691 */ 9692 9693 const justifySpaceBetween = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 9694 xmlns: "http://www.w3.org/2000/svg", 9695 viewBox: "0 0 24 24" 9696 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 9697 d: "M9 15h6V9H9v6zm-5 5h1.5V4H4v16zM18.5 4v16H20V4h-1.5z" 9698 })); 9699 /* harmony default export */ var justify_space_between = (justifySpaceBetween); 9700 9701 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/arrow-right.js 9702 9703 9704 /** 9705 * WordPress dependencies 9706 */ 9707 9708 const arrowRight = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 9709 xmlns: "http://www.w3.org/2000/svg", 9710 viewBox: "0 0 24 24" 9711 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 9712 d: "M14.3 6.7l-1.1 1.1 4 4H4v1.5h13.3l-4.1 4.4 1.1 1.1 5.8-6.3z" 9713 })); 9714 /* harmony default export */ var arrow_right = (arrowRight); 9715 9716 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/arrow-down.js 9717 9718 9719 /** 9720 * WordPress dependencies 9721 */ 9722 9723 const arrowDown = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 9724 xmlns: "http://www.w3.org/2000/svg", 9725 viewBox: "0 0 24 24" 9726 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 9727 d: "M16.2 13.2l-4 4V4h-1.5v13.3l-4.5-4.1-1 1.1 6.2 5.8 5.8-5.8-1-1.1z" 9728 })); 9729 /* harmony default export */ var arrow_down = (arrowDown); 9730 9731 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/layouts/utils.js 9732 /** 9733 * Utility to generate the proper CSS selector for layout styles. 9734 * 9735 * @param {string|string[]} selectors - CSS selectors 9736 * @param {boolean} append - string to append. 9737 * 9738 * @return {string} - CSS selector. 9739 */ 9740 function appendSelectors(selectors) { 9741 let append = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : ''; 9742 // Ideally we shouldn't need the `.editor-styles-wrapper` increased specificity here 9743 // The problem though is that we have a `.editor-styles-wrapper p { margin: reset; }` style 9744 // it's used to reset the default margin added by wp-admin to paragraphs 9745 // so we need this to be higher speficity otherwise, it won't be applied to paragraphs inside containers 9746 // When the post editor is fully iframed, this extra classname could be removed. 9747 return selectors.split(',').map(subselector => `.editor-styles-wrapper $subselector} $append}`).join(','); 9748 } 9749 9750 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/provider/block-refs-provider.js 9751 9752 9753 /** 9754 * WordPress dependencies 9755 */ 9756 9757 const BlockRefs = (0,external_wp_element_namespaceObject.createContext)({ 9758 refs: new Map(), 9759 callbacks: new Map() 9760 }); 9761 function BlockRefsProvider(_ref) { 9762 let { 9763 children 9764 } = _ref; 9765 const value = (0,external_wp_element_namespaceObject.useMemo)(() => ({ 9766 refs: new Map(), 9767 callbacks: new Map() 9768 }), []); 9769 return (0,external_wp_element_namespaceObject.createElement)(BlockRefs.Provider, { 9770 value: value 9771 }, children); 9772 } 9773 9774 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-list/use-block-props/use-block-refs.js 9775 /** 9776 * WordPress dependencies 9777 */ 9778 9779 9780 /** 9781 * Internal dependencies 9782 */ 9783 9784 9785 /** @typedef {import('@wordpress/element').RefCallback} RefCallback */ 9786 9787 /** @typedef {import('@wordpress/element').RefObject} RefObject */ 9788 9789 /** 9790 * Provides a ref to the BlockRefs context. 9791 * 9792 * @param {string} clientId The client ID of the element ref. 9793 * 9794 * @return {RefCallback} Ref callback. 9795 */ 9796 9797 function useBlockRefProvider(clientId) { 9798 const { 9799 refs, 9800 callbacks 9801 } = (0,external_wp_element_namespaceObject.useContext)(BlockRefs); 9802 const ref = (0,external_wp_element_namespaceObject.useRef)(); 9803 (0,external_wp_element_namespaceObject.useLayoutEffect)(() => { 9804 refs.set(ref, clientId); 9805 return () => { 9806 refs.delete(ref); 9807 }; 9808 }, [clientId]); 9809 return (0,external_wp_compose_namespaceObject.useRefEffect)(element => { 9810 // Update the ref in the provider. 9811 ref.current = element; // Call any update functions. 9812 9813 callbacks.forEach((id, setElement) => { 9814 if (clientId === id) { 9815 setElement(element); 9816 } 9817 }); 9818 }, [clientId]); 9819 } 9820 /** 9821 * Gets a ref pointing to the current block element. Continues to return a 9822 * stable ref even if the block client ID changes. 9823 * 9824 * @param {string} clientId The client ID to get a ref for. 9825 * 9826 * @return {RefObject} A ref containing the element. 9827 */ 9828 9829 function useBlockRef(clientId) { 9830 const { 9831 refs 9832 } = (0,external_wp_element_namespaceObject.useContext)(BlockRefs); 9833 const freshClientId = (0,external_wp_element_namespaceObject.useRef)(); 9834 freshClientId.current = clientId; // Always return an object, even if no ref exists for a given client ID, so 9835 // that `current` works at a later point. 9836 9837 return (0,external_wp_element_namespaceObject.useMemo)(() => ({ 9838 get current() { 9839 let element = null; // Multiple refs may be created for a single block. Find the 9840 // first that has an element set. 9841 9842 for (const [ref, id] of refs.entries()) { 9843 if (id === freshClientId.current && ref.current) { 9844 element = ref.current; 9845 } 9846 } 9847 9848 return element; 9849 } 9850 9851 }), []); 9852 } 9853 /** 9854 * Return the element for a given client ID. Updates whenever the element 9855 * changes, becomes available, or disappears. 9856 * 9857 * @param {string} clientId The client ID to an element for. 9858 * 9859 * @return {Element|null} The block's wrapper element. 9860 */ 9861 9862 9863 function useBlockElement(clientId) { 9864 const { 9865 callbacks 9866 } = (0,external_wp_element_namespaceObject.useContext)(BlockRefs); 9867 const ref = useBlockRef(clientId); 9868 const [element, setElement] = (0,external_wp_element_namespaceObject.useState)(null); 9869 (0,external_wp_element_namespaceObject.useLayoutEffect)(() => { 9870 if (!clientId) { 9871 return; 9872 } 9873 9874 callbacks.set(setElement, clientId); 9875 return () => { 9876 callbacks.delete(setElement); 9877 }; 9878 }, [clientId]); 9879 return ref.current || element; 9880 } 9881 9882 9883 9884 9885 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/use-setting/index.js 9886 /** 9887 * External dependencies 9888 */ 9889 9890 /** 9891 * WordPress dependencies 9892 */ 9893 9894 9895 9896 /** 9897 * Internal dependencies 9898 */ 9899 9900 9901 9902 const blockedPaths = ['color', 'border', 'typography', 'spacing']; 9903 const deprecatedFlags = { 9904 'color.palette': settings => settings.colors === undefined ? undefined : settings.colors, 9905 'color.gradients': settings => settings.gradients === undefined ? undefined : settings.gradients, 9906 'color.custom': settings => settings.disableCustomColors === undefined ? undefined : !settings.disableCustomColors, 9907 'color.customGradient': settings => settings.disableCustomGradients === undefined ? undefined : !settings.disableCustomGradients, 9908 'typography.fontSizes': settings => settings.fontSizes === undefined ? undefined : settings.fontSizes, 9909 'typography.customFontSize': settings => settings.disableCustomFontSizes === undefined ? undefined : !settings.disableCustomFontSizes, 9910 'typography.lineHeight': settings => settings.enableCustomLineHeight, 9911 'spacing.units': settings => { 9912 if (settings.enableCustomUnits === undefined) { 9913 return; 9914 } 9915 9916 if (settings.enableCustomUnits === true) { 9917 return ['px', 'em', 'rem', 'vh', 'vw', '%']; 9918 } 9919 9920 return settings.enableCustomUnits; 9921 }, 9922 'spacing.padding': settings => settings.enableCustomSpacing 9923 }; 9924 const prefixedFlags = { 9925 /* 9926 * These were only available in the plugin 9927 * and can be removed when the minimum WordPress version 9928 * for the plugin is 5.9. 9929 */ 9930 'border.customColor': 'border.color', 9931 'border.customStyle': 'border.style', 9932 'border.customWidth': 'border.width', 9933 'typography.customFontStyle': 'typography.fontStyle', 9934 'typography.customFontWeight': 'typography.fontWeight', 9935 'typography.customLetterSpacing': 'typography.letterSpacing', 9936 'typography.customTextDecorations': 'typography.textDecoration', 9937 'typography.customTextTransforms': 'typography.textTransform', 9938 9939 /* 9940 * These were part of WordPress 5.8 and we need to keep them. 9941 */ 9942 'border.customRadius': 'border.radius', 9943 'spacing.customMargin': 'spacing.margin', 9944 'spacing.customPadding': 'spacing.padding', 9945 'typography.customLineHeight': 'typography.lineHeight' 9946 }; 9947 /** 9948 * Remove `custom` prefixes for flags that did not land in 5.8. 9949 * 9950 * This provides continued support for `custom` prefixed properties. It will 9951 * be removed once third party devs have had sufficient time to update themes, 9952 * plugins, etc. 9953 * 9954 * @see https://github.com/WordPress/gutenberg/pull/34485 9955 * 9956 * @param {string} path Path to desired value in settings. 9957 * @return {string} The value for defined setting. 9958 */ 9959 9960 const removeCustomPrefixes = path => { 9961 return prefixedFlags[path] || path; 9962 }; 9963 /** 9964 * Hook that retrieves the editor setting. 9965 * It works with nested objects using by finding the value at path. 9966 * 9967 * @param {string} path The path to the setting. 9968 * @return {any} Returns the value defined for the setting. 9969 * @example 9970 * ```js 9971 * const isEnabled = useSetting( 'typography.dropCap' ); 9972 * ``` 9973 */ 9974 9975 9976 function useSetting(path) { 9977 const { 9978 name: blockName 9979 } = useBlockEditContext(); 9980 const setting = (0,external_wp_data_namespaceObject.useSelect)(select => { 9981 var _get; 9982 9983 if (blockedPaths.includes(path)) { 9984 // eslint-disable-next-line no-console 9985 console.warn('Top level useSetting paths are disabled. Please use a subpath to query the information needed.'); 9986 return undefined; 9987 } 9988 9989 const settings = select(store).getSettings(); // 1 - Use __experimental features, if available. 9990 // We cascade to the all value if the block one is not available. 9991 9992 const normalizedPath = removeCustomPrefixes(path); 9993 const defaultsPath = `__experimentalFeatures.$normalizedPath}`; 9994 const blockPath = `__experimentalFeatures.blocks.$blockName}.$normalizedPath}`; 9995 const experimentalFeaturesResult = (_get = (0,external_lodash_namespaceObject.get)(settings, blockPath)) !== null && _get !== void 0 ? _get : (0,external_lodash_namespaceObject.get)(settings, defaultsPath); 9996 9997 if (experimentalFeaturesResult !== undefined) { 9998 if (external_wp_blocks_namespaceObject.__EXPERIMENTAL_PATHS_WITH_MERGE[normalizedPath]) { 9999 var _ref, _experimentalFeatures; 10000 10001 return (_ref = (_experimentalFeatures = experimentalFeaturesResult.custom) !== null && _experimentalFeatures !== void 0 ? _experimentalFeatures : experimentalFeaturesResult.theme) !== null && _ref !== void 0 ? _ref : experimentalFeaturesResult.default; 10002 } 10003 10004 return experimentalFeaturesResult; 10005 } // 2 - Use deprecated settings, otherwise. 10006 10007 10008 const deprecatedSettingsValue = deprecatedFlags[normalizedPath] ? deprecatedFlags[normalizedPath](settings) : undefined; 10009 10010 if (deprecatedSettingsValue !== undefined) { 10011 return deprecatedSettingsValue; 10012 } // 3 - Fall back for typography.dropCap: 10013 // This is only necessary to support typography.dropCap. 10014 // when __experimentalFeatures are not present (core without plugin). 10015 // To remove when __experimentalFeatures are ported to core. 10016 10017 10018 return normalizedPath === 'typography.dropCap' ? true : undefined; 10019 }, [blockName, path]); 10020 return setting; 10021 } 10022 10023 ;// CONCATENATED MODULE: external ["wp","warning"] 10024 var external_wp_warning_namespaceObject = window["wp"]["warning"]; 10025 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inspector-controls/groups.js 10026 /** 10027 * WordPress dependencies 10028 */ 10029 10030 const InspectorControlsDefault = (0,external_wp_components_namespaceObject.createSlotFill)('InspectorControls'); 10031 const InspectorControlsAdvanced = (0,external_wp_components_namespaceObject.createSlotFill)('InspectorAdvancedControls'); 10032 const InspectorControlsBorder = (0,external_wp_components_namespaceObject.createSlotFill)('InspectorControlsBorder'); 10033 const InspectorControlsColor = (0,external_wp_components_namespaceObject.createSlotFill)('InspectorControlsColor'); 10034 const InspectorControlsDimensions = (0,external_wp_components_namespaceObject.createSlotFill)('InspectorControlsDimensions'); 10035 const InspectorControlsTypography = (0,external_wp_components_namespaceObject.createSlotFill)('InspectorControlsTypography'); 10036 const groups_groups = { 10037 default: InspectorControlsDefault, 10038 advanced: InspectorControlsAdvanced, 10039 border: InspectorControlsBorder, 10040 color: InspectorControlsColor, 10041 dimensions: InspectorControlsDimensions, 10042 typography: InspectorControlsTypography 10043 }; 10044 /* harmony default export */ var inspector_controls_groups = (groups_groups); 10045 10046 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inspector-controls/fill.js 10047 10048 10049 /** 10050 * External dependencies 10051 */ 10052 10053 /** 10054 * WordPress dependencies 10055 */ 10056 10057 10058 10059 /** 10060 * Internal dependencies 10061 */ 10062 10063 10064 10065 function InspectorControlsFill(_ref) { 10066 var _groups$group; 10067 10068 let { 10069 __experimentalGroup: group = 'default', 10070 children 10071 } = _ref; 10072 const isDisplayed = useDisplayBlockControls(); 10073 const Fill = (_groups$group = inspector_controls_groups[group]) === null || _groups$group === void 0 ? void 0 : _groups$group.Fill; 10074 10075 if (!Fill) { 10076 typeof process !== "undefined" && process.env && "production" !== "production" ? 0 : void 0; 10077 return null; 10078 } 10079 10080 if (!isDisplayed) { 10081 return null; 10082 } 10083 10084 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalStyleProvider, { 10085 document: document 10086 }, (0,external_wp_element_namespaceObject.createElement)(Fill, null, fillProps => { 10087 // Children passed to InspectorControlsFill will not have 10088 // access to any React Context whose Provider is part of 10089 // the InspectorControlsSlot tree. So we re-create the 10090 // Provider in this subtree. 10091 const value = !(0,external_lodash_namespaceObject.isEmpty)(fillProps) ? fillProps : null; 10092 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToolsPanelContext.Provider, { 10093 value: value 10094 }, children); 10095 })); 10096 } 10097 10098 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/hooks/utils.js 10099 /** 10100 * External dependencies 10101 */ 10102 10103 /** 10104 * WordPress dependencies 10105 */ 10106 10107 10108 /** 10109 * Removed falsy values from nested object. 10110 * 10111 * @param {*} object 10112 * @return {*} Object cleaned from falsy values 10113 */ 10114 10115 const cleanEmptyObject = object => { 10116 if (!(0,external_lodash_namespaceObject.isObject)(object) || Array.isArray(object)) { 10117 return object; 10118 } 10119 10120 const cleanedNestedObjects = (0,external_lodash_namespaceObject.pickBy)((0,external_lodash_namespaceObject.mapValues)(object, cleanEmptyObject), external_lodash_namespaceObject.identity); 10121 return (0,external_lodash_namespaceObject.isEmpty)(cleanedNestedObjects) ? undefined : cleanedNestedObjects; 10122 }; 10123 function immutableSet(object, path, value) { 10124 return (0,external_lodash_namespaceObject.setWith)(object ? (0,external_lodash_namespaceObject.clone)(object) : {}, path, value, external_lodash_namespaceObject.clone); 10125 } 10126 function transformStyles(activeSupports, migrationPaths, result, source, index, results) { 10127 var _source$; 10128 10129 // If there are no active supports return early. 10130 if ((0,external_lodash_namespaceObject.every)(activeSupports, isActive => !isActive)) { 10131 return result; 10132 } // If the condition verifies we are probably in the presence of a wrapping transform 10133 // e.g: nesting paragraphs in a group or columns and in that case the styles should not be transformed. 10134 10135 10136 if (results.length === 1 && result.innerBlocks.length === source.length) { 10137 return result; 10138 } // For cases where we have a transform from one block to multiple blocks 10139 // or multiple blocks to one block we apply the styles of the first source block 10140 // to the result(s). 10141 10142 10143 let referenceBlockAttributes = (_source$ = source[0]) === null || _source$ === void 0 ? void 0 : _source$.attributes; // If we are in presence of transform between more than one block in the source 10144 // that has more than one block in the result 10145 // we apply the styles on source N to the result N, 10146 // if source N does not exists we do nothing. 10147 10148 if (results.length > 1 && source.length > 1) { 10149 if (source[index]) { 10150 var _source$index; 10151 10152 referenceBlockAttributes = (_source$index = source[index]) === null || _source$index === void 0 ? void 0 : _source$index.attributes; 10153 } else { 10154 return result; 10155 } 10156 } 10157 10158 let returnBlock = result; 10159 (0,external_lodash_namespaceObject.forEach)(activeSupports, (isActive, support) => { 10160 if (isActive) { 10161 migrationPaths[support].forEach(path => { 10162 const styleValue = (0,external_lodash_namespaceObject.get)(referenceBlockAttributes, path); 10163 10164 if (styleValue) { 10165 returnBlock = { ...returnBlock, 10166 attributes: immutableSet(returnBlock.attributes, path, styleValue) 10167 }; 10168 } 10169 }); 10170 } 10171 }); 10172 return returnBlock; 10173 } 10174 /** 10175 * Check whether serialization of specific block support feature or set should 10176 * be skipped. 10177 * 10178 * @param {string|Object} blockType Block name or block type object. 10179 * @param {string} featureSet Name of block support feature set. 10180 * @param {string} feature Name of the individual feature to check. 10181 * 10182 * @return {boolean} Whether serialization should occur. 10183 */ 10184 10185 function shouldSkipSerialization(blockType, featureSet, feature) { 10186 const support = (0,external_wp_blocks_namespaceObject.getBlockSupport)(blockType, featureSet); 10187 const skipSerialization = support === null || support === void 0 ? void 0 : support.__experimentalSkipSerialization; 10188 10189 if (Array.isArray(skipSerialization)) { 10190 return skipSerialization.includes(feature); 10191 } 10192 10193 return skipSerialization; 10194 } 10195 10196 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inspector-controls/block-support-tools-panel.js 10197 10198 10199 /** 10200 * WordPress dependencies 10201 */ 10202 10203 10204 10205 /** 10206 * Internal dependencies 10207 */ 10208 10209 10210 10211 function BlockSupportToolsPanel(_ref) { 10212 let { 10213 children, 10214 group, 10215 label 10216 } = _ref; 10217 const { 10218 updateBlockAttributes 10219 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 10220 const { 10221 getBlockAttributes, 10222 getMultiSelectedBlockClientIds, 10223 getSelectedBlockClientId, 10224 hasMultiSelection 10225 } = (0,external_wp_data_namespaceObject.useSelect)(store); 10226 const panelId = getSelectedBlockClientId(); 10227 const resetAll = (0,external_wp_element_namespaceObject.useCallback)(function () { 10228 let resetFilters = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : []; 10229 const newAttributes = {}; 10230 const clientIds = hasMultiSelection() ? getMultiSelectedBlockClientIds() : [panelId]; 10231 clientIds.forEach(clientId => { 10232 const { 10233 style 10234 } = getBlockAttributes(clientId); 10235 let newBlockAttributes = { 10236 style 10237 }; 10238 resetFilters.forEach(resetFilter => { 10239 newBlockAttributes = { ...newBlockAttributes, 10240 ...resetFilter(newBlockAttributes) 10241 }; 10242 }); // Enforce a cleaned style object. 10243 10244 newBlockAttributes = { ...newBlockAttributes, 10245 style: cleanEmptyObject(newBlockAttributes.style) 10246 }; 10247 newAttributes[clientId] = newBlockAttributes; 10248 }); 10249 updateBlockAttributes(clientIds, newAttributes, true); 10250 }, [cleanEmptyObject, getBlockAttributes, getMultiSelectedBlockClientIds, hasMultiSelection, panelId, updateBlockAttributes]); 10251 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToolsPanel, { 10252 className: `$group}-block-support-panel`, 10253 label: label, 10254 resetAll: resetAll, 10255 key: panelId, 10256 panelId: panelId, 10257 hasInnerWrapper: true, 10258 shouldRenderPlaceholderItems: true // Required to maintain fills ordering. 10259 , 10260 __experimentalFirstVisibleItemClass: "first", 10261 __experimentalLastVisibleItemClass: "last" 10262 }, children); 10263 } 10264 10265 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inspector-controls/block-support-slot-container.js 10266 10267 10268 10269 /** 10270 * WordPress dependencies 10271 */ 10272 10273 10274 function BlockSupportSlotContainer(_ref) { 10275 let { 10276 Slot, 10277 ...props 10278 } = _ref; 10279 const toolsPanelContext = (0,external_wp_element_namespaceObject.useContext)(external_wp_components_namespaceObject.__experimentalToolsPanelContext); 10280 return (0,external_wp_element_namespaceObject.createElement)(Slot, _extends({}, props, { 10281 fillProps: toolsPanelContext, 10282 bubblesVirtually: true 10283 })); 10284 } 10285 10286 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inspector-controls/slot.js 10287 10288 10289 10290 /** 10291 * WordPress dependencies 10292 */ 10293 10294 10295 /** 10296 * Internal dependencies 10297 */ 10298 10299 10300 10301 10302 function InspectorControlsSlot(_ref) { 10303 var _groups$group; 10304 10305 let { 10306 __experimentalGroup: group = 'default', 10307 label, 10308 ...props 10309 } = _ref; 10310 const Slot = (_groups$group = inspector_controls_groups[group]) === null || _groups$group === void 0 ? void 0 : _groups$group.Slot; 10311 const slot = (0,external_wp_components_namespaceObject.__experimentalUseSlot)(Slot === null || Slot === void 0 ? void 0 : Slot.__unstableName); 10312 10313 if (!Slot || !slot) { 10314 typeof process !== "undefined" && process.env && "production" !== "production" ? 0 : void 0; 10315 return null; 10316 } 10317 10318 const hasFills = Boolean(slot.fills && slot.fills.length); 10319 10320 if (!hasFills) { 10321 return null; 10322 } 10323 10324 if (label) { 10325 return (0,external_wp_element_namespaceObject.createElement)(BlockSupportToolsPanel, { 10326 group: group, 10327 label: label 10328 }, (0,external_wp_element_namespaceObject.createElement)(BlockSupportSlotContainer, _extends({}, props, { 10329 Slot: Slot 10330 }))); 10331 } 10332 10333 return (0,external_wp_element_namespaceObject.createElement)(Slot, _extends({}, props, { 10334 bubblesVirtually: true 10335 })); 10336 } 10337 10338 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inspector-controls/index.js 10339 10340 10341 10342 /** 10343 * Internal dependencies 10344 */ 10345 10346 10347 const InspectorControls = InspectorControlsFill; 10348 InspectorControls.Slot = InspectorControlsSlot; // This is just here for backward compatibility. 10349 10350 const InspectorAdvancedControls = props => { 10351 return (0,external_wp_element_namespaceObject.createElement)(InspectorControlsFill, _extends({}, props, { 10352 __experimentalGroup: "advanced" 10353 })); 10354 }; 10355 10356 InspectorAdvancedControls.Slot = props => { 10357 return (0,external_wp_element_namespaceObject.createElement)(InspectorControlsSlot, _extends({}, props, { 10358 __experimentalGroup: "advanced" 10359 })); 10360 }; 10361 10362 InspectorAdvancedControls.slotName = 'InspectorAdvancedControls'; 10363 /** 10364 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/inspector-controls/README.md 10365 */ 10366 10367 /* harmony default export */ var inspector_controls = (InspectorControls); 10368 10369 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/hooks/margin.js 10370 10371 10372 /** 10373 * WordPress dependencies 10374 */ 10375 10376 10377 10378 10379 /** 10380 * Internal dependencies 10381 */ 10382 10383 10384 10385 10386 /** 10387 * Determines if there is margin support. 10388 * 10389 * @param {string|Object} blockType Block name or Block Type object. 10390 * 10391 * @return {boolean} Whether there is support. 10392 */ 10393 10394 function hasMarginSupport(blockType) { 10395 const support = (0,external_wp_blocks_namespaceObject.getBlockSupport)(blockType, SPACING_SUPPORT_KEY); 10396 return !!(true === support || support !== null && support !== void 0 && support.margin); 10397 } 10398 /** 10399 * Checks if there is a current value in the margin block support attributes. 10400 * 10401 * @param {Object} props Block props. 10402 * @return {boolean} Whether or not the block has a margin value set. 10403 */ 10404 10405 function hasMarginValue(props) { 10406 var _props$attributes$sty, _props$attributes$sty2; 10407 10408 return ((_props$attributes$sty = props.attributes.style) === null || _props$attributes$sty === void 0 ? void 0 : (_props$attributes$sty2 = _props$attributes$sty.spacing) === null || _props$attributes$sty2 === void 0 ? void 0 : _props$attributes$sty2.margin) !== undefined; 10409 } 10410 /** 10411 * Resets the margin block support attributes. This can be used when disabling 10412 * the margin support controls for a block via a `ToolsPanel`. 10413 * 10414 * @param {Object} props Block props. 10415 * @param {Object} props.attributes Block's attributes. 10416 * @param {Object} props.setAttributes Function to set block's attributes. 10417 */ 10418 10419 function resetMargin(_ref) { 10420 let { 10421 attributes = {}, 10422 setAttributes 10423 } = _ref; 10424 const { 10425 style 10426 } = attributes; 10427 setAttributes({ 10428 style: cleanEmptyObject({ ...style, 10429 spacing: { ...(style === null || style === void 0 ? void 0 : style.spacing), 10430 margin: undefined 10431 } 10432 }) 10433 }); 10434 } 10435 /** 10436 * Custom hook that checks if margin settings have been disabled. 10437 * 10438 * @param {string} name The name of the block. 10439 * 10440 * @return {boolean} Whether margin setting is disabled. 10441 */ 10442 10443 function useIsMarginDisabled() { 10444 let { 10445 name: blockName 10446 } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; 10447 const isDisabled = !useSetting('spacing.margin'); 10448 const isInvalid = !useIsDimensionsSupportValid(blockName, 'margin'); 10449 return !hasMarginSupport(blockName) || isDisabled || isInvalid; 10450 } 10451 /** 10452 * Inspector control panel containing the margin related configuration 10453 * 10454 * @param {Object} props Block props. 10455 * 10456 * @return {WPElement} Margin edit element. 10457 */ 10458 10459 function MarginEdit(props) { 10460 var _style$spacing; 10461 10462 const { 10463 name: blockName, 10464 attributes: { 10465 style 10466 }, 10467 setAttributes 10468 } = props; 10469 const units = (0,external_wp_components_namespaceObject.__experimentalUseCustomUnits)({ 10470 availableUnits: useSetting('spacing.units') || ['%', 'px', 'em', 'rem', 'vw'] 10471 }); 10472 const sides = useCustomSides(blockName, 'margin'); 10473 const splitOnAxis = sides && sides.some(side => AXIAL_SIDES.includes(side)); 10474 10475 if (useIsMarginDisabled(props)) { 10476 return null; 10477 } 10478 10479 const onChange = next => { 10480 const newStyle = { ...style, 10481 spacing: { ...(style === null || style === void 0 ? void 0 : style.spacing), 10482 margin: next 10483 } 10484 }; 10485 setAttributes({ 10486 style: cleanEmptyObject(newStyle) 10487 }); 10488 }; 10489 10490 const onChangeShowVisualizer = next => { 10491 const newStyle = { ...style, 10492 visualizers: { 10493 margin: next 10494 } 10495 }; 10496 setAttributes({ 10497 style: cleanEmptyObject(newStyle) 10498 }); 10499 }; 10500 10501 return external_wp_element_namespaceObject.Platform.select({ 10502 web: (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalBoxControl, { 10503 values: style === null || style === void 0 ? void 0 : (_style$spacing = style.spacing) === null || _style$spacing === void 0 ? void 0 : _style$spacing.margin, 10504 onChange: onChange, 10505 onChangeShowVisualizer: onChangeShowVisualizer, 10506 label: (0,external_wp_i18n_namespaceObject.__)('Margin'), 10507 sides: sides, 10508 units: units, 10509 allowReset: false, 10510 splitOnAxis: splitOnAxis 10511 })), 10512 native: null 10513 }); 10514 } 10515 10516 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/hooks/padding.js 10517 10518 10519 /** 10520 * WordPress dependencies 10521 */ 10522 10523 10524 10525 10526 /** 10527 * Internal dependencies 10528 */ 10529 10530 10531 10532 10533 /** 10534 * Determines if there is padding support. 10535 * 10536 * @param {string|Object} blockType Block name or Block Type object. 10537 * 10538 * @return {boolean} Whether there is support. 10539 */ 10540 10541 function hasPaddingSupport(blockType) { 10542 const support = (0,external_wp_blocks_namespaceObject.getBlockSupport)(blockType, SPACING_SUPPORT_KEY); 10543 return !!(true === support || support !== null && support !== void 0 && support.padding); 10544 } 10545 /** 10546 * Checks if there is a current value in the padding block support attributes. 10547 * 10548 * @param {Object} props Block props. 10549 * @return {boolean} Whether or not the block has a padding value set. 10550 */ 10551 10552 function hasPaddingValue(props) { 10553 var _props$attributes$sty, _props$attributes$sty2; 10554 10555 return ((_props$attributes$sty = props.attributes.style) === null || _props$attributes$sty === void 0 ? void 0 : (_props$attributes$sty2 = _props$attributes$sty.spacing) === null || _props$attributes$sty2 === void 0 ? void 0 : _props$attributes$sty2.padding) !== undefined; 10556 } 10557 /** 10558 * Resets the padding block support attributes. This can be used when disabling 10559 * the padding support controls for a block via a `ToolsPanel`. 10560 * 10561 * @param {Object} props Block props. 10562 * @param {Object} props.attributes Block's attributes. 10563 * @param {Object} props.setAttributes Function to set block's attributes. 10564 */ 10565 10566 function resetPadding(_ref) { 10567 let { 10568 attributes = {}, 10569 setAttributes 10570 } = _ref; 10571 const { 10572 style 10573 } = attributes; 10574 setAttributes({ 10575 style: cleanEmptyObject({ ...style, 10576 spacing: { ...(style === null || style === void 0 ? void 0 : style.spacing), 10577 padding: undefined 10578 } 10579 }) 10580 }); 10581 } 10582 /** 10583 * Custom hook that checks if padding settings have been disabled. 10584 * 10585 * @param {string} name The name of the block. 10586 * 10587 * @return {boolean} Whether padding setting is disabled. 10588 */ 10589 10590 function useIsPaddingDisabled() { 10591 let { 10592 name: blockName 10593 } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; 10594 const isDisabled = !useSetting('spacing.padding'); 10595 const isInvalid = !useIsDimensionsSupportValid(blockName, 'padding'); 10596 return !hasPaddingSupport(blockName) || isDisabled || isInvalid; 10597 } 10598 /** 10599 * Inspector control panel containing the padding related configuration 10600 * 10601 * @param {Object} props 10602 * 10603 * @return {WPElement} Padding edit element. 10604 */ 10605 10606 function PaddingEdit(props) { 10607 var _style$spacing; 10608 10609 const { 10610 name: blockName, 10611 attributes: { 10612 style 10613 }, 10614 setAttributes 10615 } = props; 10616 const units = (0,external_wp_components_namespaceObject.__experimentalUseCustomUnits)({ 10617 availableUnits: useSetting('spacing.units') || ['%', 'px', 'em', 'rem', 'vw'] 10618 }); 10619 const sides = useCustomSides(blockName, 'padding'); 10620 const splitOnAxis = sides && sides.some(side => AXIAL_SIDES.includes(side)); 10621 10622 if (useIsPaddingDisabled(props)) { 10623 return null; 10624 } 10625 10626 const onChange = next => { 10627 const newStyle = { ...style, 10628 spacing: { ...(style === null || style === void 0 ? void 0 : style.spacing), 10629 padding: next 10630 } 10631 }; 10632 setAttributes({ 10633 style: cleanEmptyObject(newStyle) 10634 }); 10635 }; 10636 10637 const onChangeShowVisualizer = next => { 10638 const newStyle = { ...style, 10639 visualizers: { 10640 padding: next 10641 } 10642 }; 10643 setAttributes({ 10644 style: cleanEmptyObject(newStyle) 10645 }); 10646 }; 10647 10648 return external_wp_element_namespaceObject.Platform.select({ 10649 web: (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalBoxControl, { 10650 values: style === null || style === void 0 ? void 0 : (_style$spacing = style.spacing) === null || _style$spacing === void 0 ? void 0 : _style$spacing.padding, 10651 onChange: onChange, 10652 onChangeShowVisualizer: onChangeShowVisualizer, 10653 label: (0,external_wp_i18n_namespaceObject.__)('Padding'), 10654 sides: sides, 10655 units: units, 10656 allowReset: false, 10657 splitOnAxis: splitOnAxis 10658 })), 10659 native: null 10660 }); 10661 } 10662 10663 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/hooks/dimensions.js 10664 10665 10666 /** 10667 * WordPress dependencies 10668 */ 10669 10670 10671 10672 10673 /** 10674 * Internal dependencies 10675 */ 10676 10677 10678 10679 10680 10681 const SPACING_SUPPORT_KEY = 'spacing'; 10682 const ALL_SIDES = ['top', 'right', 'bottom', 'left']; 10683 const AXIAL_SIDES = ['vertical', 'horizontal']; 10684 /** 10685 * Inspector controls for dimensions support. 10686 * 10687 * @param {Object} props Block props. 10688 * 10689 * @return {WPElement} Inspector controls for spacing support features. 10690 */ 10691 10692 function DimensionsPanel(props) { 10693 const isGapDisabled = useIsGapDisabled(props); 10694 const isPaddingDisabled = useIsPaddingDisabled(props); 10695 const isMarginDisabled = useIsMarginDisabled(props); 10696 const isDisabled = useIsDimensionsDisabled(props); 10697 const isSupported = hasDimensionsSupport(props.name); 10698 10699 if (isDisabled || !isSupported) { 10700 return null; 10701 } 10702 10703 const defaultSpacingControls = (0,external_wp_blocks_namespaceObject.getBlockSupport)(props.name, [SPACING_SUPPORT_KEY, '__experimentalDefaultControls']); 10704 10705 const createResetAllFilter = attribute => newAttributes => { 10706 var _newAttributes$style; 10707 10708 return { ...newAttributes, 10709 style: { ...newAttributes.style, 10710 spacing: { ...((_newAttributes$style = newAttributes.style) === null || _newAttributes$style === void 0 ? void 0 : _newAttributes$style.spacing), 10711 [attribute]: undefined 10712 } 10713 } 10714 }; 10715 }; 10716 10717 return (0,external_wp_element_namespaceObject.createElement)(inspector_controls, { 10718 __experimentalGroup: "dimensions" 10719 }, !isPaddingDisabled && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToolsPanelItem, { 10720 hasValue: () => hasPaddingValue(props), 10721 label: (0,external_wp_i18n_namespaceObject.__)('Padding'), 10722 onDeselect: () => resetPadding(props), 10723 resetAllFilter: createResetAllFilter('padding'), 10724 isShownByDefault: defaultSpacingControls === null || defaultSpacingControls === void 0 ? void 0 : defaultSpacingControls.padding, 10725 panelId: props.clientId 10726 }, (0,external_wp_element_namespaceObject.createElement)(PaddingEdit, props)), !isMarginDisabled && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToolsPanelItem, { 10727 hasValue: () => hasMarginValue(props), 10728 label: (0,external_wp_i18n_namespaceObject.__)('Margin'), 10729 onDeselect: () => resetMargin(props), 10730 resetAllFilter: createResetAllFilter('margin'), 10731 isShownByDefault: defaultSpacingControls === null || defaultSpacingControls === void 0 ? void 0 : defaultSpacingControls.margin, 10732 panelId: props.clientId 10733 }, (0,external_wp_element_namespaceObject.createElement)(MarginEdit, props)), !isGapDisabled && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToolsPanelItem, { 10734 hasValue: () => hasGapValue(props), 10735 label: (0,external_wp_i18n_namespaceObject.__)('Block spacing'), 10736 onDeselect: () => resetGap(props), 10737 resetAllFilter: createResetAllFilter('blockGap'), 10738 isShownByDefault: defaultSpacingControls === null || defaultSpacingControls === void 0 ? void 0 : defaultSpacingControls.blockGap, 10739 panelId: props.clientId 10740 }, (0,external_wp_element_namespaceObject.createElement)(GapEdit, props))); 10741 } 10742 /** 10743 * Determine whether there is dimensions related block support. 10744 * 10745 * @param {string} blockName Block name. 10746 * 10747 * @return {boolean} Whether there is support. 10748 */ 10749 10750 function hasDimensionsSupport(blockName) { 10751 if (external_wp_element_namespaceObject.Platform.OS !== 'web') { 10752 return false; 10753 } 10754 10755 return hasGapSupport(blockName) || hasPaddingSupport(blockName) || hasMarginSupport(blockName); 10756 } 10757 /** 10758 * Determines whether dimensions support has been disabled. 10759 * 10760 * @param {Object} props Block properties. 10761 * 10762 * @return {boolean} If spacing support is completely disabled. 10763 */ 10764 10765 const useIsDimensionsDisabled = function () { 10766 let props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; 10767 const gapDisabled = useIsGapDisabled(props); 10768 const paddingDisabled = useIsPaddingDisabled(props); 10769 const marginDisabled = useIsMarginDisabled(props); 10770 return gapDisabled && paddingDisabled && marginDisabled; 10771 }; 10772 /** 10773 * Custom hook to retrieve which padding/margin is supported 10774 * e.g. top, right, bottom or left. 10775 * 10776 * Sides are opted into by default. It is only if a specific side is set to 10777 * false that it is omitted. 10778 * 10779 * @param {string} blockName Block name. 10780 * @param {string} feature The feature custom sides relate to e.g. padding or margins. 10781 * 10782 * @return {Object} Sides supporting custom margin. 10783 */ 10784 10785 10786 function useCustomSides(blockName, feature) { 10787 const support = (0,external_wp_blocks_namespaceObject.getBlockSupport)(blockName, SPACING_SUPPORT_KEY); // Skip when setting is boolean as theme isn't setting arbitrary sides. 10788 10789 if (!support || typeof support[feature] === 'boolean') { 10790 return; 10791 } 10792 10793 return support[feature]; 10794 } 10795 /** 10796 * Custom hook to determine whether the sides configured in the 10797 * block support are valid. A dimension property cannot declare 10798 * support for a mix of axial and individual sides. 10799 * 10800 * @param {string} blockName Block name. 10801 * @param {string} feature The feature custom sides relate to e.g. padding or margins. 10802 * 10803 * @return {boolean} If the feature has a valid configuration of sides. 10804 */ 10805 10806 function useIsDimensionsSupportValid(blockName, feature) { 10807 const sides = useCustomSides(blockName, feature); 10808 10809 if (sides && sides.some(side => ALL_SIDES.includes(side)) && sides.some(side => AXIAL_SIDES.includes(side))) { 10810 // eslint-disable-next-line no-console 10811 console.warn(`The $feature} support for the "$blockName}" block can not be configured to support both axial and arbitrary sides.`); 10812 return false; 10813 } 10814 10815 return true; 10816 } 10817 10818 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/hooks/gap.js 10819 10820 10821 /** 10822 * WordPress dependencies 10823 */ 10824 10825 10826 10827 10828 /** 10829 * Internal dependencies 10830 */ 10831 10832 10833 10834 10835 10836 /** 10837 * Determines if there is gap support. 10838 * 10839 * @param {string|Object} blockType Block name or Block Type object. 10840 * @return {boolean} Whether there is support. 10841 */ 10842 10843 function hasGapSupport(blockType) { 10844 const support = (0,external_wp_blocks_namespaceObject.getBlockSupport)(blockType, SPACING_SUPPORT_KEY); 10845 return !!(true === support || support !== null && support !== void 0 && support.blockGap); 10846 } 10847 /** 10848 * Checks if there is a current value in the gap block support attributes. 10849 * 10850 * @param {Object} props Block props. 10851 * @return {boolean} Whether or not the block has a gap value set. 10852 */ 10853 10854 function hasGapValue(props) { 10855 var _props$attributes$sty, _props$attributes$sty2; 10856 10857 return ((_props$attributes$sty = props.attributes.style) === null || _props$attributes$sty === void 0 ? void 0 : (_props$attributes$sty2 = _props$attributes$sty.spacing) === null || _props$attributes$sty2 === void 0 ? void 0 : _props$attributes$sty2.blockGap) !== undefined; 10858 } 10859 /** 10860 * Returns a BoxControl object value from a given blockGap style value. 10861 * The string check is for backwards compatibility before Gutenberg supported 10862 * split gap values (row and column) and the value was a string n + unit. 10863 * 10864 * @param {string? | Object?} blockGapValue A block gap string or axial object value, e.g., '10px' or { top: '10px', left: '10px'}. 10865 * @return {Object|null} A value to pass to the BoxControl component. 10866 */ 10867 10868 function getGapBoxControlValueFromStyle(blockGapValue) { 10869 if (!blockGapValue) { 10870 return null; 10871 } 10872 10873 const isValueString = typeof blockGapValue === 'string'; 10874 return { 10875 top: isValueString ? blockGapValue : blockGapValue === null || blockGapValue === void 0 ? void 0 : blockGapValue.top, 10876 left: isValueString ? blockGapValue : blockGapValue === null || blockGapValue === void 0 ? void 0 : blockGapValue.left 10877 }; 10878 } 10879 /** 10880 * Returns a CSS value for the `gap` property from a given blockGap style. 10881 * 10882 * @param {string? | Object?} blockGapValue A block gap string or axial object value, e.g., '10px' or { top: '10px', left: '10px'}. 10883 * @param {string?} defaultValue A default gap value. 10884 * @return {string|null} The concatenated gap value (row and column). 10885 */ 10886 10887 function getGapCSSValue(blockGapValue) { 10888 let defaultValue = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '0'; 10889 const blockGapBoxControlValue = getGapBoxControlValueFromStyle(blockGapValue); 10890 10891 if (!blockGapBoxControlValue) { 10892 return null; 10893 } 10894 10895 const row = (blockGapBoxControlValue === null || blockGapBoxControlValue === void 0 ? void 0 : blockGapBoxControlValue.top) || defaultValue; 10896 const column = (blockGapBoxControlValue === null || blockGapBoxControlValue === void 0 ? void 0 : blockGapBoxControlValue.left) || defaultValue; 10897 return row === column ? row : `$row} $column}`; 10898 } 10899 /** 10900 * Resets the gap block support attribute. This can be used when disabling 10901 * the gap support controls for a block via a progressive discovery panel. 10902 * 10903 * @param {Object} props Block props. 10904 * @param {Object} props.attributes Block's attributes. 10905 * @param {Object} props.setAttributes Function to set block's attributes. 10906 */ 10907 10908 function resetGap(_ref) { 10909 let { 10910 attributes = {}, 10911 setAttributes 10912 } = _ref; 10913 const { 10914 style 10915 } = attributes; 10916 setAttributes({ 10917 style: { ...style, 10918 spacing: { ...(style === null || style === void 0 ? void 0 : style.spacing), 10919 blockGap: undefined 10920 } 10921 } 10922 }); 10923 } 10924 /** 10925 * Custom hook that checks if gap settings have been disabled. 10926 * 10927 * @param {string} name The name of the block. 10928 * @return {boolean} Whether the gap setting is disabled. 10929 */ 10930 10931 function useIsGapDisabled() { 10932 let { 10933 name: blockName 10934 } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; 10935 const isDisabled = !useSetting('spacing.blockGap'); 10936 return !hasGapSupport(blockName) || isDisabled; 10937 } 10938 /** 10939 * Inspector control panel containing the gap related configuration 10940 * 10941 * @param {Object} props 10942 * 10943 * @return {WPElement} Gap edit element. 10944 */ 10945 10946 function GapEdit(props) { 10947 var _style$spacing; 10948 10949 const { 10950 clientId, 10951 attributes: { 10952 style 10953 }, 10954 name: blockName, 10955 setAttributes 10956 } = props; 10957 const units = (0,external_wp_components_namespaceObject.__experimentalUseCustomUnits)({ 10958 availableUnits: useSetting('spacing.units') || ['%', 'px', 'em', 'rem', 'vw'] 10959 }); 10960 const sides = useCustomSides(blockName, 'blockGap'); 10961 const ref = useBlockRef(clientId); 10962 10963 if (useIsGapDisabled(props)) { 10964 return null; 10965 } 10966 10967 const splitOnAxis = sides && sides.some(side => AXIAL_SIDES.includes(side)); 10968 10969 const onChange = next => { 10970 var _window; 10971 10972 let blockGap = next; // If splitOnAxis activated we need to return a BoxControl object to the BoxControl component. 10973 10974 if (!!next && splitOnAxis) { 10975 blockGap = { ...getGapBoxControlValueFromStyle(next) 10976 }; 10977 } 10978 10979 const newStyle = { ...style, 10980 spacing: { ...(style === null || style === void 0 ? void 0 : style.spacing), 10981 blockGap 10982 } 10983 }; 10984 setAttributes({ 10985 style: cleanEmptyObject(newStyle) 10986 }); // In Safari, changing the `gap` CSS value on its own will not trigger the layout 10987 // to be recalculated / re-rendered. To force the updated gap to re-render, here 10988 // we replace the block's node with itself. 10989 10990 const isSafari = ((_window = window) === null || _window === void 0 ? void 0 : _window.navigator.userAgent) && window.navigator.userAgent.includes('Safari') && !window.navigator.userAgent.includes('Chrome ') && !window.navigator.userAgent.includes('Chromium '); 10991 10992 if (ref.current && isSafari) { 10993 var _ref$current$parentNo; 10994 10995 (_ref$current$parentNo = ref.current.parentNode) === null || _ref$current$parentNo === void 0 ? void 0 : _ref$current$parentNo.replaceChild(ref.current, ref.current); 10996 } 10997 }; 10998 10999 const gapValue = getGapBoxControlValueFromStyle(style === null || style === void 0 ? void 0 : (_style$spacing = style.spacing) === null || _style$spacing === void 0 ? void 0 : _style$spacing.blockGap); // The BoxControl component expects a full complement of side values. 11000 // Gap row and column values translate to top/bottom and left/right respectively. 11001 11002 const boxControlGapValue = splitOnAxis ? { ...gapValue, 11003 right: gapValue === null || gapValue === void 0 ? void 0 : gapValue.left, 11004 bottom: gapValue === null || gapValue === void 0 ? void 0 : gapValue.top 11005 } : gapValue === null || gapValue === void 0 ? void 0 : gapValue.top; 11006 return external_wp_element_namespaceObject.Platform.select({ 11007 web: (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, splitOnAxis ? (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalBoxControl, { 11008 label: (0,external_wp_i18n_namespaceObject.__)('Block spacing'), 11009 min: 0, 11010 onChange: onChange, 11011 units: units, 11012 sides: sides, 11013 values: boxControlGapValue, 11014 allowReset: false, 11015 splitOnAxis: splitOnAxis 11016 }) : (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalUnitControl, { 11017 label: (0,external_wp_i18n_namespaceObject.__)('Block spacing'), 11018 __unstableInputWidth: "80px", 11019 min: 0, 11020 onChange: onChange, 11021 units: units // Default to `row` for combined values. 11022 , 11023 value: boxControlGapValue 11024 })), 11025 native: null 11026 }); 11027 } 11028 11029 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-vertical-alignment-control/icons.js 11030 11031 11032 /** 11033 * WordPress dependencies 11034 */ 11035 11036 const alignBottom = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, { 11037 xmlns: "http://www.w3.org/2000/svg", 11038 viewBox: "0 0 24 24" 11039 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, { 11040 d: "M15 4H9v11h6V4zM4 18.5V20h16v-1.5H4z" 11041 })); 11042 const alignCenter = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, { 11043 xmlns: "http://www.w3.org/2000/svg", 11044 viewBox: "0 0 24 24" 11045 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, { 11046 d: "M20 11h-5V4H9v7H4v1.5h5V20h6v-7.5h5z" 11047 })); 11048 const alignTop = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, { 11049 xmlns: "http://www.w3.org/2000/svg", 11050 viewBox: "0 0 24 24" 11051 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, { 11052 d: "M9 20h6V9H9v11zM4 4v1.5h16V4H4z" 11053 })); 11054 11055 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-vertical-alignment-control/ui.js 11056 11057 11058 11059 /** 11060 * WordPress dependencies 11061 */ 11062 11063 11064 /** 11065 * Internal dependencies 11066 */ 11067 11068 11069 const BLOCK_ALIGNMENTS_CONTROLS = { 11070 top: { 11071 icon: alignTop, 11072 title: (0,external_wp_i18n_namespaceObject._x)('Align top', 'Block vertical alignment setting') 11073 }, 11074 center: { 11075 icon: alignCenter, 11076 title: (0,external_wp_i18n_namespaceObject._x)('Align middle', 'Block vertical alignment setting') 11077 }, 11078 bottom: { 11079 icon: alignBottom, 11080 title: (0,external_wp_i18n_namespaceObject._x)('Align bottom', 'Block vertical alignment setting') 11081 } 11082 }; 11083 const DEFAULT_CONTROLS = ['top', 'center', 'bottom']; 11084 const DEFAULT_CONTROL = 'top'; 11085 const POPOVER_PROPS = { 11086 isAlternate: true 11087 }; 11088 11089 function BlockVerticalAlignmentUI(_ref) { 11090 let { 11091 value, 11092 onChange, 11093 controls = DEFAULT_CONTROLS, 11094 isCollapsed = true, 11095 isToolbar 11096 } = _ref; 11097 11098 function applyOrUnset(align) { 11099 return () => onChange(value === align ? undefined : align); 11100 } 11101 11102 const activeAlignment = BLOCK_ALIGNMENTS_CONTROLS[value]; 11103 const defaultAlignmentControl = BLOCK_ALIGNMENTS_CONTROLS[DEFAULT_CONTROL]; 11104 const UIComponent = isToolbar ? external_wp_components_namespaceObject.ToolbarGroup : external_wp_components_namespaceObject.ToolbarDropdownMenu; 11105 const extraProps = isToolbar ? { 11106 isCollapsed 11107 } : {}; 11108 return (0,external_wp_element_namespaceObject.createElement)(UIComponent, _extends({ 11109 popoverProps: POPOVER_PROPS, 11110 icon: activeAlignment ? activeAlignment.icon : defaultAlignmentControl.icon, 11111 label: (0,external_wp_i18n_namespaceObject._x)('Change vertical alignment', 'Block vertical alignment setting label'), 11112 controls: controls.map(control => { 11113 return { ...BLOCK_ALIGNMENTS_CONTROLS[control], 11114 isActive: value === control, 11115 role: isCollapsed ? 'menuitemradio' : undefined, 11116 onClick: applyOrUnset(control) 11117 }; 11118 }) 11119 }, extraProps)); 11120 } 11121 /** 11122 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/block-vertical-alignment-toolbar/README.md 11123 */ 11124 11125 11126 /* harmony default export */ var ui = (BlockVerticalAlignmentUI); 11127 11128 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-vertical-alignment-control/index.js 11129 11130 11131 11132 /** 11133 * Internal dependencies 11134 */ 11135 11136 11137 const BlockVerticalAlignmentControl = props => { 11138 return (0,external_wp_element_namespaceObject.createElement)(ui, _extends({}, props, { 11139 isToolbar: false 11140 })); 11141 }; 11142 11143 const BlockVerticalAlignmentToolbar = props => { 11144 return (0,external_wp_element_namespaceObject.createElement)(ui, _extends({}, props, { 11145 isToolbar: true 11146 })); 11147 }; 11148 /** 11149 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/block-vertical-alignment-control/README.md 11150 */ 11151 11152 11153 11154 11155 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/justify-content-control/ui.js 11156 11157 11158 11159 /** 11160 * WordPress dependencies 11161 */ 11162 11163 11164 11165 const icons = { 11166 left: justify_left, 11167 center: justify_center, 11168 right: justify_right, 11169 'space-between': justify_space_between 11170 }; 11171 11172 function JustifyContentUI(_ref) { 11173 let { 11174 allowedControls = ['left', 'center', 'right', 'space-between'], 11175 isCollapsed = true, 11176 onChange, 11177 value, 11178 popoverProps, 11179 isToolbar 11180 } = _ref; 11181 11182 // If the control is already selected we want a click 11183 // again on the control to deselect the item, so we 11184 // call onChange( undefined ) 11185 const handleClick = next => { 11186 if (next === value) { 11187 onChange(undefined); 11188 } else { 11189 onChange(next); 11190 } 11191 }; 11192 11193 const icon = value ? icons[value] : icons.left; 11194 const allControls = [{ 11195 name: 'left', 11196 icon: justify_left, 11197 title: (0,external_wp_i18n_namespaceObject.__)('Justify items left'), 11198 isActive: 'left' === value, 11199 onClick: () => handleClick('left') 11200 }, { 11201 name: 'center', 11202 icon: justify_center, 11203 title: (0,external_wp_i18n_namespaceObject.__)('Justify items center'), 11204 isActive: 'center' === value, 11205 onClick: () => handleClick('center') 11206 }, { 11207 name: 'right', 11208 icon: justify_right, 11209 title: (0,external_wp_i18n_namespaceObject.__)('Justify items right'), 11210 isActive: 'right' === value, 11211 onClick: () => handleClick('right') 11212 }, { 11213 name: 'space-between', 11214 icon: justify_space_between, 11215 title: (0,external_wp_i18n_namespaceObject.__)('Space between items'), 11216 isActive: 'space-between' === value, 11217 onClick: () => handleClick('space-between') 11218 }]; 11219 const UIComponent = isToolbar ? external_wp_components_namespaceObject.ToolbarGroup : external_wp_components_namespaceObject.ToolbarDropdownMenu; 11220 const extraProps = isToolbar ? { 11221 isCollapsed 11222 } : {}; 11223 return (0,external_wp_element_namespaceObject.createElement)(UIComponent, _extends({ 11224 icon: icon, 11225 popoverProps: popoverProps, 11226 label: (0,external_wp_i18n_namespaceObject.__)('Change items justification'), 11227 controls: allControls.filter(elem => allowedControls.includes(elem.name)) 11228 }, extraProps)); 11229 } 11230 11231 /* harmony default export */ var justify_content_control_ui = (JustifyContentUI); 11232 11233 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/justify-content-control/index.js 11234 11235 11236 11237 /** 11238 * Internal dependencies 11239 */ 11240 11241 11242 const JustifyContentControl = props => { 11243 return (0,external_wp_element_namespaceObject.createElement)(justify_content_control_ui, _extends({}, props, { 11244 isToolbar: false 11245 })); 11246 }; 11247 11248 const JustifyToolbar = props => { 11249 return (0,external_wp_element_namespaceObject.createElement)(justify_content_control_ui, _extends({}, props, { 11250 isToolbar: true 11251 })); 11252 }; 11253 /** 11254 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/justify-content-control/README.md 11255 */ 11256 11257 11258 11259 11260 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/layouts/flex.js 11261 11262 11263 /** 11264 * WordPress dependencies 11265 */ 11266 11267 11268 11269 /** 11270 * Internal dependencies 11271 */ 11272 11273 11274 11275 11276 11277 // Used with the default, horizontal flex orientation. 11278 11279 const justifyContentMap = { 11280 left: 'flex-start', 11281 right: 'flex-end', 11282 center: 'center', 11283 'space-between': 'space-between' 11284 }; // Used with the vertical (column) flex orientation. 11285 11286 const alignItemsMap = { 11287 left: 'flex-start', 11288 right: 'flex-end', 11289 center: 'center' 11290 }; 11291 const verticalAlignmentMap = { 11292 top: 'flex-start', 11293 center: 'center', 11294 bottom: 'flex-end' 11295 }; 11296 const flexWrapOptions = ['wrap', 'nowrap']; 11297 /* harmony default export */ var flex = ({ 11298 name: 'flex', 11299 label: (0,external_wp_i18n_namespaceObject.__)('Flex'), 11300 inspectorControls: function FlexLayoutInspectorControls(_ref) { 11301 let { 11302 layout = {}, 11303 onChange, 11304 layoutBlockSupport = {} 11305 } = _ref; 11306 const { 11307 allowOrientation = true 11308 } = layoutBlockSupport; 11309 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Flex, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FlexItem, null, (0,external_wp_element_namespaceObject.createElement)(FlexLayoutJustifyContentControl, { 11310 layout: layout, 11311 onChange: onChange 11312 })), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FlexItem, null, allowOrientation && (0,external_wp_element_namespaceObject.createElement)(OrientationControl, { 11313 layout: layout, 11314 onChange: onChange 11315 }))), (0,external_wp_element_namespaceObject.createElement)(FlexWrapControl, { 11316 layout: layout, 11317 onChange: onChange 11318 })); 11319 }, 11320 toolBarControls: function FlexLayoutToolbarControls(_ref2) { 11321 let { 11322 layout = {}, 11323 onChange, 11324 layoutBlockSupport 11325 } = _ref2; 11326 11327 if (layoutBlockSupport !== null && layoutBlockSupport !== void 0 && layoutBlockSupport.allowSwitching) { 11328 return null; 11329 } 11330 11331 const { 11332 allowVerticalAlignment = true 11333 } = layoutBlockSupport; 11334 return (0,external_wp_element_namespaceObject.createElement)(block_controls, { 11335 group: "block", 11336 __experimentalShareWithChildBlocks: true 11337 }, (0,external_wp_element_namespaceObject.createElement)(FlexLayoutJustifyContentControl, { 11338 layout: layout, 11339 onChange: onChange, 11340 isToolbar: true 11341 }), allowVerticalAlignment && (layout === null || layout === void 0 ? void 0 : layout.orientation) !== 'vertical' && (0,external_wp_element_namespaceObject.createElement)(FlexLayoutVerticalAlignmentControl, { 11342 layout: layout, 11343 onChange: onChange, 11344 isToolbar: true 11345 })); 11346 }, 11347 save: function FlexLayoutStyle(_ref3) { 11348 var _style$spacing, _style$spacing2; 11349 11350 let { 11351 selector, 11352 layout, 11353 style, 11354 blockName 11355 } = _ref3; 11356 const { 11357 orientation = 'horizontal' 11358 } = layout; 11359 const blockGapSupport = useSetting('spacing.blockGap'); 11360 const hasBlockGapStylesSupport = blockGapSupport !== null; // If a block's block.json skips serialization for spacing or spacing.blockGap, 11361 // don't apply the user-defined value to the styles. 11362 11363 const blockGapValue = style !== null && style !== void 0 && (_style$spacing = style.spacing) !== null && _style$spacing !== void 0 && _style$spacing.blockGap && !shouldSkipSerialization(blockName, 'spacing', 'blockGap') ? getGapCSSValue(style === null || style === void 0 ? void 0 : (_style$spacing2 = style.spacing) === null || _style$spacing2 === void 0 ? void 0 : _style$spacing2.blockGap, '0.5em') : 'var( --wp--style--block-gap, 0.5em )'; 11364 const justifyContent = justifyContentMap[layout.justifyContent] || justifyContentMap.left; 11365 const flexWrap = flexWrapOptions.includes(layout.flexWrap) ? layout.flexWrap : 'wrap'; 11366 const verticalAlignment = verticalAlignmentMap[layout.verticalAlignment] || verticalAlignmentMap.center; 11367 const rowOrientation = ` 11368 flex-direction: row; 11369 align-items: $verticalAlignment}; 11370 justify-content: $justifyContent}; 11371 `; 11372 const alignItems = alignItemsMap[layout.justifyContent] || alignItemsMap.left; 11373 const columnOrientation = ` 11374 flex-direction: column; 11375 align-items: $alignItems}; 11376 `; 11377 return (0,external_wp_element_namespaceObject.createElement)("style", null, ` 11378 $appendSelectors(selector)} { 11379 display: flex; 11380 flex-wrap: $flexWrap}; 11381 gap: $hasBlockGapStylesSupport ? blockGapValue : '0.5em'}; 11382 $orientation === 'horizontal' ? rowOrientation : columnOrientation} 11383 } 11384 11385 $appendSelectors(selector, '> *')} { 11386 margin: 0; 11387 } 11388 `); 11389 }, 11390 11391 getOrientation(layout) { 11392 const { 11393 orientation = 'horizontal' 11394 } = layout; 11395 return orientation; 11396 }, 11397 11398 getAlignments() { 11399 return []; 11400 } 11401 11402 }); 11403 11404 function FlexLayoutVerticalAlignmentControl(_ref4) { 11405 let { 11406 layout, 11407 onChange, 11408 isToolbar = false 11409 } = _ref4; 11410 const { 11411 verticalAlignment = verticalAlignmentMap.center 11412 } = layout; 11413 11414 const onVerticalAlignmentChange = value => { 11415 onChange({ ...layout, 11416 verticalAlignment: value 11417 }); 11418 }; 11419 11420 if (isToolbar) { 11421 return (0,external_wp_element_namespaceObject.createElement)(BlockVerticalAlignmentControl, { 11422 onChange: onVerticalAlignmentChange, 11423 value: verticalAlignment 11424 }); 11425 } 11426 11427 const verticalAlignmentOptions = [{ 11428 value: 'flex-start', 11429 label: (0,external_wp_i18n_namespaceObject.__)('Align items top') 11430 }, { 11431 value: 'center', 11432 label: (0,external_wp_i18n_namespaceObject.__)('Align items center') 11433 }, { 11434 value: 'flex-end', 11435 label: (0,external_wp_i18n_namespaceObject.__)('Align items bottom') 11436 }]; 11437 return (0,external_wp_element_namespaceObject.createElement)("fieldset", { 11438 className: "block-editor-hooks__flex-layout-vertical-alignment-control" 11439 }, (0,external_wp_element_namespaceObject.createElement)("legend", null, (0,external_wp_i18n_namespaceObject.__)('Vertical alignment')), (0,external_wp_element_namespaceObject.createElement)("div", null, verticalAlignmentOptions.map((value, icon, label) => { 11440 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 11441 key: value, 11442 label: label, 11443 icon: icon, 11444 isPressed: verticalAlignment === value, 11445 onClick: () => onVerticalAlignmentChange(value) 11446 }); 11447 }))); 11448 } 11449 11450 function FlexLayoutJustifyContentControl(_ref5) { 11451 let { 11452 layout, 11453 onChange, 11454 isToolbar = false 11455 } = _ref5; 11456 const { 11457 justifyContent = 'left', 11458 orientation = 'horizontal' 11459 } = layout; 11460 11461 const onJustificationChange = value => { 11462 onChange({ ...layout, 11463 justifyContent: value 11464 }); 11465 }; 11466 11467 const allowedControls = ['left', 'center', 'right']; 11468 11469 if (orientation === 'horizontal') { 11470 allowedControls.push('space-between'); 11471 } 11472 11473 if (isToolbar) { 11474 return (0,external_wp_element_namespaceObject.createElement)(JustifyContentControl, { 11475 allowedControls: allowedControls, 11476 value: justifyContent, 11477 onChange: onJustificationChange, 11478 popoverProps: { 11479 position: 'bottom right', 11480 isAlternate: true 11481 } 11482 }); 11483 } 11484 11485 const justificationOptions = [{ 11486 value: 'left', 11487 icon: justify_left, 11488 label: (0,external_wp_i18n_namespaceObject.__)('Justify items left') 11489 }, { 11490 value: 'center', 11491 icon: justify_center, 11492 label: (0,external_wp_i18n_namespaceObject.__)('Justify items center') 11493 }, { 11494 value: 'right', 11495 icon: justify_right, 11496 label: (0,external_wp_i18n_namespaceObject.__)('Justify items right') 11497 }]; 11498 11499 if (orientation === 'horizontal') { 11500 justificationOptions.push({ 11501 value: 'space-between', 11502 icon: justify_space_between, 11503 label: (0,external_wp_i18n_namespaceObject.__)('Space between items') 11504 }); 11505 } 11506 11507 return (0,external_wp_element_namespaceObject.createElement)("fieldset", { 11508 className: "block-editor-hooks__flex-layout-justification-controls" 11509 }, (0,external_wp_element_namespaceObject.createElement)("legend", null, (0,external_wp_i18n_namespaceObject.__)('Justification')), (0,external_wp_element_namespaceObject.createElement)("div", null, justificationOptions.map(_ref6 => { 11510 let { 11511 value, 11512 icon, 11513 label 11514 } = _ref6; 11515 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 11516 key: value, 11517 label: label, 11518 icon: icon, 11519 isPressed: justifyContent === value, 11520 onClick: () => onJustificationChange(value) 11521 }); 11522 }))); 11523 } 11524 11525 function FlexWrapControl(_ref7) { 11526 let { 11527 layout, 11528 onChange 11529 } = _ref7; 11530 const { 11531 flexWrap = 'wrap' 11532 } = layout; 11533 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, { 11534 label: (0,external_wp_i18n_namespaceObject.__)('Allow to wrap to multiple lines'), 11535 onChange: value => { 11536 onChange({ ...layout, 11537 flexWrap: value ? 'wrap' : 'nowrap' 11538 }); 11539 }, 11540 checked: flexWrap === 'wrap' 11541 }); 11542 } 11543 11544 function OrientationControl(_ref8) { 11545 let { 11546 layout, 11547 onChange 11548 } = _ref8; 11549 const { 11550 orientation = 'horizontal' 11551 } = layout; 11552 return (0,external_wp_element_namespaceObject.createElement)("fieldset", { 11553 className: "block-editor-hooks__flex-layout-orientation-controls" 11554 }, (0,external_wp_element_namespaceObject.createElement)("legend", null, (0,external_wp_i18n_namespaceObject.__)('Orientation')), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 11555 label: 'horizontal', 11556 icon: arrow_right, 11557 isPressed: orientation === 'horizontal', 11558 onClick: () => onChange({ ...layout, 11559 orientation: 'horizontal' 11560 }) 11561 }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 11562 label: 'vertical', 11563 icon: arrow_down, 11564 isPressed: orientation === 'vertical', 11565 onClick: () => onChange({ ...layout, 11566 orientation: 'vertical' 11567 }) 11568 })); 11569 } 11570 11571 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/icon/index.js 11572 /** 11573 * WordPress dependencies 11574 */ 11575 11576 /** @typedef {{icon: JSX.Element, size?: number} & import('@wordpress/primitives').SVGProps} IconProps */ 11577 11578 /** 11579 * Return an SVG icon. 11580 * 11581 * @param {IconProps} props icon is the SVG component to render 11582 * size is a number specifiying the icon size in pixels 11583 * Other props will be passed to wrapped SVG component 11584 * 11585 * @return {JSX.Element} Icon component 11586 */ 11587 11588 function Icon(_ref) { 11589 let { 11590 icon, 11591 size = 24, 11592 ...props 11593 } = _ref; 11594 return (0,external_wp_element_namespaceObject.cloneElement)(icon, { 11595 width: size, 11596 height: size, 11597 ...props 11598 }); 11599 } 11600 11601 /* harmony default export */ var build_module_icon = (Icon); 11602 11603 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/layouts/flow.js 11604 11605 11606 /** 11607 * WordPress dependencies 11608 */ 11609 11610 11611 11612 /** 11613 * Internal dependencies 11614 */ 11615 11616 11617 11618 11619 11620 /* harmony default export */ var flow = ({ 11621 name: 'default', 11622 label: (0,external_wp_i18n_namespaceObject.__)('Flow'), 11623 inspectorControls: function DefaultLayoutInspectorControls(_ref) { 11624 let { 11625 layout, 11626 onChange 11627 } = _ref; 11628 const { 11629 wideSize, 11630 contentSize 11631 } = layout; 11632 const units = (0,external_wp_components_namespaceObject.__experimentalUseCustomUnits)({ 11633 availableUnits: useSetting('spacing.units') || ['%', 'px', 'em', 'rem', 'vw'] 11634 }); 11635 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("div", { 11636 className: "block-editor-hooks__layout-controls" 11637 }, (0,external_wp_element_namespaceObject.createElement)("div", { 11638 className: "block-editor-hooks__layout-controls-unit" 11639 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalUnitControl, { 11640 label: (0,external_wp_i18n_namespaceObject.__)('Content'), 11641 labelPosition: "top", 11642 __unstableInputWidth: "80px", 11643 value: contentSize || wideSize || '', 11644 onChange: nextWidth => { 11645 nextWidth = 0 > parseFloat(nextWidth) ? '0' : nextWidth; 11646 onChange({ ...layout, 11647 contentSize: nextWidth 11648 }); 11649 }, 11650 units: units 11651 }), (0,external_wp_element_namespaceObject.createElement)(build_module_icon, { 11652 icon: position_center 11653 })), (0,external_wp_element_namespaceObject.createElement)("div", { 11654 className: "block-editor-hooks__layout-controls-unit" 11655 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalUnitControl, { 11656 label: (0,external_wp_i18n_namespaceObject.__)('Wide'), 11657 labelPosition: "top", 11658 __unstableInputWidth: "80px", 11659 value: wideSize || contentSize || '', 11660 onChange: nextWidth => { 11661 nextWidth = 0 > parseFloat(nextWidth) ? '0' : nextWidth; 11662 onChange({ ...layout, 11663 wideSize: nextWidth 11664 }); 11665 }, 11666 units: units 11667 }), (0,external_wp_element_namespaceObject.createElement)(build_module_icon, { 11668 icon: stretch_wide 11669 }))), (0,external_wp_element_namespaceObject.createElement)("div", { 11670 className: "block-editor-hooks__layout-controls-reset" 11671 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 11672 variant: "secondary", 11673 isSmall: true, 11674 disabled: !contentSize && !wideSize, 11675 onClick: () => onChange({ 11676 contentSize: undefined, 11677 wideSize: undefined, 11678 inherit: false 11679 }) 11680 }, (0,external_wp_i18n_namespaceObject.__)('Reset'))), (0,external_wp_element_namespaceObject.createElement)("p", { 11681 className: "block-editor-hooks__layout-controls-helptext" 11682 }, (0,external_wp_i18n_namespaceObject.__)('Customize the width for all elements that are assigned to the center or wide columns.'))); 11683 }, 11684 toolBarControls: function DefaultLayoutToolbarControls() { 11685 return null; 11686 }, 11687 save: function DefaultLayoutStyle(_ref2) { 11688 var _style$spacing; 11689 11690 let { 11691 selector, 11692 layout = {}, 11693 style, 11694 blockName 11695 } = _ref2; 11696 const { 11697 contentSize, 11698 wideSize 11699 } = layout; 11700 const blockGapSupport = useSetting('spacing.blockGap'); 11701 const hasBlockGapStylesSupport = blockGapSupport !== null; 11702 const blockGapStyleValue = getGapBoxControlValueFromStyle(style === null || style === void 0 ? void 0 : (_style$spacing = style.spacing) === null || _style$spacing === void 0 ? void 0 : _style$spacing.blockGap); // If a block's block.json skips serialization for spacing or 11703 // spacing.blockGap, don't apply the user-defined value to the styles. 11704 11705 const blockGapValue = blockGapStyleValue !== null && blockGapStyleValue !== void 0 && blockGapStyleValue.top && !shouldSkipSerialization(blockName, 'spacing', 'blockGap') ? blockGapStyleValue === null || blockGapStyleValue === void 0 ? void 0 : blockGapStyleValue.top : 'var( --wp--style--block-gap )'; 11706 let output = !!contentSize || !!wideSize ? ` 11707 $appendSelectors(selector, '> :where(:not(.alignleft):not(.alignright))')} { 11708 max-width: $contentSize !== null && contentSize !== void 0 ? contentSize : wideSize}; 11709 margin-left: auto !important; 11710 margin-right: auto !important; 11711 } 11712 $appendSelectors(selector, '> .alignwide')} { 11713 max-width: $wideSize !== null && wideSize !== void 0 ? wideSize : contentSize}; 11714 } 11715 $appendSelectors(selector, '> .alignfull')} { 11716 max-width: none; 11717 } 11718 ` : ''; 11719 output += ` 11720 $appendSelectors(selector, '> .alignleft')} { 11721 float: left; 11722 margin-inline-start: 0; 11723 margin-inline-end: 2em; 11724 } 11725 $appendSelectors(selector, '> .alignright')} { 11726 float: right; 11727 margin-inline-start: 2em; 11728 margin-inline-end: 0; 11729 } 11730 11731 $appendSelectors(selector, '> .aligncenter')} { 11732 margin-left: auto !important; 11733 margin-right: auto !important; 11734 } 11735 `; 11736 11737 if (hasBlockGapStylesSupport) { 11738 output += ` 11739 $appendSelectors(selector, '> *')} { 11740 margin-block-start: 0; 11741 margin-block-end: 0; 11742 } 11743 $appendSelectors(selector, '> * + *')} { 11744 margin-block-start: $blockGapValue}; 11745 } 11746 `; 11747 } 11748 11749 return (0,external_wp_element_namespaceObject.createElement)("style", null, output); 11750 }, 11751 11752 getOrientation() { 11753 return 'vertical'; 11754 }, 11755 11756 getAlignments(layout) { 11757 const alignmentInfo = getAlignmentsInfo(layout); 11758 11759 if (layout.alignments !== undefined) { 11760 if (!layout.alignments.includes('none')) { 11761 layout.alignments.unshift('none'); 11762 } 11763 11764 return layout.alignments.map(alignment => ({ 11765 name: alignment, 11766 info: alignmentInfo[alignment] 11767 })); 11768 } 11769 11770 const { 11771 contentSize, 11772 wideSize 11773 } = layout; 11774 const alignments = [{ 11775 name: 'left' 11776 }, { 11777 name: 'center' 11778 }, { 11779 name: 'right' 11780 }]; 11781 11782 if (contentSize) { 11783 alignments.unshift({ 11784 name: 'full' 11785 }); 11786 } 11787 11788 if (wideSize) { 11789 alignments.unshift({ 11790 name: 'wide', 11791 info: alignmentInfo.wide 11792 }); 11793 } 11794 11795 alignments.unshift({ 11796 name: 'none', 11797 info: alignmentInfo.none 11798 }); 11799 return alignments; 11800 } 11801 11802 }); 11803 /** 11804 * Helper method to assign contextual info to clarify 11805 * alignment settings. 11806 * 11807 * Besides checking if `contentSize` and `wideSize` have a 11808 * value, we now show this information only if their values 11809 * are not a `css var`. This needs to change when parsing 11810 * css variables land. 11811 * 11812 * @see https://github.com/WordPress/gutenberg/pull/34710#issuecomment-918000752 11813 * 11814 * @param {Object} layout The layout object. 11815 * @return {Object} An object with contextual info per alignment. 11816 */ 11817 11818 function getAlignmentsInfo(layout) { 11819 const { 11820 contentSize, 11821 wideSize 11822 } = layout; 11823 const alignmentInfo = {}; 11824 const sizeRegex = /^(?!0)\d+(px|em|rem|vw|vh|%)?$/i; 11825 11826 if (sizeRegex.test(contentSize)) { 11827 // translators: %s: container size (i.e. 600px etc) 11828 alignmentInfo.none = (0,external_wp_i18n_namespaceObject.sprintf)((0,external_wp_i18n_namespaceObject.__)('Max %s wide'), contentSize); 11829 } 11830 11831 if (sizeRegex.test(wideSize)) { 11832 // translators: %s: container size (i.e. 600px etc) 11833 alignmentInfo.wide = (0,external_wp_i18n_namespaceObject.sprintf)((0,external_wp_i18n_namespaceObject.__)('Max %s wide'), wideSize); 11834 } 11835 11836 return alignmentInfo; 11837 } 11838 11839 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/layouts/index.js 11840 /** 11841 * Internal dependencies 11842 */ 11843 11844 11845 const layoutTypes = [flow, flex]; 11846 /** 11847 * Retrieves a layout type by name. 11848 * 11849 * @param {string} name - The name of the layout type. 11850 * @return {Object} Layout type. 11851 */ 11852 11853 function getLayoutType() { 11854 let name = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; 11855 return layoutTypes.find(layoutType => layoutType.name === name); 11856 } 11857 /** 11858 * Retrieves the available layout types. 11859 * 11860 * @return {Array} Layout types. 11861 */ 11862 11863 function getLayoutTypes() { 11864 return layoutTypes; 11865 } 11866 11867 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-list/layout.js 11868 11869 11870 11871 /** 11872 * WordPress dependencies 11873 */ 11874 11875 /** 11876 * Internal dependencies 11877 */ 11878 11879 11880 const defaultLayout = { 11881 type: 'default' 11882 }; 11883 const Layout = (0,external_wp_element_namespaceObject.createContext)(defaultLayout); 11884 /** 11885 * Allows to define the layout. 11886 */ 11887 11888 const LayoutProvider = Layout.Provider; 11889 /** 11890 * React hook used to retrieve the layout config. 11891 */ 11892 11893 function useLayout() { 11894 return (0,external_wp_element_namespaceObject.useContext)(Layout); 11895 } 11896 function LayoutStyle(_ref) { 11897 let { 11898 layout = {}, 11899 ...props 11900 } = _ref; 11901 const layoutType = getLayoutType(layout.type); 11902 11903 if (layoutType) { 11904 return (0,external_wp_element_namespaceObject.createElement)(layoutType.save, _extends({ 11905 layout: layout 11906 }, props)); 11907 } 11908 11909 return null; 11910 } 11911 11912 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-alignment-control/use-available-alignments.js 11913 /** 11914 * WordPress dependencies 11915 */ 11916 11917 /** 11918 * Internal dependencies 11919 */ 11920 11921 11922 11923 11924 const use_available_alignments_DEFAULT_CONTROLS = ['none', 'left', 'center', 'right', 'wide', 'full']; 11925 const WIDE_CONTROLS = ['wide', 'full']; 11926 function useAvailableAlignments() { 11927 let controls = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : use_available_alignments_DEFAULT_CONTROLS; 11928 11929 // Always add the `none` option if not exists. 11930 if (!controls.includes('none')) { 11931 controls = ['none', ...controls]; 11932 } 11933 11934 const { 11935 wideControlsEnabled = false, 11936 themeSupportsLayout 11937 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 11938 const { 11939 getSettings 11940 } = select(store); 11941 const settings = getSettings(); 11942 return { 11943 wideControlsEnabled: settings.alignWide, 11944 themeSupportsLayout: settings.supportsLayout 11945 }; 11946 }, []); 11947 const layout = useLayout(); 11948 const layoutType = getLayoutType(layout === null || layout === void 0 ? void 0 : layout.type); 11949 const layoutAlignments = layoutType.getAlignments(layout); 11950 11951 if (themeSupportsLayout) { 11952 const alignments = layoutAlignments.filter(_ref => { 11953 let { 11954 name: alignmentName 11955 } = _ref; 11956 return controls.includes(alignmentName); 11957 }); // While we treat `none` as an alignment, we shouldn't return it if no 11958 // other alignments exist. 11959 11960 if (alignments.length === 1 && alignments[0].name === 'none') { 11961 return []; 11962 } 11963 11964 return alignments; 11965 } // Starting here, it's the fallback for themes not supporting the layout config. 11966 11967 11968 if (layoutType.name !== 'default') { 11969 return []; 11970 } 11971 11972 const { 11973 alignments: availableAlignments = use_available_alignments_DEFAULT_CONTROLS 11974 } = layout; 11975 const enabledControls = controls.filter(control => (layout.alignments || // Ignore the global wideAlignment check if the layout explicitely defines alignments. 11976 wideControlsEnabled || !WIDE_CONTROLS.includes(control)) && availableAlignments.includes(control)).map(enabledControl => ({ 11977 name: enabledControl 11978 })); // While we treat `none` as an alignment, we shouldn't return it if no 11979 // other alignments exist. 11980 11981 if (enabledControls.length === 1 && enabledControls[0].name === 'none') { 11982 return []; 11983 } 11984 11985 return enabledControls; 11986 } 11987 11988 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-alignment-control/ui.js 11989 11990 11991 11992 /** 11993 * External dependencies 11994 */ 11995 11996 /** 11997 * WordPress dependencies 11998 */ 11999 12000 12001 12002 12003 12004 /** 12005 * Internal dependencies 12006 */ 12007 12008 12009 const ui_BLOCK_ALIGNMENTS_CONTROLS = { 12010 none: { 12011 icon: align_none, 12012 title: (0,external_wp_i18n_namespaceObject._x)('None', 'Alignment option') 12013 }, 12014 left: { 12015 icon: position_left, 12016 title: (0,external_wp_i18n_namespaceObject.__)('Align left') 12017 }, 12018 center: { 12019 icon: position_center, 12020 title: (0,external_wp_i18n_namespaceObject.__)('Align center') 12021 }, 12022 right: { 12023 icon: position_right, 12024 title: (0,external_wp_i18n_namespaceObject.__)('Align right') 12025 }, 12026 wide: { 12027 icon: stretch_wide, 12028 title: (0,external_wp_i18n_namespaceObject.__)('Wide width') 12029 }, 12030 full: { 12031 icon: stretch_full_width, 12032 title: (0,external_wp_i18n_namespaceObject.__)('Full width') 12033 } 12034 }; 12035 const ui_DEFAULT_CONTROL = 'none'; 12036 const ui_POPOVER_PROPS = { 12037 isAlternate: true 12038 }; 12039 12040 function BlockAlignmentUI(_ref) { 12041 let { 12042 value, 12043 onChange, 12044 controls, 12045 isToolbar, 12046 isCollapsed = true 12047 } = _ref; 12048 const enabledControls = useAvailableAlignments(controls); 12049 const hasEnabledControls = !!enabledControls.length; 12050 12051 if (!hasEnabledControls) { 12052 return null; 12053 } 12054 12055 function onChangeAlignment(align) { 12056 onChange([value, 'none'].includes(align) ? undefined : align); 12057 } 12058 12059 const activeAlignmentControl = ui_BLOCK_ALIGNMENTS_CONTROLS[value]; 12060 const defaultAlignmentControl = ui_BLOCK_ALIGNMENTS_CONTROLS[ui_DEFAULT_CONTROL]; 12061 const UIComponent = isToolbar ? external_wp_components_namespaceObject.ToolbarGroup : external_wp_components_namespaceObject.ToolbarDropdownMenu; 12062 const commonProps = { 12063 popoverProps: ui_POPOVER_PROPS, 12064 icon: activeAlignmentControl ? activeAlignmentControl.icon : defaultAlignmentControl.icon, 12065 label: (0,external_wp_i18n_namespaceObject.__)('Align'), 12066 toggleProps: { 12067 describedBy: (0,external_wp_i18n_namespaceObject.__)('Change alignment') 12068 } 12069 }; 12070 const extraProps = isToolbar || external_wp_element_namespaceObject.Platform.isNative ? { 12071 isCollapsed: isToolbar ? isCollapsed : undefined, 12072 controls: enabledControls.map(_ref2 => { 12073 let { 12074 name: controlName 12075 } = _ref2; 12076 return { ...ui_BLOCK_ALIGNMENTS_CONTROLS[controlName], 12077 isActive: value === controlName || !value && controlName === 'none', 12078 role: isCollapsed ? 'menuitemradio' : undefined, 12079 onClick: () => onChangeAlignment(controlName) 12080 }; 12081 }) 12082 } : { 12083 children: _ref3 => { 12084 let { 12085 onClose 12086 } = _ref3; 12087 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuGroup, { 12088 className: "block-editor-block-alignment-control__menu-group" 12089 }, enabledControls.map(_ref4 => { 12090 let { 12091 name: controlName, 12092 info 12093 } = _ref4; 12094 const { 12095 icon, 12096 title 12097 } = ui_BLOCK_ALIGNMENTS_CONTROLS[controlName]; // If no value is provided, mark as selected the `none` option. 12098 12099 const isSelected = controlName === value || !value && controlName === 'none'; 12100 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, { 12101 key: controlName, 12102 icon: icon, 12103 iconPosition: "left", 12104 className: classnames_default()('components-dropdown-menu__menu-item', { 12105 'is-active': isSelected 12106 }), 12107 isSelected: isSelected, 12108 onClick: () => { 12109 onChangeAlignment(controlName); 12110 onClose(); 12111 }, 12112 role: "menuitemradio", 12113 info: info 12114 }, title); 12115 }))); 12116 } 12117 }; 12118 return (0,external_wp_element_namespaceObject.createElement)(UIComponent, _extends({}, commonProps, extraProps)); 12119 } 12120 12121 /* harmony default export */ var block_alignment_control_ui = (BlockAlignmentUI); 12122 12123 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-alignment-control/index.js 12124 12125 12126 12127 /** 12128 * Internal dependencies 12129 */ 12130 12131 12132 const BlockAlignmentControl = props => { 12133 return (0,external_wp_element_namespaceObject.createElement)(block_alignment_control_ui, _extends({}, props, { 12134 isToolbar: false 12135 })); 12136 }; 12137 12138 const BlockAlignmentToolbar = props => { 12139 return (0,external_wp_element_namespaceObject.createElement)(block_alignment_control_ui, _extends({}, props, { 12140 isToolbar: true 12141 })); 12142 }; 12143 /** 12144 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/block-alignment-control/README.md 12145 */ 12146 12147 12148 12149 12150 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/hooks/align.js 12151 12152 12153 12154 /** 12155 * External dependencies 12156 */ 12157 12158 12159 /** 12160 * WordPress dependencies 12161 */ 12162 12163 12164 12165 12166 /** 12167 * Internal dependencies 12168 */ 12169 12170 12171 12172 /** 12173 * An array which includes all possible valid alignments, 12174 * used to validate if an alignment is valid or not. 12175 * 12176 * @constant 12177 * @type {string[]} 12178 */ 12179 12180 const ALL_ALIGNMENTS = ['left', 'center', 'right', 'wide', 'full']; 12181 /** 12182 * An array which includes all wide alignments. 12183 * In order for this alignments to be valid they need to be supported by the block, 12184 * and by the theme. 12185 * 12186 * @constant 12187 * @type {string[]} 12188 */ 12189 12190 const WIDE_ALIGNMENTS = ['wide', 'full']; 12191 /** 12192 * Returns the valid alignments. 12193 * Takes into consideration the aligns supported by a block, if the block supports wide controls or not and if theme supports wide controls or not. 12194 * Exported just for testing purposes, not exported outside the module. 12195 * 12196 * @param {?boolean|string[]} blockAlign Aligns supported by the block. 12197 * @param {?boolean} hasWideBlockSupport True if block supports wide alignments. And False otherwise. 12198 * @param {?boolean} hasWideEnabled True if theme supports wide alignments. And False otherwise. 12199 * 12200 * @return {string[]} Valid alignments. 12201 */ 12202 12203 function getValidAlignments(blockAlign) { 12204 let hasWideBlockSupport = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true; 12205 let hasWideEnabled = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true; 12206 let validAlignments; 12207 12208 if (Array.isArray(blockAlign)) { 12209 validAlignments = ALL_ALIGNMENTS.filter(value => blockAlign.includes(value)); 12210 } else if (blockAlign === true) { 12211 // `true` includes all alignments... 12212 validAlignments = [...ALL_ALIGNMENTS]; 12213 } else { 12214 validAlignments = []; 12215 } 12216 12217 if (!hasWideEnabled || blockAlign === true && !hasWideBlockSupport) { 12218 return (0,external_lodash_namespaceObject.without)(validAlignments, ...WIDE_ALIGNMENTS); 12219 } 12220 12221 return validAlignments; 12222 } 12223 /** 12224 * Filters registered block settings, extending attributes to include `align`. 12225 * 12226 * @param {Object} settings Original block settings. 12227 * 12228 * @return {Object} Filtered block settings. 12229 */ 12230 12231 function addAttribute(settings) { 12232 // Allow blocks to specify their own attribute definition with default values if needed. 12233 if ((0,external_lodash_namespaceObject.has)(settings.attributes, ['align', 'type'])) { 12234 return settings; 12235 } 12236 12237 if ((0,external_wp_blocks_namespaceObject.hasBlockSupport)(settings, 'align')) { 12238 // Gracefully handle if settings.attributes is undefined. 12239 settings.attributes = { ...settings.attributes, 12240 align: { 12241 type: 'string', 12242 // Allow for '' since it is used by updateAlignment function 12243 // in withToolbarControls for special cases with defined default values. 12244 enum: [...ALL_ALIGNMENTS, ''] 12245 } 12246 }; 12247 } 12248 12249 return settings; 12250 } 12251 /** 12252 * Override the default edit UI to include new toolbar controls for block 12253 * alignment, if block defines support. 12254 * 12255 * @param {Function} BlockEdit Original component. 12256 * 12257 * @return {Function} Wrapped component. 12258 */ 12259 12260 const withToolbarControls = (0,external_wp_compose_namespaceObject.createHigherOrderComponent)(BlockEdit => props => { 12261 const { 12262 name: blockName 12263 } = props; // Compute the block valid alignments by taking into account, 12264 // if the theme supports wide alignments or not and the layout's 12265 // availble alignments. We do that for conditionally rendering 12266 // Slot. 12267 12268 const blockAllowedAlignments = getValidAlignments((0,external_wp_blocks_namespaceObject.getBlockSupport)(blockName, 'align'), (0,external_wp_blocks_namespaceObject.hasBlockSupport)(blockName, 'alignWide', true)); 12269 const validAlignments = useAvailableAlignments(blockAllowedAlignments).map(_ref => { 12270 let { 12271 name 12272 } = _ref; 12273 return name; 12274 }); 12275 12276 const updateAlignment = nextAlign => { 12277 if (!nextAlign) { 12278 var _blockType$attributes, _blockType$attributes2; 12279 12280 const blockType = (0,external_wp_blocks_namespaceObject.getBlockType)(props.name); 12281 const blockDefaultAlign = blockType === null || blockType === void 0 ? void 0 : (_blockType$attributes = blockType.attributes) === null || _blockType$attributes === void 0 ? void 0 : (_blockType$attributes2 = _blockType$attributes.align) === null || _blockType$attributes2 === void 0 ? void 0 : _blockType$attributes2.default; 12282 12283 if (blockDefaultAlign) { 12284 nextAlign = ''; 12285 } 12286 } 12287 12288 props.setAttributes({ 12289 align: nextAlign 12290 }); 12291 }; 12292 12293 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, !!validAlignments.length && (0,external_wp_element_namespaceObject.createElement)(block_controls, { 12294 group: "block", 12295 __experimentalShareWithChildBlocks: true 12296 }, (0,external_wp_element_namespaceObject.createElement)(BlockAlignmentControl, { 12297 value: props.attributes.align, 12298 onChange: updateAlignment, 12299 controls: validAlignments 12300 })), (0,external_wp_element_namespaceObject.createElement)(BlockEdit, props)); 12301 }, 'withToolbarControls'); 12302 /** 12303 * Override the default block element to add alignment wrapper props. 12304 * 12305 * @param {Function} BlockListBlock Original component. 12306 * 12307 * @return {Function} Wrapped component. 12308 */ 12309 12310 const withDataAlign = (0,external_wp_compose_namespaceObject.createHigherOrderComponent)(BlockListBlock => props => { 12311 const { 12312 name, 12313 attributes 12314 } = props; 12315 const { 12316 align 12317 } = attributes; 12318 const blockAllowedAlignments = getValidAlignments((0,external_wp_blocks_namespaceObject.getBlockSupport)(name, 'align'), (0,external_wp_blocks_namespaceObject.hasBlockSupport)(name, 'alignWide', true)); 12319 const validAlignments = useAvailableAlignments(blockAllowedAlignments); // If an alignment is not assigned, there's no need to go through the 12320 // effort to validate or assign its value. 12321 12322 if (align === undefined) { 12323 return (0,external_wp_element_namespaceObject.createElement)(BlockListBlock, props); 12324 } 12325 12326 let wrapperProps = props.wrapperProps; 12327 12328 if (validAlignments.some(alignment => alignment.name === align)) { 12329 wrapperProps = { ...wrapperProps, 12330 'data-align': align 12331 }; 12332 } 12333 12334 return (0,external_wp_element_namespaceObject.createElement)(BlockListBlock, _extends({}, props, { 12335 wrapperProps: wrapperProps 12336 })); 12337 }); 12338 /** 12339 * Override props assigned to save component to inject alignment class name if 12340 * block supports it. 12341 * 12342 * @param {Object} props Additional props applied to save element. 12343 * @param {Object} blockType Block type. 12344 * @param {Object} attributes Block attributes. 12345 * 12346 * @return {Object} Filtered props applied to save element. 12347 */ 12348 12349 function addAssignedAlign(props, blockType, attributes) { 12350 const { 12351 align 12352 } = attributes; 12353 const blockAlign = (0,external_wp_blocks_namespaceObject.getBlockSupport)(blockType, 'align'); 12354 const hasWideBlockSupport = (0,external_wp_blocks_namespaceObject.hasBlockSupport)(blockType, 'alignWide', true); // Compute valid alignments without taking into account if 12355 // the theme supports wide alignments or not. 12356 // This way changing themes does not impact the block save. 12357 12358 const isAlignValid = getValidAlignments(blockAlign, hasWideBlockSupport).includes(align); 12359 12360 if (isAlignValid) { 12361 props.className = classnames_default()(`align$align}`, props.className); 12362 } 12363 12364 return props; 12365 } 12366 (0,external_wp_hooks_namespaceObject.addFilter)('blocks.registerBlockType', 'core/align/addAttribute', addAttribute); 12367 (0,external_wp_hooks_namespaceObject.addFilter)('editor.BlockListBlock', 'core/editor/align/with-data-align', withDataAlign); 12368 (0,external_wp_hooks_namespaceObject.addFilter)('editor.BlockEdit', 'core/editor/align/with-toolbar-controls', withToolbarControls); 12369 (0,external_wp_hooks_namespaceObject.addFilter)('blocks.getSaveContent.extraProps', 'core/align/addAssignedAlign', addAssignedAlign); 12370 12371 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/hooks/lock.js 12372 /** 12373 * External dependencies 12374 */ 12375 12376 /** 12377 * WordPress dependencies 12378 */ 12379 12380 12381 /** 12382 * Filters registered block settings, extending attributes to include `lock`. 12383 * 12384 * @param {Object} settings Original block settings. 12385 * 12386 * @return {Object} Filtered block settings. 12387 */ 12388 12389 function lock_addAttribute(settings) { 12390 // Allow blocks to specify their own attribute definition with default values if needed. 12391 if ((0,external_lodash_namespaceObject.has)(settings.attributes, ['lock', 'type'])) { 12392 return settings; 12393 } // Gracefully handle if settings.attributes is undefined. 12394 12395 12396 settings.attributes = { ...settings.attributes, 12397 lock: { 12398 type: 'object' 12399 } 12400 }; 12401 return settings; 12402 } 12403 (0,external_wp_hooks_namespaceObject.addFilter)('blocks.registerBlockType', 'core/lock/addAttribute', lock_addAttribute); 12404 12405 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/hooks/anchor.js 12406 12407 12408 /** 12409 * External dependencies 12410 */ 12411 12412 /** 12413 * WordPress dependencies 12414 */ 12415 12416 12417 12418 12419 12420 12421 12422 /** 12423 * Internal dependencies 12424 */ 12425 12426 12427 /** 12428 * Regular expression matching invalid anchor characters for replacement. 12429 * 12430 * @type {RegExp} 12431 */ 12432 12433 const ANCHOR_REGEX = /[\s#]/g; 12434 const ANCHOR_SCHEMA = { 12435 type: 'string', 12436 source: 'attribute', 12437 attribute: 'id', 12438 selector: '*' 12439 }; 12440 /** 12441 * Filters registered block settings, extending attributes with anchor using ID 12442 * of the first node. 12443 * 12444 * @param {Object} settings Original block settings. 12445 * 12446 * @return {Object} Filtered block settings. 12447 */ 12448 12449 function anchor_addAttribute(settings) { 12450 // Allow blocks to specify their own attribute definition with default values if needed. 12451 if ((0,external_lodash_namespaceObject.has)(settings.attributes, ['anchor', 'type'])) { 12452 return settings; 12453 } 12454 12455 if ((0,external_wp_blocks_namespaceObject.hasBlockSupport)(settings, 'anchor')) { 12456 // Gracefully handle if settings.attributes is undefined. 12457 settings.attributes = { ...settings.attributes, 12458 anchor: ANCHOR_SCHEMA 12459 }; 12460 } 12461 12462 return settings; 12463 } 12464 /** 12465 * Override the default edit UI to include a new block inspector control for 12466 * assigning the anchor ID, if block supports anchor. 12467 * 12468 * @param {WPComponent} BlockEdit Original component. 12469 * 12470 * @return {WPComponent} Wrapped component. 12471 */ 12472 12473 const withInspectorControl = (0,external_wp_compose_namespaceObject.createHigherOrderComponent)(BlockEdit => { 12474 return props => { 12475 const hasAnchor = (0,external_wp_blocks_namespaceObject.hasBlockSupport)(props.name, 'anchor'); 12476 12477 if (hasAnchor && props.isSelected) { 12478 const isWeb = external_wp_element_namespaceObject.Platform.OS === 'web'; 12479 const textControl = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, { 12480 className: "html-anchor-control", 12481 label: (0,external_wp_i18n_namespaceObject.__)('HTML anchor'), 12482 help: (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_i18n_namespaceObject.__)('Enter a word or two — without spaces — to make a unique web address just for this block, called an “anchor.” Then, you’ll be able to link directly to this section of your page.'), isWeb && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ExternalLink, { 12483 href: (0,external_wp_i18n_namespaceObject.__)('https://wordpress.org/support/article/page-jumps/') 12484 }, (0,external_wp_i18n_namespaceObject.__)('Learn more about anchors'))), 12485 value: props.attributes.anchor || '', 12486 placeholder: !isWeb ? (0,external_wp_i18n_namespaceObject.__)('Add an anchor') : null, 12487 onChange: nextValue => { 12488 nextValue = nextValue.replace(ANCHOR_REGEX, '-'); 12489 props.setAttributes({ 12490 anchor: nextValue 12491 }); 12492 }, 12493 autoCapitalize: "none", 12494 autoComplete: "off" 12495 }); 12496 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(BlockEdit, props), isWeb && (0,external_wp_element_namespaceObject.createElement)(inspector_controls, { 12497 __experimentalGroup: "advanced" 12498 }, textControl), !isWeb && props.name === 'core/heading' && (0,external_wp_element_namespaceObject.createElement)(inspector_controls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, { 12499 title: (0,external_wp_i18n_namespaceObject.__)('Heading settings') 12500 }, textControl))); 12501 } 12502 12503 return (0,external_wp_element_namespaceObject.createElement)(BlockEdit, props); 12504 }; 12505 }, 'withInspectorControl'); 12506 /** 12507 * Override props assigned to save component to inject anchor ID, if block 12508 * supports anchor. This is only applied if the block's save result is an 12509 * element and not a markup string. 12510 * 12511 * @param {Object} extraProps Additional props applied to save element. 12512 * @param {Object} blockType Block type. 12513 * @param {Object} attributes Current block attributes. 12514 * 12515 * @return {Object} Filtered props applied to save element. 12516 */ 12517 12518 function addSaveProps(extraProps, blockType, attributes) { 12519 if ((0,external_wp_blocks_namespaceObject.hasBlockSupport)(blockType, 'anchor')) { 12520 extraProps.id = attributes.anchor === '' ? null : attributes.anchor; 12521 } 12522 12523 return extraProps; 12524 } 12525 (0,external_wp_hooks_namespaceObject.addFilter)('blocks.registerBlockType', 'core/anchor/attribute', anchor_addAttribute); 12526 (0,external_wp_hooks_namespaceObject.addFilter)('editor.BlockEdit', 'core/editor/anchor/with-inspector-control', withInspectorControl); 12527 (0,external_wp_hooks_namespaceObject.addFilter)('blocks.getSaveContent.extraProps', 'core/anchor/save-props', addSaveProps); 12528 12529 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/hooks/custom-class-name.js 12530 12531 12532 /** 12533 * External dependencies 12534 */ 12535 12536 /** 12537 * WordPress dependencies 12538 */ 12539 12540 12541 12542 12543 12544 12545 /** 12546 * Internal dependencies 12547 */ 12548 12549 12550 /** 12551 * Filters registered block settings, extending attributes with anchor using ID 12552 * of the first node. 12553 * 12554 * @param {Object} settings Original block settings. 12555 * 12556 * @return {Object} Filtered block settings. 12557 */ 12558 12559 function custom_class_name_addAttribute(settings) { 12560 if ((0,external_wp_blocks_namespaceObject.hasBlockSupport)(settings, 'customClassName', true)) { 12561 // Gracefully handle if settings.attributes is undefined. 12562 settings.attributes = { ...settings.attributes, 12563 className: { 12564 type: 'string' 12565 } 12566 }; 12567 } 12568 12569 return settings; 12570 } 12571 /** 12572 * Override the default edit UI to include a new block inspector control for 12573 * assigning the custom class name, if block supports custom class name. 12574 * 12575 * @param {WPComponent} BlockEdit Original component. 12576 * 12577 * @return {WPComponent} Wrapped component. 12578 */ 12579 12580 const custom_class_name_withInspectorControl = (0,external_wp_compose_namespaceObject.createHigherOrderComponent)(BlockEdit => { 12581 return props => { 12582 const hasCustomClassName = (0,external_wp_blocks_namespaceObject.hasBlockSupport)(props.name, 'customClassName', true); 12583 12584 if (hasCustomClassName && props.isSelected) { 12585 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(BlockEdit, props), (0,external_wp_element_namespaceObject.createElement)(inspector_controls, { 12586 __experimentalGroup: "advanced" 12587 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, { 12588 autoComplete: "off", 12589 label: (0,external_wp_i18n_namespaceObject.__)('Additional CSS class(es)'), 12590 value: props.attributes.className || '', 12591 onChange: nextValue => { 12592 props.setAttributes({ 12593 className: nextValue !== '' ? nextValue : undefined 12594 }); 12595 }, 12596 help: (0,external_wp_i18n_namespaceObject.__)('Separate multiple classes with spaces.') 12597 }))); 12598 } 12599 12600 return (0,external_wp_element_namespaceObject.createElement)(BlockEdit, props); 12601 }; 12602 }, 'withInspectorControl'); 12603 /** 12604 * Override props assigned to save component to inject anchor ID, if block 12605 * supports anchor. This is only applied if the block's save result is an 12606 * element and not a markup string. 12607 * 12608 * @param {Object} extraProps Additional props applied to save element. 12609 * @param {Object} blockType Block type. 12610 * @param {Object} attributes Current block attributes. 12611 * 12612 * @return {Object} Filtered props applied to save element. 12613 */ 12614 12615 function custom_class_name_addSaveProps(extraProps, blockType, attributes) { 12616 if ((0,external_wp_blocks_namespaceObject.hasBlockSupport)(blockType, 'customClassName', true) && attributes.className) { 12617 extraProps.className = classnames_default()(extraProps.className, attributes.className); 12618 } 12619 12620 return extraProps; 12621 } 12622 function addTransforms(result, source, index, results) { 12623 if (!(0,external_wp_blocks_namespaceObject.hasBlockSupport)(result.name, 'customClassName', true)) { 12624 return result; 12625 } // If the condition verifies we are probably in the presence of a wrapping transform 12626 // e.g: nesting paragraphs in a group or columns and in that case the class should not be kept. 12627 12628 12629 if (results.length === 1 && result.innerBlocks.length === source.length) { 12630 return result; 12631 } // If we are transforming one block to multiple blocks or multiple blocks to one block, 12632 // we ignore the class during the transform. 12633 12634 12635 if (results.length === 1 && source.length > 1 || results.length > 1 && source.length === 1) { 12636 return result; 12637 } // If we are in presence of transform between one or more block in the source 12638 // that have one or more blocks in the result 12639 // we apply the class on source N to the result N, 12640 // if source N does not exists we do nothing. 12641 12642 12643 if (source[index]) { 12644 var _source$index; 12645 12646 const originClassName = (_source$index = source[index]) === null || _source$index === void 0 ? void 0 : _source$index.attributes.className; 12647 12648 if (originClassName) { 12649 return { ...result, 12650 attributes: { ...result.attributes, 12651 className: originClassName 12652 } 12653 }; 12654 } 12655 } 12656 12657 return result; 12658 } 12659 (0,external_wp_hooks_namespaceObject.addFilter)('blocks.registerBlockType', 'core/custom-class-name/attribute', custom_class_name_addAttribute); 12660 (0,external_wp_hooks_namespaceObject.addFilter)('editor.BlockEdit', 'core/editor/custom-class-name/with-inspector-control', custom_class_name_withInspectorControl); 12661 (0,external_wp_hooks_namespaceObject.addFilter)('blocks.getSaveContent.extraProps', 'core/custom-class-name/save-props', custom_class_name_addSaveProps); 12662 (0,external_wp_hooks_namespaceObject.addFilter)('blocks.switchToBlockType.transformedBlock', 'core/color/addTransforms', addTransforms); 12663 12664 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/hooks/generated-class-name.js 12665 /** 12666 * External dependencies 12667 */ 12668 12669 /** 12670 * WordPress dependencies 12671 */ 12672 12673 12674 12675 /** 12676 * Override props assigned to save component to inject generated className if 12677 * block supports it. This is only applied if the block's save result is an 12678 * element and not a markup string. 12679 * 12680 * @param {Object} extraProps Additional props applied to save element. 12681 * @param {Object} blockType Block type. 12682 * 12683 * @return {Object} Filtered props applied to save element. 12684 */ 12685 12686 function addGeneratedClassName(extraProps, blockType) { 12687 // Adding the generated className. 12688 if ((0,external_wp_blocks_namespaceObject.hasBlockSupport)(blockType, 'className', true)) { 12689 if (typeof extraProps.className === 'string') { 12690 // We have some extra classes and want to add the default classname 12691 // We use uniq to prevent duplicate classnames. 12692 extraProps.className = (0,external_lodash_namespaceObject.uniq)([(0,external_wp_blocks_namespaceObject.getBlockDefaultClassName)(blockType.name), ...extraProps.className.split(' ')]).join(' ').trim(); 12693 } else { 12694 // There is no string in the className variable, 12695 // so we just dump the default name in there. 12696 extraProps.className = (0,external_wp_blocks_namespaceObject.getBlockDefaultClassName)(blockType.name); 12697 } 12698 } 12699 12700 return extraProps; 12701 } 12702 (0,external_wp_hooks_namespaceObject.addFilter)('blocks.getSaveContent.extraProps', 'core/generated-class-name/save-props', addGeneratedClassName); 12703 12704 ;// CONCATENATED MODULE: ./node_modules/@wordpress/style-engine/build-module/styles/utils.js 12705 /** 12706 * External dependencies 12707 */ 12708 12709 /** 12710 * Internal dependencies 12711 */ 12712 12713 function generateBoxRules(style, options, path, ruleKey) { 12714 const boxStyle = (0,external_lodash_namespaceObject.get)(style, path); 12715 12716 if (!boxStyle) { 12717 return []; 12718 } 12719 12720 const rules = []; 12721 12722 if (typeof boxStyle === 'string') { 12723 rules.push({ 12724 selector: options.selector, 12725 key: ruleKey, 12726 value: boxStyle 12727 }); 12728 } else { 12729 const sideRules = ['top', 'right', 'bottom', 'left'].reduce((acc, side) => { 12730 const value = (0,external_lodash_namespaceObject.get)(boxStyle, [side]); 12731 12732 if (value) { 12733 acc.push({ 12734 selector: options.selector, 12735 key: `$ruleKey}${(0,external_lodash_namespaceObject.upperFirst)(side)}`, 12736 value 12737 }); 12738 } 12739 12740 return acc; 12741 }, []); 12742 rules.push(...sideRules); 12743 } 12744 12745 return rules; 12746 } 12747 12748 ;// CONCATENATED MODULE: ./node_modules/@wordpress/style-engine/build-module/styles/padding.js 12749 /** 12750 * Internal dependencies 12751 */ 12752 12753 const padding = { 12754 name: 'padding', 12755 generate: (style, options) => { 12756 return generateBoxRules(style, options, ['spacing', 'padding'], 'padding'); 12757 } 12758 }; 12759 /* harmony default export */ var styles_padding = (padding); 12760 12761 ;// CONCATENATED MODULE: ./node_modules/@wordpress/style-engine/build-module/styles/margin.js 12762 /** 12763 * Internal dependencies 12764 */ 12765 12766 const margin = { 12767 name: 'margin', 12768 generate: (style, options) => { 12769 return generateBoxRules(style, options, ['spacing', 'margin'], 'margin'); 12770 } 12771 }; 12772 /* harmony default export */ var styles_margin = (margin); 12773 12774 ;// CONCATENATED MODULE: ./node_modules/@wordpress/style-engine/build-module/styles/index.js 12775 /** 12776 * Internal dependencies 12777 */ 12778 12779 12780 const styleDefinitions = [styles_margin, styles_padding]; 12781 12782 ;// CONCATENATED MODULE: ./node_modules/@wordpress/style-engine/build-module/index.js 12783 /** 12784 * External dependencies 12785 */ 12786 12787 /** 12788 * Internal dependencies 12789 */ 12790 12791 12792 /** 12793 * Generates a stylesheet for a given style object and selector. 12794 * 12795 * @param style Style object. 12796 * @param options Options object with settings to adjust how the styles are generated. 12797 * 12798 * @return generated stylesheet. 12799 */ 12800 12801 function generate(style, options) { 12802 const rules = getCSSRules(style, options); 12803 const groupedRules = groupBy(rules, 'selector'); 12804 const selectorRules = Object.keys(groupedRules).reduce((acc, subSelector) => { 12805 acc.push(`$subSelector} { $groupedRules[subSelector].map(rule => `$kebabCase(rule.key)}: $rule.value};`).join(' ')} }`); 12806 return acc; 12807 }, []); 12808 return selectorRules.join('\n'); 12809 } 12810 /** 12811 * Returns a JSON representation of the generated CSS rules. 12812 * 12813 * @param style Style object. 12814 * @param options Options object with settings to adjust how the styles are generated. 12815 * 12816 * @return generated styles. 12817 */ 12818 12819 function getCSSRules(style, options) { 12820 const rules = []; 12821 styleDefinitions.forEach(definition => { 12822 rules.push(...definition.generate(style, options)); 12823 }); 12824 return rules; 12825 } 12826 12827 ;// CONCATENATED MODULE: external ["wp","dom"] 12828 var external_wp_dom_namespaceObject = window["wp"]["dom"]; 12829 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-context/index.js 12830 12831 12832 /** 12833 * WordPress dependencies 12834 */ 12835 12836 /** @typedef {import('react').ReactNode} ReactNode */ 12837 12838 /** 12839 * @typedef BlockContextProviderProps 12840 * 12841 * @property {Record<string,*>} value Context value to merge with current 12842 * value. 12843 * @property {ReactNode} children Component children. 12844 */ 12845 12846 /** @type {import('react').Context<Record<string,*>>} */ 12847 12848 const block_context_Context = (0,external_wp_element_namespaceObject.createContext)({}); 12849 /** 12850 * Component which merges passed value with current consumed block context. 12851 * 12852 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/block-context/README.md 12853 * 12854 * @param {BlockContextProviderProps} props 12855 */ 12856 12857 function BlockContextProvider(_ref) { 12858 let { 12859 value, 12860 children 12861 } = _ref; 12862 const context = (0,external_wp_element_namespaceObject.useContext)(block_context_Context); 12863 const nextValue = (0,external_wp_element_namespaceObject.useMemo)(() => ({ ...context, 12864 ...value 12865 }), [context, value]); 12866 return (0,external_wp_element_namespaceObject.createElement)(block_context_Context.Provider, { 12867 value: nextValue, 12868 children: children 12869 }); 12870 } 12871 /* harmony default export */ var block_context = (block_context_Context); 12872 12873 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-edit/edit.js 12874 12875 12876 12877 /** 12878 * External dependencies 12879 */ 12880 12881 12882 /** 12883 * WordPress dependencies 12884 */ 12885 12886 12887 12888 12889 /** 12890 * Internal dependencies 12891 */ 12892 12893 12894 /** 12895 * Default value used for blocks which do not define their own context needs, 12896 * used to guarantee that a block's `context` prop will always be an object. It 12897 * is assigned as a constant since it is always expected to be an empty object, 12898 * and in order to avoid unnecessary React reconciliations of a changing object. 12899 * 12900 * @type {{}} 12901 */ 12902 12903 const DEFAULT_BLOCK_CONTEXT = {}; 12904 const Edit = props => { 12905 const { 12906 attributes = {}, 12907 name 12908 } = props; 12909 const blockType = (0,external_wp_blocks_namespaceObject.getBlockType)(name); 12910 const blockContext = (0,external_wp_element_namespaceObject.useContext)(block_context); // Assign context values using the block type's declared context needs. 12911 12912 const context = (0,external_wp_element_namespaceObject.useMemo)(() => { 12913 return blockType && blockType.usesContext ? (0,external_lodash_namespaceObject.pick)(blockContext, blockType.usesContext) : DEFAULT_BLOCK_CONTEXT; 12914 }, [blockType, blockContext]); 12915 12916 if (!blockType) { 12917 return null; 12918 } // `edit` and `save` are functions or components describing the markup 12919 // with which a block is displayed. If `blockType` is valid, assign 12920 // them preferentially as the render value for the block. 12921 12922 12923 const Component = blockType.edit || blockType.save; 12924 12925 if (blockType.apiVersion > 1) { 12926 return (0,external_wp_element_namespaceObject.createElement)(Component, _extends({}, props, { 12927 context: context 12928 })); 12929 } // Generate a class name for the block's editable form. 12930 12931 12932 const generatedClassName = (0,external_wp_blocks_namespaceObject.hasBlockSupport)(blockType, 'className', true) ? (0,external_wp_blocks_namespaceObject.getBlockDefaultClassName)(name) : null; 12933 const className = classnames_default()(generatedClassName, attributes.className); 12934 return (0,external_wp_element_namespaceObject.createElement)(Component, _extends({}, props, { 12935 context: context, 12936 className: className 12937 })); 12938 }; 12939 /* harmony default export */ var edit = ((0,external_wp_components_namespaceObject.withFilters)('editor.BlockEdit')(Edit)); 12940 12941 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-edit/index.js 12942 12943 12944 /** 12945 * WordPress dependencies 12946 */ 12947 12948 /** 12949 * Internal dependencies 12950 */ 12951 12952 12953 12954 /** 12955 * The `useBlockEditContext` hook provides information about the block this hook is being used in. 12956 * It returns an object with the `name`, `isSelected` state, and the `clientId` of the block. 12957 * It is useful if you want to create custom hooks that need access to the current blocks clientId 12958 * but don't want to rely on the data getting passed in as a parameter. 12959 * 12960 * @return {Object} Block edit context 12961 */ 12962 12963 12964 function BlockEdit(props) { 12965 const { 12966 name, 12967 isSelected, 12968 clientId 12969 } = props; 12970 const context = { 12971 name, 12972 isSelected, 12973 clientId 12974 }; 12975 return (0,external_wp_element_namespaceObject.createElement)(Provider // It is important to return the same object if props haven't 12976 // changed to avoid unnecessary rerenders. 12977 // See https://reactjs.org/docs/context.html#caveats. 12978 , { 12979 value: (0,external_wp_element_namespaceObject.useMemo)(() => context, Object.values(context)) 12980 }, (0,external_wp_element_namespaceObject.createElement)(edit, props)); 12981 } 12982 12983 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/more-horizontal.js 12984 12985 12986 /** 12987 * WordPress dependencies 12988 */ 12989 12990 const moreHorizontal = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 12991 xmlns: "http://www.w3.org/2000/svg", 12992 viewBox: "0 0 24 24" 12993 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 12994 d: "M11 13h2v-2h-2v2zm-6 0h2v-2H5v2zm12-2v2h2v-2h-2z" 12995 })); 12996 /* harmony default export */ var more_horizontal = (moreHorizontal); 12997 12998 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/warning/index.js 12999 13000 13001 /** 13002 * External dependencies 13003 */ 13004 13005 /** 13006 * WordPress dependencies 13007 */ 13008 13009 13010 13011 13012 13013 13014 function Warning(_ref) { 13015 let { 13016 className, 13017 actions, 13018 children, 13019 secondaryActions 13020 } = _ref; 13021 return (0,external_wp_element_namespaceObject.createElement)("div", { 13022 className: classnames_default()(className, 'block-editor-warning') 13023 }, (0,external_wp_element_namespaceObject.createElement)("div", { 13024 className: "block-editor-warning__contents" 13025 }, (0,external_wp_element_namespaceObject.createElement)("p", { 13026 className: "block-editor-warning__message" 13027 }, children), (external_wp_element_namespaceObject.Children.count(actions) > 0 || secondaryActions) && (0,external_wp_element_namespaceObject.createElement)("div", { 13028 className: "block-editor-warning__actions" 13029 }, external_wp_element_namespaceObject.Children.count(actions) > 0 && external_wp_element_namespaceObject.Children.map(actions, (action, i) => (0,external_wp_element_namespaceObject.createElement)("span", { 13030 key: i, 13031 className: "block-editor-warning__action" 13032 }, action)), secondaryActions && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.DropdownMenu, { 13033 className: "block-editor-warning__secondary", 13034 icon: more_horizontal, 13035 label: (0,external_wp_i18n_namespaceObject.__)('More options'), 13036 popoverProps: { 13037 position: 'bottom left', 13038 className: 'block-editor-warning__dropdown' 13039 }, 13040 noIcons: true 13041 }, () => (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuGroup, null, secondaryActions.map((item, pos) => (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, { 13042 onClick: item.onClick, 13043 key: pos 13044 }, item.title))))))); 13045 } 13046 /** 13047 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/warning/README.md 13048 */ 13049 13050 13051 /* harmony default export */ var warning = (Warning); 13052 13053 // EXTERNAL MODULE: ./node_modules/diff/lib/diff/character.js 13054 var character = __webpack_require__(1973); 13055 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-compare/block-view.js 13056 13057 13058 /** 13059 * WordPress dependencies 13060 */ 13061 13062 13063 13064 function BlockView(_ref) { 13065 let { 13066 title, 13067 rawContent, 13068 renderedContent, 13069 action, 13070 actionText, 13071 className 13072 } = _ref; 13073 return (0,external_wp_element_namespaceObject.createElement)("div", { 13074 className: className 13075 }, (0,external_wp_element_namespaceObject.createElement)("div", { 13076 className: "block-editor-block-compare__content" 13077 }, (0,external_wp_element_namespaceObject.createElement)("h2", { 13078 className: "block-editor-block-compare__heading" 13079 }, title), (0,external_wp_element_namespaceObject.createElement)("div", { 13080 className: "block-editor-block-compare__html" 13081 }, rawContent), (0,external_wp_element_namespaceObject.createElement)("div", { 13082 className: "block-editor-block-compare__preview edit-post-visual-editor" 13083 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.RawHTML, null, (0,external_wp_dom_namespaceObject.safeHTML)(renderedContent)))), (0,external_wp_element_namespaceObject.createElement)("div", { 13084 className: "block-editor-block-compare__action" 13085 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 13086 variant: "secondary", 13087 tabIndex: "0", 13088 onClick: action 13089 }, actionText))); 13090 } 13091 13092 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-compare/index.js 13093 13094 13095 /** 13096 * External dependencies 13097 */ 13098 13099 // diff doesn't tree-shake correctly, so we import from the individual 13100 // module here, to avoid including too much of the library 13101 13102 13103 /** 13104 * WordPress dependencies 13105 */ 13106 13107 13108 13109 /** 13110 * Internal dependencies 13111 */ 13112 13113 13114 13115 function BlockCompare(_ref) { 13116 let { 13117 block, 13118 onKeep, 13119 onConvert, 13120 convertor, 13121 convertButtonText 13122 } = _ref; 13123 13124 function getDifference(originalContent, newContent) { 13125 const difference = (0,character/* diffChars */.Kx)(originalContent, newContent); 13126 return difference.map((item, pos) => { 13127 const classes = classnames_default()({ 13128 'block-editor-block-compare__added': item.added, 13129 'block-editor-block-compare__removed': item.removed 13130 }); 13131 return (0,external_wp_element_namespaceObject.createElement)("span", { 13132 key: pos, 13133 className: classes 13134 }, item.value); 13135 }); 13136 } 13137 13138 function getConvertedContent(convertedBlock) { 13139 // The convertor may return an array of items or a single item. 13140 const newBlocks = (0,external_lodash_namespaceObject.castArray)(convertedBlock); // Get converted block details. 13141 13142 const newContent = newBlocks.map(item => (0,external_wp_blocks_namespaceObject.getSaveContent)(item.name, item.attributes, item.innerBlocks)); 13143 return newContent.join(''); 13144 } 13145 13146 const converted = getConvertedContent(convertor(block)); 13147 const difference = getDifference(block.originalContent, converted); 13148 return (0,external_wp_element_namespaceObject.createElement)("div", { 13149 className: "block-editor-block-compare__wrapper" 13150 }, (0,external_wp_element_namespaceObject.createElement)(BlockView, { 13151 title: (0,external_wp_i18n_namespaceObject.__)('Current'), 13152 className: "block-editor-block-compare__current", 13153 action: onKeep, 13154 actionText: (0,external_wp_i18n_namespaceObject.__)('Convert to HTML'), 13155 rawContent: block.originalContent, 13156 renderedContent: block.originalContent 13157 }), (0,external_wp_element_namespaceObject.createElement)(BlockView, { 13158 title: (0,external_wp_i18n_namespaceObject.__)('After Conversion'), 13159 className: "block-editor-block-compare__converted", 13160 action: onConvert, 13161 actionText: convertButtonText, 13162 rawContent: difference, 13163 renderedContent: converted 13164 })); 13165 } 13166 13167 /* harmony default export */ var block_compare = (BlockCompare); 13168 13169 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-list/block-invalid-warning.js 13170 13171 13172 /** 13173 * WordPress dependencies 13174 */ 13175 13176 13177 13178 13179 13180 13181 /** 13182 * Internal dependencies 13183 */ 13184 13185 13186 13187 13188 function BlockInvalidWarning(_ref) { 13189 let { 13190 convertToHTML, 13191 convertToBlocks, 13192 convertToClassic, 13193 attemptBlockRecovery, 13194 block 13195 } = _ref; 13196 const hasHTMLBlock = !!(0,external_wp_blocks_namespaceObject.getBlockType)('core/html'); 13197 const [compare, setCompare] = (0,external_wp_element_namespaceObject.useState)(false); 13198 const onCompare = (0,external_wp_element_namespaceObject.useCallback)(() => setCompare(true), []); 13199 const onCompareClose = (0,external_wp_element_namespaceObject.useCallback)(() => setCompare(false), []); // We memo the array here to prevent the children components from being updated unexpectedly. 13200 13201 const hiddenActions = (0,external_wp_element_namespaceObject.useMemo)(() => [{ 13202 // translators: Button to fix block content 13203 title: (0,external_wp_i18n_namespaceObject._x)('Resolve', 'imperative verb'), 13204 onClick: onCompare 13205 }, hasHTMLBlock && { 13206 title: (0,external_wp_i18n_namespaceObject.__)('Convert to HTML'), 13207 onClick: convertToHTML 13208 }, { 13209 title: (0,external_wp_i18n_namespaceObject.__)('Convert to Classic Block'), 13210 onClick: convertToClassic 13211 }].filter(Boolean), [onCompare, convertToHTML, convertToClassic]); 13212 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(warning, { 13213 actions: [(0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 13214 key: "recover", 13215 onClick: attemptBlockRecovery, 13216 variant: "primary" 13217 }, (0,external_wp_i18n_namespaceObject.__)('Attempt Block Recovery'))], 13218 secondaryActions: hiddenActions 13219 }, (0,external_wp_i18n_namespaceObject.__)('This block contains unexpected or invalid content.')), compare && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Modal, { 13220 title: // translators: Dialog title to fix block content 13221 (0,external_wp_i18n_namespaceObject.__)('Resolve Block'), 13222 onRequestClose: onCompareClose, 13223 className: "block-editor-block-compare" 13224 }, (0,external_wp_element_namespaceObject.createElement)(block_compare, { 13225 block: block, 13226 onKeep: convertToHTML, 13227 onConvert: convertToBlocks, 13228 convertor: blockToBlocks, 13229 convertButtonText: (0,external_wp_i18n_namespaceObject.__)('Convert to Blocks') 13230 }))); 13231 } 13232 13233 const blockToClassic = block => (0,external_wp_blocks_namespaceObject.createBlock)('core/freeform', { 13234 content: block.originalContent 13235 }); 13236 13237 const blockToHTML = block => (0,external_wp_blocks_namespaceObject.createBlock)('core/html', { 13238 content: block.originalContent 13239 }); 13240 13241 const blockToBlocks = block => (0,external_wp_blocks_namespaceObject.rawHandler)({ 13242 HTML: block.originalContent 13243 }); 13244 13245 const recoverBlock = _ref2 => { 13246 let { 13247 name, 13248 attributes, 13249 innerBlocks 13250 } = _ref2; 13251 return (0,external_wp_blocks_namespaceObject.createBlock)(name, attributes, innerBlocks); 13252 }; 13253 13254 /* harmony default export */ var block_invalid_warning = ((0,external_wp_compose_namespaceObject.compose)([(0,external_wp_data_namespaceObject.withSelect)((select, _ref3) => { 13255 let { 13256 clientId 13257 } = _ref3; 13258 return { 13259 block: select(store).getBlock(clientId) 13260 }; 13261 }), (0,external_wp_data_namespaceObject.withDispatch)((dispatch, _ref4) => { 13262 let { 13263 block 13264 } = _ref4; 13265 const { 13266 replaceBlock 13267 } = dispatch(store); 13268 return { 13269 convertToClassic() { 13270 replaceBlock(block.clientId, blockToClassic(block)); 13271 }, 13272 13273 convertToHTML() { 13274 replaceBlock(block.clientId, blockToHTML(block)); 13275 }, 13276 13277 convertToBlocks() { 13278 replaceBlock(block.clientId, blockToBlocks(block)); 13279 }, 13280 13281 attemptBlockRecovery() { 13282 replaceBlock(block.clientId, recoverBlock(block)); 13283 } 13284 13285 }; 13286 })])(BlockInvalidWarning)); 13287 13288 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-list/block-crash-warning.js 13289 13290 13291 /** 13292 * WordPress dependencies 13293 */ 13294 13295 /** 13296 * Internal dependencies 13297 */ 13298 13299 13300 const block_crash_warning_warning = (0,external_wp_element_namespaceObject.createElement)(warning, { 13301 className: "block-editor-block-list__block-crash-warning" 13302 }, (0,external_wp_i18n_namespaceObject.__)('This block has encountered an error and cannot be previewed.')); 13303 /* harmony default export */ var block_crash_warning = (() => block_crash_warning_warning); 13304 13305 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-list/block-crash-boundary.js 13306 /** 13307 * WordPress dependencies 13308 */ 13309 13310 13311 class BlockCrashBoundary extends external_wp_element_namespaceObject.Component { 13312 constructor() { 13313 super(...arguments); 13314 this.state = { 13315 hasError: false 13316 }; 13317 } 13318 13319 componentDidCatch() { 13320 this.setState({ 13321 hasError: true 13322 }); 13323 } 13324 13325 render() { 13326 if (this.state.hasError) { 13327 return this.props.fallback; 13328 } 13329 13330 return this.props.children; 13331 } 13332 13333 } 13334 13335 /* harmony default export */ var block_crash_boundary = (BlockCrashBoundary); 13336 13337 // EXTERNAL MODULE: ./node_modules/react-autosize-textarea/lib/index.js 13338 var lib = __webpack_require__(773); 13339 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-list/block-html.js 13340 13341 13342 /** 13343 * External dependencies 13344 */ 13345 13346 /** 13347 * WordPress dependencies 13348 */ 13349 13350 13351 13352 13353 /** 13354 * Internal dependencies 13355 */ 13356 13357 13358 13359 function BlockHTML(_ref) { 13360 let { 13361 clientId 13362 } = _ref; 13363 const [html, setHtml] = (0,external_wp_element_namespaceObject.useState)(''); 13364 const block = (0,external_wp_data_namespaceObject.useSelect)(select => select(store).getBlock(clientId), [clientId]); 13365 const { 13366 updateBlock 13367 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 13368 13369 const onChange = () => { 13370 const blockType = (0,external_wp_blocks_namespaceObject.getBlockType)(block.name); 13371 13372 if (!blockType) { 13373 return; 13374 } 13375 13376 const attributes = (0,external_wp_blocks_namespaceObject.getBlockAttributes)(blockType, html, block.attributes); // If html is empty we reset the block to the default HTML and mark it as valid to avoid triggering an error 13377 13378 const content = html ? html : (0,external_wp_blocks_namespaceObject.getSaveContent)(blockType, attributes); 13379 const [isValid] = html ? (0,external_wp_blocks_namespaceObject.validateBlock)({ ...block, 13380 attributes, 13381 originalContent: content 13382 }) : [true]; 13383 updateBlock(clientId, { 13384 attributes, 13385 originalContent: content, 13386 isValid 13387 }); // Ensure the state is updated if we reset so it displays the default content. 13388 13389 if (!html) { 13390 setHtml({ 13391 content 13392 }); 13393 } 13394 }; 13395 13396 (0,external_wp_element_namespaceObject.useEffect)(() => { 13397 setHtml((0,external_wp_blocks_namespaceObject.getBlockContent)(block)); 13398 }, [block]); 13399 return (0,external_wp_element_namespaceObject.createElement)(lib/* default */.Z, { 13400 className: "block-editor-block-list__block-html-textarea", 13401 value: html, 13402 onBlur: onChange, 13403 onChange: event => setHtml(event.target.value) 13404 }); 13405 } 13406 13407 /* harmony default export */ var block_html = (BlockHTML); 13408 13409 ;// CONCATENATED MODULE: ./node_modules/@react-spring/rafz/dist/react-spring-rafz.esm.js 13410 let updateQueue = makeQueue(); 13411 const raf = fn => schedule(fn, updateQueue); 13412 let writeQueue = makeQueue(); 13413 13414 raf.write = fn => schedule(fn, writeQueue); 13415 13416 let onStartQueue = makeQueue(); 13417 13418 raf.onStart = fn => schedule(fn, onStartQueue); 13419 13420 let onFrameQueue = makeQueue(); 13421 13422 raf.onFrame = fn => schedule(fn, onFrameQueue); 13423 13424 let onFinishQueue = makeQueue(); 13425 13426 raf.onFinish = fn => schedule(fn, onFinishQueue); 13427 13428 let timeouts = []; 13429 13430 raf.setTimeout = (handler, ms) => { 13431 let time = raf.now() + ms; 13432 13433 let cancel = () => { 13434 let i = timeouts.findIndex(t => t.cancel == cancel); 13435 if (~i) timeouts.splice(i, 1); 13436 pendingCount -= ~i ? 1 : 0; 13437 }; 13438 13439 let timeout = { 13440 time, 13441 handler, 13442 cancel 13443 }; 13444 timeouts.splice(findTimeout(time), 0, timeout); 13445 pendingCount += 1; 13446 start(); 13447 return timeout; 13448 }; 13449 13450 let findTimeout = time => ~(~timeouts.findIndex(t => t.time > time) || ~timeouts.length); 13451 13452 raf.cancel = fn => { 13453 onStartQueue.delete(fn); 13454 onFrameQueue.delete(fn); 13455 updateQueue.delete(fn); 13456 writeQueue.delete(fn); 13457 onFinishQueue.delete(fn); 13458 }; 13459 13460 raf.sync = fn => { 13461 sync = true; 13462 raf.batchedUpdates(fn); 13463 sync = false; 13464 }; 13465 13466 raf.throttle = fn => { 13467 let lastArgs; 13468 13469 function queuedFn() { 13470 try { 13471 fn(...lastArgs); 13472 } finally { 13473 lastArgs = null; 13474 } 13475 } 13476 13477 function throttled(...args) { 13478 lastArgs = args; 13479 raf.onStart(queuedFn); 13480 } 13481 13482 throttled.handler = fn; 13483 13484 throttled.cancel = () => { 13485 onStartQueue.delete(queuedFn); 13486 lastArgs = null; 13487 }; 13488 13489 return throttled; 13490 }; 13491 13492 let nativeRaf = typeof window != 'undefined' ? window.requestAnimationFrame : () => {}; 13493 13494 raf.use = impl => nativeRaf = impl; 13495 13496 raf.now = typeof performance != 'undefined' ? () => performance.now() : Date.now; 13497 13498 raf.batchedUpdates = fn => fn(); 13499 13500 raf.catch = console.error; 13501 raf.frameLoop = 'always'; 13502 13503 raf.advance = () => { 13504 if (raf.frameLoop !== 'demand') { 13505 console.warn('Cannot call the manual advancement of rafz whilst frameLoop is not set as demand'); 13506 } else { 13507 update(); 13508 } 13509 }; 13510 13511 let ts = -1; 13512 let pendingCount = 0; 13513 let sync = false; 13514 13515 function schedule(fn, queue) { 13516 if (sync) { 13517 queue.delete(fn); 13518 fn(0); 13519 } else { 13520 queue.add(fn); 13521 start(); 13522 } 13523 } 13524 13525 function start() { 13526 if (ts < 0) { 13527 ts = 0; 13528 13529 if (raf.frameLoop !== 'demand') { 13530 nativeRaf(loop); 13531 } 13532 } 13533 } 13534 13535 function stop() { 13536 ts = -1; 13537 } 13538 13539 function loop() { 13540 if (~ts) { 13541 nativeRaf(loop); 13542 raf.batchedUpdates(update); 13543 } 13544 } 13545 13546 function update() { 13547 let prevTs = ts; 13548 ts = raf.now(); 13549 let count = findTimeout(ts); 13550 13551 if (count) { 13552 eachSafely(timeouts.splice(0, count), t => t.handler()); 13553 pendingCount -= count; 13554 } 13555 13556 onStartQueue.flush(); 13557 updateQueue.flush(prevTs ? Math.min(64, ts - prevTs) : 16.667); 13558 onFrameQueue.flush(); 13559 writeQueue.flush(); 13560 onFinishQueue.flush(); 13561 13562 if (!pendingCount) { 13563 stop(); 13564 } 13565 } 13566 13567 function makeQueue() { 13568 let next = new Set(); 13569 let current = next; 13570 return { 13571 add(fn) { 13572 pendingCount += current == next && !next.has(fn) ? 1 : 0; 13573 next.add(fn); 13574 }, 13575 13576 delete(fn) { 13577 pendingCount -= current == next && next.has(fn) ? 1 : 0; 13578 return next.delete(fn); 13579 }, 13580 13581 flush(arg) { 13582 if (current.size) { 13583 next = new Set(); 13584 pendingCount -= current.size; 13585 eachSafely(current, fn => fn(arg) && next.add(fn)); 13586 pendingCount += next.size; 13587 current = next; 13588 } 13589 } 13590 13591 }; 13592 } 13593 13594 function eachSafely(values, each) { 13595 values.forEach(value => { 13596 try { 13597 each(value); 13598 } catch (e) { 13599 raf.catch(e); 13600 } 13601 }); 13602 } 13603 13604 const __raf = { 13605 count() { 13606 return pendingCount; 13607 }, 13608 13609 isRunning() { 13610 return ts >= 0; 13611 }, 13612 13613 clear() { 13614 ts = -1; 13615 timeouts = []; 13616 onStartQueue = makeQueue(); 13617 updateQueue = makeQueue(); 13618 onFrameQueue = makeQueue(); 13619 writeQueue = makeQueue(); 13620 onFinishQueue = makeQueue(); 13621 pendingCount = 0; 13622 } 13623 13624 }; 13625 13626 13627 13628 // EXTERNAL MODULE: external "React" 13629 var external_React_ = __webpack_require__(9196); 13630 var external_React_default = /*#__PURE__*/__webpack_require__.n(external_React_); 13631 ;// CONCATENATED MODULE: ./node_modules/@react-spring/shared/dist/react-spring-shared.esm.js 13632 13633 13634 13635 13636 13637 function noop() {} 13638 const defineHidden = (obj, key, value) => Object.defineProperty(obj, key, { 13639 value, 13640 writable: true, 13641 configurable: true 13642 }); 13643 const react_spring_shared_esm_is = { 13644 arr: Array.isArray, 13645 obj: a => !!a && a.constructor.name === 'Object', 13646 fun: a => typeof a === 'function', 13647 str: a => typeof a === 'string', 13648 num: a => typeof a === 'number', 13649 und: a => a === undefined 13650 }; 13651 function isEqual(a, b) { 13652 if (react_spring_shared_esm_is.arr(a)) { 13653 if (!react_spring_shared_esm_is.arr(b) || a.length !== b.length) return false; 13654 13655 for (let i = 0; i < a.length; i++) { 13656 if (a[i] !== b[i]) return false; 13657 } 13658 13659 return true; 13660 } 13661 13662 return a === b; 13663 } 13664 const react_spring_shared_esm_each = (obj, fn) => obj.forEach(fn); 13665 function eachProp(obj, fn, ctx) { 13666 if (react_spring_shared_esm_is.arr(obj)) { 13667 for (let i = 0; i < obj.length; i++) { 13668 fn.call(ctx, obj[i], `$i}`); 13669 } 13670 13671 return; 13672 } 13673 13674 for (const key in obj) { 13675 if (obj.hasOwnProperty(key)) { 13676 fn.call(ctx, obj[key], key); 13677 } 13678 } 13679 } 13680 const react_spring_shared_esm_toArray = a => react_spring_shared_esm_is.und(a) ? [] : react_spring_shared_esm_is.arr(a) ? a : [a]; 13681 function flush(queue, iterator) { 13682 if (queue.size) { 13683 const items = Array.from(queue); 13684 queue.clear(); 13685 react_spring_shared_esm_each(items, iterator); 13686 } 13687 } 13688 const flushCalls = (queue, ...args) => flush(queue, fn => fn(...args)); 13689 const isSSR = () => typeof window === 'undefined' || !window.navigator || /ServerSideRendering|^Deno\//.test(window.navigator.userAgent); 13690 13691 let createStringInterpolator$1; 13692 let to; 13693 let colors$1 = null; 13694 let skipAnimation = false; 13695 let willAdvance = noop; 13696 const react_spring_shared_esm_assign = globals => { 13697 if (globals.to) to = globals.to; 13698 if (globals.now) raf.now = globals.now; 13699 if (globals.colors !== undefined) colors$1 = globals.colors; 13700 if (globals.skipAnimation != null) skipAnimation = globals.skipAnimation; 13701 if (globals.createStringInterpolator) createStringInterpolator$1 = globals.createStringInterpolator; 13702 if (globals.requestAnimationFrame) raf.use(globals.requestAnimationFrame); 13703 if (globals.batchedUpdates) raf.batchedUpdates = globals.batchedUpdates; 13704 if (globals.willAdvance) willAdvance = globals.willAdvance; 13705 if (globals.frameLoop) raf.frameLoop = globals.frameLoop; 13706 }; 13707 13708 var globals = /*#__PURE__*/Object.freeze({ 13709 __proto__: null, 13710 get createStringInterpolator () { return createStringInterpolator$1; }, 13711 get to () { return to; }, 13712 get colors () { return colors$1; }, 13713 get skipAnimation () { return skipAnimation; }, 13714 get willAdvance () { return willAdvance; }, 13715 assign: react_spring_shared_esm_assign 13716 }); 13717 13718 const startQueue = new Set(); 13719 let currentFrame = []; 13720 let prevFrame = []; 13721 let priority = 0; 13722 const frameLoop = { 13723 get idle() { 13724 return !startQueue.size && !currentFrame.length; 13725 }, 13726 13727 start(animation) { 13728 if (priority > animation.priority) { 13729 startQueue.add(animation); 13730 raf.onStart(flushStartQueue); 13731 } else { 13732 startSafely(animation); 13733 raf(advance); 13734 } 13735 }, 13736 13737 advance, 13738 13739 sort(animation) { 13740 if (priority) { 13741 raf.onFrame(() => frameLoop.sort(animation)); 13742 } else { 13743 const prevIndex = currentFrame.indexOf(animation); 13744 13745 if (~prevIndex) { 13746 currentFrame.splice(prevIndex, 1); 13747 startUnsafely(animation); 13748 } 13749 } 13750 }, 13751 13752 clear() { 13753 currentFrame = []; 13754 startQueue.clear(); 13755 } 13756 13757 }; 13758 13759 function flushStartQueue() { 13760 startQueue.forEach(startSafely); 13761 startQueue.clear(); 13762 raf(advance); 13763 } 13764 13765 function startSafely(animation) { 13766 if (!currentFrame.includes(animation)) startUnsafely(animation); 13767 } 13768 13769 function startUnsafely(animation) { 13770 currentFrame.splice(findIndex(currentFrame, other => other.priority > animation.priority), 0, animation); 13771 } 13772 13773 function advance(dt) { 13774 const nextFrame = prevFrame; 13775 13776 for (let i = 0; i < currentFrame.length; i++) { 13777 const animation = currentFrame[i]; 13778 priority = animation.priority; 13779 13780 if (!animation.idle) { 13781 willAdvance(animation); 13782 animation.advance(dt); 13783 13784 if (!animation.idle) { 13785 nextFrame.push(animation); 13786 } 13787 } 13788 } 13789 13790 priority = 0; 13791 prevFrame = currentFrame; 13792 prevFrame.length = 0; 13793 currentFrame = nextFrame; 13794 return currentFrame.length > 0; 13795 } 13796 13797 function findIndex(arr, test) { 13798 const index = arr.findIndex(test); 13799 return index < 0 ? arr.length : index; 13800 } 13801 13802 const colors = { 13803 transparent: 0x00000000, 13804 aliceblue: 0xf0f8ffff, 13805 antiquewhite: 0xfaebd7ff, 13806 aqua: 0x00ffffff, 13807 aquamarine: 0x7fffd4ff, 13808 azure: 0xf0ffffff, 13809 beige: 0xf5f5dcff, 13810 bisque: 0xffe4c4ff, 13811 black: 0x000000ff, 13812 blanchedalmond: 0xffebcdff, 13813 blue: 0x0000ffff, 13814 blueviolet: 0x8a2be2ff, 13815 brown: 0xa52a2aff, 13816 burlywood: 0xdeb887ff, 13817 burntsienna: 0xea7e5dff, 13818 cadetblue: 0x5f9ea0ff, 13819 chartreuse: 0x7fff00ff, 13820 chocolate: 0xd2691eff, 13821 coral: 0xff7f50ff, 13822 cornflowerblue: 0x6495edff, 13823 cornsilk: 0xfff8dcff, 13824 crimson: 0xdc143cff, 13825 cyan: 0x00ffffff, 13826 darkblue: 0x00008bff, 13827 darkcyan: 0x008b8bff, 13828 darkgoldenrod: 0xb8860bff, 13829 darkgray: 0xa9a9a9ff, 13830 darkgreen: 0x006400ff, 13831 darkgrey: 0xa9a9a9ff, 13832 darkkhaki: 0xbdb76bff, 13833 darkmagenta: 0x8b008bff, 13834 darkolivegreen: 0x556b2fff, 13835 darkorange: 0xff8c00ff, 13836 darkorchid: 0x9932ccff, 13837 darkred: 0x8b0000ff, 13838 darksalmon: 0xe9967aff, 13839 darkseagreen: 0x8fbc8fff, 13840 darkslateblue: 0x483d8bff, 13841 darkslategray: 0x2f4f4fff, 13842 darkslategrey: 0x2f4f4fff, 13843 darkturquoise: 0x00ced1ff, 13844 darkviolet: 0x9400d3ff, 13845 deeppink: 0xff1493ff, 13846 deepskyblue: 0x00bfffff, 13847 dimgray: 0x696969ff, 13848 dimgrey: 0x696969ff, 13849 dodgerblue: 0x1e90ffff, 13850 firebrick: 0xb22222ff, 13851 floralwhite: 0xfffaf0ff, 13852 forestgreen: 0x228b22ff, 13853 fuchsia: 0xff00ffff, 13854 gainsboro: 0xdcdcdcff, 13855 ghostwhite: 0xf8f8ffff, 13856 gold: 0xffd700ff, 13857 goldenrod: 0xdaa520ff, 13858 gray: 0x808080ff, 13859 green: 0x008000ff, 13860 greenyellow: 0xadff2fff, 13861 grey: 0x808080ff, 13862 honeydew: 0xf0fff0ff, 13863 hotpink: 0xff69b4ff, 13864 indianred: 0xcd5c5cff, 13865 indigo: 0x4b0082ff, 13866 ivory: 0xfffff0ff, 13867 khaki: 0xf0e68cff, 13868 lavender: 0xe6e6faff, 13869 lavenderblush: 0xfff0f5ff, 13870 lawngreen: 0x7cfc00ff, 13871 lemonchiffon: 0xfffacdff, 13872 lightblue: 0xadd8e6ff, 13873 lightcoral: 0xf08080ff, 13874 lightcyan: 0xe0ffffff, 13875 lightgoldenrodyellow: 0xfafad2ff, 13876 lightgray: 0xd3d3d3ff, 13877 lightgreen: 0x90ee90ff, 13878 lightgrey: 0xd3d3d3ff, 13879 lightpink: 0xffb6c1ff, 13880 lightsalmon: 0xffa07aff, 13881 lightseagreen: 0x20b2aaff, 13882 lightskyblue: 0x87cefaff, 13883 lightslategray: 0x778899ff, 13884 lightslategrey: 0x778899ff, 13885 lightsteelblue: 0xb0c4deff, 13886 lightyellow: 0xffffe0ff, 13887 lime: 0x00ff00ff, 13888 limegreen: 0x32cd32ff, 13889 linen: 0xfaf0e6ff, 13890 magenta: 0xff00ffff, 13891 maroon: 0x800000ff, 13892 mediumaquamarine: 0x66cdaaff, 13893 mediumblue: 0x0000cdff, 13894 mediumorchid: 0xba55d3ff, 13895 mediumpurple: 0x9370dbff, 13896 mediumseagreen: 0x3cb371ff, 13897 mediumslateblue: 0x7b68eeff, 13898 mediumspringgreen: 0x00fa9aff, 13899 mediumturquoise: 0x48d1ccff, 13900 mediumvioletred: 0xc71585ff, 13901 midnightblue: 0x191970ff, 13902 mintcream: 0xf5fffaff, 13903 mistyrose: 0xffe4e1ff, 13904 moccasin: 0xffe4b5ff, 13905 navajowhite: 0xffdeadff, 13906 navy: 0x000080ff, 13907 oldlace: 0xfdf5e6ff, 13908 olive: 0x808000ff, 13909 olivedrab: 0x6b8e23ff, 13910 orange: 0xffa500ff, 13911 orangered: 0xff4500ff, 13912 orchid: 0xda70d6ff, 13913 palegoldenrod: 0xeee8aaff, 13914 palegreen: 0x98fb98ff, 13915 paleturquoise: 0xafeeeeff, 13916 palevioletred: 0xdb7093ff, 13917 papayawhip: 0xffefd5ff, 13918 peachpuff: 0xffdab9ff, 13919 peru: 0xcd853fff, 13920 pink: 0xffc0cbff, 13921 plum: 0xdda0ddff, 13922 powderblue: 0xb0e0e6ff, 13923 purple: 0x800080ff, 13924 rebeccapurple: 0x663399ff, 13925 red: 0xff0000ff, 13926 rosybrown: 0xbc8f8fff, 13927 royalblue: 0x4169e1ff, 13928 saddlebrown: 0x8b4513ff, 13929 salmon: 0xfa8072ff, 13930 sandybrown: 0xf4a460ff, 13931 seagreen: 0x2e8b57ff, 13932 seashell: 0xfff5eeff, 13933 sienna: 0xa0522dff, 13934 silver: 0xc0c0c0ff, 13935 skyblue: 0x87ceebff, 13936 slateblue: 0x6a5acdff, 13937 slategray: 0x708090ff, 13938 slategrey: 0x708090ff, 13939 snow: 0xfffafaff, 13940 springgreen: 0x00ff7fff, 13941 steelblue: 0x4682b4ff, 13942 tan: 0xd2b48cff, 13943 teal: 0x008080ff, 13944 thistle: 0xd8bfd8ff, 13945 tomato: 0xff6347ff, 13946 turquoise: 0x40e0d0ff, 13947 violet: 0xee82eeff, 13948 wheat: 0xf5deb3ff, 13949 white: 0xffffffff, 13950 whitesmoke: 0xf5f5f5ff, 13951 yellow: 0xffff00ff, 13952 yellowgreen: 0x9acd32ff 13953 }; 13954 13955 const NUMBER = '[-+]?\\d*\\.?\\d+'; 13956 const PERCENTAGE = NUMBER + '%'; 13957 13958 function call(...parts) { 13959 return '\\(\\s*(' + parts.join(')\\s*,\\s*(') + ')\\s*\\)'; 13960 } 13961 13962 const rgb = new RegExp('rgb' + call(NUMBER, NUMBER, NUMBER)); 13963 const rgba = new RegExp('rgba' + call(NUMBER, NUMBER, NUMBER, NUMBER)); 13964 const hsl = new RegExp('hsl' + call(NUMBER, PERCENTAGE, PERCENTAGE)); 13965 const hsla = new RegExp('hsla' + call(NUMBER, PERCENTAGE, PERCENTAGE, NUMBER)); 13966 const hex3 = /^#([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/; 13967 const hex4 = /^#([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/; 13968 const hex6 = /^#([0-9a-fA-F]{6})$/; 13969 const hex8 = /^#([0-9a-fA-F]{8})$/; 13970 13971 function normalizeColor(color) { 13972 let match; 13973 13974 if (typeof color === 'number') { 13975 return color >>> 0 === color && color >= 0 && color <= 0xffffffff ? color : null; 13976 } 13977 13978 if (match = hex6.exec(color)) return parseInt(match[1] + 'ff', 16) >>> 0; 13979 13980 if (colors$1 && colors$1[color] !== undefined) { 13981 return colors$1[color]; 13982 } 13983 13984 if (match = rgb.exec(color)) { 13985 return (parse255(match[1]) << 24 | parse255(match[2]) << 16 | parse255(match[3]) << 8 | 0x000000ff) >>> 0; 13986 } 13987 13988 if (match = rgba.exec(color)) { 13989 return (parse255(match[1]) << 24 | parse255(match[2]) << 16 | parse255(match[3]) << 8 | parse1(match[4])) >>> 0; 13990 } 13991 13992 if (match = hex3.exec(color)) { 13993 return parseInt(match[1] + match[1] + match[2] + match[2] + match[3] + match[3] + 'ff', 16) >>> 0; 13994 } 13995 13996 if (match = hex8.exec(color)) return parseInt(match[1], 16) >>> 0; 13997 13998 if (match = hex4.exec(color)) { 13999 return parseInt(match[1] + match[1] + match[2] + match[2] + match[3] + match[3] + match[4] + match[4], 16) >>> 0; 14000 } 14001 14002 if (match = hsl.exec(color)) { 14003 return (hslToRgb(parse360(match[1]), parsePercentage(match[2]), parsePercentage(match[3])) | 0x000000ff) >>> 0; 14004 } 14005 14006 if (match = hsla.exec(color)) { 14007 return (hslToRgb(parse360(match[1]), parsePercentage(match[2]), parsePercentage(match[3])) | parse1(match[4])) >>> 0; 14008 } 14009 14010 return null; 14011 } 14012 14013 function hue2rgb(p, q, t) { 14014 if (t < 0) t += 1; 14015 if (t > 1) t -= 1; 14016 if (t < 1 / 6) return p + (q - p) * 6 * t; 14017 if (t < 1 / 2) return q; 14018 if (t < 2 / 3) return p + (q - p) * (2 / 3 - t) * 6; 14019 return p; 14020 } 14021 14022 function hslToRgb(h, s, l) { 14023 const q = l < 0.5 ? l * (1 + s) : l + s - l * s; 14024 const p = 2 * l - q; 14025 const r = hue2rgb(p, q, h + 1 / 3); 14026 const g = hue2rgb(p, q, h); 14027 const b = hue2rgb(p, q, h - 1 / 3); 14028 return Math.round(r * 255) << 24 | Math.round(g * 255) << 16 | Math.round(b * 255) << 8; 14029 } 14030 14031 function parse255(str) { 14032 const int = parseInt(str, 10); 14033 if (int < 0) return 0; 14034 if (int > 255) return 255; 14035 return int; 14036 } 14037 14038 function parse360(str) { 14039 const int = parseFloat(str); 14040 return (int % 360 + 360) % 360 / 360; 14041 } 14042 14043 function parse1(str) { 14044 const num = parseFloat(str); 14045 if (num < 0) return 0; 14046 if (num > 1) return 255; 14047 return Math.round(num * 255); 14048 } 14049 14050 function parsePercentage(str) { 14051 const int = parseFloat(str); 14052 if (int < 0) return 0; 14053 if (int > 100) return 1; 14054 return int / 100; 14055 } 14056 14057 function colorToRgba(input) { 14058 let int32Color = normalizeColor(input); 14059 if (int32Color === null) return input; 14060 int32Color = int32Color || 0; 14061 let r = (int32Color & 0xff000000) >>> 24; 14062 let g = (int32Color & 0x00ff0000) >>> 16; 14063 let b = (int32Color & 0x0000ff00) >>> 8; 14064 let a = (int32Color & 0x000000ff) / 255; 14065 return `rgba($r}, $g}, $b}, $a})`; 14066 } 14067 14068 const createInterpolator = (range, output, extrapolate) => { 14069 if (react_spring_shared_esm_is.fun(range)) { 14070 return range; 14071 } 14072 14073 if (react_spring_shared_esm_is.arr(range)) { 14074 return createInterpolator({ 14075 range, 14076 output: output, 14077 extrapolate 14078 }); 14079 } 14080 14081 if (react_spring_shared_esm_is.str(range.output[0])) { 14082 return createStringInterpolator$1(range); 14083 } 14084 14085 const config = range; 14086 const outputRange = config.output; 14087 const inputRange = config.range || [0, 1]; 14088 const extrapolateLeft = config.extrapolateLeft || config.extrapolate || 'extend'; 14089 const extrapolateRight = config.extrapolateRight || config.extrapolate || 'extend'; 14090 14091 const easing = config.easing || (t => t); 14092 14093 return input => { 14094 const range = findRange(input, inputRange); 14095 return interpolate(input, inputRange[range], inputRange[range + 1], outputRange[range], outputRange[range + 1], easing, extrapolateLeft, extrapolateRight, config.map); 14096 }; 14097 }; 14098 14099 function interpolate(input, inputMin, inputMax, outputMin, outputMax, easing, extrapolateLeft, extrapolateRight, map) { 14100 let result = map ? map(input) : input; 14101 14102 if (result < inputMin) { 14103 if (extrapolateLeft === 'identity') return result;else if (extrapolateLeft === 'clamp') result = inputMin; 14104 } 14105 14106 if (result > inputMax) { 14107 if (extrapolateRight === 'identity') return result;else if (extrapolateRight === 'clamp') result = inputMax; 14108 } 14109 14110 if (outputMin === outputMax) return outputMin; 14111 if (inputMin === inputMax) return input <= inputMin ? outputMin : outputMax; 14112 if (inputMin === -Infinity) result = -result;else if (inputMax === Infinity) result = result - inputMin;else result = (result - inputMin) / (inputMax - inputMin); 14113 result = easing(result); 14114 if (outputMin === -Infinity) result = -result;else if (outputMax === Infinity) result = result + outputMin;else result = result * (outputMax - outputMin) + outputMin; 14115 return result; 14116 } 14117 14118 function findRange(input, inputRange) { 14119 for (var i = 1; i < inputRange.length - 1; ++i) if (inputRange[i] >= input) break; 14120 14121 return i - 1; 14122 } 14123 14124 function react_spring_shared_esm_extends() { 14125 react_spring_shared_esm_extends = Object.assign || function (target) { 14126 for (var i = 1; i < arguments.length; i++) { 14127 var source = arguments[i]; 14128 14129 for (var key in source) { 14130 if (Object.prototype.hasOwnProperty.call(source, key)) { 14131 target[key] = source[key]; 14132 } 14133 } 14134 } 14135 14136 return target; 14137 }; 14138 14139 return react_spring_shared_esm_extends.apply(this, arguments); 14140 } 14141 14142 const $get = Symbol.for('FluidValue.get'); 14143 const $observers = Symbol.for('FluidValue.observers'); 14144 14145 const hasFluidValue = arg => Boolean(arg && arg[$get]); 14146 14147 const getFluidValue = arg => arg && arg[$get] ? arg[$get]() : arg; 14148 14149 const getFluidObservers = target => target[$observers] || null; 14150 14151 function callFluidObserver(observer, event) { 14152 if (observer.eventObserved) { 14153 observer.eventObserved(event); 14154 } else { 14155 observer(event); 14156 } 14157 } 14158 14159 function callFluidObservers(target, event) { 14160 let observers = target[$observers]; 14161 14162 if (observers) { 14163 observers.forEach(observer => { 14164 callFluidObserver(observer, event); 14165 }); 14166 } 14167 } 14168 14169 class FluidValue { 14170 constructor(get) { 14171 this[$get] = void 0; 14172 this[$observers] = void 0; 14173 14174 if (!get && !(get = this.get)) { 14175 throw Error('Unknown getter'); 14176 } 14177 14178 setFluidGetter(this, get); 14179 } 14180 14181 } 14182 14183 const setFluidGetter = (target, get) => setHidden(target, $get, get); 14184 14185 function addFluidObserver(target, observer) { 14186 if (target[$get]) { 14187 let observers = target[$observers]; 14188 14189 if (!observers) { 14190 setHidden(target, $observers, observers = new Set()); 14191 } 14192 14193 if (!observers.has(observer)) { 14194 observers.add(observer); 14195 14196 if (target.observerAdded) { 14197 target.observerAdded(observers.size, observer); 14198 } 14199 } 14200 } 14201 14202 return observer; 14203 } 14204 14205 function removeFluidObserver(target, observer) { 14206 let observers = target[$observers]; 14207 14208 if (observers && observers.has(observer)) { 14209 const count = observers.size - 1; 14210 14211 if (count) { 14212 observers.delete(observer); 14213 } else { 14214 target[$observers] = null; 14215 } 14216 14217 if (target.observerRemoved) { 14218 target.observerRemoved(count, observer); 14219 } 14220 } 14221 } 14222 14223 const setHidden = (target, key, value) => Object.defineProperty(target, key, { 14224 value, 14225 writable: true, 14226 configurable: true 14227 }); 14228 14229 const numberRegex = /[+\-]?(?:0|[1-9]\d*)(?:\.\d*)?(?:[eE][+\-]?\d+)?/g; 14230 const colorRegex = /(#(?:[0-9a-f]{2}){2,4}|(#[0-9a-f]{3})|(rgb|hsl)a?\((-?\d+%?[,\s]+){2,3}\s*[\d\.]+%?\))/gi; 14231 const unitRegex = new RegExp(`($numberRegex.source})(%|[a-z]+)`, 'i'); 14232 const rgbaRegex = /rgba\(([0-9\.-]+), ([0-9\.-]+), ([0-9\.-]+), ([0-9\.-]+)\)/gi; 14233 const cssVariableRegex = /var\((--[a-zA-Z0-9-_]+),? ?([a-zA-Z0-9 ()%#.,-]+)?\)/; 14234 14235 const variableToRgba = input => { 14236 const [token, fallback] = parseCSSVariable(input); 14237 14238 if (!token || isSSR()) { 14239 return input; 14240 } 14241 14242 const value = window.getComputedStyle(document.documentElement).getPropertyValue(token); 14243 14244 if (value) { 14245 return value.trim(); 14246 } else if (fallback && fallback.startsWith('--')) { 14247 const _value = window.getComputedStyle(document.documentElement).getPropertyValue(fallback); 14248 14249 if (_value) { 14250 return _value; 14251 } else { 14252 return input; 14253 } 14254 } else if (fallback && cssVariableRegex.test(fallback)) { 14255 return variableToRgba(fallback); 14256 } else if (fallback) { 14257 return fallback; 14258 } 14259 14260 return input; 14261 }; 14262 14263 const parseCSSVariable = current => { 14264 const match = cssVariableRegex.exec(current); 14265 if (!match) return [,]; 14266 const [, token, fallback] = match; 14267 return [token, fallback]; 14268 }; 14269 14270 let namedColorRegex; 14271 14272 const rgbaRound = (_, p1, p2, p3, p4) => `rgba($Math.round(p1)}, $Math.round(p2)}, $Math.round(p3)}, $p4})`; 14273 14274 const createStringInterpolator = config => { 14275 if (!namedColorRegex) namedColorRegex = colors$1 ? new RegExp(`($Object.keys(colors$1).join('|')})(?!\\w)`, 'g') : /^\b$/; 14276 const output = config.output.map(value => { 14277 return getFluidValue(value).replace(cssVariableRegex, variableToRgba).replace(colorRegex, colorToRgba).replace(namedColorRegex, colorToRgba); 14278 }); 14279 const keyframes = output.map(value => value.match(numberRegex).map(Number)); 14280 const outputRanges = keyframes[0].map((_, i) => keyframes.map(values => { 14281 if (!(i in values)) { 14282 throw Error('The arity of each "output" value must be equal'); 14283 } 14284 14285 return values[i]; 14286 })); 14287 const interpolators = outputRanges.map(output => createInterpolator(react_spring_shared_esm_extends({}, config, { 14288 output 14289 }))); 14290 return input => { 14291 var _output$find; 14292 14293 const missingUnit = !unitRegex.test(output[0]) && ((_output$find = output.find(value => unitRegex.test(value))) == null ? void 0 : _output$find.replace(numberRegex, '')); 14294 let i = 0; 14295 return output[0].replace(numberRegex, () => `$interpolators[i++](input)}$missingUnit || ''}`).replace(rgbaRegex, rgbaRound); 14296 }; 14297 }; 14298 14299 const prefix = 'react-spring: '; 14300 14301 const once = fn => { 14302 const func = fn; 14303 let called = false; 14304 14305 if (typeof func != 'function') { 14306 throw new TypeError(`$prefix}once requires a function parameter`); 14307 } 14308 14309 return (...args) => { 14310 if (!called) { 14311 func(...args); 14312 called = true; 14313 } 14314 }; 14315 }; 14316 14317 const warnInterpolate = once(console.warn); 14318 function react_spring_shared_esm_deprecateInterpolate() { 14319 warnInterpolate(`$prefix}The "interpolate" function is deprecated in v9 (use "to" instead)`); 14320 } 14321 const warnDirectCall = once(console.warn); 14322 function deprecateDirectCall() { 14323 warnDirectCall(`$prefix}Directly calling start instead of using the api object is deprecated in v9 (use ".start" instead), this will be removed in later 0.X.0 versions`); 14324 } 14325 14326 function isAnimatedString(value) { 14327 return react_spring_shared_esm_is.str(value) && (value[0] == '#' || /\d/.test(value) || !isSSR() && cssVariableRegex.test(value) || value in (colors$1 || {})); 14328 } 14329 14330 const react_spring_shared_esm_useOnce = effect => (0,external_React_.useEffect)(effect, emptyDeps); 14331 const emptyDeps = []; 14332 14333 function react_spring_shared_esm_useForceUpdate() { 14334 const update = (0,external_React_.useState)()[1]; 14335 const mounted = (0,external_React_.useState)(makeMountedRef)[0]; 14336 react_spring_shared_esm_useOnce(mounted.unmount); 14337 return () => { 14338 if (mounted.current) { 14339 update({}); 14340 } 14341 }; 14342 } 14343 14344 function makeMountedRef() { 14345 const mounted = { 14346 current: true, 14347 unmount: () => () => { 14348 mounted.current = false; 14349 } 14350 }; 14351 return mounted; 14352 } 14353 14354 function useMemoOne(getResult, inputs) { 14355 const [initial] = (0,external_React_.useState)(() => ({ 14356 inputs, 14357 result: getResult() 14358 })); 14359 const committed = (0,external_React_.useRef)(); 14360 const prevCache = committed.current; 14361 let cache = prevCache; 14362 14363 if (cache) { 14364 const useCache = Boolean(inputs && cache.inputs && areInputsEqual(inputs, cache.inputs)); 14365 14366 if (!useCache) { 14367 cache = { 14368 inputs, 14369 result: getResult() 14370 }; 14371 } 14372 } else { 14373 cache = initial; 14374 } 14375 14376 (0,external_React_.useEffect)(() => { 14377 committed.current = cache; 14378 14379 if (prevCache == initial) { 14380 initial.inputs = initial.result = undefined; 14381 } 14382 }, [cache]); 14383 return cache.result; 14384 } 14385 14386 function areInputsEqual(next, prev) { 14387 if (next.length !== prev.length) { 14388 return false; 14389 } 14390 14391 for (let i = 0; i < next.length; i++) { 14392 if (next[i] !== prev[i]) { 14393 return false; 14394 } 14395 } 14396 14397 return true; 14398 } 14399 14400 function react_spring_shared_esm_usePrev(value) { 14401 const prevRef = (0,external_React_.useRef)(); 14402 (0,external_React_.useEffect)(() => { 14403 prevRef.current = value; 14404 }); 14405 return prevRef.current; 14406 } 14407 14408 const react_spring_shared_esm_useLayoutEffect = typeof window !== 'undefined' && window.document && window.document.createElement ? external_React_.useLayoutEffect : external_React_.useEffect; 14409 14410 14411 14412 ;// CONCATENATED MODULE: ./node_modules/@react-spring/animated/dist/react-spring-animated.esm.js 14413 14414 14415 14416 14417 const $node = Symbol.for('Animated:node'); 14418 const isAnimated = value => !!value && value[$node] === value; 14419 const getAnimated = owner => owner && owner[$node]; 14420 const setAnimated = (owner, node) => defineHidden(owner, $node, node); 14421 const getPayload = owner => owner && owner[$node] && owner[$node].getPayload(); 14422 class Animated { 14423 constructor() { 14424 this.payload = void 0; 14425 setAnimated(this, this); 14426 } 14427 14428 getPayload() { 14429 return this.payload || []; 14430 } 14431 14432 } 14433 14434 class AnimatedValue extends Animated { 14435 constructor(_value) { 14436 super(); 14437 this.done = true; 14438 this.elapsedTime = void 0; 14439 this.lastPosition = void 0; 14440 this.lastVelocity = void 0; 14441 this.v0 = void 0; 14442 this.durationProgress = 0; 14443 this._value = _value; 14444 14445 if (react_spring_shared_esm_is.num(this._value)) { 14446 this.lastPosition = this._value; 14447 } 14448 } 14449 14450 static create(value) { 14451 return new AnimatedValue(value); 14452 } 14453 14454 getPayload() { 14455 return [this]; 14456 } 14457 14458 getValue() { 14459 return this._value; 14460 } 14461 14462 setValue(value, step) { 14463 if (react_spring_shared_esm_is.num(value)) { 14464 this.lastPosition = value; 14465 14466 if (step) { 14467 value = Math.round(value / step) * step; 14468 14469 if (this.done) { 14470 this.lastPosition = value; 14471 } 14472 } 14473 } 14474 14475 if (this._value === value) { 14476 return false; 14477 } 14478 14479 this._value = value; 14480 return true; 14481 } 14482 14483 reset() { 14484 const { 14485 done 14486 } = this; 14487 this.done = false; 14488 14489 if (react_spring_shared_esm_is.num(this._value)) { 14490 this.elapsedTime = 0; 14491 this.durationProgress = 0; 14492 this.lastPosition = this._value; 14493 if (done) this.lastVelocity = null; 14494 this.v0 = null; 14495 } 14496 } 14497 14498 } 14499 14500 class AnimatedString extends AnimatedValue { 14501 constructor(value) { 14502 super(0); 14503 this._string = null; 14504 this._toString = void 0; 14505 this._toString = createInterpolator({ 14506 output: [value, value] 14507 }); 14508 } 14509 14510 static create(value) { 14511 return new AnimatedString(value); 14512 } 14513 14514 getValue() { 14515 let value = this._string; 14516 return value == null ? this._string = this._toString(this._value) : value; 14517 } 14518 14519 setValue(value) { 14520 if (react_spring_shared_esm_is.str(value)) { 14521 if (value == this._string) { 14522 return false; 14523 } 14524 14525 this._string = value; 14526 this._value = 1; 14527 } else if (super.setValue(value)) { 14528 this._string = null; 14529 } else { 14530 return false; 14531 } 14532 14533 return true; 14534 } 14535 14536 reset(goal) { 14537 if (goal) { 14538 this._toString = createInterpolator({ 14539 output: [this.getValue(), goal] 14540 }); 14541 } 14542 14543 this._value = 0; 14544 super.reset(); 14545 } 14546 14547 } 14548 14549 const TreeContext = { 14550 dependencies: null 14551 }; 14552 14553 class AnimatedObject extends Animated { 14554 constructor(source) { 14555 super(); 14556 this.source = source; 14557 this.setValue(source); 14558 } 14559 14560 getValue(animated) { 14561 const values = {}; 14562 eachProp(this.source, (source, key) => { 14563 if (isAnimated(source)) { 14564 values[key] = source.getValue(animated); 14565 } else if (hasFluidValue(source)) { 14566 values[key] = getFluidValue(source); 14567 } else if (!animated) { 14568 values[key] = source; 14569 } 14570 }); 14571 return values; 14572 } 14573 14574 setValue(source) { 14575 this.source = source; 14576 this.payload = this._makePayload(source); 14577 } 14578 14579 reset() { 14580 if (this.payload) { 14581 react_spring_shared_esm_each(this.payload, node => node.reset()); 14582 } 14583 } 14584 14585 _makePayload(source) { 14586 if (source) { 14587 const payload = new Set(); 14588 eachProp(source, this._addToPayload, payload); 14589 return Array.from(payload); 14590 } 14591 } 14592 14593 _addToPayload(source) { 14594 if (TreeContext.dependencies && hasFluidValue(source)) { 14595 TreeContext.dependencies.add(source); 14596 } 14597 14598 const payload = getPayload(source); 14599 14600 if (payload) { 14601 react_spring_shared_esm_each(payload, node => this.add(node)); 14602 } 14603 } 14604 14605 } 14606 14607 class AnimatedArray extends AnimatedObject { 14608 constructor(source) { 14609 super(source); 14610 } 14611 14612 static create(source) { 14613 return new AnimatedArray(source); 14614 } 14615 14616 getValue() { 14617 return this.source.map(node => node.getValue()); 14618 } 14619 14620 setValue(source) { 14621 const payload = this.getPayload(); 14622 14623 if (source.length == payload.length) { 14624 return payload.map((node, i) => node.setValue(source[i])).some(Boolean); 14625 } 14626 14627 super.setValue(source.map(makeAnimated)); 14628 return true; 14629 } 14630 14631 } 14632 14633 function makeAnimated(value) { 14634 const nodeType = isAnimatedString(value) ? AnimatedString : AnimatedValue; 14635 return nodeType.create(value); 14636 } 14637 14638 function getAnimatedType(value) { 14639 const parentNode = getAnimated(value); 14640 return parentNode ? parentNode.constructor : react_spring_shared_esm_is.arr(value) ? AnimatedArray : isAnimatedString(value) ? AnimatedString : AnimatedValue; 14641 } 14642 14643 function react_spring_animated_esm_extends() { 14644 react_spring_animated_esm_extends = Object.assign || function (target) { 14645 for (var i = 1; i < arguments.length; i++) { 14646 var source = arguments[i]; 14647 14648 for (var key in source) { 14649 if (Object.prototype.hasOwnProperty.call(source, key)) { 14650 target[key] = source[key]; 14651 } 14652 } 14653 } 14654 14655 return target; 14656 }; 14657 14658 return react_spring_animated_esm_extends.apply(this, arguments); 14659 } 14660 14661 const withAnimated = (Component, host) => { 14662 const hasInstance = !react_spring_shared_esm_is.fun(Component) || Component.prototype && Component.prototype.isReactComponent; 14663 return (0,external_React_.forwardRef)((givenProps, givenRef) => { 14664 const instanceRef = (0,external_React_.useRef)(null); 14665 const ref = hasInstance && (0,external_React_.useCallback)(value => { 14666 instanceRef.current = updateRef(givenRef, value); 14667 }, [givenRef]); 14668 const [props, deps] = getAnimatedState(givenProps, host); 14669 const forceUpdate = react_spring_shared_esm_useForceUpdate(); 14670 14671 const callback = () => { 14672 const instance = instanceRef.current; 14673 14674 if (hasInstance && !instance) { 14675 return; 14676 } 14677 14678 const didUpdate = instance ? host.applyAnimatedValues(instance, props.getValue(true)) : false; 14679 14680 if (didUpdate === false) { 14681 forceUpdate(); 14682 } 14683 }; 14684 14685 const observer = new PropsObserver(callback, deps); 14686 const observerRef = (0,external_React_.useRef)(); 14687 react_spring_shared_esm_useLayoutEffect(() => { 14688 const lastObserver = observerRef.current; 14689 observerRef.current = observer; 14690 react_spring_shared_esm_each(deps, dep => addFluidObserver(dep, observer)); 14691 14692 if (lastObserver) { 14693 react_spring_shared_esm_each(lastObserver.deps, dep => removeFluidObserver(dep, lastObserver)); 14694 raf.cancel(lastObserver.update); 14695 } 14696 }); 14697 (0,external_React_.useEffect)(callback, []); 14698 react_spring_shared_esm_useOnce(() => () => { 14699 const observer = observerRef.current; 14700 react_spring_shared_esm_each(observer.deps, dep => removeFluidObserver(dep, observer)); 14701 }); 14702 const usedProps = host.getComponentProps(props.getValue()); 14703 return external_React_.createElement(Component, react_spring_animated_esm_extends({}, usedProps, { 14704 ref: ref 14705 })); 14706 }); 14707 }; 14708 14709 class PropsObserver { 14710 constructor(update, deps) { 14711 this.update = update; 14712 this.deps = deps; 14713 } 14714 14715 eventObserved(event) { 14716 if (event.type == 'change') { 14717 raf.write(this.update); 14718 } 14719 } 14720 14721 } 14722 14723 function getAnimatedState(props, host) { 14724 const dependencies = new Set(); 14725 TreeContext.dependencies = dependencies; 14726 if (props.style) props = react_spring_animated_esm_extends({}, props, { 14727 style: host.createAnimatedStyle(props.style) 14728 }); 14729 props = new AnimatedObject(props); 14730 TreeContext.dependencies = null; 14731 return [props, dependencies]; 14732 } 14733 14734 function updateRef(ref, value) { 14735 if (ref) { 14736 if (react_spring_shared_esm_is.fun(ref)) ref(value);else ref.current = value; 14737 } 14738 14739 return value; 14740 } 14741 14742 const cacheKey = Symbol.for('AnimatedComponent'); 14743 const createHost = (components, { 14744 applyAnimatedValues: _applyAnimatedValues = () => false, 14745 createAnimatedStyle: _createAnimatedStyle = style => new AnimatedObject(style), 14746 getComponentProps: _getComponentProps = props => props 14747 } = {}) => { 14748 const hostConfig = { 14749 applyAnimatedValues: _applyAnimatedValues, 14750 createAnimatedStyle: _createAnimatedStyle, 14751 getComponentProps: _getComponentProps 14752 }; 14753 14754 const animated = Component => { 14755 const displayName = getDisplayName(Component) || 'Anonymous'; 14756 14757 if (react_spring_shared_esm_is.str(Component)) { 14758 Component = animated[Component] || (animated[Component] = withAnimated(Component, hostConfig)); 14759 } else { 14760 Component = Component[cacheKey] || (Component[cacheKey] = withAnimated(Component, hostConfig)); 14761 } 14762 14763 Component.displayName = `Animated($displayName})`; 14764 return Component; 14765 }; 14766 14767 eachProp(components, (Component, key) => { 14768 if (react_spring_shared_esm_is.arr(components)) { 14769 key = getDisplayName(Component); 14770 } 14771 14772 animated[key] = animated(Component); 14773 }); 14774 return { 14775 animated 14776 }; 14777 }; 14778 14779 const getDisplayName = arg => react_spring_shared_esm_is.str(arg) ? arg : arg && react_spring_shared_esm_is.str(arg.displayName) ? arg.displayName : react_spring_shared_esm_is.fun(arg) && arg.name || null; 14780 14781 14782 14783 ;// CONCATENATED MODULE: ./node_modules/@react-spring/core/dist/react-spring-core.esm.js 14784 14785 14786 14787 14788 14789 14790 14791 14792 function react_spring_core_esm_extends() { 14793 react_spring_core_esm_extends = Object.assign || function (target) { 14794 for (var i = 1; i < arguments.length; i++) { 14795 var source = arguments[i]; 14796 14797 for (var key in source) { 14798 if (Object.prototype.hasOwnProperty.call(source, key)) { 14799 target[key] = source[key]; 14800 } 14801 } 14802 } 14803 14804 return target; 14805 }; 14806 14807 return react_spring_core_esm_extends.apply(this, arguments); 14808 } 14809 14810 function callProp(value, ...args) { 14811 return react_spring_shared_esm_is.fun(value) ? value(...args) : value; 14812 } 14813 const matchProp = (value, key) => value === true || !!(key && value && (react_spring_shared_esm_is.fun(value) ? value(key) : react_spring_shared_esm_toArray(value).includes(key))); 14814 const resolveProp = (prop, key) => react_spring_shared_esm_is.obj(prop) ? key && prop[key] : prop; 14815 const getDefaultProp = (props, key) => props.default === true ? props[key] : props.default ? props.default[key] : undefined; 14816 14817 const noopTransform = value => value; 14818 14819 const getDefaultProps = (props, transform = noopTransform) => { 14820 let keys = DEFAULT_PROPS; 14821 14822 if (props.default && props.default !== true) { 14823 props = props.default; 14824 keys = Object.keys(props); 14825 } 14826 14827 const defaults = {}; 14828 14829 for (const key of keys) { 14830 const value = transform(props[key], key); 14831 14832 if (!react_spring_shared_esm_is.und(value)) { 14833 defaults[key] = value; 14834 } 14835 } 14836 14837 return defaults; 14838 }; 14839 const DEFAULT_PROPS = ['config', 'onProps', 'onStart', 'onChange', 'onPause', 'onResume', 'onRest']; 14840 const RESERVED_PROPS = { 14841 config: 1, 14842 from: 1, 14843 to: 1, 14844 ref: 1, 14845 loop: 1, 14846 reset: 1, 14847 pause: 1, 14848 cancel: 1, 14849 reverse: 1, 14850 immediate: 1, 14851 default: 1, 14852 delay: 1, 14853 onProps: 1, 14854 onStart: 1, 14855 onChange: 1, 14856 onPause: 1, 14857 onResume: 1, 14858 onRest: 1, 14859 onResolve: 1, 14860 items: 1, 14861 trail: 1, 14862 sort: 1, 14863 expires: 1, 14864 initial: 1, 14865 enter: 1, 14866 update: 1, 14867 leave: 1, 14868 children: 1, 14869 onDestroyed: 1, 14870 keys: 1, 14871 callId: 1, 14872 parentId: 1 14873 }; 14874 14875 function getForwardProps(props) { 14876 const forward = {}; 14877 let count = 0; 14878 eachProp(props, (value, prop) => { 14879 if (!RESERVED_PROPS[prop]) { 14880 forward[prop] = value; 14881 count++; 14882 } 14883 }); 14884 14885 if (count) { 14886 return forward; 14887 } 14888 } 14889 14890 function inferTo(props) { 14891 const to = getForwardProps(props); 14892 14893 if (to) { 14894 const out = { 14895 to 14896 }; 14897 eachProp(props, (val, key) => key in to || (out[key] = val)); 14898 return out; 14899 } 14900 14901 return react_spring_core_esm_extends({}, props); 14902 } 14903 function computeGoal(value) { 14904 value = getFluidValue(value); 14905 return react_spring_shared_esm_is.arr(value) ? value.map(computeGoal) : isAnimatedString(value) ? globals.createStringInterpolator({ 14906 range: [0, 1], 14907 output: [value, value] 14908 })(1) : value; 14909 } 14910 function hasProps(props) { 14911 for (const _ in props) return true; 14912 14913 return false; 14914 } 14915 function isAsyncTo(to) { 14916 return react_spring_shared_esm_is.fun(to) || react_spring_shared_esm_is.arr(to) && react_spring_shared_esm_is.obj(to[0]); 14917 } 14918 function detachRefs(ctrl, ref) { 14919 var _ctrl$ref; 14920 14921 (_ctrl$ref = ctrl.ref) == null ? void 0 : _ctrl$ref.delete(ctrl); 14922 ref == null ? void 0 : ref.delete(ctrl); 14923 } 14924 function replaceRef(ctrl, ref) { 14925 if (ref && ctrl.ref !== ref) { 14926 var _ctrl$ref2; 14927 14928 (_ctrl$ref2 = ctrl.ref) == null ? void 0 : _ctrl$ref2.delete(ctrl); 14929 ref.add(ctrl); 14930 ctrl.ref = ref; 14931 } 14932 } 14933 14934 function useChain(refs, timeSteps, timeFrame = 1000) { 14935 useLayoutEffect(() => { 14936 if (timeSteps) { 14937 let prevDelay = 0; 14938 each(refs, (ref, i) => { 14939 const controllers = ref.current; 14940 14941 if (controllers.length) { 14942 let delay = timeFrame * timeSteps[i]; 14943 if (isNaN(delay)) delay = prevDelay;else prevDelay = delay; 14944 each(controllers, ctrl => { 14945 each(ctrl.queue, props => { 14946 const memoizedDelayProp = props.delay; 14947 14948 props.delay = key => delay + callProp(memoizedDelayProp || 0, key); 14949 }); 14950 }); 14951 ref.start(); 14952 } 14953 }); 14954 } else { 14955 let p = Promise.resolve(); 14956 each(refs, ref => { 14957 const controllers = ref.current; 14958 14959 if (controllers.length) { 14960 const queues = controllers.map(ctrl => { 14961 const q = ctrl.queue; 14962 ctrl.queue = []; 14963 return q; 14964 }); 14965 p = p.then(() => { 14966 each(controllers, (ctrl, i) => each(queues[i] || [], update => ctrl.queue.push(update))); 14967 return Promise.all(ref.start()); 14968 }); 14969 } 14970 }); 14971 } 14972 }); 14973 } 14974 14975 const config = { 14976 default: { 14977 tension: 170, 14978 friction: 26 14979 }, 14980 gentle: { 14981 tension: 120, 14982 friction: 14 14983 }, 14984 wobbly: { 14985 tension: 180, 14986 friction: 12 14987 }, 14988 stiff: { 14989 tension: 210, 14990 friction: 20 14991 }, 14992 slow: { 14993 tension: 280, 14994 friction: 60 14995 }, 14996 molasses: { 14997 tension: 280, 14998 friction: 120 14999 } 15000 }; 15001 const c1 = 1.70158; 15002 const c2 = c1 * 1.525; 15003 const c3 = c1 + 1; 15004 const c4 = 2 * Math.PI / 3; 15005 const c5 = 2 * Math.PI / 4.5; 15006 15007 const bounceOut = x => { 15008 const n1 = 7.5625; 15009 const d1 = 2.75; 15010 15011 if (x < 1 / d1) { 15012 return n1 * x * x; 15013 } else if (x < 2 / d1) { 15014 return n1 * (x -= 1.5 / d1) * x + 0.75; 15015 } else if (x < 2.5 / d1) { 15016 return n1 * (x -= 2.25 / d1) * x + 0.9375; 15017 } else { 15018 return n1 * (x -= 2.625 / d1) * x + 0.984375; 15019 } 15020 }; 15021 15022 const easings = { 15023 linear: x => x, 15024 easeInQuad: x => x * x, 15025 easeOutQuad: x => 1 - (1 - x) * (1 - x), 15026 easeInOutQuad: x => x < 0.5 ? 2 * x * x : 1 - Math.pow(-2 * x + 2, 2) / 2, 15027 easeInCubic: x => x * x * x, 15028 easeOutCubic: x => 1 - Math.pow(1 - x, 3), 15029 easeInOutCubic: x => x < 0.5 ? 4 * x * x * x : 1 - Math.pow(-2 * x + 2, 3) / 2, 15030 easeInQuart: x => x * x * x * x, 15031 easeOutQuart: x => 1 - Math.pow(1 - x, 4), 15032 easeInOutQuart: x => x < 0.5 ? 8 * x * x * x * x : 1 - Math.pow(-2 * x + 2, 4) / 2, 15033 easeInQuint: x => x * x * x * x * x, 15034 easeOutQuint: x => 1 - Math.pow(1 - x, 5), 15035 easeInOutQuint: x => x < 0.5 ? 16 * x * x * x * x * x : 1 - Math.pow(-2 * x + 2, 5) / 2, 15036 easeInSine: x => 1 - Math.cos(x * Math.PI / 2), 15037 easeOutSine: x => Math.sin(x * Math.PI / 2), 15038 easeInOutSine: x => -(Math.cos(Math.PI * x) - 1) / 2, 15039 easeInExpo: x => x === 0 ? 0 : Math.pow(2, 10 * x - 10), 15040 easeOutExpo: x => x === 1 ? 1 : 1 - Math.pow(2, -10 * x), 15041 easeInOutExpo: x => x === 0 ? 0 : x === 1 ? 1 : x < 0.5 ? Math.pow(2, 20 * x - 10) / 2 : (2 - Math.pow(2, -20 * x + 10)) / 2, 15042 easeInCirc: x => 1 - Math.sqrt(1 - Math.pow(x, 2)), 15043 easeOutCirc: x => Math.sqrt(1 - Math.pow(x - 1, 2)), 15044 easeInOutCirc: x => x < 0.5 ? (1 - Math.sqrt(1 - Math.pow(2 * x, 2))) / 2 : (Math.sqrt(1 - Math.pow(-2 * x + 2, 2)) + 1) / 2, 15045 easeInBack: x => c3 * x * x * x - c1 * x * x, 15046 easeOutBack: x => 1 + c3 * Math.pow(x - 1, 3) + c1 * Math.pow(x - 1, 2), 15047 easeInOutBack: x => x < 0.5 ? Math.pow(2 * x, 2) * ((c2 + 1) * 2 * x - c2) / 2 : (Math.pow(2 * x - 2, 2) * ((c2 + 1) * (x * 2 - 2) + c2) + 2) / 2, 15048 easeInElastic: x => x === 0 ? 0 : x === 1 ? 1 : -Math.pow(2, 10 * x - 10) * Math.sin((x * 10 - 10.75) * c4), 15049 easeOutElastic: x => x === 0 ? 0 : x === 1 ? 1 : Math.pow(2, -10 * x) * Math.sin((x * 10 - 0.75) * c4) + 1, 15050 easeInOutElastic: x => x === 0 ? 0 : x === 1 ? 1 : x < 0.5 ? -(Math.pow(2, 20 * x - 10) * Math.sin((20 * x - 11.125) * c5)) / 2 : Math.pow(2, -20 * x + 10) * Math.sin((20 * x - 11.125) * c5) / 2 + 1, 15051 easeInBounce: x => 1 - bounceOut(1 - x), 15052 easeOutBounce: bounceOut, 15053 easeInOutBounce: x => x < 0.5 ? (1 - bounceOut(1 - 2 * x)) / 2 : (1 + bounceOut(2 * x - 1)) / 2 15054 }; 15055 15056 const defaults = react_spring_core_esm_extends({}, config.default, { 15057 mass: 1, 15058 damping: 1, 15059 easing: easings.linear, 15060 clamp: false 15061 }); 15062 15063 class AnimationConfig { 15064 constructor() { 15065 this.tension = void 0; 15066 this.friction = void 0; 15067 this.frequency = void 0; 15068 this.damping = void 0; 15069 this.mass = void 0; 15070 this.velocity = 0; 15071 this.restVelocity = void 0; 15072 this.precision = void 0; 15073 this.progress = void 0; 15074 this.duration = void 0; 15075 this.easing = void 0; 15076 this.clamp = void 0; 15077 this.bounce = void 0; 15078 this.decay = void 0; 15079 this.round = void 0; 15080 Object.assign(this, defaults); 15081 } 15082 15083 } 15084 function mergeConfig(config, newConfig, defaultConfig) { 15085 if (defaultConfig) { 15086 defaultConfig = react_spring_core_esm_extends({}, defaultConfig); 15087 sanitizeConfig(defaultConfig, newConfig); 15088 newConfig = react_spring_core_esm_extends({}, defaultConfig, newConfig); 15089 } 15090 15091 sanitizeConfig(config, newConfig); 15092 Object.assign(config, newConfig); 15093 15094 for (const key in defaults) { 15095 if (config[key] == null) { 15096 config[key] = defaults[key]; 15097 } 15098 } 15099 15100 let { 15101 mass, 15102 frequency, 15103 damping 15104 } = config; 15105 15106 if (!react_spring_shared_esm_is.und(frequency)) { 15107 if (frequency < 0.01) frequency = 0.01; 15108 if (damping < 0) damping = 0; 15109 config.tension = Math.pow(2 * Math.PI / frequency, 2) * mass; 15110 config.friction = 4 * Math.PI * damping * mass / frequency; 15111 } 15112 15113 return config; 15114 } 15115 15116 function sanitizeConfig(config, props) { 15117 if (!react_spring_shared_esm_is.und(props.decay)) { 15118 config.duration = undefined; 15119 } else { 15120 const isTensionConfig = !react_spring_shared_esm_is.und(props.tension) || !react_spring_shared_esm_is.und(props.friction); 15121 15122 if (isTensionConfig || !react_spring_shared_esm_is.und(props.frequency) || !react_spring_shared_esm_is.und(props.damping) || !react_spring_shared_esm_is.und(props.mass)) { 15123 config.duration = undefined; 15124 config.decay = undefined; 15125 } 15126 15127 if (isTensionConfig) { 15128 config.frequency = undefined; 15129 } 15130 } 15131 } 15132 15133 const emptyArray = []; 15134 class Animation { 15135 constructor() { 15136 this.changed = false; 15137 this.values = emptyArray; 15138 this.toValues = null; 15139 this.fromValues = emptyArray; 15140 this.to = void 0; 15141 this.from = void 0; 15142 this.config = new AnimationConfig(); 15143 this.immediate = false; 15144 } 15145 15146 } 15147 15148 function scheduleProps(callId, { 15149 key, 15150 props, 15151 defaultProps, 15152 state, 15153 actions 15154 }) { 15155 return new Promise((resolve, reject) => { 15156 var _props$cancel; 15157 15158 let delay; 15159 let timeout; 15160 let cancel = matchProp((_props$cancel = props.cancel) != null ? _props$cancel : defaultProps == null ? void 0 : defaultProps.cancel, key); 15161 15162 if (cancel) { 15163 onStart(); 15164 } else { 15165 if (!react_spring_shared_esm_is.und(props.pause)) { 15166 state.paused = matchProp(props.pause, key); 15167 } 15168 15169 let pause = defaultProps == null ? void 0 : defaultProps.pause; 15170 15171 if (pause !== true) { 15172 pause = state.paused || matchProp(pause, key); 15173 } 15174 15175 delay = callProp(props.delay || 0, key); 15176 15177 if (pause) { 15178 state.resumeQueue.add(onResume); 15179 actions.pause(); 15180 } else { 15181 actions.resume(); 15182 onResume(); 15183 } 15184 } 15185 15186 function onPause() { 15187 state.resumeQueue.add(onResume); 15188 state.timeouts.delete(timeout); 15189 timeout.cancel(); 15190 delay = timeout.time - raf.now(); 15191 } 15192 15193 function onResume() { 15194 if (delay > 0 && !globals.skipAnimation) { 15195 state.delayed = true; 15196 timeout = raf.setTimeout(onStart, delay); 15197 state.pauseQueue.add(onPause); 15198 state.timeouts.add(timeout); 15199 } else { 15200 onStart(); 15201 } 15202 } 15203 15204 function onStart() { 15205 if (state.delayed) { 15206 state.delayed = false; 15207 } 15208 15209 state.pauseQueue.delete(onPause); 15210 state.timeouts.delete(timeout); 15211 15212 if (callId <= (state.cancelId || 0)) { 15213 cancel = true; 15214 } 15215 15216 try { 15217 actions.start(react_spring_core_esm_extends({}, props, { 15218 callId, 15219 cancel 15220 }), resolve); 15221 } catch (err) { 15222 reject(err); 15223 } 15224 } 15225 }); 15226 } 15227 15228 const getCombinedResult = (target, results) => results.length == 1 ? results[0] : results.some(result => result.cancelled) ? getCancelledResult(target.get()) : results.every(result => result.noop) ? getNoopResult(target.get()) : getFinishedResult(target.get(), results.every(result => result.finished)); 15229 const getNoopResult = value => ({ 15230 value, 15231 noop: true, 15232 finished: true, 15233 cancelled: false 15234 }); 15235 const getFinishedResult = (value, finished, cancelled = false) => ({ 15236 value, 15237 finished, 15238 cancelled 15239 }); 15240 const getCancelledResult = value => ({ 15241 value, 15242 cancelled: true, 15243 finished: false 15244 }); 15245 15246 function runAsync(to, props, state, target) { 15247 const { 15248 callId, 15249 parentId, 15250 onRest 15251 } = props; 15252 const { 15253 asyncTo: prevTo, 15254 promise: prevPromise 15255 } = state; 15256 15257 if (!parentId && to === prevTo && !props.reset) { 15258 return prevPromise; 15259 } 15260 15261 return state.promise = (async () => { 15262 state.asyncId = callId; 15263 state.asyncTo = to; 15264 const defaultProps = getDefaultProps(props, (value, key) => key === 'onRest' ? undefined : value); 15265 let preventBail; 15266 let bail; 15267 const bailPromise = new Promise((resolve, reject) => (preventBail = resolve, bail = reject)); 15268 15269 const bailIfEnded = bailSignal => { 15270 const bailResult = callId <= (state.cancelId || 0) && getCancelledResult(target) || callId !== state.asyncId && getFinishedResult(target, false); 15271 15272 if (bailResult) { 15273 bailSignal.result = bailResult; 15274 bail(bailSignal); 15275 throw bailSignal; 15276 } 15277 }; 15278 15279 const animate = (arg1, arg2) => { 15280 const bailSignal = new BailSignal(); 15281 const skipAnimationSignal = new SkipAniamtionSignal(); 15282 return (async () => { 15283 if (globals.skipAnimation) { 15284 stopAsync(state); 15285 skipAnimationSignal.result = getFinishedResult(target, false); 15286 bail(skipAnimationSignal); 15287 throw skipAnimationSignal; 15288 } 15289 15290 bailIfEnded(bailSignal); 15291 const props = react_spring_shared_esm_is.obj(arg1) ? react_spring_core_esm_extends({}, arg1) : react_spring_core_esm_extends({}, arg2, { 15292 to: arg1 15293 }); 15294 props.parentId = callId; 15295 eachProp(defaultProps, (value, key) => { 15296 if (react_spring_shared_esm_is.und(props[key])) { 15297 props[key] = value; 15298 } 15299 }); 15300 const result = await target.start(props); 15301 bailIfEnded(bailSignal); 15302 15303 if (state.paused) { 15304 await new Promise(resume => { 15305 state.resumeQueue.add(resume); 15306 }); 15307 } 15308 15309 return result; 15310 })(); 15311 }; 15312 15313 let result; 15314 15315 if (globals.skipAnimation) { 15316 stopAsync(state); 15317 return getFinishedResult(target, false); 15318 } 15319 15320 try { 15321 let animating; 15322 15323 if (react_spring_shared_esm_is.arr(to)) { 15324 animating = (async queue => { 15325 for (const props of queue) { 15326 await animate(props); 15327 } 15328 })(to); 15329 } else { 15330 animating = Promise.resolve(to(animate, target.stop.bind(target))); 15331 } 15332 15333 await Promise.all([animating.then(preventBail), bailPromise]); 15334 result = getFinishedResult(target.get(), true, false); 15335 } catch (err) { 15336 if (err instanceof BailSignal) { 15337 result = err.result; 15338 } else if (err instanceof SkipAniamtionSignal) { 15339 result = err.result; 15340 } else { 15341 throw err; 15342 } 15343 } finally { 15344 if (callId == state.asyncId) { 15345 state.asyncId = parentId; 15346 state.asyncTo = parentId ? prevTo : undefined; 15347 state.promise = parentId ? prevPromise : undefined; 15348 } 15349 } 15350 15351 if (react_spring_shared_esm_is.fun(onRest)) { 15352 raf.batchedUpdates(() => { 15353 onRest(result, target, target.item); 15354 }); 15355 } 15356 15357 return result; 15358 })(); 15359 } 15360 function stopAsync(state, cancelId) { 15361 flush(state.timeouts, t => t.cancel()); 15362 state.pauseQueue.clear(); 15363 state.resumeQueue.clear(); 15364 state.asyncId = state.asyncTo = state.promise = undefined; 15365 if (cancelId) state.cancelId = cancelId; 15366 } 15367 class BailSignal extends Error { 15368 constructor() { 15369 super('An async animation has been interrupted. You see this error because you ' + 'forgot to use `await` or `.catch(...)` on its returned promise.'); 15370 this.result = void 0; 15371 } 15372 15373 } 15374 class SkipAniamtionSignal extends Error { 15375 constructor() { 15376 super('SkipAnimationSignal'); 15377 this.result = void 0; 15378 } 15379 15380 } 15381 15382 const isFrameValue = value => value instanceof FrameValue; 15383 let nextId$1 = 1; 15384 class FrameValue extends FluidValue { 15385 constructor(...args) { 15386 super(...args); 15387 this.id = nextId$1++; 15388 this.key = void 0; 15389 this._priority = 0; 15390 } 15391 15392 get priority() { 15393 return this._priority; 15394 } 15395 15396 set priority(priority) { 15397 if (this._priority != priority) { 15398 this._priority = priority; 15399 15400 this._onPriorityChange(priority); 15401 } 15402 } 15403 15404 get() { 15405 const node = getAnimated(this); 15406 return node && node.getValue(); 15407 } 15408 15409 to(...args) { 15410 return globals.to(this, args); 15411 } 15412 15413 interpolate(...args) { 15414 react_spring_shared_esm_deprecateInterpolate(); 15415 return globals.to(this, args); 15416 } 15417 15418 toJSON() { 15419 return this.get(); 15420 } 15421 15422 observerAdded(count) { 15423 if (count == 1) this._attach(); 15424 } 15425 15426 observerRemoved(count) { 15427 if (count == 0) this._detach(); 15428 } 15429 15430 _attach() {} 15431 15432 _detach() {} 15433 15434 _onChange(value, idle = false) { 15435 callFluidObservers(this, { 15436 type: 'change', 15437 parent: this, 15438 value, 15439 idle 15440 }); 15441 } 15442 15443 _onPriorityChange(priority) { 15444 if (!this.idle) { 15445 frameLoop.sort(this); 15446 } 15447 15448 callFluidObservers(this, { 15449 type: 'priority', 15450 parent: this, 15451 priority 15452 }); 15453 } 15454 15455 } 15456 15457 const $P = Symbol.for('SpringPhase'); 15458 const HAS_ANIMATED = 1; 15459 const IS_ANIMATING = 2; 15460 const IS_PAUSED = 4; 15461 const hasAnimated = target => (target[$P] & HAS_ANIMATED) > 0; 15462 const isAnimating = target => (target[$P] & IS_ANIMATING) > 0; 15463 const isPaused = target => (target[$P] & IS_PAUSED) > 0; 15464 const setActiveBit = (target, active) => active ? target[$P] |= IS_ANIMATING | HAS_ANIMATED : target[$P] &= ~IS_ANIMATING; 15465 const setPausedBit = (target, paused) => paused ? target[$P] |= IS_PAUSED : target[$P] &= ~IS_PAUSED; 15466 15467 class SpringValue extends FrameValue { 15468 constructor(arg1, arg2) { 15469 super(); 15470 this.key = void 0; 15471 this.animation = new Animation(); 15472 this.queue = void 0; 15473 this.defaultProps = {}; 15474 this._state = { 15475 paused: false, 15476 delayed: false, 15477 pauseQueue: new Set(), 15478 resumeQueue: new Set(), 15479 timeouts: new Set() 15480 }; 15481 this._pendingCalls = new Set(); 15482 this._lastCallId = 0; 15483 this._lastToId = 0; 15484 this._memoizedDuration = 0; 15485 15486 if (!react_spring_shared_esm_is.und(arg1) || !react_spring_shared_esm_is.und(arg2)) { 15487 const props = react_spring_shared_esm_is.obj(arg1) ? react_spring_core_esm_extends({}, arg1) : react_spring_core_esm_extends({}, arg2, { 15488 from: arg1 15489 }); 15490 15491 if (react_spring_shared_esm_is.und(props.default)) { 15492 props.default = true; 15493 } 15494 15495 this.start(props); 15496 } 15497 } 15498 15499 get idle() { 15500 return !(isAnimating(this) || this._state.asyncTo) || isPaused(this); 15501 } 15502 15503 get goal() { 15504 return getFluidValue(this.animation.to); 15505 } 15506 15507 get velocity() { 15508 const node = getAnimated(this); 15509 return node instanceof AnimatedValue ? node.lastVelocity || 0 : node.getPayload().map(node => node.lastVelocity || 0); 15510 } 15511 15512 get hasAnimated() { 15513 return hasAnimated(this); 15514 } 15515 15516 get isAnimating() { 15517 return isAnimating(this); 15518 } 15519 15520 get isPaused() { 15521 return isPaused(this); 15522 } 15523 15524 get isDelayed() { 15525 return this._state.delayed; 15526 } 15527 15528 advance(dt) { 15529 let idle = true; 15530 let changed = false; 15531 const anim = this.animation; 15532 let { 15533 config, 15534 toValues 15535 } = anim; 15536 const payload = getPayload(anim.to); 15537 15538 if (!payload && hasFluidValue(anim.to)) { 15539 toValues = react_spring_shared_esm_toArray(getFluidValue(anim.to)); 15540 } 15541 15542 anim.values.forEach((node, i) => { 15543 if (node.done) return; 15544 const to = node.constructor == AnimatedString ? 1 : payload ? payload[i].lastPosition : toValues[i]; 15545 let finished = anim.immediate; 15546 let position = to; 15547 15548 if (!finished) { 15549 position = node.lastPosition; 15550 15551 if (config.tension <= 0) { 15552 node.done = true; 15553 return; 15554 } 15555 15556 let elapsed = node.elapsedTime += dt; 15557 const from = anim.fromValues[i]; 15558 const v0 = node.v0 != null ? node.v0 : node.v0 = react_spring_shared_esm_is.arr(config.velocity) ? config.velocity[i] : config.velocity; 15559 let velocity; 15560 15561 if (!react_spring_shared_esm_is.und(config.duration)) { 15562 let p = 1; 15563 15564 if (config.duration > 0) { 15565 if (this._memoizedDuration !== config.duration) { 15566 this._memoizedDuration = config.duration; 15567 15568 if (node.durationProgress > 0) { 15569 node.elapsedTime = config.duration * node.durationProgress; 15570 elapsed = node.elapsedTime += dt; 15571 } 15572 } 15573 15574 p = (config.progress || 0) + elapsed / this._memoizedDuration; 15575 p = p > 1 ? 1 : p < 0 ? 0 : p; 15576 node.durationProgress = p; 15577 } 15578 15579 position = from + config.easing(p) * (to - from); 15580 velocity = (position - node.lastPosition) / dt; 15581 finished = p == 1; 15582 } else if (config.decay) { 15583 const decay = config.decay === true ? 0.998 : config.decay; 15584 const e = Math.exp(-(1 - decay) * elapsed); 15585 position = from + v0 / (1 - decay) * (1 - e); 15586 finished = Math.abs(node.lastPosition - position) < 0.1; 15587 velocity = v0 * e; 15588 } else { 15589 velocity = node.lastVelocity == null ? v0 : node.lastVelocity; 15590 const precision = config.precision || (from == to ? 0.005 : Math.min(1, Math.abs(to - from) * 0.001)); 15591 const restVelocity = config.restVelocity || precision / 10; 15592 const bounceFactor = config.clamp ? 0 : config.bounce; 15593 const canBounce = !react_spring_shared_esm_is.und(bounceFactor); 15594 const isGrowing = from == to ? node.v0 > 0 : from < to; 15595 let isMoving; 15596 let isBouncing = false; 15597 const step = 1; 15598 const numSteps = Math.ceil(dt / step); 15599 15600 for (let n = 0; n < numSteps; ++n) { 15601 isMoving = Math.abs(velocity) > restVelocity; 15602 15603 if (!isMoving) { 15604 finished = Math.abs(to - position) <= precision; 15605 15606 if (finished) { 15607 break; 15608 } 15609 } 15610 15611 if (canBounce) { 15612 isBouncing = position == to || position > to == isGrowing; 15613 15614 if (isBouncing) { 15615 velocity = -velocity * bounceFactor; 15616 position = to; 15617 } 15618 } 15619 15620 const springForce = -config.tension * 0.000001 * (position - to); 15621 const dampingForce = -config.friction * 0.001 * velocity; 15622 const acceleration = (springForce + dampingForce) / config.mass; 15623 velocity = velocity + acceleration * step; 15624 position = position + velocity * step; 15625 } 15626 } 15627 15628 node.lastVelocity = velocity; 15629 15630 if (Number.isNaN(position)) { 15631 console.warn(`Got NaN while animating:`, this); 15632 finished = true; 15633 } 15634 } 15635 15636 if (payload && !payload[i].done) { 15637 finished = false; 15638 } 15639 15640 if (finished) { 15641 node.done = true; 15642 } else { 15643 idle = false; 15644 } 15645 15646 if (node.setValue(position, config.round)) { 15647 changed = true; 15648 } 15649 }); 15650 const node = getAnimated(this); 15651 const currVal = node.getValue(); 15652 15653 if (idle) { 15654 const finalVal = getFluidValue(anim.to); 15655 15656 if ((currVal !== finalVal || changed) && !config.decay) { 15657 node.setValue(finalVal); 15658 15659 this._onChange(finalVal); 15660 } else if (changed && config.decay) { 15661 this._onChange(currVal); 15662 } 15663 15664 this._stop(); 15665 } else if (changed) { 15666 this._onChange(currVal); 15667 } 15668 } 15669 15670 set(value) { 15671 raf.batchedUpdates(() => { 15672 this._stop(); 15673 15674 this._focus(value); 15675 15676 this._set(value); 15677 }); 15678 return this; 15679 } 15680 15681 pause() { 15682 this._update({ 15683 pause: true 15684 }); 15685 } 15686 15687 resume() { 15688 this._update({ 15689 pause: false 15690 }); 15691 } 15692 15693 finish() { 15694 if (isAnimating(this)) { 15695 const { 15696 to, 15697 config 15698 } = this.animation; 15699 raf.batchedUpdates(() => { 15700 this._onStart(); 15701 15702 if (!config.decay) { 15703 this._set(to, false); 15704 } 15705 15706 this._stop(); 15707 }); 15708 } 15709 15710 return this; 15711 } 15712 15713 update(props) { 15714 const queue = this.queue || (this.queue = []); 15715 queue.push(props); 15716 return this; 15717 } 15718 15719 start(to, arg2) { 15720 let queue; 15721 15722 if (!react_spring_shared_esm_is.und(to)) { 15723 queue = [react_spring_shared_esm_is.obj(to) ? to : react_spring_core_esm_extends({}, arg2, { 15724 to 15725 })]; 15726 } else { 15727 queue = this.queue || []; 15728 this.queue = []; 15729 } 15730 15731 return Promise.all(queue.map(props => { 15732 const up = this._update(props); 15733 15734 return up; 15735 })).then(results => getCombinedResult(this, results)); 15736 } 15737 15738 stop(cancel) { 15739 const { 15740 to 15741 } = this.animation; 15742 15743 this._focus(this.get()); 15744 15745 stopAsync(this._state, cancel && this._lastCallId); 15746 raf.batchedUpdates(() => this._stop(to, cancel)); 15747 return this; 15748 } 15749 15750 reset() { 15751 this._update({ 15752 reset: true 15753 }); 15754 } 15755 15756 eventObserved(event) { 15757 if (event.type == 'change') { 15758 this._start(); 15759 } else if (event.type == 'priority') { 15760 this.priority = event.priority + 1; 15761 } 15762 } 15763 15764 _prepareNode(props) { 15765 const key = this.key || ''; 15766 let { 15767 to, 15768 from 15769 } = props; 15770 to = react_spring_shared_esm_is.obj(to) ? to[key] : to; 15771 15772 if (to == null || isAsyncTo(to)) { 15773 to = undefined; 15774 } 15775 15776 from = react_spring_shared_esm_is.obj(from) ? from[key] : from; 15777 15778 if (from == null) { 15779 from = undefined; 15780 } 15781 15782 const range = { 15783 to, 15784 from 15785 }; 15786 15787 if (!hasAnimated(this)) { 15788 if (props.reverse) [to, from] = [from, to]; 15789 from = getFluidValue(from); 15790 15791 if (!react_spring_shared_esm_is.und(from)) { 15792 this._set(from); 15793 } else if (!getAnimated(this)) { 15794 this._set(to); 15795 } 15796 } 15797 15798 return range; 15799 } 15800 15801 _update(_ref, isLoop) { 15802 let props = react_spring_core_esm_extends({}, _ref); 15803 15804 const { 15805 key, 15806 defaultProps 15807 } = this; 15808 if (props.default) Object.assign(defaultProps, getDefaultProps(props, (value, prop) => /^on/.test(prop) ? resolveProp(value, key) : value)); 15809 mergeActiveFn(this, props, 'onProps'); 15810 sendEvent(this, 'onProps', props, this); 15811 15812 const range = this._prepareNode(props); 15813 15814 if (Object.isFrozen(this)) { 15815 throw Error('Cannot animate a `SpringValue` object that is frozen. ' + 'Did you forget to pass your component to `animated(...)` before animating its props?'); 15816 } 15817 15818 const state = this._state; 15819 return scheduleProps(++this._lastCallId, { 15820 key, 15821 props, 15822 defaultProps, 15823 state, 15824 actions: { 15825 pause: () => { 15826 if (!isPaused(this)) { 15827 setPausedBit(this, true); 15828 flushCalls(state.pauseQueue); 15829 sendEvent(this, 'onPause', getFinishedResult(this, checkFinished(this, this.animation.to)), this); 15830 } 15831 }, 15832 resume: () => { 15833 if (isPaused(this)) { 15834 setPausedBit(this, false); 15835 15836 if (isAnimating(this)) { 15837 this._resume(); 15838 } 15839 15840 flushCalls(state.resumeQueue); 15841 sendEvent(this, 'onResume', getFinishedResult(this, checkFinished(this, this.animation.to)), this); 15842 } 15843 }, 15844 start: this._merge.bind(this, range) 15845 } 15846 }).then(result => { 15847 if (props.loop && result.finished && !(isLoop && result.noop)) { 15848 const nextProps = createLoopUpdate(props); 15849 15850 if (nextProps) { 15851 return this._update(nextProps, true); 15852 } 15853 } 15854 15855 return result; 15856 }); 15857 } 15858 15859 _merge(range, props, resolve) { 15860 if (props.cancel) { 15861 this.stop(true); 15862 return resolve(getCancelledResult(this)); 15863 } 15864 15865 const hasToProp = !react_spring_shared_esm_is.und(range.to); 15866 const hasFromProp = !react_spring_shared_esm_is.und(range.from); 15867 15868 if (hasToProp || hasFromProp) { 15869 if (props.callId > this._lastToId) { 15870 this._lastToId = props.callId; 15871 } else { 15872 return resolve(getCancelledResult(this)); 15873 } 15874 } 15875 15876 const { 15877 key, 15878 defaultProps, 15879 animation: anim 15880 } = this; 15881 const { 15882 to: prevTo, 15883 from: prevFrom 15884 } = anim; 15885 let { 15886 to = prevTo, 15887 from = prevFrom 15888 } = range; 15889 15890 if (hasFromProp && !hasToProp && (!props.default || react_spring_shared_esm_is.und(to))) { 15891 to = from; 15892 } 15893 15894 if (props.reverse) [to, from] = [from, to]; 15895 const hasFromChanged = !isEqual(from, prevFrom); 15896 15897 if (hasFromChanged) { 15898 anim.from = from; 15899 } 15900 15901 from = getFluidValue(from); 15902 const hasToChanged = !isEqual(to, prevTo); 15903 15904 if (hasToChanged) { 15905 this._focus(to); 15906 } 15907 15908 const hasAsyncTo = isAsyncTo(props.to); 15909 const { 15910 config 15911 } = anim; 15912 const { 15913 decay, 15914 velocity 15915 } = config; 15916 15917 if (hasToProp || hasFromProp) { 15918 config.velocity = 0; 15919 } 15920 15921 if (props.config && !hasAsyncTo) { 15922 mergeConfig(config, callProp(props.config, key), props.config !== defaultProps.config ? callProp(defaultProps.config, key) : void 0); 15923 } 15924 15925 let node = getAnimated(this); 15926 15927 if (!node || react_spring_shared_esm_is.und(to)) { 15928 return resolve(getFinishedResult(this, true)); 15929 } 15930 15931 const reset = react_spring_shared_esm_is.und(props.reset) ? hasFromProp && !props.default : !react_spring_shared_esm_is.und(from) && matchProp(props.reset, key); 15932 const value = reset ? from : this.get(); 15933 const goal = computeGoal(to); 15934 const isAnimatable = react_spring_shared_esm_is.num(goal) || react_spring_shared_esm_is.arr(goal) || isAnimatedString(goal); 15935 const immediate = !hasAsyncTo && (!isAnimatable || matchProp(defaultProps.immediate || props.immediate, key)); 15936 15937 if (hasToChanged) { 15938 const nodeType = getAnimatedType(to); 15939 15940 if (nodeType !== node.constructor) { 15941 if (immediate) { 15942 node = this._set(goal); 15943 } else throw Error(`Cannot animate between $node.constructor.name} and $nodeType.name}, as the "to" prop suggests`); 15944 } 15945 } 15946 15947 const goalType = node.constructor; 15948 let started = hasFluidValue(to); 15949 let finished = false; 15950 15951 if (!started) { 15952 const hasValueChanged = reset || !hasAnimated(this) && hasFromChanged; 15953 15954 if (hasToChanged || hasValueChanged) { 15955 finished = isEqual(computeGoal(value), goal); 15956 started = !finished; 15957 } 15958 15959 if (!isEqual(anim.immediate, immediate) && !immediate || !isEqual(config.decay, decay) || !isEqual(config.velocity, velocity)) { 15960 started = true; 15961 } 15962 } 15963 15964 if (finished && isAnimating(this)) { 15965 if (anim.changed && !reset) { 15966 started = true; 15967 } else if (!started) { 15968 this._stop(prevTo); 15969 } 15970 } 15971 15972 if (!hasAsyncTo) { 15973 if (started || hasFluidValue(prevTo)) { 15974 anim.values = node.getPayload(); 15975 anim.toValues = hasFluidValue(to) ? null : goalType == AnimatedString ? [1] : react_spring_shared_esm_toArray(goal); 15976 } 15977 15978 if (anim.immediate != immediate) { 15979 anim.immediate = immediate; 15980 15981 if (!immediate && !reset) { 15982 this._set(prevTo); 15983 } 15984 } 15985 15986 if (started) { 15987 const { 15988 onRest 15989 } = anim; 15990 react_spring_shared_esm_each(ACTIVE_EVENTS, type => mergeActiveFn(this, props, type)); 15991 const result = getFinishedResult(this, checkFinished(this, prevTo)); 15992 flushCalls(this._pendingCalls, result); 15993 15994 this._pendingCalls.add(resolve); 15995 15996 if (anim.changed) raf.batchedUpdates(() => { 15997 anim.changed = !reset; 15998 onRest == null ? void 0 : onRest(result, this); 15999 16000 if (reset) { 16001 callProp(defaultProps.onRest, result); 16002 } else { 16003 anim.onStart == null ? void 0 : anim.onStart(result, this); 16004 } 16005 }); 16006 } 16007 } 16008 16009 if (reset) { 16010 this._set(value); 16011 } 16012 16013 if (hasAsyncTo) { 16014 resolve(runAsync(props.to, props, this._state, this)); 16015 } else if (started) { 16016 this._start(); 16017 } else if (isAnimating(this) && !hasToChanged) { 16018 this._pendingCalls.add(resolve); 16019 } else { 16020 resolve(getNoopResult(value)); 16021 } 16022 } 16023 16024 _focus(value) { 16025 const anim = this.animation; 16026 16027 if (value !== anim.to) { 16028 if (getFluidObservers(this)) { 16029 this._detach(); 16030 } 16031 16032 anim.to = value; 16033 16034 if (getFluidObservers(this)) { 16035 this._attach(); 16036 } 16037 } 16038 } 16039 16040 _attach() { 16041 let priority = 0; 16042 const { 16043 to 16044 } = this.animation; 16045 16046 if (hasFluidValue(to)) { 16047 addFluidObserver(to, this); 16048 16049 if (isFrameValue(to)) { 16050 priority = to.priority + 1; 16051 } 16052 } 16053 16054 this.priority = priority; 16055 } 16056 16057 _detach() { 16058 const { 16059 to 16060 } = this.animation; 16061 16062 if (hasFluidValue(to)) { 16063 removeFluidObserver(to, this); 16064 } 16065 } 16066 16067 _set(arg, idle = true) { 16068 const value = getFluidValue(arg); 16069 16070 if (!react_spring_shared_esm_is.und(value)) { 16071 const oldNode = getAnimated(this); 16072 16073 if (!oldNode || !isEqual(value, oldNode.getValue())) { 16074 const nodeType = getAnimatedType(value); 16075 16076 if (!oldNode || oldNode.constructor != nodeType) { 16077 setAnimated(this, nodeType.create(value)); 16078 } else { 16079 oldNode.setValue(value); 16080 } 16081 16082 if (oldNode) { 16083 raf.batchedUpdates(() => { 16084 this._onChange(value, idle); 16085 }); 16086 } 16087 } 16088 } 16089 16090 return getAnimated(this); 16091 } 16092 16093 _onStart() { 16094 const anim = this.animation; 16095 16096 if (!anim.changed) { 16097 anim.changed = true; 16098 sendEvent(this, 'onStart', getFinishedResult(this, checkFinished(this, anim.to)), this); 16099 } 16100 } 16101 16102 _onChange(value, idle) { 16103 if (!idle) { 16104 this._onStart(); 16105 16106 callProp(this.animation.onChange, value, this); 16107 } 16108 16109 callProp(this.defaultProps.onChange, value, this); 16110 16111 super._onChange(value, idle); 16112 } 16113 16114 _start() { 16115 const anim = this.animation; 16116 getAnimated(this).reset(getFluidValue(anim.to)); 16117 16118 if (!anim.immediate) { 16119 anim.fromValues = anim.values.map(node => node.lastPosition); 16120 } 16121 16122 if (!isAnimating(this)) { 16123 setActiveBit(this, true); 16124 16125 if (!isPaused(this)) { 16126 this._resume(); 16127 } 16128 } 16129 } 16130 16131 _resume() { 16132 if (globals.skipAnimation) { 16133 this.finish(); 16134 } else { 16135 frameLoop.start(this); 16136 } 16137 } 16138 16139 _stop(goal, cancel) { 16140 if (isAnimating(this)) { 16141 setActiveBit(this, false); 16142 const anim = this.animation; 16143 react_spring_shared_esm_each(anim.values, node => { 16144 node.done = true; 16145 }); 16146 16147 if (anim.toValues) { 16148 anim.onChange = anim.onPause = anim.onResume = undefined; 16149 } 16150 16151 callFluidObservers(this, { 16152 type: 'idle', 16153 parent: this 16154 }); 16155 const result = cancel ? getCancelledResult(this.get()) : getFinishedResult(this.get(), checkFinished(this, goal != null ? goal : anim.to)); 16156 flushCalls(this._pendingCalls, result); 16157 16158 if (anim.changed) { 16159 anim.changed = false; 16160 sendEvent(this, 'onRest', result, this); 16161 } 16162 } 16163 } 16164 16165 } 16166 16167 function checkFinished(target, to) { 16168 const goal = computeGoal(to); 16169 const value = computeGoal(target.get()); 16170 return isEqual(value, goal); 16171 } 16172 16173 function createLoopUpdate(props, loop = props.loop, to = props.to) { 16174 let loopRet = callProp(loop); 16175 16176 if (loopRet) { 16177 const overrides = loopRet !== true && inferTo(loopRet); 16178 const reverse = (overrides || props).reverse; 16179 const reset = !overrides || overrides.reset; 16180 return createUpdate(react_spring_core_esm_extends({}, props, { 16181 loop, 16182 default: false, 16183 pause: undefined, 16184 to: !reverse || isAsyncTo(to) ? to : undefined, 16185 from: reset ? props.from : undefined, 16186 reset 16187 }, overrides)); 16188 } 16189 } 16190 function createUpdate(props) { 16191 const { 16192 to, 16193 from 16194 } = props = inferTo(props); 16195 const keys = new Set(); 16196 if (react_spring_shared_esm_is.obj(to)) findDefined(to, keys); 16197 if (react_spring_shared_esm_is.obj(from)) findDefined(from, keys); 16198 props.keys = keys.size ? Array.from(keys) : null; 16199 return props; 16200 } 16201 function declareUpdate(props) { 16202 const update = createUpdate(props); 16203 16204 if (react_spring_shared_esm_is.und(update.default)) { 16205 update.default = getDefaultProps(update); 16206 } 16207 16208 return update; 16209 } 16210 16211 function findDefined(values, keys) { 16212 eachProp(values, (value, key) => value != null && keys.add(key)); 16213 } 16214 16215 const ACTIVE_EVENTS = ['onStart', 'onRest', 'onChange', 'onPause', 'onResume']; 16216 16217 function mergeActiveFn(target, props, type) { 16218 target.animation[type] = props[type] !== getDefaultProp(props, type) ? resolveProp(props[type], target.key) : undefined; 16219 } 16220 16221 function sendEvent(target, type, ...args) { 16222 var _target$animation$typ, _target$animation, _target$defaultProps$, _target$defaultProps; 16223 16224 (_target$animation$typ = (_target$animation = target.animation)[type]) == null ? void 0 : _target$animation$typ.call(_target$animation, ...args); 16225 (_target$defaultProps$ = (_target$defaultProps = target.defaultProps)[type]) == null ? void 0 : _target$defaultProps$.call(_target$defaultProps, ...args); 16226 } 16227 16228 const BATCHED_EVENTS = ['onStart', 'onChange', 'onRest']; 16229 let nextId = 1; 16230 class Controller { 16231 constructor(props, flush) { 16232 this.id = nextId++; 16233 this.springs = {}; 16234 this.queue = []; 16235 this.ref = void 0; 16236 this._flush = void 0; 16237 this._initialProps = void 0; 16238 this._lastAsyncId = 0; 16239 this._active = new Set(); 16240 this._changed = new Set(); 16241 this._started = false; 16242 this._item = void 0; 16243 this._state = { 16244 paused: false, 16245 pauseQueue: new Set(), 16246 resumeQueue: new Set(), 16247 timeouts: new Set() 16248 }; 16249 this._events = { 16250 onStart: new Map(), 16251 onChange: new Map(), 16252 onRest: new Map() 16253 }; 16254 this._onFrame = this._onFrame.bind(this); 16255 16256 if (flush) { 16257 this._flush = flush; 16258 } 16259 16260 if (props) { 16261 this.start(react_spring_core_esm_extends({ 16262 default: true 16263 }, props)); 16264 } 16265 } 16266 16267 get idle() { 16268 return !this._state.asyncTo && Object.values(this.springs).every(spring => { 16269 return spring.idle && !spring.isDelayed && !spring.isPaused; 16270 }); 16271 } 16272 16273 get item() { 16274 return this._item; 16275 } 16276 16277 set item(item) { 16278 this._item = item; 16279 } 16280 16281 get() { 16282 const values = {}; 16283 this.each((spring, key) => values[key] = spring.get()); 16284 return values; 16285 } 16286 16287 set(values) { 16288 for (const key in values) { 16289 const value = values[key]; 16290 16291 if (!react_spring_shared_esm_is.und(value)) { 16292 this.springs[key].set(value); 16293 } 16294 } 16295 } 16296 16297 update(props) { 16298 if (props) { 16299 this.queue.push(createUpdate(props)); 16300 } 16301 16302 return this; 16303 } 16304 16305 start(props) { 16306 let { 16307 queue 16308 } = this; 16309 16310 if (props) { 16311 queue = react_spring_shared_esm_toArray(props).map(createUpdate); 16312 } else { 16313 this.queue = []; 16314 } 16315 16316 if (this._flush) { 16317 return this._flush(this, queue); 16318 } 16319 16320 prepareKeys(this, queue); 16321 return flushUpdateQueue(this, queue); 16322 } 16323 16324 stop(arg, keys) { 16325 if (arg !== !!arg) { 16326 keys = arg; 16327 } 16328 16329 if (keys) { 16330 const springs = this.springs; 16331 react_spring_shared_esm_each(react_spring_shared_esm_toArray(keys), key => springs[key].stop(!!arg)); 16332 } else { 16333 stopAsync(this._state, this._lastAsyncId); 16334 this.each(spring => spring.stop(!!arg)); 16335 } 16336 16337 return this; 16338 } 16339 16340 pause(keys) { 16341 if (react_spring_shared_esm_is.und(keys)) { 16342 this.start({ 16343 pause: true 16344 }); 16345 } else { 16346 const springs = this.springs; 16347 react_spring_shared_esm_each(react_spring_shared_esm_toArray(keys), key => springs[key].pause()); 16348 } 16349 16350 return this; 16351 } 16352 16353 resume(keys) { 16354 if (react_spring_shared_esm_is.und(keys)) { 16355 this.start({ 16356 pause: false 16357 }); 16358 } else { 16359 const springs = this.springs; 16360 react_spring_shared_esm_each(react_spring_shared_esm_toArray(keys), key => springs[key].resume()); 16361 } 16362 16363 return this; 16364 } 16365 16366 each(iterator) { 16367 eachProp(this.springs, iterator); 16368 } 16369 16370 _onFrame() { 16371 const { 16372 onStart, 16373 onChange, 16374 onRest 16375 } = this._events; 16376 const active = this._active.size > 0; 16377 const changed = this._changed.size > 0; 16378 16379 if (active && !this._started || changed && !this._started) { 16380 this._started = true; 16381 flush(onStart, ([onStart, result]) => { 16382 result.value = this.get(); 16383 onStart(result, this, this._item); 16384 }); 16385 } 16386 16387 const idle = !active && this._started; 16388 const values = changed || idle && onRest.size ? this.get() : null; 16389 16390 if (changed && onChange.size) { 16391 flush(onChange, ([onChange, result]) => { 16392 result.value = values; 16393 onChange(result, this, this._item); 16394 }); 16395 } 16396 16397 if (idle) { 16398 this._started = false; 16399 flush(onRest, ([onRest, result]) => { 16400 result.value = values; 16401 onRest(result, this, this._item); 16402 }); 16403 } 16404 } 16405 16406 eventObserved(event) { 16407 if (event.type == 'change') { 16408 this._changed.add(event.parent); 16409 16410 if (!event.idle) { 16411 this._active.add(event.parent); 16412 } 16413 } else if (event.type == 'idle') { 16414 this._active.delete(event.parent); 16415 } else return; 16416 16417 raf.onFrame(this._onFrame); 16418 } 16419 16420 } 16421 function flushUpdateQueue(ctrl, queue) { 16422 return Promise.all(queue.map(props => flushUpdate(ctrl, props))).then(results => getCombinedResult(ctrl, results)); 16423 } 16424 async function flushUpdate(ctrl, props, isLoop) { 16425 const { 16426 keys, 16427 to, 16428 from, 16429 loop, 16430 onRest, 16431 onResolve 16432 } = props; 16433 const defaults = react_spring_shared_esm_is.obj(props.default) && props.default; 16434 16435 if (loop) { 16436 props.loop = false; 16437 } 16438 16439 if (to === false) props.to = null; 16440 if (from === false) props.from = null; 16441 const asyncTo = react_spring_shared_esm_is.arr(to) || react_spring_shared_esm_is.fun(to) ? to : undefined; 16442 16443 if (asyncTo) { 16444 props.to = undefined; 16445 props.onRest = undefined; 16446 16447 if (defaults) { 16448 defaults.onRest = undefined; 16449 } 16450 } else { 16451 react_spring_shared_esm_each(BATCHED_EVENTS, key => { 16452 const handler = props[key]; 16453 16454 if (react_spring_shared_esm_is.fun(handler)) { 16455 const queue = ctrl['_events'][key]; 16456 16457 props[key] = ({ 16458 finished, 16459 cancelled 16460 }) => { 16461 const result = queue.get(handler); 16462 16463 if (result) { 16464 if (!finished) result.finished = false; 16465 if (cancelled) result.cancelled = true; 16466 } else { 16467 queue.set(handler, { 16468 value: null, 16469 finished: finished || false, 16470 cancelled: cancelled || false 16471 }); 16472 } 16473 }; 16474 16475 if (defaults) { 16476 defaults[key] = props[key]; 16477 } 16478 } 16479 }); 16480 } 16481 16482 const state = ctrl['_state']; 16483 16484 if (props.pause === !state.paused) { 16485 state.paused = props.pause; 16486 flushCalls(props.pause ? state.pauseQueue : state.resumeQueue); 16487 } else if (state.paused) { 16488 props.pause = true; 16489 } 16490 16491 const promises = (keys || Object.keys(ctrl.springs)).map(key => ctrl.springs[key].start(props)); 16492 const cancel = props.cancel === true || getDefaultProp(props, 'cancel') === true; 16493 16494 if (asyncTo || cancel && state.asyncId) { 16495 promises.push(scheduleProps(++ctrl['_lastAsyncId'], { 16496 props, 16497 state, 16498 actions: { 16499 pause: noop, 16500 resume: noop, 16501 16502 start(props, resolve) { 16503 if (cancel) { 16504 stopAsync(state, ctrl['_lastAsyncId']); 16505 resolve(getCancelledResult(ctrl)); 16506 } else { 16507 props.onRest = onRest; 16508 resolve(runAsync(asyncTo, props, state, ctrl)); 16509 } 16510 } 16511 16512 } 16513 })); 16514 } 16515 16516 if (state.paused) { 16517 await new Promise(resume => { 16518 state.resumeQueue.add(resume); 16519 }); 16520 } 16521 16522 const result = getCombinedResult(ctrl, await Promise.all(promises)); 16523 16524 if (loop && result.finished && !(isLoop && result.noop)) { 16525 const nextProps = createLoopUpdate(props, loop, to); 16526 16527 if (nextProps) { 16528 prepareKeys(ctrl, [nextProps]); 16529 return flushUpdate(ctrl, nextProps, true); 16530 } 16531 } 16532 16533 if (onResolve) { 16534 raf.batchedUpdates(() => onResolve(result, ctrl, ctrl.item)); 16535 } 16536 16537 return result; 16538 } 16539 function getSprings(ctrl, props) { 16540 const springs = react_spring_core_esm_extends({}, ctrl.springs); 16541 16542 if (props) { 16543 react_spring_shared_esm_each(react_spring_shared_esm_toArray(props), props => { 16544 if (react_spring_shared_esm_is.und(props.keys)) { 16545 props = createUpdate(props); 16546 } 16547 16548 if (!react_spring_shared_esm_is.obj(props.to)) { 16549 props = react_spring_core_esm_extends({}, props, { 16550 to: undefined 16551 }); 16552 } 16553 16554 prepareSprings(springs, props, key => { 16555 return createSpring(key); 16556 }); 16557 }); 16558 } 16559 16560 setSprings(ctrl, springs); 16561 return springs; 16562 } 16563 function setSprings(ctrl, springs) { 16564 eachProp(springs, (spring, key) => { 16565 if (!ctrl.springs[key]) { 16566 ctrl.springs[key] = spring; 16567 addFluidObserver(spring, ctrl); 16568 } 16569 }); 16570 } 16571 16572 function createSpring(key, observer) { 16573 const spring = new SpringValue(); 16574 spring.key = key; 16575 16576 if (observer) { 16577 addFluidObserver(spring, observer); 16578 } 16579 16580 return spring; 16581 } 16582 16583 function prepareSprings(springs, props, create) { 16584 if (props.keys) { 16585 react_spring_shared_esm_each(props.keys, key => { 16586 const spring = springs[key] || (springs[key] = create(key)); 16587 spring['_prepareNode'](props); 16588 }); 16589 } 16590 } 16591 16592 function prepareKeys(ctrl, queue) { 16593 react_spring_shared_esm_each(queue, props => { 16594 prepareSprings(ctrl.springs, props, key => { 16595 return createSpring(key, ctrl); 16596 }); 16597 }); 16598 } 16599 16600 function _objectWithoutPropertiesLoose(source, excluded) { 16601 if (source == null) return {}; 16602 var target = {}; 16603 var sourceKeys = Object.keys(source); 16604 var key, i; 16605 16606 for (i = 0; i < sourceKeys.length; i++) { 16607 key = sourceKeys[i]; 16608 if (excluded.indexOf(key) >= 0) continue; 16609 target[key] = source[key]; 16610 } 16611 16612 return target; 16613 } 16614 16615 const _excluded$3 = ["children"]; 16616 const SpringContext = _ref => { 16617 let { 16618 children 16619 } = _ref, 16620 props = _objectWithoutPropertiesLoose(_ref, _excluded$3); 16621 16622 const inherited = (0,external_React_.useContext)(ctx); 16623 const pause = props.pause || !!inherited.pause, 16624 immediate = props.immediate || !!inherited.immediate; 16625 props = useMemoOne(() => ({ 16626 pause, 16627 immediate 16628 }), [pause, immediate]); 16629 const { 16630 Provider 16631 } = ctx; 16632 return external_React_.createElement(Provider, { 16633 value: props 16634 }, children); 16635 }; 16636 const ctx = makeContext(SpringContext, {}); 16637 SpringContext.Provider = ctx.Provider; 16638 SpringContext.Consumer = ctx.Consumer; 16639 16640 function makeContext(target, init) { 16641 Object.assign(target, external_React_.createContext(init)); 16642 target.Provider._context = target; 16643 target.Consumer._context = target; 16644 return target; 16645 } 16646 16647 const SpringRef = () => { 16648 const current = []; 16649 16650 const SpringRef = function SpringRef(props) { 16651 deprecateDirectCall(); 16652 const results = []; 16653 react_spring_shared_esm_each(current, (ctrl, i) => { 16654 if (react_spring_shared_esm_is.und(props)) { 16655 results.push(ctrl.start()); 16656 } else { 16657 const update = _getProps(props, ctrl, i); 16658 16659 if (update) { 16660 results.push(ctrl.start(update)); 16661 } 16662 } 16663 }); 16664 return results; 16665 }; 16666 16667 SpringRef.current = current; 16668 16669 SpringRef.add = function (ctrl) { 16670 if (!current.includes(ctrl)) { 16671 current.push(ctrl); 16672 } 16673 }; 16674 16675 SpringRef.delete = function (ctrl) { 16676 const i = current.indexOf(ctrl); 16677 if (~i) current.splice(i, 1); 16678 }; 16679 16680 SpringRef.pause = function () { 16681 react_spring_shared_esm_each(current, ctrl => ctrl.pause(...arguments)); 16682 return this; 16683 }; 16684 16685 SpringRef.resume = function () { 16686 react_spring_shared_esm_each(current, ctrl => ctrl.resume(...arguments)); 16687 return this; 16688 }; 16689 16690 SpringRef.set = function (values) { 16691 react_spring_shared_esm_each(current, ctrl => ctrl.set(values)); 16692 }; 16693 16694 SpringRef.start = function (props) { 16695 const results = []; 16696 react_spring_shared_esm_each(current, (ctrl, i) => { 16697 if (react_spring_shared_esm_is.und(props)) { 16698 results.push(ctrl.start()); 16699 } else { 16700 const update = this._getProps(props, ctrl, i); 16701 16702 if (update) { 16703 results.push(ctrl.start(update)); 16704 } 16705 } 16706 }); 16707 return results; 16708 }; 16709 16710 SpringRef.stop = function () { 16711 react_spring_shared_esm_each(current, ctrl => ctrl.stop(...arguments)); 16712 return this; 16713 }; 16714 16715 SpringRef.update = function (props) { 16716 react_spring_shared_esm_each(current, (ctrl, i) => ctrl.update(this._getProps(props, ctrl, i))); 16717 return this; 16718 }; 16719 16720 const _getProps = function _getProps(arg, ctrl, index) { 16721 return react_spring_shared_esm_is.fun(arg) ? arg(index, ctrl) : arg; 16722 }; 16723 16724 SpringRef._getProps = _getProps; 16725 return SpringRef; 16726 }; 16727 16728 function useSprings(length, props, deps) { 16729 const propsFn = react_spring_shared_esm_is.fun(props) && props; 16730 if (propsFn && !deps) deps = []; 16731 const ref = (0,external_React_.useMemo)(() => propsFn || arguments.length == 3 ? SpringRef() : void 0, []); 16732 const layoutId = (0,external_React_.useRef)(0); 16733 const forceUpdate = react_spring_shared_esm_useForceUpdate(); 16734 const state = (0,external_React_.useMemo)(() => ({ 16735 ctrls: [], 16736 queue: [], 16737 16738 flush(ctrl, updates) { 16739 const springs = getSprings(ctrl, updates); 16740 const canFlushSync = layoutId.current > 0 && !state.queue.length && !Object.keys(springs).some(key => !ctrl.springs[key]); 16741 return canFlushSync ? flushUpdateQueue(ctrl, updates) : new Promise(resolve => { 16742 setSprings(ctrl, springs); 16743 state.queue.push(() => { 16744 resolve(flushUpdateQueue(ctrl, updates)); 16745 }); 16746 forceUpdate(); 16747 }); 16748 } 16749 16750 }), []); 16751 const ctrls = (0,external_React_.useRef)([...state.ctrls]); 16752 const updates = []; 16753 const prevLength = react_spring_shared_esm_usePrev(length) || 0; 16754 (0,external_React_.useMemo)(() => { 16755 react_spring_shared_esm_each(ctrls.current.slice(length, prevLength), ctrl => { 16756 detachRefs(ctrl, ref); 16757 ctrl.stop(true); 16758 }); 16759 ctrls.current.length = length; 16760 declareUpdates(prevLength, length); 16761 }, [length]); 16762 (0,external_React_.useMemo)(() => { 16763 declareUpdates(0, Math.min(prevLength, length)); 16764 }, deps); 16765 16766 function declareUpdates(startIndex, endIndex) { 16767 for (let i = startIndex; i < endIndex; i++) { 16768 const ctrl = ctrls.current[i] || (ctrls.current[i] = new Controller(null, state.flush)); 16769 const update = propsFn ? propsFn(i, ctrl) : props[i]; 16770 16771 if (update) { 16772 updates[i] = declareUpdate(update); 16773 } 16774 } 16775 } 16776 16777 const springs = ctrls.current.map((ctrl, i) => getSprings(ctrl, updates[i])); 16778 const context = (0,external_React_.useContext)(SpringContext); 16779 const prevContext = react_spring_shared_esm_usePrev(context); 16780 const hasContext = context !== prevContext && hasProps(context); 16781 react_spring_shared_esm_useLayoutEffect(() => { 16782 layoutId.current++; 16783 state.ctrls = ctrls.current; 16784 const { 16785 queue 16786 } = state; 16787 16788 if (queue.length) { 16789 state.queue = []; 16790 react_spring_shared_esm_each(queue, cb => cb()); 16791 } 16792 16793 react_spring_shared_esm_each(ctrls.current, (ctrl, i) => { 16794 ref == null ? void 0 : ref.add(ctrl); 16795 16796 if (hasContext) { 16797 ctrl.start({ 16798 default: context 16799 }); 16800 } 16801 16802 const update = updates[i]; 16803 16804 if (update) { 16805 replaceRef(ctrl, update.ref); 16806 16807 if (ctrl.ref) { 16808 ctrl.queue.push(update); 16809 } else { 16810 ctrl.start(update); 16811 } 16812 } 16813 }); 16814 }); 16815 react_spring_shared_esm_useOnce(() => () => { 16816 react_spring_shared_esm_each(state.ctrls, ctrl => ctrl.stop(true)); 16817 }); 16818 const values = springs.map(x => react_spring_core_esm_extends({}, x)); 16819 return ref ? [values, ref] : values; 16820 } 16821 16822 function useSpring(props, deps) { 16823 const isFn = react_spring_shared_esm_is.fun(props); 16824 const [[values], ref] = useSprings(1, isFn ? props : [props], isFn ? deps || [] : deps); 16825 return isFn || arguments.length == 2 ? [values, ref] : values; 16826 } 16827 16828 const initSpringRef = () => SpringRef(); 16829 16830 const useSpringRef = () => useState(initSpringRef)[0]; 16831 16832 function useTrail(length, propsArg, deps) { 16833 var _passedRef; 16834 16835 const propsFn = is.fun(propsArg) && propsArg; 16836 if (propsFn && !deps) deps = []; 16837 let reverse = true; 16838 let passedRef = undefined; 16839 const result = useSprings(length, (i, ctrl) => { 16840 const props = propsFn ? propsFn(i, ctrl) : propsArg; 16841 passedRef = props.ref; 16842 reverse = reverse && props.reverse; 16843 return props; 16844 }, deps || [{}]); 16845 const ref = (_passedRef = passedRef) != null ? _passedRef : result[1]; 16846 useLayoutEffect(() => { 16847 each(ref.current, (ctrl, i) => { 16848 const parent = ref.current[i + (reverse ? 1 : -1)]; 16849 16850 if (parent) { 16851 ctrl.start({ 16852 to: parent.springs 16853 }); 16854 } else { 16855 ctrl.start(); 16856 } 16857 }); 16858 }, deps); 16859 16860 if (propsFn || arguments.length == 3) { 16861 ref['_getProps'] = (propsArg, ctrl, i) => { 16862 const props = is.fun(propsArg) ? propsArg(i, ctrl) : propsArg; 16863 16864 if (props) { 16865 const parent = ref.current[i + (props.reverse ? 1 : -1)]; 16866 if (parent) props.to = parent.springs; 16867 return props; 16868 } 16869 }; 16870 16871 return result; 16872 } 16873 16874 ref['start'] = propsArg => { 16875 const results = []; 16876 each(ref.current, (ctrl, i) => { 16877 const props = is.fun(propsArg) ? propsArg(i, ctrl) : propsArg; 16878 const parent = ref.current[i + (reverse ? 1 : -1)]; 16879 16880 if (parent) { 16881 results.push(ctrl.start(react_spring_core_esm_extends({}, props, { 16882 to: parent.springs 16883 }))); 16884 } else { 16885 results.push(ctrl.start(react_spring_core_esm_extends({}, props))); 16886 } 16887 }); 16888 return results; 16889 }; 16890 16891 return result[0]; 16892 } 16893 16894 let TransitionPhase; 16895 16896 (function (TransitionPhase) { 16897 TransitionPhase["MOUNT"] = "mount"; 16898 TransitionPhase["ENTER"] = "enter"; 16899 TransitionPhase["UPDATE"] = "update"; 16900 TransitionPhase["LEAVE"] = "leave"; 16901 })(TransitionPhase || (TransitionPhase = {})); 16902 16903 function useTransition(data, props, deps) { 16904 const propsFn = is.fun(props) && props; 16905 const { 16906 reset, 16907 sort, 16908 trail = 0, 16909 expires = true, 16910 exitBeforeEnter = false, 16911 onDestroyed, 16912 ref: propsRef, 16913 config: propsConfig 16914 } = propsFn ? propsFn() : props; 16915 const ref = useMemo(() => propsFn || arguments.length == 3 ? SpringRef() : void 0, []); 16916 const items = toArray(data); 16917 const transitions = []; 16918 const usedTransitions = useRef(null); 16919 const prevTransitions = reset ? null : usedTransitions.current; 16920 useLayoutEffect(() => { 16921 usedTransitions.current = transitions; 16922 }); 16923 useOnce(() => () => { 16924 each(usedTransitions.current, t => { 16925 if (t.expired) { 16926 clearTimeout(t.expirationId); 16927 } 16928 16929 detachRefs(t.ctrl, ref); 16930 t.ctrl.stop(true); 16931 }); 16932 }); 16933 const keys = getKeys(items, propsFn ? propsFn() : props, prevTransitions); 16934 const expired = reset && usedTransitions.current || []; 16935 useLayoutEffect(() => each(expired, ({ 16936 ctrl, 16937 item, 16938 key 16939 }) => { 16940 detachRefs(ctrl, ref); 16941 callProp(onDestroyed, item, key); 16942 })); 16943 const reused = []; 16944 if (prevTransitions) each(prevTransitions, (t, i) => { 16945 if (t.expired) { 16946 clearTimeout(t.expirationId); 16947 expired.push(t); 16948 } else { 16949 i = reused[i] = keys.indexOf(t.key); 16950 if (~i) transitions[i] = t; 16951 } 16952 }); 16953 each(items, (item, i) => { 16954 if (!transitions[i]) { 16955 transitions[i] = { 16956 key: keys[i], 16957 item, 16958 phase: TransitionPhase.MOUNT, 16959 ctrl: new Controller() 16960 }; 16961 transitions[i].ctrl.item = item; 16962 } 16963 }); 16964 16965 if (reused.length) { 16966 let i = -1; 16967 const { 16968 leave 16969 } = propsFn ? propsFn() : props; 16970 each(reused, (keyIndex, prevIndex) => { 16971 const t = prevTransitions[prevIndex]; 16972 16973 if (~keyIndex) { 16974 i = transitions.indexOf(t); 16975 transitions[i] = react_spring_core_esm_extends({}, t, { 16976 item: items[keyIndex] 16977 }); 16978 } else if (leave) { 16979 transitions.splice(++i, 0, t); 16980 } 16981 }); 16982 } 16983 16984 if (is.fun(sort)) { 16985 transitions.sort((a, b) => sort(a.item, b.item)); 16986 } 16987 16988 let delay = -trail; 16989 const forceUpdate = useForceUpdate(); 16990 const defaultProps = getDefaultProps(props); 16991 const changes = new Map(); 16992 const exitingTransitions = useRef(new Map()); 16993 const forceChange = useRef(false); 16994 each(transitions, (t, i) => { 16995 const key = t.key; 16996 const prevPhase = t.phase; 16997 const p = propsFn ? propsFn() : props; 16998 let to; 16999 let phase; 17000 let propsDelay = callProp(p.delay || 0, key); 17001 17002 if (prevPhase == TransitionPhase.MOUNT) { 17003 to = p.enter; 17004 phase = TransitionPhase.ENTER; 17005 } else { 17006 const isLeave = keys.indexOf(key) < 0; 17007 17008 if (prevPhase != TransitionPhase.LEAVE) { 17009 if (isLeave) { 17010 to = p.leave; 17011 phase = TransitionPhase.LEAVE; 17012 } else if (to = p.update) { 17013 phase = TransitionPhase.UPDATE; 17014 } else return; 17015 } else if (!isLeave) { 17016 to = p.enter; 17017 phase = TransitionPhase.ENTER; 17018 } else return; 17019 } 17020 17021 to = callProp(to, t.item, i); 17022 to = is.obj(to) ? inferTo(to) : { 17023 to 17024 }; 17025 17026 if (!to.config) { 17027 const config = propsConfig || defaultProps.config; 17028 to.config = callProp(config, t.item, i, phase); 17029 } 17030 17031 delay += trail; 17032 17033 const payload = react_spring_core_esm_extends({}, defaultProps, { 17034 delay: propsDelay + delay, 17035 ref: propsRef, 17036 immediate: p.immediate, 17037 reset: false 17038 }, to); 17039 17040 if (phase == TransitionPhase.ENTER && is.und(payload.from)) { 17041 const _p = propsFn ? propsFn() : props; 17042 17043 const from = is.und(_p.initial) || prevTransitions ? _p.from : _p.initial; 17044 payload.from = callProp(from, t.item, i); 17045 } 17046 17047 const { 17048 onResolve 17049 } = payload; 17050 17051 payload.onResolve = result => { 17052 callProp(onResolve, result); 17053 const transitions = usedTransitions.current; 17054 const t = transitions.find(t => t.key === key); 17055 if (!t) return; 17056 17057 if (result.cancelled && t.phase != TransitionPhase.UPDATE) { 17058 return; 17059 } 17060 17061 if (t.ctrl.idle) { 17062 const idle = transitions.every(t => t.ctrl.idle); 17063 17064 if (t.phase == TransitionPhase.LEAVE) { 17065 const expiry = callProp(expires, t.item); 17066 17067 if (expiry !== false) { 17068 const expiryMs = expiry === true ? 0 : expiry; 17069 t.expired = true; 17070 17071 if (!idle && expiryMs > 0) { 17072 if (expiryMs <= 0x7fffffff) t.expirationId = setTimeout(forceUpdate, expiryMs); 17073 return; 17074 } 17075 } 17076 } 17077 17078 if (idle && transitions.some(t => t.expired)) { 17079 exitingTransitions.current.delete(t); 17080 17081 if (exitBeforeEnter) { 17082 forceChange.current = true; 17083 } 17084 17085 forceUpdate(); 17086 } 17087 } 17088 }; 17089 17090 const springs = getSprings(t.ctrl, payload); 17091 17092 if (phase === TransitionPhase.LEAVE && exitBeforeEnter) { 17093 exitingTransitions.current.set(t, { 17094 phase, 17095 springs, 17096 payload 17097 }); 17098 } else { 17099 changes.set(t, { 17100 phase, 17101 springs, 17102 payload 17103 }); 17104 } 17105 }); 17106 const context = useContext(SpringContext); 17107 const prevContext = usePrev(context); 17108 const hasContext = context !== prevContext && hasProps(context); 17109 useLayoutEffect(() => { 17110 if (hasContext) { 17111 each(transitions, t => { 17112 t.ctrl.start({ 17113 default: context 17114 }); 17115 }); 17116 } 17117 }, [context]); 17118 each(changes, (_, t) => { 17119 if (exitingTransitions.current.size) { 17120 const ind = transitions.findIndex(state => state.key === t.key); 17121 transitions.splice(ind, 1); 17122 } 17123 }); 17124 useLayoutEffect(() => { 17125 each(exitingTransitions.current.size ? exitingTransitions.current : changes, ({ 17126 phase, 17127 payload 17128 }, t) => { 17129 const { 17130 ctrl 17131 } = t; 17132 t.phase = phase; 17133 ref == null ? void 0 : ref.add(ctrl); 17134 17135 if (hasContext && phase == TransitionPhase.ENTER) { 17136 ctrl.start({ 17137 default: context 17138 }); 17139 } 17140 17141 if (payload) { 17142 replaceRef(ctrl, payload.ref); 17143 17144 if (ctrl.ref && !forceChange.current) { 17145 ctrl.update(payload); 17146 } else { 17147 ctrl.start(payload); 17148 17149 if (forceChange.current) { 17150 forceChange.current = false; 17151 } 17152 } 17153 } 17154 }); 17155 }, reset ? void 0 : deps); 17156 17157 const renderTransitions = render => React.createElement(React.Fragment, null, transitions.map((t, i) => { 17158 const { 17159 springs 17160 } = changes.get(t) || t.ctrl; 17161 const elem = render(react_spring_core_esm_extends({}, springs), t.item, t, i); 17162 return elem && elem.type ? React.createElement(elem.type, react_spring_core_esm_extends({}, elem.props, { 17163 key: is.str(t.key) || is.num(t.key) ? t.key : t.ctrl.id, 17164 ref: elem.ref 17165 })) : elem; 17166 })); 17167 17168 return ref ? [renderTransitions, ref] : renderTransitions; 17169 } 17170 let nextKey = 1; 17171 17172 function getKeys(items, { 17173 key, 17174 keys = key 17175 }, prevTransitions) { 17176 if (keys === null) { 17177 const reused = new Set(); 17178 return items.map(item => { 17179 const t = prevTransitions && prevTransitions.find(t => t.item === item && t.phase !== TransitionPhase.LEAVE && !reused.has(t)); 17180 17181 if (t) { 17182 reused.add(t); 17183 return t.key; 17184 } 17185 17186 return nextKey++; 17187 }); 17188 } 17189 17190 return is.und(keys) ? items : is.fun(keys) ? items.map(keys) : toArray(keys); 17191 } 17192 17193 const _excluded$2 = (/* unused pure expression or super */ null && (["children"])); 17194 function Spring(_ref) { 17195 let { 17196 children 17197 } = _ref, 17198 props = _objectWithoutPropertiesLoose(_ref, _excluded$2); 17199 17200 return children(useSpring(props)); 17201 } 17202 17203 const _excluded$1 = (/* unused pure expression or super */ null && (["items", "children"])); 17204 function Trail(_ref) { 17205 let { 17206 items, 17207 children 17208 } = _ref, 17209 props = _objectWithoutPropertiesLoose(_ref, _excluded$1); 17210 17211 const trails = useTrail(items.length, props); 17212 return items.map((item, index) => { 17213 const result = children(item, index); 17214 return is.fun(result) ? result(trails[index]) : result; 17215 }); 17216 } 17217 17218 const _excluded = (/* unused pure expression or super */ null && (["items", "children"])); 17219 function Transition(_ref) { 17220 let { 17221 items, 17222 children 17223 } = _ref, 17224 props = _objectWithoutPropertiesLoose(_ref, _excluded); 17225 17226 return useTransition(items, props)(children); 17227 } 17228 17229 class Interpolation extends FrameValue { 17230 constructor(source, args) { 17231 super(); 17232 this.key = void 0; 17233 this.idle = true; 17234 this.calc = void 0; 17235 this._active = new Set(); 17236 this.source = source; 17237 this.calc = createInterpolator(...args); 17238 17239 const value = this._get(); 17240 17241 const nodeType = getAnimatedType(value); 17242 setAnimated(this, nodeType.create(value)); 17243 } 17244 17245 advance(_dt) { 17246 const value = this._get(); 17247 17248 const oldValue = this.get(); 17249 17250 if (!isEqual(value, oldValue)) { 17251 getAnimated(this).setValue(value); 17252 17253 this._onChange(value, this.idle); 17254 } 17255 17256 if (!this.idle && checkIdle(this._active)) { 17257 becomeIdle(this); 17258 } 17259 } 17260 17261 _get() { 17262 const inputs = react_spring_shared_esm_is.arr(this.source) ? this.source.map(getFluidValue) : react_spring_shared_esm_toArray(getFluidValue(this.source)); 17263 return this.calc(...inputs); 17264 } 17265 17266 _start() { 17267 if (this.idle && !checkIdle(this._active)) { 17268 this.idle = false; 17269 react_spring_shared_esm_each(getPayload(this), node => { 17270 node.done = false; 17271 }); 17272 17273 if (globals.skipAnimation) { 17274 raf.batchedUpdates(() => this.advance()); 17275 becomeIdle(this); 17276 } else { 17277 frameLoop.start(this); 17278 } 17279 } 17280 } 17281 17282 _attach() { 17283 let priority = 1; 17284 react_spring_shared_esm_each(react_spring_shared_esm_toArray(this.source), source => { 17285 if (hasFluidValue(source)) { 17286 addFluidObserver(source, this); 17287 } 17288 17289 if (isFrameValue(source)) { 17290 if (!source.idle) { 17291 this._active.add(source); 17292 } 17293 17294 priority = Math.max(priority, source.priority + 1); 17295 } 17296 }); 17297 this.priority = priority; 17298 17299 this._start(); 17300 } 17301 17302 _detach() { 17303 react_spring_shared_esm_each(react_spring_shared_esm_toArray(this.source), source => { 17304 if (hasFluidValue(source)) { 17305 removeFluidObserver(source, this); 17306 } 17307 }); 17308 17309 this._active.clear(); 17310 17311 becomeIdle(this); 17312 } 17313 17314 eventObserved(event) { 17315 if (event.type == 'change') { 17316 if (event.idle) { 17317 this.advance(); 17318 } else { 17319 this._active.add(event.parent); 17320 17321 this._start(); 17322 } 17323 } else if (event.type == 'idle') { 17324 this._active.delete(event.parent); 17325 } else if (event.type == 'priority') { 17326 this.priority = react_spring_shared_esm_toArray(this.source).reduce((highest, parent) => Math.max(highest, (isFrameValue(parent) ? parent.priority : 0) + 1), 0); 17327 } 17328 } 17329 17330 } 17331 17332 function isIdle(source) { 17333 return source.idle !== false; 17334 } 17335 17336 function checkIdle(active) { 17337 return !active.size || Array.from(active).every(isIdle); 17338 } 17339 17340 function becomeIdle(self) { 17341 if (!self.idle) { 17342 self.idle = true; 17343 react_spring_shared_esm_each(getPayload(self), node => { 17344 node.done = true; 17345 }); 17346 callFluidObservers(self, { 17347 type: 'idle', 17348 parent: self 17349 }); 17350 } 17351 } 17352 17353 const react_spring_core_esm_to = (source, ...args) => new Interpolation(source, args); 17354 const react_spring_core_esm_interpolate = (source, ...args) => (deprecateInterpolate(), new Interpolation(source, args)); 17355 17356 globals.assign({ 17357 createStringInterpolator: createStringInterpolator, 17358 to: (source, args) => new Interpolation(source, args) 17359 }); 17360 const react_spring_core_esm_update = frameLoop.advance; 17361 17362 17363 17364 ;// CONCATENATED MODULE: external "ReactDOM" 17365 var external_ReactDOM_namespaceObject = window["ReactDOM"]; 17366 ;// CONCATENATED MODULE: ./node_modules/@react-spring/web/dist/react-spring-web.esm.js 17367 17368 17369 17370 17371 17372 17373 function react_spring_web_esm_objectWithoutPropertiesLoose(source, excluded) { 17374 if (source == null) return {}; 17375 var target = {}; 17376 var sourceKeys = Object.keys(source); 17377 var key, i; 17378 17379 for (i = 0; i < sourceKeys.length; i++) { 17380 key = sourceKeys[i]; 17381 if (excluded.indexOf(key) >= 0) continue; 17382 target[key] = source[key]; 17383 } 17384 17385 return target; 17386 } 17387 17388 const react_spring_web_esm_excluded$2 = ["style", "children", "scrollTop", "scrollLeft"]; 17389 const isCustomPropRE = /^--/; 17390 17391 function dangerousStyleValue(name, value) { 17392 if (value == null || typeof value === 'boolean' || value === '') return ''; 17393 if (typeof value === 'number' && value !== 0 && !isCustomPropRE.test(name) && !(isUnitlessNumber.hasOwnProperty(name) && isUnitlessNumber[name])) return value + 'px'; 17394 return ('' + value).trim(); 17395 } 17396 17397 const attributeCache = {}; 17398 function applyAnimatedValues(instance, props) { 17399 if (!instance.nodeType || !instance.setAttribute) { 17400 return false; 17401 } 17402 17403 const isFilterElement = instance.nodeName === 'filter' || instance.parentNode && instance.parentNode.nodeName === 'filter'; 17404 17405 const _ref = props, 17406 { 17407 style, 17408 children, 17409 scrollTop, 17410 scrollLeft 17411 } = _ref, 17412 attributes = react_spring_web_esm_objectWithoutPropertiesLoose(_ref, react_spring_web_esm_excluded$2); 17413 17414 const values = Object.values(attributes); 17415 const names = Object.keys(attributes).map(name => isFilterElement || instance.hasAttribute(name) ? name : attributeCache[name] || (attributeCache[name] = name.replace(/([A-Z])/g, n => '-' + n.toLowerCase()))); 17416 17417 if (children !== void 0) { 17418 instance.textContent = children; 17419 } 17420 17421 for (let name in style) { 17422 if (style.hasOwnProperty(name)) { 17423 const value = dangerousStyleValue(name, style[name]); 17424 17425 if (isCustomPropRE.test(name)) { 17426 instance.style.setProperty(name, value); 17427 } else { 17428 instance.style[name] = value; 17429 } 17430 } 17431 } 17432 17433 names.forEach((name, i) => { 17434 instance.setAttribute(name, values[i]); 17435 }); 17436 17437 if (scrollTop !== void 0) { 17438 instance.scrollTop = scrollTop; 17439 } 17440 17441 if (scrollLeft !== void 0) { 17442 instance.scrollLeft = scrollLeft; 17443 } 17444 } 17445 let isUnitlessNumber = { 17446 animationIterationCount: true, 17447 borderImageOutset: true, 17448 borderImageSlice: true, 17449 borderImageWidth: true, 17450 boxFlex: true, 17451 boxFlexGroup: true, 17452 boxOrdinalGroup: true, 17453 columnCount: true, 17454 columns: true, 17455 flex: true, 17456 flexGrow: true, 17457 flexPositive: true, 17458 flexShrink: true, 17459 flexNegative: true, 17460 flexOrder: true, 17461 gridRow: true, 17462 gridRowEnd: true, 17463 gridRowSpan: true, 17464 gridRowStart: true, 17465 gridColumn: true, 17466 gridColumnEnd: true, 17467 gridColumnSpan: true, 17468 gridColumnStart: true, 17469 fontWeight: true, 17470 lineClamp: true, 17471 lineHeight: true, 17472 opacity: true, 17473 order: true, 17474 orphans: true, 17475 tabSize: true, 17476 widows: true, 17477 zIndex: true, 17478 zoom: true, 17479 fillOpacity: true, 17480 floodOpacity: true, 17481 stopOpacity: true, 17482 strokeDasharray: true, 17483 strokeDashoffset: true, 17484 strokeMiterlimit: true, 17485 strokeOpacity: true, 17486 strokeWidth: true 17487 }; 17488 17489 const prefixKey = (prefix, key) => prefix + key.charAt(0).toUpperCase() + key.substring(1); 17490 17491 const prefixes = ['Webkit', 'Ms', 'Moz', 'O']; 17492 isUnitlessNumber = Object.keys(isUnitlessNumber).reduce((acc, prop) => { 17493 prefixes.forEach(prefix => acc[prefixKey(prefix, prop)] = acc[prop]); 17494 return acc; 17495 }, isUnitlessNumber); 17496 17497 const react_spring_web_esm_excluded$1 = ["x", "y", "z"]; 17498 const domTransforms = /^(matrix|translate|scale|rotate|skew)/; 17499 const pxTransforms = /^(translate)/; 17500 const degTransforms = /^(rotate|skew)/; 17501 17502 const addUnit = (value, unit) => react_spring_shared_esm_is.num(value) && value !== 0 ? value + unit : value; 17503 17504 const isValueIdentity = (value, id) => react_spring_shared_esm_is.arr(value) ? value.every(v => isValueIdentity(v, id)) : react_spring_shared_esm_is.num(value) ? value === id : parseFloat(value) === id; 17505 17506 class AnimatedStyle extends AnimatedObject { 17507 constructor(_ref) { 17508 let { 17509 x, 17510 y, 17511 z 17512 } = _ref, 17513 style = react_spring_web_esm_objectWithoutPropertiesLoose(_ref, react_spring_web_esm_excluded$1); 17514 17515 const inputs = []; 17516 const transforms = []; 17517 17518 if (x || y || z) { 17519 inputs.push([x || 0, y || 0, z || 0]); 17520 transforms.push(xyz => [`translate3d($xyz.map(v => addUnit(v, 'px')).join(',')})`, isValueIdentity(xyz, 0)]); 17521 } 17522 17523 eachProp(style, (value, key) => { 17524 if (key === 'transform') { 17525 inputs.push([value || '']); 17526 transforms.push(transform => [transform, transform === '']); 17527 } else if (domTransforms.test(key)) { 17528 delete style[key]; 17529 if (react_spring_shared_esm_is.und(value)) return; 17530 const unit = pxTransforms.test(key) ? 'px' : degTransforms.test(key) ? 'deg' : ''; 17531 inputs.push(react_spring_shared_esm_toArray(value)); 17532 transforms.push(key === 'rotate3d' ? ([x, y, z, deg]) => [`rotate3d($x},$y},$z},$addUnit(deg, unit)})`, isValueIdentity(deg, 0)] : input => [`$key}($input.map(v => addUnit(v, unit)).join(',')})`, isValueIdentity(input, key.startsWith('scale') ? 1 : 0)]); 17533 } 17534 }); 17535 17536 if (inputs.length) { 17537 style.transform = new FluidTransform(inputs, transforms); 17538 } 17539 17540 super(style); 17541 } 17542 17543 } 17544 17545 class FluidTransform extends FluidValue { 17546 constructor(inputs, transforms) { 17547 super(); 17548 this._value = null; 17549 this.inputs = inputs; 17550 this.transforms = transforms; 17551 } 17552 17553 get() { 17554 return this._value || (this._value = this._get()); 17555 } 17556 17557 _get() { 17558 let transform = ''; 17559 let identity = true; 17560 react_spring_shared_esm_each(this.inputs, (input, i) => { 17561 const arg1 = getFluidValue(input[0]); 17562 const [t, id] = this.transforms[i](react_spring_shared_esm_is.arr(arg1) ? arg1 : input.map(getFluidValue)); 17563 transform += ' ' + t; 17564 identity = identity && id; 17565 }); 17566 return identity ? 'none' : transform; 17567 } 17568 17569 observerAdded(count) { 17570 if (count == 1) react_spring_shared_esm_each(this.inputs, input => react_spring_shared_esm_each(input, value => hasFluidValue(value) && addFluidObserver(value, this))); 17571 } 17572 17573 observerRemoved(count) { 17574 if (count == 0) react_spring_shared_esm_each(this.inputs, input => react_spring_shared_esm_each(input, value => hasFluidValue(value) && removeFluidObserver(value, this))); 17575 } 17576 17577 eventObserved(event) { 17578 if (event.type == 'change') { 17579 this._value = null; 17580 } 17581 17582 callFluidObservers(this, event); 17583 } 17584 17585 } 17586 17587 const primitives = ['a', 'abbr', 'address', 'area', 'article', 'aside', 'audio', 'b', 'base', 'bdi', 'bdo', 'big', 'blockquote', 'body', 'br', 'button', 'canvas', 'caption', 'cite', 'code', 'col', 'colgroup', 'data', 'datalist', 'dd', 'del', 'details', 'dfn', 'dialog', 'div', 'dl', 'dt', 'em', 'embed', 'fieldset', 'figcaption', 'figure', 'footer', 'form', 'h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'head', 'header', 'hgroup', 'hr', 'html', 'i', 'iframe', 'img', 'input', 'ins', 'kbd', 'keygen', 'label', 'legend', 'li', 'link', 'main', 'map', 'mark', 'menu', 'menuitem', 'meta', 'meter', 'nav', 'noscript', 'object', 'ol', 'optgroup', 'option', 'output', 'p', 'param', 'picture', 'pre', 'progress', 'q', 'rp', 'rt', 'ruby', 's', 'samp', 'script', 'section', 'select', 'small', 'source', 'span', 'strong', 'style', 'sub', 'summary', 'sup', 'table', 'tbody', 'td', 'textarea', 'tfoot', 'th', 'thead', 'time', 'title', 'tr', 'track', 'u', 'ul', 'var', 'video', 'wbr', 'circle', 'clipPath', 'defs', 'ellipse', 'foreignObject', 'g', 'image', 'line', 'linearGradient', 'mask', 'path', 'pattern', 'polygon', 'polyline', 'radialGradient', 'rect', 'stop', 'svg', 'text', 'tspan']; 17588 17589 const react_spring_web_esm_excluded = ["scrollTop", "scrollLeft"]; 17590 globals.assign({ 17591 batchedUpdates: external_ReactDOM_namespaceObject.unstable_batchedUpdates, 17592 createStringInterpolator: createStringInterpolator, 17593 colors: colors 17594 }); 17595 const host = createHost(primitives, { 17596 applyAnimatedValues, 17597 createAnimatedStyle: style => new AnimatedStyle(style), 17598 getComponentProps: _ref => { 17599 let props = react_spring_web_esm_objectWithoutPropertiesLoose(_ref, react_spring_web_esm_excluded); 17600 17601 return props; 17602 } 17603 }); 17604 const animated = host.animated; 17605 17606 17607 17608 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/use-moving-animation/index.js 17609 /** 17610 * External dependencies 17611 */ 17612 17613 /** 17614 * WordPress dependencies 17615 */ 17616 17617 17618 17619 17620 /** 17621 * Simple reducer used to increment a counter. 17622 * 17623 * @param {number} state Previous counter value. 17624 * @return {number} New state value. 17625 */ 17626 17627 const counterReducer = state => state + 1; 17628 17629 const getAbsolutePosition = element => { 17630 return { 17631 top: element.offsetTop, 17632 left: element.offsetLeft 17633 }; 17634 }; 17635 /** 17636 * Hook used to compute the styles required to move a div into a new position. 17637 * 17638 * The way this animation works is the following: 17639 * - It first renders the element as if there was no animation. 17640 * - It takes a snapshot of the position of the block to use it 17641 * as a destination point for the animation. 17642 * - It restores the element to the previous position using a CSS transform 17643 * - It uses the "resetAnimation" flag to reset the animation 17644 * from the beginning in order to animate to the new destination point. 17645 * 17646 * @param {Object} $1 Options 17647 * @param {boolean} $1.isSelected Whether it's the current block or not. 17648 * @param {boolean} $1.adjustScrolling Adjust the scroll position to the current block. 17649 * @param {boolean} $1.enableAnimation Enable/Disable animation. 17650 * @param {*} $1.triggerAnimationOnChange Variable used to trigger the animation if it changes. 17651 */ 17652 17653 17654 function useMovingAnimation(_ref) { 17655 let { 17656 isSelected, 17657 adjustScrolling, 17658 enableAnimation, 17659 triggerAnimationOnChange 17660 } = _ref; 17661 const ref = (0,external_wp_element_namespaceObject.useRef)(); 17662 const prefersReducedMotion = (0,external_wp_compose_namespaceObject.useReducedMotion)() || !enableAnimation; 17663 const [triggeredAnimation, triggerAnimation] = (0,external_wp_element_namespaceObject.useReducer)(counterReducer, 0); 17664 const [finishedAnimation, endAnimation] = (0,external_wp_element_namespaceObject.useReducer)(counterReducer, 0); 17665 const [transform, setTransform] = (0,external_wp_element_namespaceObject.useState)({ 17666 x: 0, 17667 y: 0 17668 }); 17669 const previous = (0,external_wp_element_namespaceObject.useMemo)(() => ref.current ? getAbsolutePosition(ref.current) : null, [triggerAnimationOnChange]); // Calculate the previous position of the block relative to the viewport and 17670 // return a function to maintain that position by scrolling. 17671 17672 const preserveScrollPosition = (0,external_wp_element_namespaceObject.useMemo)(() => { 17673 if (!adjustScrolling || !ref.current) { 17674 return () => {}; 17675 } 17676 17677 const scrollContainer = (0,external_wp_dom_namespaceObject.getScrollContainer)(ref.current); 17678 17679 if (!scrollContainer) { 17680 return () => {}; 17681 } 17682 17683 const prevRect = ref.current.getBoundingClientRect(); 17684 return () => { 17685 const blockRect = ref.current.getBoundingClientRect(); 17686 const diff = blockRect.top - prevRect.top; 17687 17688 if (diff) { 17689 scrollContainer.scrollTop += diff; 17690 } 17691 }; 17692 }, [triggerAnimationOnChange, adjustScrolling]); 17693 (0,external_wp_element_namespaceObject.useLayoutEffect)(() => { 17694 if (triggeredAnimation) { 17695 endAnimation(); 17696 } 17697 }, [triggeredAnimation]); 17698 (0,external_wp_element_namespaceObject.useLayoutEffect)(() => { 17699 if (!previous) { 17700 return; 17701 } 17702 17703 if (prefersReducedMotion) { 17704 // If the animation is disabled and the scroll needs to be adjusted, 17705 // just move directly to the final scroll position. 17706 preserveScrollPosition(); 17707 return; 17708 } 17709 17710 ref.current.style.transform = ''; 17711 const destination = getAbsolutePosition(ref.current); 17712 triggerAnimation(); 17713 setTransform({ 17714 x: Math.round(previous.left - destination.left), 17715 y: Math.round(previous.top - destination.top) 17716 }); 17717 }, [triggerAnimationOnChange]); // Only called when either the x or y value changes. 17718 17719 function onFrameChange(_ref2) { 17720 let { 17721 x, 17722 y 17723 } = _ref2; 17724 17725 if (!ref.current) { 17726 return; 17727 } 17728 17729 const isMoving = x === 0 && y === 0; 17730 ref.current.style.transformOrigin = isMoving ? '' : 'center'; 17731 ref.current.style.transform = isMoving ? '' : `translate3d($x}px,$y}px,0)`; 17732 ref.current.style.zIndex = !isSelected || isMoving ? '' : '1'; 17733 preserveScrollPosition(); 17734 } // Called for every frame computed by useSpring. 17735 17736 17737 function onChange(_ref3) { 17738 let { 17739 value 17740 } = _ref3; 17741 let { 17742 x, 17743 y 17744 } = value; 17745 x = Math.round(x); 17746 y = Math.round(y); 17747 17748 if (x !== onChange.x || y !== onChange.y) { 17749 onFrameChange({ 17750 x, 17751 y 17752 }); 17753 onChange.x = x; 17754 onChange.y = y; 17755 } 17756 } 17757 17758 onChange.x = 0; 17759 onChange.y = 0; 17760 useSpring({ 17761 from: { 17762 x: transform.x, 17763 y: transform.y 17764 }, 17765 to: { 17766 x: 0, 17767 y: 0 17768 }, 17769 reset: triggeredAnimation !== finishedAnimation, 17770 config: { 17771 mass: 5, 17772 tension: 2000, 17773 friction: 200 17774 }, 17775 immediate: prefersReducedMotion, 17776 onChange 17777 }); 17778 return ref; 17779 } 17780 17781 /* harmony default export */ var use_moving_animation = (useMovingAnimation); 17782 17783 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/utils/dom.js 17784 const BLOCK_SELECTOR = '.block-editor-block-list__block'; 17785 const APPENDER_SELECTOR = '.block-list-appender'; 17786 const BLOCK_APPENDER_CLASS = '.block-editor-button-block-appender'; 17787 /** 17788 * Returns true if two elements are contained within the same block. 17789 * 17790 * @param {Element} a First element. 17791 * @param {Element} b Second element. 17792 * 17793 * @return {boolean} Whether elements are in the same block. 17794 */ 17795 17796 function isInSameBlock(a, b) { 17797 return a.closest(BLOCK_SELECTOR) === b.closest(BLOCK_SELECTOR); 17798 } 17799 /** 17800 * Returns true if an element is considered part of the block and not its inner 17801 * blocks or appender. 17802 * 17803 * @param {Element} blockElement Block container element. 17804 * @param {Element} element Element. 17805 * 17806 * @return {boolean} Whether an element is considered part of the block and not 17807 * its inner blocks or appender. 17808 */ 17809 17810 function isInsideRootBlock(blockElement, element) { 17811 const parentBlock = element.closest([BLOCK_SELECTOR, APPENDER_SELECTOR, BLOCK_APPENDER_CLASS].join(',')); 17812 return parentBlock === blockElement; 17813 } 17814 /** 17815 * Finds the block client ID given any DOM node inside the block. 17816 * 17817 * @param {Node?} node DOM node. 17818 * 17819 * @return {string|undefined} Client ID or undefined if the node is not part of 17820 * a block. 17821 */ 17822 17823 function getBlockClientId(node) { 17824 while (node && node.nodeType !== node.ELEMENT_NODE) { 17825 node = node.parentNode; 17826 } 17827 17828 if (!node) { 17829 return; 17830 } 17831 17832 const elementNode = 17833 /** @type {Element} */ 17834 node; 17835 const blockNode = elementNode.closest(BLOCK_SELECTOR); 17836 17837 if (!blockNode) { 17838 return; 17839 } 17840 17841 return blockNode.id.slice('block-'.length); 17842 } 17843 17844 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-list/use-block-props/use-focus-first-element.js 17845 /** 17846 * External dependencies 17847 */ 17848 17849 /** 17850 * WordPress dependencies 17851 */ 17852 17853 17854 17855 17856 /** 17857 * Internal dependencies 17858 */ 17859 17860 17861 17862 /** @typedef {import('@wordpress/element').RefObject} RefObject */ 17863 17864 /** 17865 * Returns the initial position if the block needs to be focussed, `undefined` 17866 * otherwise. The initial position is either 0 (start) or -1 (end). 17867 * 17868 * @param {string} clientId Block client ID. 17869 * 17870 * @return {number} The initial position, either 0 (start) or -1 (end). 17871 */ 17872 17873 function useInitialPosition(clientId) { 17874 return (0,external_wp_data_namespaceObject.useSelect)(select => { 17875 const { 17876 getSelectedBlocksInitialCaretPosition, 17877 isNavigationMode, 17878 isBlockSelected 17879 } = select(store); 17880 17881 if (!isBlockSelected(clientId)) { 17882 return; 17883 } 17884 17885 if (isNavigationMode()) { 17886 return; 17887 } // If there's no initial position, return 0 to focus the start. 17888 17889 17890 return getSelectedBlocksInitialCaretPosition(); 17891 }, [clientId]); 17892 } 17893 /** 17894 * Transitions focus to the block or inner tabbable when the block becomes 17895 * selected and an initial position is set. 17896 * 17897 * @param {string} clientId Block client ID. 17898 * 17899 * @return {RefObject} React ref with the block element. 17900 */ 17901 17902 17903 function useFocusFirstElement(clientId) { 17904 const ref = (0,external_wp_element_namespaceObject.useRef)(); 17905 const initialPosition = useInitialPosition(clientId); 17906 const { 17907 isBlockSelected, 17908 isMultiSelecting 17909 } = (0,external_wp_data_namespaceObject.useSelect)(store); 17910 (0,external_wp_element_namespaceObject.useEffect)(() => { 17911 // Check if the block is still selected at the time this effect runs. 17912 if (!isBlockSelected(clientId) || isMultiSelecting()) { 17913 return; 17914 } 17915 17916 if (initialPosition === undefined || initialPosition === null) { 17917 return; 17918 } 17919 17920 if (!ref.current) { 17921 return; 17922 } 17923 17924 const { 17925 ownerDocument 17926 } = ref.current; // Do not focus the block if it already contains the active element. 17927 17928 if (ref.current.contains(ownerDocument.activeElement)) { 17929 return; 17930 } // Find all tabbables within node. 17931 17932 17933 const textInputs = external_wp_dom_namespaceObject.focus.tabbable.find(ref.current).filter(node => (0,external_wp_dom_namespaceObject.isTextField)(node)); // If reversed (e.g. merge via backspace), use the last in the set of 17934 // tabbables. 17935 17936 const isReverse = -1 === initialPosition; 17937 const target = (isReverse ? external_lodash_namespaceObject.last : external_lodash_namespaceObject.first)(textInputs) || ref.current; 17938 17939 if (!isInsideRootBlock(ref.current, target)) { 17940 ref.current.focus(); 17941 return; 17942 } // Check to see if element is focussable before a generic caret insert. 17943 17944 17945 if (!ref.current.getAttribute('contenteditable')) { 17946 const focusElement = external_wp_dom_namespaceObject.focus.tabbable.findNext(ref.current); // Make sure focusElement is valid, contained in the same block, and a form field. 17947 17948 if (focusElement && isInsideRootBlock(ref.current, focusElement) && (0,external_wp_dom_namespaceObject.isFormElement)(focusElement)) { 17949 focusElement.focus(); 17950 return; 17951 } 17952 } 17953 17954 (0,external_wp_dom_namespaceObject.placeCaretAtHorizontalEdge)(target, isReverse); 17955 }, [initialPosition, clientId]); 17956 return ref; 17957 } 17958 17959 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-list/use-block-props/use-is-hovered.js 17960 /** 17961 * WordPress dependencies 17962 */ 17963 17964 17965 /** 17966 * Internal dependencies 17967 */ 17968 17969 17970 17971 function listener(event) { 17972 if (event.defaultPrevented) { 17973 return; 17974 } 17975 17976 const action = event.type === 'mouseover' ? 'add' : 'remove'; 17977 event.preventDefault(); 17978 event.currentTarget.classList[action]('is-hovered'); 17979 } 17980 /** 17981 * Adds `is-hovered` class when the block is hovered and in navigation or 17982 * outline mode. 17983 */ 17984 17985 17986 function useIsHovered() { 17987 const isEnabled = (0,external_wp_data_namespaceObject.useSelect)(select => { 17988 const { 17989 isNavigationMode, 17990 getSettings 17991 } = select(store); 17992 return isNavigationMode() || getSettings().outlineMode; 17993 }, []); 17994 return (0,external_wp_compose_namespaceObject.useRefEffect)(node => { 17995 if (isEnabled) { 17996 node.addEventListener('mouseout', listener); 17997 node.addEventListener('mouseover', listener); 17998 return () => { 17999 node.removeEventListener('mouseout', listener); 18000 node.removeEventListener('mouseover', listener); // Remove class in case it lingers. 18001 18002 node.classList.remove('is-hovered'); 18003 }; 18004 } 18005 }, [isEnabled]); 18006 } 18007 18008 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-list/use-block-props/use-block-class-names.js 18009 /** 18010 * External dependencies 18011 */ 18012 18013 /** 18014 * WordPress dependencies 18015 */ 18016 18017 18018 18019 /** 18020 * Internal dependencies 18021 */ 18022 18023 18024 /** 18025 * Returns the class names used for the different states of the block. 18026 * 18027 * @param {string} clientId The block client ID. 18028 * 18029 * @return {string} The class names. 18030 */ 18031 18032 function useBlockClassNames(clientId) { 18033 return (0,external_wp_data_namespaceObject.useSelect)(select => { 18034 const { 18035 isBlockBeingDragged, 18036 isBlockHighlighted, 18037 isBlockSelected, 18038 isBlockMultiSelected, 18039 getBlockName, 18040 getSettings, 18041 hasSelectedInnerBlock, 18042 isTyping, 18043 __experimentalGetActiveBlockIdByBlockNames: getActiveBlockIdByBlockNames 18044 } = select(store); 18045 const { 18046 __experimentalSpotlightEntityBlocks: spotlightEntityBlocks, 18047 outlineMode 18048 } = getSettings(); 18049 const isDragging = isBlockBeingDragged(clientId); 18050 const isSelected = isBlockSelected(clientId); 18051 const name = getBlockName(clientId); 18052 const checkDeep = true; // "ancestor" is the more appropriate label due to "deep" check. 18053 18054 const isAncestorOfSelectedBlock = hasSelectedInnerBlock(clientId, checkDeep); 18055 const activeEntityBlockId = getActiveBlockIdByBlockNames(spotlightEntityBlocks); 18056 return classnames_default()({ 18057 'is-selected': isSelected, 18058 'is-highlighted': isBlockHighlighted(clientId), 18059 'is-multi-selected': isBlockMultiSelected(clientId), 18060 'is-reusable': (0,external_wp_blocks_namespaceObject.isReusableBlock)((0,external_wp_blocks_namespaceObject.getBlockType)(name)), 18061 'is-dragging': isDragging, 18062 'has-child-selected': isAncestorOfSelectedBlock, 18063 'has-active-entity': activeEntityBlockId, 18064 // Determine if there is an active entity area to spotlight. 18065 'is-active-entity': activeEntityBlockId === clientId, 18066 'remove-outline': isSelected && outlineMode && isTyping() 18067 }); 18068 }, [clientId]); 18069 } 18070 18071 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-list/use-block-props/use-block-default-class-name.js 18072 /** 18073 * WordPress dependencies 18074 */ 18075 18076 18077 /** 18078 * Internal dependencies 18079 */ 18080 18081 18082 /** 18083 * Returns the default class name if the block is a light block and it supports 18084 * `className`. 18085 * 18086 * @param {string} clientId The block client ID. 18087 * 18088 * @return {string} The class name, e.g. `wp-block-paragraph`. 18089 */ 18090 18091 function useBlockDefaultClassName(clientId) { 18092 return (0,external_wp_data_namespaceObject.useSelect)(select => { 18093 const name = select(store).getBlockName(clientId); 18094 const blockType = (0,external_wp_blocks_namespaceObject.getBlockType)(name); 18095 const hasLightBlockWrapper = (blockType === null || blockType === void 0 ? void 0 : blockType.apiVersion) > 1; 18096 18097 if (!hasLightBlockWrapper) { 18098 return; 18099 } 18100 18101 return (0,external_wp_blocks_namespaceObject.getBlockDefaultClassName)(name); 18102 }, [clientId]); 18103 } 18104 18105 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-list/use-block-props/use-block-custom-class-name.js 18106 /** 18107 * WordPress dependencies 18108 */ 18109 18110 18111 /** 18112 * Internal dependencies 18113 */ 18114 18115 18116 /** 18117 * Returns the custom class name if the block is a light block. 18118 * 18119 * @param {string} clientId The block client ID. 18120 * 18121 * @return {string} The custom class name. 18122 */ 18123 18124 function useBlockCustomClassName(clientId) { 18125 // It's good for this to be a separate selector because it will be executed 18126 // on every attribute change, while the other selectors are not re-evaluated 18127 // as much. 18128 return (0,external_wp_data_namespaceObject.useSelect)(select => { 18129 const { 18130 getBlockName, 18131 getBlockAttributes 18132 } = select(store); 18133 const attributes = getBlockAttributes(clientId); 18134 18135 if (!(attributes !== null && attributes !== void 0 && attributes.className)) { 18136 return; 18137 } 18138 18139 const blockType = (0,external_wp_blocks_namespaceObject.getBlockType)(getBlockName(clientId)); 18140 const hasLightBlockWrapper = (blockType === null || blockType === void 0 ? void 0 : blockType.apiVersion) > 1; 18141 18142 if (!hasLightBlockWrapper) { 18143 return; 18144 } 18145 18146 return attributes.className; 18147 }, [clientId]); 18148 } 18149 18150 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-list/use-block-props/use-block-moving-mode-class-names.js 18151 /** 18152 * External dependencies 18153 */ 18154 18155 /** 18156 * WordPress dependencies 18157 */ 18158 18159 18160 /** 18161 * Internal dependencies 18162 */ 18163 18164 18165 /** 18166 * Returns the class names used for block moving mode. 18167 * 18168 * @param {string} clientId The block client ID to insert above. 18169 * 18170 * @return {string} The class names. 18171 */ 18172 18173 function useBlockMovingModeClassNames(clientId) { 18174 return (0,external_wp_data_namespaceObject.useSelect)(select => { 18175 const { 18176 hasBlockMovingClientId, 18177 canInsertBlockType, 18178 getBlockName, 18179 getBlockRootClientId, 18180 isBlockSelected 18181 } = select(store); // The classes are only relevant for the selected block. Avoid 18182 // re-rendering all blocks! 18183 18184 if (!isBlockSelected(clientId)) { 18185 return; 18186 } 18187 18188 const movingClientId = hasBlockMovingClientId(); 18189 18190 if (!movingClientId) { 18191 return; 18192 } 18193 18194 return classnames_default()('is-block-moving-mode', { 18195 'can-insert-moving-block': canInsertBlockType(getBlockName(movingClientId), getBlockRootClientId(clientId)) 18196 }); 18197 }, [clientId]); 18198 } 18199 18200 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-list/use-block-props/use-focus-handler.js 18201 /** 18202 * WordPress dependencies 18203 */ 18204 18205 18206 /** 18207 * Internal dependencies 18208 */ 18209 18210 18211 18212 /** 18213 * Selects the block if it receives focus. 18214 * 18215 * @param {string} clientId Block client ID. 18216 */ 18217 18218 function useFocusHandler(clientId) { 18219 const { 18220 isBlockSelected 18221 } = (0,external_wp_data_namespaceObject.useSelect)(store); 18222 const { 18223 selectBlock, 18224 selectionChange 18225 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 18226 return (0,external_wp_compose_namespaceObject.useRefEffect)(node => { 18227 /** 18228 * Marks the block as selected when focused and not already 18229 * selected. This specifically handles the case where block does not 18230 * set focus on its own (via `setFocus`), typically if there is no 18231 * focusable input in the block. 18232 * 18233 * @param {FocusEvent} event Focus event. 18234 */ 18235 function onFocus(event) { 18236 // When the whole editor is editable, let writing flow handle 18237 // selection. 18238 if (node.parentElement.closest('[contenteditable="true"]')) { 18239 return; 18240 } // Check synchronously because a non-selected block might be 18241 // getting data through `useSelect` asynchronously. 18242 18243 18244 if (isBlockSelected(clientId)) { 18245 // Potentially change selection away from rich text. 18246 if (!event.target.isContentEditable) { 18247 selectionChange(clientId); 18248 } 18249 18250 return; 18251 } // If an inner block is focussed, that block is resposible for 18252 // setting the selected block. 18253 18254 18255 if (!isInsideRootBlock(node, event.target)) { 18256 return; 18257 } 18258 18259 selectBlock(clientId); 18260 } 18261 18262 node.addEventListener('focusin', onFocus); 18263 return () => { 18264 node.removeEventListener('focusin', onFocus); 18265 }; 18266 }, [isBlockSelected, selectBlock]); 18267 } 18268 18269 ;// CONCATENATED MODULE: external ["wp","keycodes"] 18270 var external_wp_keycodes_namespaceObject = window["wp"]["keycodes"]; 18271 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-list/use-block-props/use-selected-block-event-handlers.js 18272 /** 18273 * WordPress dependencies 18274 */ 18275 18276 18277 18278 18279 /** 18280 * Internal dependencies 18281 */ 18282 18283 18284 /** 18285 * Adds block behaviour: 18286 * - Removes the block on BACKSPACE. 18287 * - Inserts a default block on ENTER. 18288 * - Disables dragging of block contents. 18289 * 18290 * @param {string} clientId Block client ID. 18291 */ 18292 18293 function useEventHandlers(clientId) { 18294 const isSelected = (0,external_wp_data_namespaceObject.useSelect)(select => select(store).isBlockSelected(clientId), [clientId]); 18295 const { 18296 getBlockRootClientId, 18297 getBlockIndex 18298 } = (0,external_wp_data_namespaceObject.useSelect)(store); 18299 const { 18300 insertDefaultBlock, 18301 removeBlock 18302 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 18303 return (0,external_wp_compose_namespaceObject.useRefEffect)(node => { 18304 if (!isSelected) { 18305 return; 18306 } 18307 /** 18308 * Interprets keydown event intent to remove or insert after block if 18309 * key event occurs on wrapper node. This can occur when the block has 18310 * no text fields of its own, particularly after initial insertion, to 18311 * allow for easy deletion and continuous writing flow to add additional 18312 * content. 18313 * 18314 * @param {KeyboardEvent} event Keydown event. 18315 */ 18316 18317 18318 function onKeyDown(event) { 18319 const { 18320 keyCode, 18321 target 18322 } = event; 18323 18324 if (keyCode !== external_wp_keycodes_namespaceObject.ENTER && keyCode !== external_wp_keycodes_namespaceObject.BACKSPACE && keyCode !== external_wp_keycodes_namespaceObject.DELETE) { 18325 return; 18326 } 18327 18328 if (target !== node || (0,external_wp_dom_namespaceObject.isTextField)(target)) { 18329 return; 18330 } 18331 18332 event.preventDefault(); 18333 18334 if (keyCode === external_wp_keycodes_namespaceObject.ENTER) { 18335 insertDefaultBlock({}, getBlockRootClientId(clientId), getBlockIndex(clientId) + 1); 18336 } else { 18337 removeBlock(clientId); 18338 } 18339 } 18340 /** 18341 * Prevents default dragging behavior within a block. To do: we must 18342 * handle this in the future and clean up the drag target. 18343 * 18344 * @param {DragEvent} event Drag event. 18345 */ 18346 18347 18348 function onDragStart(event) { 18349 event.preventDefault(); 18350 } 18351 18352 node.addEventListener('keydown', onKeyDown); 18353 node.addEventListener('dragstart', onDragStart); 18354 return () => { 18355 node.removeEventListener('keydown', onKeyDown); 18356 node.removeEventListener('dragstart', onDragStart); 18357 }; 18358 }, [clientId, isSelected, getBlockRootClientId, getBlockIndex, insertDefaultBlock, removeBlock]); 18359 } 18360 18361 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-list/use-block-props/use-nav-mode-exit.js 18362 /** 18363 * WordPress dependencies 18364 */ 18365 18366 18367 /** 18368 * Internal dependencies 18369 */ 18370 18371 18372 /** 18373 * Allows navigation mode to be exited by clicking in the selected block. 18374 * 18375 * @param {string} clientId Block client ID. 18376 */ 18377 18378 function useNavModeExit(clientId) { 18379 const { 18380 isNavigationMode, 18381 isBlockSelected 18382 } = (0,external_wp_data_namespaceObject.useSelect)(store); 18383 const { 18384 setNavigationMode, 18385 selectBlock 18386 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 18387 return (0,external_wp_compose_namespaceObject.useRefEffect)(node => { 18388 function onMouseDown(event) { 18389 // Don't select a block if it's already handled by a child 18390 // block. 18391 if (isNavigationMode() && !event.defaultPrevented) { 18392 // Prevent focus from moving to the block. 18393 event.preventDefault(); // When clicking on a selected block, exit navigation mode. 18394 18395 if (isBlockSelected(clientId)) { 18396 setNavigationMode(false); 18397 } else { 18398 selectBlock(clientId); 18399 } 18400 } 18401 } 18402 18403 node.addEventListener('mousedown', onMouseDown); 18404 return () => { 18405 node.addEventListener('mousedown', onMouseDown); 18406 }; 18407 }, [clientId, isNavigationMode, isBlockSelected, setNavigationMode]); 18408 } 18409 18410 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-list/use-block-props/use-intersection-observer.js 18411 /** 18412 * WordPress dependencies 18413 */ 18414 18415 18416 /** 18417 * Internal dependencies 18418 */ 18419 18420 18421 function useIntersectionObserver() { 18422 const observer = (0,external_wp_element_namespaceObject.useContext)(IntersectionObserver); 18423 return (0,external_wp_compose_namespaceObject.useRefEffect)(node => { 18424 if (observer) { 18425 observer.observe(node); 18426 return () => { 18427 observer.unobserve(node); 18428 }; 18429 } 18430 }, [observer]); 18431 } 18432 18433 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-list/use-block-props/index.js 18434 /** 18435 * External dependencies 18436 */ 18437 18438 /** 18439 * WordPress dependencies 18440 */ 18441 18442 18443 18444 18445 18446 18447 18448 /** 18449 * Internal dependencies 18450 */ 18451 18452 18453 18454 18455 18456 18457 18458 18459 18460 18461 18462 18463 18464 18465 18466 18467 /** 18468 * If the block count exceeds the threshold, we disable the reordering animation 18469 * to avoid laginess. 18470 */ 18471 18472 const BLOCK_ANIMATION_THRESHOLD = 200; 18473 /** 18474 * This hook is used to lightly mark an element as a block element. The element 18475 * should be the outermost element of a block. Call this hook and pass the 18476 * returned props to the element to mark as a block. If you define a ref for the 18477 * element, it is important to pass the ref to this hook, which the hook in turn 18478 * will pass to the component through the props it returns. Optionally, you can 18479 * also pass any other props through this hook, and they will be merged and 18480 * returned. 18481 * 18482 * @param {Object} props Optional. Props to pass to the element. Must contain 18483 * the ref if one is defined. 18484 * @param {Object} options Options for internal use only. 18485 * @param {boolean} options.__unstableIsHtml 18486 * 18487 * @return {Object} Props to pass to the element to mark as a block. 18488 */ 18489 18490 function useBlockProps() { 18491 let props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; 18492 let { 18493 __unstableIsHtml 18494 } = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; 18495 const { 18496 clientId, 18497 className, 18498 wrapperProps = {}, 18499 isAligned 18500 } = (0,external_wp_element_namespaceObject.useContext)(BlockListBlockContext); 18501 const { 18502 index, 18503 mode, 18504 name, 18505 blockApiVersion, 18506 blockTitle, 18507 isPartOfSelection, 18508 adjustScrolling, 18509 enableAnimation 18510 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 18511 const { 18512 getBlockIndex, 18513 getBlockMode, 18514 getBlockName, 18515 isTyping, 18516 getGlobalBlockCount, 18517 isBlockSelected, 18518 isBlockMultiSelected, 18519 isAncestorMultiSelected, 18520 isFirstMultiSelectedBlock 18521 } = select(store); 18522 const isSelected = isBlockSelected(clientId); 18523 const isPartOfMultiSelection = isBlockMultiSelected(clientId) || isAncestorMultiSelected(clientId); 18524 const blockName = getBlockName(clientId); 18525 const blockType = (0,external_wp_blocks_namespaceObject.getBlockType)(blockName); 18526 return { 18527 index: getBlockIndex(clientId), 18528 mode: getBlockMode(clientId), 18529 name: blockName, 18530 blockApiVersion: (blockType === null || blockType === void 0 ? void 0 : blockType.apiVersion) || 1, 18531 blockTitle: blockType === null || blockType === void 0 ? void 0 : blockType.title, 18532 isPartOfSelection: isSelected || isPartOfMultiSelection, 18533 adjustScrolling: isSelected || isFirstMultiSelectedBlock(clientId), 18534 enableAnimation: !isTyping() && getGlobalBlockCount() <= BLOCK_ANIMATION_THRESHOLD 18535 }; 18536 }, [clientId]); // translators: %s: Type of block (i.e. Text, Image etc) 18537 18538 const blockLabel = (0,external_wp_i18n_namespaceObject.sprintf)((0,external_wp_i18n_namespaceObject.__)('Block: %s'), blockTitle); 18539 const htmlSuffix = mode === 'html' && !__unstableIsHtml ? '-visual' : ''; 18540 const mergedRefs = (0,external_wp_compose_namespaceObject.useMergeRefs)([props.ref, useFocusFirstElement(clientId), useBlockRefProvider(clientId), useFocusHandler(clientId), useEventHandlers(clientId), useNavModeExit(clientId), useIsHovered(), useIntersectionObserver(), use_moving_animation({ 18541 isSelected: isPartOfSelection, 18542 adjustScrolling, 18543 enableAnimation, 18544 triggerAnimationOnChange: index 18545 })]); 18546 const blockEditContext = useBlockEditContext(); // Ensures it warns only inside the `edit` implementation for the block. 18547 18548 if (blockApiVersion < 2 && clientId === blockEditContext.clientId) { 18549 typeof process !== "undefined" && process.env && "production" !== "production" ? 0 : void 0; 18550 } 18551 18552 return { ...wrapperProps, 18553 ...props, 18554 ref: mergedRefs, 18555 id: `block-$clientId}$htmlSuffix}`, 18556 tabIndex: 0, 18557 role: 'document', 18558 'aria-label': blockLabel, 18559 'data-block': clientId, 18560 'data-type': name, 18561 'data-title': blockTitle, 18562 className: classnames_default()( // The wp-block className is important for editor styles. 18563 classnames_default()('block-editor-block-list__block', { 18564 'wp-block': !isAligned 18565 }), className, props.className, wrapperProps.className, useBlockClassNames(clientId), useBlockDefaultClassName(clientId), useBlockCustomClassName(clientId), useBlockMovingModeClassNames(clientId)), 18566 style: { ...wrapperProps.style, 18567 ...props.style 18568 } 18569 }; 18570 } 18571 /** 18572 * Call within a save function to get the props for the block wrapper. 18573 * 18574 * @param {Object} props Optional. Props to pass to the element. 18575 */ 18576 18577 useBlockProps.save = external_wp_blocks_namespaceObject.__unstableGetBlockProps; 18578 18579 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-list/block.js 18580 18581 18582 /** 18583 * External dependencies 18584 */ 18585 18586 18587 /** 18588 * WordPress dependencies 18589 */ 18590 18591 18592 18593 18594 18595 18596 18597 /** 18598 * Internal dependencies 18599 */ 18600 18601 18602 18603 18604 18605 18606 18607 18608 const BlockListBlockContext = (0,external_wp_element_namespaceObject.createContext)(); 18609 /** 18610 * Merges wrapper props with special handling for classNames and styles. 18611 * 18612 * @param {Object} propsA 18613 * @param {Object} propsB 18614 * 18615 * @return {Object} Merged props. 18616 */ 18617 18618 function mergeWrapperProps(propsA, propsB) { 18619 const newProps = { ...propsA, 18620 ...propsB 18621 }; 18622 18623 if (propsA && propsB && propsA.className && propsB.className) { 18624 newProps.className = classnames_default()(propsA.className, propsB.className); 18625 } 18626 18627 if (propsA && propsB && propsA.style && propsB.style) { 18628 newProps.style = { ...propsA.style, 18629 ...propsB.style 18630 }; 18631 } 18632 18633 return newProps; 18634 } 18635 18636 function Block(_ref) { 18637 let { 18638 children, 18639 isHtml, 18640 ...props 18641 } = _ref; 18642 return (0,external_wp_element_namespaceObject.createElement)("div", useBlockProps(props, { 18643 __unstableIsHtml: isHtml 18644 }), children); 18645 } 18646 18647 function BlockListBlock(_ref2) { 18648 var _wrapperProps; 18649 18650 let { 18651 block: { 18652 __unstableBlockSource 18653 }, 18654 mode, 18655 isLocked, 18656 canRemove, 18657 clientId, 18658 isSelected, 18659 isSelectionEnabled, 18660 className, 18661 name, 18662 isValid, 18663 attributes, 18664 wrapperProps, 18665 setAttributes, 18666 onReplace, 18667 onInsertBlocksAfter, 18668 onMerge, 18669 toggleSelection 18670 } = _ref2; 18671 const themeSupportsLayout = (0,external_wp_data_namespaceObject.useSelect)(select => { 18672 const { 18673 getSettings 18674 } = select(store); 18675 return getSettings().supportsLayout; 18676 }, []); 18677 const { 18678 removeBlock 18679 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 18680 const onRemove = (0,external_wp_element_namespaceObject.useCallback)(() => removeBlock(clientId), [clientId]); // We wrap the BlockEdit component in a div that hides it when editing in 18681 // HTML mode. This allows us to render all of the ancillary pieces 18682 // (InspectorControls, etc.) which are inside `BlockEdit` but not 18683 // `BlockHTML`, even in HTML mode. 18684 18685 let blockEdit = (0,external_wp_element_namespaceObject.createElement)(BlockEdit, { 18686 name: name, 18687 isSelected: isSelected, 18688 attributes: attributes, 18689 setAttributes: setAttributes, 18690 insertBlocksAfter: isLocked ? undefined : onInsertBlocksAfter, 18691 onReplace: canRemove ? onReplace : undefined, 18692 onRemove: canRemove ? onRemove : undefined, 18693 mergeBlocks: canRemove ? onMerge : undefined, 18694 clientId: clientId, 18695 isSelectionEnabled: isSelectionEnabled, 18696 toggleSelection: toggleSelection 18697 }); 18698 const blockType = (0,external_wp_blocks_namespaceObject.getBlockType)(name); // Determine whether the block has props to apply to the wrapper. 18699 18700 if (blockType !== null && blockType !== void 0 && blockType.getEditWrapperProps) { 18701 wrapperProps = mergeWrapperProps(wrapperProps, blockType.getEditWrapperProps(attributes)); 18702 } 18703 18704 const isAligned = wrapperProps && !!wrapperProps['data-align'] && !themeSupportsLayout; // For aligned blocks, provide a wrapper element so the block can be 18705 // positioned relative to the block column. 18706 // This is only kept for classic themes that don't support layout 18707 // Historically we used to rely on extra divs and data-align to 18708 // provide the alignments styles in the editor. 18709 // Due to the differences between frontend and backend, we migrated 18710 // to the layout feature, and we're now aligning the markup of frontend 18711 // and backend. 18712 18713 if (isAligned) { 18714 blockEdit = (0,external_wp_element_namespaceObject.createElement)("div", { 18715 className: "wp-block", 18716 "data-align": wrapperProps['data-align'] 18717 }, blockEdit); 18718 } 18719 18720 let block; 18721 18722 if (!isValid) { 18723 const saveContent = __unstableBlockSource ? (0,external_wp_blocks_namespaceObject.serializeRawBlock)(__unstableBlockSource) : (0,external_wp_blocks_namespaceObject.getSaveContent)(blockType, attributes); 18724 block = (0,external_wp_element_namespaceObject.createElement)(Block, { 18725 className: "has-warning" 18726 }, (0,external_wp_element_namespaceObject.createElement)(block_invalid_warning, { 18727 clientId: clientId 18728 }), (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.RawHTML, null, (0,external_wp_dom_namespaceObject.safeHTML)(saveContent))); 18729 } else if (mode === 'html') { 18730 // Render blockEdit so the inspector controls don't disappear. 18731 // See #8969. 18732 block = (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("div", { 18733 style: { 18734 display: 'none' 18735 } 18736 }, blockEdit), (0,external_wp_element_namespaceObject.createElement)(Block, { 18737 isHtml: true 18738 }, (0,external_wp_element_namespaceObject.createElement)(block_html, { 18739 clientId: clientId 18740 }))); 18741 } else if ((blockType === null || blockType === void 0 ? void 0 : blockType.apiVersion) > 1) { 18742 block = blockEdit; 18743 } else { 18744 block = (0,external_wp_element_namespaceObject.createElement)(Block, wrapperProps, blockEdit); 18745 } 18746 18747 const value = { 18748 clientId, 18749 className: (_wrapperProps = wrapperProps) !== null && _wrapperProps !== void 0 && _wrapperProps['data-align'] && themeSupportsLayout ? classnames_default()(className, `align$wrapperProps['data-align']}`) : className, 18750 wrapperProps: (0,external_lodash_namespaceObject.omit)(wrapperProps, ['data-align']), 18751 isAligned 18752 }; 18753 const memoizedValue = (0,external_wp_element_namespaceObject.useMemo)(() => value, Object.values(value)); 18754 return (0,external_wp_element_namespaceObject.createElement)(BlockListBlockContext.Provider, { 18755 value: memoizedValue 18756 }, (0,external_wp_element_namespaceObject.createElement)(block_crash_boundary, { 18757 fallback: (0,external_wp_element_namespaceObject.createElement)(Block, { 18758 className: "has-warning" 18759 }, (0,external_wp_element_namespaceObject.createElement)(block_crash_warning, null)) 18760 }, block)); 18761 } 18762 18763 const applyWithSelect = (0,external_wp_data_namespaceObject.withSelect)((select, _ref3) => { 18764 let { 18765 clientId, 18766 rootClientId 18767 } = _ref3; 18768 const { 18769 isBlockSelected, 18770 getBlockMode, 18771 isSelectionEnabled, 18772 getTemplateLock, 18773 __unstableGetBlockWithoutInnerBlocks, 18774 canRemoveBlock, 18775 canMoveBlock 18776 } = select(store); 18777 18778 const block = __unstableGetBlockWithoutInnerBlocks(clientId); 18779 18780 const isSelected = isBlockSelected(clientId); 18781 const templateLock = getTemplateLock(rootClientId); 18782 const canRemove = canRemoveBlock(clientId, rootClientId); 18783 const canMove = canMoveBlock(clientId, rootClientId); // The fallback to `{}` is a temporary fix. 18784 // This function should never be called when a block is not present in 18785 // the state. It happens now because the order in withSelect rendering 18786 // is not correct. 18787 18788 const { 18789 name, 18790 attributes, 18791 isValid 18792 } = block || {}; // Do not add new properties here, use `useSelect` instead to avoid 18793 // leaking new props to the public API (editor.BlockListBlock filter). 18794 18795 return { 18796 mode: getBlockMode(clientId), 18797 isSelectionEnabled: isSelectionEnabled(), 18798 isLocked: !!templateLock, 18799 canRemove, 18800 canMove, 18801 // Users of the editor.BlockListBlock filter used to be able to 18802 // access the block prop. 18803 // Ideally these blocks would rely on the clientId prop only. 18804 // This is kept for backward compatibility reasons. 18805 block, 18806 name, 18807 attributes, 18808 isValid, 18809 isSelected 18810 }; 18811 }); 18812 const applyWithDispatch = (0,external_wp_data_namespaceObject.withDispatch)((dispatch, ownProps, _ref4) => { 18813 let { 18814 select 18815 } = _ref4; 18816 const { 18817 updateBlockAttributes, 18818 insertBlocks, 18819 mergeBlocks, 18820 replaceBlocks, 18821 toggleSelection, 18822 __unstableMarkLastChangeAsPersistent 18823 } = dispatch(store); // Do not add new properties here, use `useDispatch` instead to avoid 18824 // leaking new props to the public API (editor.BlockListBlock filter). 18825 18826 return { 18827 setAttributes(newAttributes) { 18828 const { 18829 getMultiSelectedBlockClientIds 18830 } = select(store); 18831 const multiSelectedBlockClientIds = getMultiSelectedBlockClientIds(); 18832 const { 18833 clientId 18834 } = ownProps; 18835 const clientIds = multiSelectedBlockClientIds.length ? multiSelectedBlockClientIds : [clientId]; 18836 updateBlockAttributes(clientIds, newAttributes); 18837 }, 18838 18839 onInsertBlocks(blocks, index) { 18840 const { 18841 rootClientId 18842 } = ownProps; 18843 insertBlocks(blocks, index, rootClientId); 18844 }, 18845 18846 onInsertBlocksAfter(blocks) { 18847 const { 18848 clientId, 18849 rootClientId 18850 } = ownProps; 18851 const { 18852 getBlockIndex 18853 } = select(store); 18854 const index = getBlockIndex(clientId); 18855 insertBlocks(blocks, index + 1, rootClientId); 18856 }, 18857 18858 onMerge(forward) { 18859 const { 18860 clientId 18861 } = ownProps; 18862 const { 18863 getPreviousBlockClientId, 18864 getNextBlockClientId 18865 } = select(store); 18866 18867 if (forward) { 18868 const nextBlockClientId = getNextBlockClientId(clientId); 18869 18870 if (nextBlockClientId) { 18871 mergeBlocks(clientId, nextBlockClientId); 18872 } 18873 } else { 18874 const previousBlockClientId = getPreviousBlockClientId(clientId); 18875 18876 if (previousBlockClientId) { 18877 mergeBlocks(previousBlockClientId, clientId); 18878 } 18879 } 18880 }, 18881 18882 onReplace(blocks, indexToSelect, initialPosition) { 18883 if (blocks.length && !(0,external_wp_blocks_namespaceObject.isUnmodifiedDefaultBlock)(blocks[blocks.length - 1])) { 18884 __unstableMarkLastChangeAsPersistent(); 18885 } 18886 18887 replaceBlocks([ownProps.clientId], blocks, indexToSelect, initialPosition); 18888 }, 18889 18890 toggleSelection(selectionEnabled) { 18891 toggleSelection(selectionEnabled); 18892 } 18893 18894 }; 18895 }); 18896 /* harmony default export */ var block = ((0,external_wp_compose_namespaceObject.compose)(external_wp_compose_namespaceObject.pure, applyWithSelect, applyWithDispatch, // Block is sometimes not mounted at the right time, causing it be undefined 18897 // see issue for more info 18898 // https://github.com/WordPress/gutenberg/issues/17013 18899 (0,external_wp_compose_namespaceObject.ifCondition)(_ref5 => { 18900 let { 18901 block 18902 } = _ref5; 18903 return !!block; 18904 }), (0,external_wp_components_namespaceObject.withFilters)('editor.BlockListBlock'))(BlockListBlock)); 18905 18906 ;// CONCATENATED MODULE: external ["wp","htmlEntities"] 18907 var external_wp_htmlEntities_namespaceObject = window["wp"]["htmlEntities"]; 18908 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/plus.js 18909 18910 18911 /** 18912 * WordPress dependencies 18913 */ 18914 18915 const plus = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 18916 xmlns: "http://www.w3.org/2000/svg", 18917 viewBox: "0 0 24 24" 18918 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 18919 d: "M18 11.2h-5.2V6h-1.6v5.2H6v1.6h5.2V18h1.6v-5.2H18z" 18920 })); 18921 /* harmony default export */ var library_plus = (plus); 18922 18923 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inserter/tips.js 18924 18925 18926 /** 18927 * WordPress dependencies 18928 */ 18929 18930 18931 18932 const globalTips = [(0,external_wp_element_namespaceObject.createInterpolateElement)((0,external_wp_i18n_namespaceObject.__)('While writing, you can press <kbd>/</kbd> to quickly insert new blocks.'), { 18933 kbd: (0,external_wp_element_namespaceObject.createElement)("kbd", null) 18934 }), (0,external_wp_element_namespaceObject.createInterpolateElement)((0,external_wp_i18n_namespaceObject.__)('Indent a list by pressing <kbd>space</kbd> at the beginning of a line.'), { 18935 kbd: (0,external_wp_element_namespaceObject.createElement)("kbd", null) 18936 }), (0,external_wp_element_namespaceObject.createInterpolateElement)((0,external_wp_i18n_namespaceObject.__)('Outdent a list by pressing <kbd>backspace</kbd> at the beginning of a line.'), { 18937 kbd: (0,external_wp_element_namespaceObject.createElement)("kbd", null) 18938 }), (0,external_wp_i18n_namespaceObject.__)('Drag files into the editor to automatically insert media blocks.'), (0,external_wp_i18n_namespaceObject.__)("Change a block's type by pressing the block icon on the toolbar.")]; 18939 18940 function Tips() { 18941 const [randomIndex] = (0,external_wp_element_namespaceObject.useState)( // Disable Reason: I'm not generating an HTML id. 18942 // eslint-disable-next-line no-restricted-syntax 18943 Math.floor(Math.random() * globalTips.length)); 18944 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Tip, null, globalTips[randomIndex]); 18945 } 18946 18947 /* harmony default export */ var tips = (Tips); 18948 18949 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/block-default.js 18950 18951 18952 /** 18953 * WordPress dependencies 18954 */ 18955 18956 const blockDefault = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 18957 xmlns: "http://www.w3.org/2000/svg", 18958 viewBox: "0 0 24 24" 18959 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 18960 d: "M19 8h-1V6h-5v2h-2V6H6v2H5c-1.1 0-2 .9-2 2v8c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2v-8c0-1.1-.9-2-2-2zm.5 10c0 .3-.2.5-.5.5H5c-.3 0-.5-.2-.5-.5v-8c0-.3.2-.5.5-.5h14c.3 0 .5.2.5.5v8z" 18961 })); 18962 /* harmony default export */ var block_default = (blockDefault); 18963 18964 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-icon/index.js 18965 18966 18967 /** 18968 * External dependencies 18969 */ 18970 18971 /** 18972 * WordPress dependencies 18973 */ 18974 18975 18976 18977 18978 18979 function BlockIcon(_ref) { 18980 var _icon; 18981 18982 let { 18983 icon, 18984 showColors = false, 18985 className 18986 } = _ref; 18987 18988 if (((_icon = icon) === null || _icon === void 0 ? void 0 : _icon.src) === 'block-default') { 18989 icon = { 18990 src: block_default 18991 }; 18992 } 18993 18994 const renderedIcon = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Icon, { 18995 icon: icon && icon.src ? icon.src : icon 18996 }); 18997 const style = showColors ? { 18998 backgroundColor: icon && icon.background, 18999 color: icon && icon.foreground 19000 } : {}; 19001 return (0,external_wp_element_namespaceObject.createElement)("span", { 19002 style: style, 19003 className: classnames_default()('block-editor-block-icon', className, { 19004 'has-colors': showColors 19005 }) 19006 }, renderedIcon); 19007 } 19008 /** 19009 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/block-icon/README.md 19010 */ 19011 19012 19013 /* harmony default export */ var block_icon = ((0,external_wp_element_namespaceObject.memo)(BlockIcon)); 19014 19015 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-card/index.js 19016 19017 19018 /** 19019 * WordPress dependencies 19020 */ 19021 19022 /** 19023 * Internal dependencies 19024 */ 19025 19026 19027 19028 function BlockCard(_ref) { 19029 let { 19030 title, 19031 icon, 19032 description, 19033 blockType 19034 } = _ref; 19035 19036 if (blockType) { 19037 external_wp_deprecated_default()('`blockType` property in `BlockCard component`', { 19038 since: '5.7', 19039 alternative: '`title, icon and description` properties' 19040 }); 19041 ({ 19042 title, 19043 icon, 19044 description 19045 } = blockType); 19046 } 19047 19048 return (0,external_wp_element_namespaceObject.createElement)("div", { 19049 className: "block-editor-block-card" 19050 }, (0,external_wp_element_namespaceObject.createElement)(block_icon, { 19051 icon: icon, 19052 showColors: true 19053 }), (0,external_wp_element_namespaceObject.createElement)("div", { 19054 className: "block-editor-block-card__content" 19055 }, (0,external_wp_element_namespaceObject.createElement)("h2", { 19056 className: "block-editor-block-card__title" 19057 }, title), (0,external_wp_element_namespaceObject.createElement)("span", { 19058 className: "block-editor-block-card__description" 19059 }, description))); 19060 } 19061 19062 /* harmony default export */ var block_card = (BlockCard); 19063 19064 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/provider/with-registry-provider.js 19065 19066 19067 19068 /** 19069 * WordPress dependencies 19070 */ 19071 19072 19073 19074 /** 19075 * Internal dependencies 19076 */ 19077 19078 19079 19080 const withRegistryProvider = (0,external_wp_compose_namespaceObject.createHigherOrderComponent)(WrappedComponent => { 19081 return (0,external_wp_data_namespaceObject.withRegistry)(_ref => { 19082 let { 19083 useSubRegistry = true, 19084 registry, 19085 ...props 19086 } = _ref; 19087 19088 if (!useSubRegistry) { 19089 return (0,external_wp_element_namespaceObject.createElement)(WrappedComponent, _extends({ 19090 registry: registry 19091 }, props)); 19092 } 19093 19094 const [subRegistry, setSubRegistry] = (0,external_wp_element_namespaceObject.useState)(null); 19095 (0,external_wp_element_namespaceObject.useEffect)(() => { 19096 const newRegistry = (0,external_wp_data_namespaceObject.createRegistry)({}, registry); 19097 newRegistry.registerStore(STORE_NAME, storeConfig); 19098 setSubRegistry(newRegistry); 19099 }, [registry]); 19100 19101 if (!subRegistry) { 19102 return null; 19103 } 19104 19105 return (0,external_wp_element_namespaceObject.createElement)(external_wp_data_namespaceObject.RegistryProvider, { 19106 value: subRegistry 19107 }, (0,external_wp_element_namespaceObject.createElement)(WrappedComponent, _extends({ 19108 registry: subRegistry 19109 }, props))); 19110 }); 19111 }, 'withRegistryProvider'); 19112 /* harmony default export */ var with_registry_provider = (withRegistryProvider); 19113 19114 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/provider/use-block-sync.js 19115 /** 19116 * External dependencies 19117 */ 19118 19119 /** 19120 * WordPress dependencies 19121 */ 19122 19123 19124 19125 19126 /** 19127 * Internal dependencies 19128 */ 19129 19130 19131 /** 19132 * A function to call when the block value has been updated in the block-editor 19133 * store. 19134 * 19135 * @callback onBlockUpdate 19136 * @param {Object[]} blocks The updated blocks. 19137 * @param {Object} options The updated block options, such as selectionStart 19138 * and selectionEnd. 19139 */ 19140 19141 /** 19142 * useBlockSync is a side effect which handles bidirectional sync between the 19143 * block-editor store and a controlling data source which provides blocks. This 19144 * is most commonly used by the BlockEditorProvider to synchronize the contents 19145 * of the block-editor store with the root entity, like a post. 19146 * 19147 * Another example would be the template part block, which provides blocks from 19148 * a separate entity data source than a root entity. This hook syncs edits to 19149 * the template part in the block editor back to the entity and vice-versa. 19150 * 19151 * Here are some of its basic functions: 19152 * - Initalizes the block-editor store for the given clientID to the blocks 19153 * given via props. 19154 * - Adds incoming changes (like undo) to the block-editor store. 19155 * - Adds outgoing changes (like editing content) to the controlling entity, 19156 * determining if a change should be considered persistent or not. 19157 * - Handles edge cases and race conditions which occur in those operations. 19158 * - Ignores changes which happen to other entities (like nested inner block 19159 * controllers. 19160 * - Passes selection state from the block-editor store to the controlling entity. 19161 * 19162 * @param {Object} props Props for the block sync hook 19163 * @param {string} props.clientId The client ID of the inner block controller. 19164 * If none is passed, then it is assumed to be a 19165 * root controller rather than an inner block 19166 * controller. 19167 * @param {Object[]} props.value The control value for the blocks. This value 19168 * is used to initalize the block-editor store 19169 * and for resetting the blocks to incoming 19170 * changes like undo. 19171 * @param {Object} props.selection The selection state responsible to restore the selection on undo/redo. 19172 * @param {onBlockUpdate} props.onChange Function to call when a persistent 19173 * change has been made in the block-editor blocks 19174 * for the given clientId. For example, after 19175 * this function is called, an entity is marked 19176 * dirty because it has changes to save. 19177 * @param {onBlockUpdate} props.onInput Function to call when a non-persistent 19178 * change has been made in the block-editor blocks 19179 * for the given clientId. When this is called, 19180 * controlling sources do not become dirty. 19181 */ 19182 19183 function useBlockSync(_ref) { 19184 let { 19185 clientId = null, 19186 value: controlledBlocks, 19187 selection: controlledSelection, 19188 onChange = external_lodash_namespaceObject.noop, 19189 onInput = external_lodash_namespaceObject.noop 19190 } = _ref; 19191 const registry = (0,external_wp_data_namespaceObject.useRegistry)(); 19192 const { 19193 resetBlocks, 19194 resetSelection, 19195 replaceInnerBlocks, 19196 setHasControlledInnerBlocks, 19197 __unstableMarkNextChangeAsNotPersistent 19198 } = registry.dispatch(store); 19199 const { 19200 getBlockName, 19201 getBlocks 19202 } = registry.select(store); 19203 const isControlled = (0,external_wp_data_namespaceObject.useSelect)(select => { 19204 return !clientId || select(store).areInnerBlocksControlled(clientId); 19205 }, [clientId]); 19206 const pendingChanges = (0,external_wp_element_namespaceObject.useRef)({ 19207 incoming: null, 19208 outgoing: [] 19209 }); 19210 const subscribed = (0,external_wp_element_namespaceObject.useRef)(false); 19211 19212 const setControlledBlocks = () => { 19213 if (!controlledBlocks) { 19214 return; 19215 } // We don't need to persist this change because we only replace 19216 // controlled inner blocks when the change was caused by an entity, 19217 // and so it would already be persisted. 19218 19219 19220 __unstableMarkNextChangeAsNotPersistent(); 19221 19222 if (clientId) { 19223 // It is important to batch here because otherwise, 19224 // as soon as `setHasControlledInnerBlocks` is called 19225 // the effect to restore might be triggered 19226 // before the actual blocks get set properly in state. 19227 registry.batch(() => { 19228 setHasControlledInnerBlocks(clientId, true); 19229 const storeBlocks = controlledBlocks.map(block => (0,external_wp_blocks_namespaceObject.cloneBlock)(block)); 19230 19231 if (subscribed.current) { 19232 pendingChanges.current.incoming = storeBlocks; 19233 } 19234 19235 __unstableMarkNextChangeAsNotPersistent(); 19236 19237 replaceInnerBlocks(clientId, storeBlocks); 19238 }); 19239 } else { 19240 if (subscribed.current) { 19241 pendingChanges.current.incoming = controlledBlocks; 19242 } 19243 19244 resetBlocks(controlledBlocks); 19245 } 19246 }; // Add a subscription to the block-editor registry to detect when changes 19247 // have been made. This lets us inform the data source of changes. This 19248 // is an effect so that the subscriber can run synchronously without 19249 // waiting for React renders for changes. 19250 19251 19252 const onInputRef = (0,external_wp_element_namespaceObject.useRef)(onInput); 19253 const onChangeRef = (0,external_wp_element_namespaceObject.useRef)(onChange); 19254 (0,external_wp_element_namespaceObject.useEffect)(() => { 19255 onInputRef.current = onInput; 19256 onChangeRef.current = onChange; 19257 }, [onInput, onChange]); // Determine if blocks need to be reset when they change. 19258 19259 (0,external_wp_element_namespaceObject.useEffect)(() => { 19260 if (pendingChanges.current.outgoing.includes(controlledBlocks)) { 19261 // Skip block reset if the value matches expected outbound sync 19262 // triggered by this component by a preceding change detection. 19263 // Only skip if the value matches expectation, since a reset should 19264 // still occur if the value is modified (not equal by reference), 19265 // to allow that the consumer may apply modifications to reflect 19266 // back on the editor. 19267 if ((0,external_lodash_namespaceObject.last)(pendingChanges.current.outgoing) === controlledBlocks) { 19268 pendingChanges.current.outgoing = []; 19269 } 19270 } else if (getBlocks(clientId) !== controlledBlocks) { 19271 // Reset changing value in all other cases than the sync described 19272 // above. Since this can be reached in an update following an out- 19273 // bound sync, unset the outbound value to avoid considering it in 19274 // subsequent renders. 19275 pendingChanges.current.outgoing = []; 19276 setControlledBlocks(); 19277 19278 if (controlledSelection) { 19279 resetSelection(controlledSelection.selectionStart, controlledSelection.selectionEnd, controlledSelection.initialPosition); 19280 } 19281 } 19282 }, [controlledBlocks, clientId]); 19283 (0,external_wp_element_namespaceObject.useEffect)(() => { 19284 // When the block becomes uncontrolled, it means its inner state has been reset 19285 // we need to take the blocks again from the external value property. 19286 if (!isControlled) { 19287 pendingChanges.current.outgoing = []; 19288 setControlledBlocks(); 19289 } 19290 }, [isControlled]); 19291 (0,external_wp_element_namespaceObject.useEffect)(() => { 19292 const { 19293 getSelectionStart, 19294 getSelectionEnd, 19295 getSelectedBlocksInitialCaretPosition, 19296 isLastBlockChangePersistent, 19297 __unstableIsLastBlockChangeIgnored, 19298 areInnerBlocksControlled 19299 } = registry.select(store); 19300 let blocks = getBlocks(clientId); 19301 let isPersistent = isLastBlockChangePersistent(); 19302 let previousAreBlocksDifferent = false; 19303 subscribed.current = true; 19304 const unsubscribe = registry.subscribe(() => { 19305 // Sometimes, when changing block lists, lingering subscriptions 19306 // might trigger before they are cleaned up. If the block for which 19307 // the subscription runs is no longer in the store, this would clear 19308 // its parent entity's block list. To avoid this, we bail out if 19309 // the subscription is triggering for a block (`clientId !== null`) 19310 // and its block name can't be found because it's not on the list. 19311 // (`getBlockName( clientId ) === null`). 19312 if (clientId !== null && getBlockName(clientId) === null) return; // When RESET_BLOCKS on parent blocks get called, the controlled blocks 19313 // can reset to uncontrolled, in these situations, it means we need to populate 19314 // the blocks again from the external blocks (the value property here) 19315 // and we should stop triggering onChange 19316 19317 const isStillControlled = !clientId || areInnerBlocksControlled(clientId); 19318 19319 if (!isStillControlled) { 19320 return; 19321 } 19322 19323 const newIsPersistent = isLastBlockChangePersistent(); 19324 const newBlocks = getBlocks(clientId); 19325 const areBlocksDifferent = newBlocks !== blocks; 19326 blocks = newBlocks; 19327 19328 if (areBlocksDifferent && (pendingChanges.current.incoming || __unstableIsLastBlockChangeIgnored())) { 19329 pendingChanges.current.incoming = null; 19330 isPersistent = newIsPersistent; 19331 return; 19332 } // Since we often dispatch an action to mark the previous action as 19333 // persistent, we need to make sure that the blocks changed on the 19334 // previous action before committing the change. 19335 19336 19337 const didPersistenceChange = previousAreBlocksDifferent && !areBlocksDifferent && newIsPersistent && !isPersistent; 19338 19339 if (areBlocksDifferent || didPersistenceChange) { 19340 isPersistent = newIsPersistent; // We know that onChange/onInput will update controlledBlocks. 19341 // We need to be aware that it was caused by an outgoing change 19342 // so that we do not treat it as an incoming change later on, 19343 // which would cause a block reset. 19344 19345 pendingChanges.current.outgoing.push(blocks); // Inform the controlling entity that changes have been made to 19346 // the block-editor store they should be aware about. 19347 19348 const updateParent = isPersistent ? onChangeRef.current : onInputRef.current; 19349 updateParent(blocks, { 19350 selection: { 19351 selectionStart: getSelectionStart(), 19352 selectionEnd: getSelectionEnd(), 19353 initialPosition: getSelectedBlocksInitialCaretPosition() 19354 } 19355 }); 19356 } 19357 19358 previousAreBlocksDifferent = areBlocksDifferent; 19359 }); 19360 return () => unsubscribe(); 19361 }, [registry, clientId]); 19362 } 19363 19364 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/provider/index.js 19365 19366 19367 /** 19368 * WordPress dependencies 19369 */ 19370 19371 19372 /** 19373 * Internal dependencies 19374 */ 19375 19376 19377 19378 19379 19380 /** @typedef {import('@wordpress/data').WPDataRegistry} WPDataRegistry */ 19381 19382 function BlockEditorProvider(props) { 19383 const { 19384 children, 19385 settings 19386 } = props; 19387 const { 19388 updateSettings 19389 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 19390 (0,external_wp_element_namespaceObject.useEffect)(() => { 19391 updateSettings(settings); 19392 }, [settings]); // Syncs the entity provider with changes in the block-editor store. 19393 19394 useBlockSync(props); 19395 return (0,external_wp_element_namespaceObject.createElement)(BlockRefsProvider, null, children); 19396 } 19397 19398 /* harmony default export */ var provider = (with_registry_provider(BlockEditorProvider)); 19399 19400 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-preview/live.js 19401 19402 19403 /** 19404 * WordPress dependencies 19405 */ 19406 19407 /** 19408 * Internal dependencies 19409 */ 19410 19411 19412 function LiveBlockPreview(_ref) { 19413 let { 19414 onClick 19415 } = _ref; 19416 return (0,external_wp_element_namespaceObject.createElement)("div", { 19417 tabIndex: 0, 19418 role: "button", 19419 onClick: onClick, 19420 onKeyPress: onClick 19421 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Disabled, null, (0,external_wp_element_namespaceObject.createElement)(BlockList, null))); 19422 } 19423 19424 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-selection-clearer/index.js 19425 19426 19427 19428 /** 19429 * WordPress dependencies 19430 */ 19431 19432 19433 /** 19434 * Internal dependencies 19435 */ 19436 19437 19438 /** 19439 * Pass the returned ref callback to an element that should clear block 19440 * selection. Selection will only be cleared if the element is clicked directly, 19441 * not if a child element is clicked. 19442 * 19443 * @return {import('react').RefCallback} Ref callback. 19444 */ 19445 19446 function useBlockSelectionClearer() { 19447 const { 19448 hasSelectedBlock, 19449 hasMultiSelection 19450 } = (0,external_wp_data_namespaceObject.useSelect)(store); 19451 const { 19452 clearSelectedBlock 19453 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 19454 return (0,external_wp_compose_namespaceObject.useRefEffect)(node => { 19455 function onMouseDown(event) { 19456 if (!hasSelectedBlock() && !hasMultiSelection()) { 19457 return; 19458 } // Only handle clicks on the element, not the children. 19459 19460 19461 if (event.target !== node) { 19462 return; 19463 } 19464 19465 clearSelectedBlock(); 19466 } 19467 19468 node.addEventListener('mousedown', onMouseDown); 19469 return () => { 19470 node.removeEventListener('mousedown', onMouseDown); 19471 }; 19472 }, [hasSelectedBlock, hasMultiSelection, clearSelectedBlock]); 19473 } 19474 function BlockSelectionClearer(props) { 19475 return (0,external_wp_element_namespaceObject.createElement)("div", _extends({ 19476 ref: useBlockSelectionClearer() 19477 }, props)); 19478 } 19479 19480 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/writing-flow/use-multi-selection.js 19481 /** 19482 * External dependencies 19483 */ 19484 19485 /** 19486 * WordPress dependencies 19487 */ 19488 19489 19490 19491 /** 19492 * Internal dependencies 19493 */ 19494 19495 19496 19497 19498 function selector(select) { 19499 const { 19500 isMultiSelecting, 19501 getMultiSelectedBlockClientIds, 19502 hasMultiSelection, 19503 getSelectedBlockClientId, 19504 getSelectedBlocksInitialCaretPosition, 19505 __unstableIsFullySelected 19506 } = select(store); 19507 return { 19508 isMultiSelecting: isMultiSelecting(), 19509 multiSelectedBlockClientIds: getMultiSelectedBlockClientIds(), 19510 hasMultiSelection: hasMultiSelection(), 19511 selectedBlockClientId: getSelectedBlockClientId(), 19512 initialPosition: getSelectedBlocksInitialCaretPosition(), 19513 isFullSelection: __unstableIsFullySelected() 19514 }; 19515 } 19516 19517 function useMultiSelection() { 19518 const { 19519 initialPosition, 19520 isMultiSelecting, 19521 multiSelectedBlockClientIds, 19522 hasMultiSelection, 19523 selectedBlockClientId, 19524 isFullSelection 19525 } = (0,external_wp_data_namespaceObject.useSelect)(selector, []); 19526 const selectedRef = useBlockRef(selectedBlockClientId); // These must be in the right DOM order. 19527 19528 const startRef = useBlockRef((0,external_lodash_namespaceObject.first)(multiSelectedBlockClientIds)); 19529 const endRef = useBlockRef((0,external_lodash_namespaceObject.last)(multiSelectedBlockClientIds)); 19530 /** 19531 * When the component updates, and there is multi selection, we need to 19532 * select the entire block contents. 19533 */ 19534 19535 return (0,external_wp_compose_namespaceObject.useRefEffect)(node => { 19536 const { 19537 ownerDocument 19538 } = node; 19539 const { 19540 defaultView 19541 } = ownerDocument; // Allow initialPosition to bypass focus behavior. This is useful 19542 // for the list view or other areas where we don't want to transfer 19543 // focus to the editor canvas. 19544 19545 if (initialPosition === undefined || initialPosition === null) { 19546 return; 19547 } 19548 19549 if (!hasMultiSelection || isMultiSelecting) { 19550 if (!selectedBlockClientId || isMultiSelecting) { 19551 return; 19552 } 19553 19554 const selection = defaultView.getSelection(); 19555 19556 if (selection.rangeCount && !selection.isCollapsed) { 19557 const blockNode = selectedRef.current; 19558 const { 19559 startContainer, 19560 endContainer 19561 } = selection.getRangeAt(0); 19562 19563 if (!!blockNode && (!blockNode.contains(startContainer) || !blockNode.contains(endContainer))) { 19564 selection.removeAllRanges(); 19565 } 19566 } 19567 19568 return; 19569 } 19570 19571 const { 19572 length 19573 } = multiSelectedBlockClientIds; 19574 19575 if (length < 2) { 19576 return; 19577 } 19578 19579 if (!isFullSelection) { 19580 return; 19581 } // Allow cross contentEditable selection by temporarily making 19582 // all content editable. We can't rely on using the store and 19583 // React because re-rending happens too slowly. We need to be 19584 // able to select across instances immediately. 19585 19586 19587 node.contentEditable = true; // For some browsers, like Safari, it is important that focus happens 19588 // BEFORE selection. 19589 19590 node.focus(); // The block refs might not be immediately available 19591 // when dragging blocks into another block. 19592 19593 if (!startRef.current || !endRef.current) { 19594 return; 19595 } 19596 19597 const selection = defaultView.getSelection(); 19598 const range = ownerDocument.createRange(); // These must be in the right DOM order. 19599 19600 range.setStartBefore(startRef.current); 19601 range.setEndAfter(endRef.current); 19602 selection.removeAllRanges(); 19603 selection.addRange(range); 19604 }, [hasMultiSelection, isMultiSelecting, multiSelectedBlockClientIds, selectedBlockClientId, initialPosition, isFullSelection]); 19605 } 19606 19607 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/writing-flow/use-tab-nav.js 19608 19609 19610 /** 19611 * WordPress dependencies 19612 */ 19613 19614 19615 19616 19617 19618 /** 19619 * Internal dependencies 19620 */ 19621 19622 19623 function useTabNav() { 19624 const container = (0,external_wp_element_namespaceObject.useRef)(); 19625 const focusCaptureBeforeRef = (0,external_wp_element_namespaceObject.useRef)(); 19626 const focusCaptureAfterRef = (0,external_wp_element_namespaceObject.useRef)(); 19627 const lastFocus = (0,external_wp_element_namespaceObject.useRef)(); 19628 const { 19629 hasMultiSelection, 19630 getSelectedBlockClientId, 19631 getBlockCount 19632 } = (0,external_wp_data_namespaceObject.useSelect)(store); 19633 const { 19634 setNavigationMode 19635 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 19636 const isNavigationMode = (0,external_wp_data_namespaceObject.useSelect)(select => select(store).isNavigationMode(), []); // Don't allow tabbing to this element in Navigation mode. 19637 19638 const focusCaptureTabIndex = !isNavigationMode ? '0' : undefined; // Reference that holds the a flag for enabling or disabling 19639 // capturing on the focus capture elements. 19640 19641 const noCapture = (0,external_wp_element_namespaceObject.useRef)(); 19642 19643 function onFocusCapture(event) { 19644 // Do not capture incoming focus if set by us in WritingFlow. 19645 if (noCapture.current) { 19646 noCapture.current = null; 19647 } else if (hasMultiSelection()) { 19648 container.current.focus(); 19649 } else if (getSelectedBlockClientId()) { 19650 lastFocus.current.focus(); 19651 } else { 19652 setNavigationMode(true); 19653 const isBefore = // eslint-disable-next-line no-bitwise 19654 event.target.compareDocumentPosition(container.current) & event.target.DOCUMENT_POSITION_FOLLOWING; 19655 const action = isBefore ? 'findNext' : 'findPrevious'; 19656 external_wp_dom_namespaceObject.focus.tabbable[action](event.target).focus(); 19657 } 19658 } 19659 19660 const before = (0,external_wp_element_namespaceObject.createElement)("div", { 19661 ref: focusCaptureBeforeRef, 19662 tabIndex: focusCaptureTabIndex, 19663 onFocus: onFocusCapture 19664 }); 19665 const after = (0,external_wp_element_namespaceObject.createElement)("div", { 19666 ref: focusCaptureAfterRef, 19667 tabIndex: focusCaptureTabIndex, 19668 onFocus: onFocusCapture 19669 }); 19670 const ref = (0,external_wp_compose_namespaceObject.useRefEffect)(node => { 19671 function onKeyDown(event) { 19672 if (event.defaultPrevented) { 19673 return; 19674 } 19675 19676 if (event.keyCode === external_wp_keycodes_namespaceObject.ESCAPE && !hasMultiSelection()) { 19677 event.preventDefault(); 19678 setNavigationMode(true); 19679 return; 19680 } // In Edit mode, Tab should focus the first tabbable element after 19681 // the content, which is normally the sidebar (with block controls) 19682 // and Shift+Tab should focus the first tabbable element before the 19683 // content, which is normally the block toolbar. 19684 // Arrow keys can be used, and Tab and arrow keys can be used in 19685 // Navigation mode (press Esc), to navigate through blocks. 19686 19687 19688 if (event.keyCode !== external_wp_keycodes_namespaceObject.TAB) { 19689 return; 19690 } 19691 19692 const isShift = event.shiftKey; 19693 const direction = isShift ? 'findPrevious' : 'findNext'; 19694 19695 if (!hasMultiSelection() && !getSelectedBlockClientId()) { 19696 // Preserve the behaviour of entering navigation mode when 19697 // tabbing into the content without a block selection. 19698 // `onFocusCapture` already did this previously, but we need to 19699 // do it again here because after clearing block selection, 19700 // focus land on the writing flow container and pressing Tab 19701 // will no longer send focus through the focus capture element. 19702 if (event.target === node) setNavigationMode(true); 19703 return; 19704 } // Allow tabbing from the block wrapper to a form element, 19705 // and between form elements rendered in a block, 19706 // such as inside a placeholder. Form elements are generally 19707 // meant to be UI rather than part of the content. Ideally 19708 // these are not rendered in the content and perhaps in the 19709 // future they can be rendered in an iframe or shadow DOM. 19710 19711 19712 if (((0,external_wp_dom_namespaceObject.isFormElement)(event.target) || event.target.getAttribute('data-block') === getSelectedBlockClientId()) && (0,external_wp_dom_namespaceObject.isFormElement)(external_wp_dom_namespaceObject.focus.tabbable[direction](event.target))) { 19713 return; 19714 } 19715 19716 const next = isShift ? focusCaptureBeforeRef : focusCaptureAfterRef; // Disable focus capturing on the focus capture element, so it 19717 // doesn't refocus this block and so it allows default behaviour 19718 // (moving focus to the next tabbable element). 19719 19720 noCapture.current = true; // Focusing the focus capture element, which is located above and 19721 // below the editor, should not scroll the page all the way up or 19722 // down. 19723 19724 next.current.focus({ 19725 preventScroll: true 19726 }); 19727 } 19728 19729 function onFocusOut(event) { 19730 lastFocus.current = event.target; 19731 const { 19732 ownerDocument 19733 } = node; // If focus disappears due to there being no blocks, move focus to 19734 // the writing flow wrapper. 19735 19736 if (!event.relatedTarget && ownerDocument.activeElement === ownerDocument.body && getBlockCount() === 0) { 19737 node.focus(); 19738 } 19739 } // When tabbing back to an element in block list, this event handler prevents scrolling if the 19740 // focus capture divs (before/after) are outside of the viewport. (For example shift+tab back to a paragraph 19741 // when focus is on a sidebar element. This prevents the scrollable writing area from jumping either to the 19742 // top or bottom of the document. 19743 // 19744 // Note that it isn't possible to disable scrolling in the onFocus event. We need to intercept this 19745 // earlier in the keypress handler, and call focus( { preventScroll: true } ) instead. 19746 // https://developer.mozilla.org/en-US/docs/Web/API/HTMLOrForeignElement/focus#parameters 19747 19748 19749 function preventScrollOnTab(event) { 19750 var _event$target; 19751 19752 if (event.keyCode !== external_wp_keycodes_namespaceObject.TAB) { 19753 return; 19754 } 19755 19756 if (((_event$target = event.target) === null || _event$target === void 0 ? void 0 : _event$target.getAttribute('role')) === 'region') { 19757 return; 19758 } 19759 19760 if (container.current === event.target) { 19761 return; 19762 } 19763 19764 const isShift = event.shiftKey; 19765 const direction = isShift ? 'findPrevious' : 'findNext'; 19766 const target = external_wp_dom_namespaceObject.focus.tabbable[direction](event.target); // Only do something when the next tabbable is a focus capture div (before/after) 19767 19768 if (target === focusCaptureBeforeRef.current || target === focusCaptureAfterRef.current) { 19769 event.preventDefault(); 19770 target.focus({ 19771 preventScroll: true 19772 }); 19773 } 19774 } 19775 19776 const { 19777 ownerDocument 19778 } = node; 19779 const { 19780 defaultView 19781 } = ownerDocument; 19782 defaultView.addEventListener('keydown', preventScrollOnTab); 19783 node.addEventListener('keydown', onKeyDown); 19784 node.addEventListener('focusout', onFocusOut); 19785 return () => { 19786 defaultView.removeEventListener('keydown', preventScrollOnTab); 19787 node.removeEventListener('keydown', onKeyDown); 19788 node.removeEventListener('focusout', onFocusOut); 19789 }; 19790 }, []); 19791 const mergedRefs = (0,external_wp_compose_namespaceObject.useMergeRefs)([container, ref]); 19792 return [before, mergedRefs, after]; 19793 } 19794 19795 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/writing-flow/use-arrow-nav.js 19796 /** 19797 * External dependencies 19798 */ 19799 19800 /** 19801 * WordPress dependencies 19802 */ 19803 19804 19805 19806 19807 19808 /** 19809 * Internal dependencies 19810 */ 19811 19812 19813 19814 /** 19815 * Returns true if the element should consider edge navigation upon a keyboard 19816 * event of the given directional key code, or false otherwise. 19817 * 19818 * @param {Element} element HTML element to test. 19819 * @param {number} keyCode KeyboardEvent keyCode to test. 19820 * @param {boolean} hasModifier Whether a modifier is pressed. 19821 * 19822 * @return {boolean} Whether element should consider edge navigation. 19823 */ 19824 19825 function isNavigationCandidate(element, keyCode, hasModifier) { 19826 const isVertical = keyCode === external_wp_keycodes_namespaceObject.UP || keyCode === external_wp_keycodes_namespaceObject.DOWN; // Currently, all elements support unmodified vertical navigation. 19827 19828 if (isVertical && !hasModifier) { 19829 return true; 19830 } // Native inputs should not navigate horizontally. 19831 19832 19833 const { 19834 tagName 19835 } = element; 19836 return tagName !== 'INPUT' && tagName !== 'TEXTAREA'; 19837 } 19838 /** 19839 * Returns the optimal tab target from the given focused element in the desired 19840 * direction. A preference is made toward text fields, falling back to the block 19841 * focus stop if no other candidates exist for the block. 19842 * 19843 * @param {Element} target Currently focused text field. 19844 * @param {boolean} isReverse True if considering as the first field. 19845 * @param {Element} containerElement Element containing all blocks. 19846 * @param {boolean} onlyVertical Whether to only consider tabbable elements 19847 * that are visually above or under the 19848 * target. 19849 * 19850 * @return {?Element} Optimal tab target, if one exists. 19851 */ 19852 19853 function getClosestTabbable(target, isReverse, containerElement, onlyVertical) { 19854 // Since the current focus target is not guaranteed to be a text field, find 19855 // all focusables. Tabbability is considered later. 19856 let focusableNodes = external_wp_dom_namespaceObject.focus.focusable.find(containerElement); 19857 19858 if (isReverse) { 19859 focusableNodes = (0,external_lodash_namespaceObject.reverse)(focusableNodes); 19860 } // Consider as candidates those focusables after the current target. It's 19861 // assumed this can only be reached if the target is focusable (on its 19862 // keydown event), so no need to verify it exists in the set. 19863 19864 19865 focusableNodes = focusableNodes.slice(focusableNodes.indexOf(target) + 1); 19866 let targetRect; 19867 19868 if (onlyVertical) { 19869 targetRect = target.getBoundingClientRect(); 19870 } 19871 19872 function isTabCandidate(node) { 19873 // Not a candidate if the node is not tabbable. 19874 if (!external_wp_dom_namespaceObject.focus.tabbable.isTabbableIndex(node)) { 19875 return false; 19876 } // Skip focusable elements such as links within content editable nodes. 19877 19878 19879 if (node.isContentEditable && node.contentEditable !== 'true') { 19880 return false; 19881 } 19882 19883 if (onlyVertical) { 19884 const nodeRect = node.getBoundingClientRect(); 19885 19886 if (nodeRect.left >= targetRect.right || nodeRect.right <= targetRect.left) { 19887 return false; 19888 } 19889 } 19890 19891 return true; 19892 } 19893 19894 return (0,external_lodash_namespaceObject.find)(focusableNodes, isTabCandidate); 19895 } 19896 function useArrowNav() { 19897 const { 19898 getSelectedBlockClientId, 19899 getMultiSelectedBlocksEndClientId, 19900 getPreviousBlockClientId, 19901 getNextBlockClientId, 19902 getSettings, 19903 hasMultiSelection 19904 } = (0,external_wp_data_namespaceObject.useSelect)(store); 19905 return (0,external_wp_compose_namespaceObject.useRefEffect)(node => { 19906 // Here a DOMRect is stored while moving the caret vertically so 19907 // vertical position of the start position can be restored. This is to 19908 // recreate browser behaviour across blocks. 19909 let verticalRect; 19910 19911 function onMouseDown() { 19912 verticalRect = null; 19913 } 19914 /** 19915 * Returns true if the given target field is the last in its block which 19916 * can be considered for tab transition. For example, in a block with 19917 * two text fields, this would return true when reversing from the first 19918 * of the two fields, but false when reversing from the second. 19919 * 19920 * @param {Element} target Currently focused text field. 19921 * @param {boolean} isReverse True if considering as the first field. 19922 * 19923 * @return {boolean} Whether field is at edge for tab transition. 19924 */ 19925 19926 19927 function isTabbableEdge(target, isReverse) { 19928 const closestTabbable = getClosestTabbable(target, isReverse, node); 19929 return !closestTabbable || !isInSameBlock(target, closestTabbable); 19930 } 19931 19932 function onKeyDown(event) { 19933 const { 19934 keyCode, 19935 target 19936 } = event; 19937 const isUp = keyCode === external_wp_keycodes_namespaceObject.UP; 19938 const isDown = keyCode === external_wp_keycodes_namespaceObject.DOWN; 19939 const isLeft = keyCode === external_wp_keycodes_namespaceObject.LEFT; 19940 const isRight = keyCode === external_wp_keycodes_namespaceObject.RIGHT; 19941 const isReverse = isUp || isLeft; 19942 const isHorizontal = isLeft || isRight; 19943 const isVertical = isUp || isDown; 19944 const isNav = isHorizontal || isVertical; 19945 const isShift = event.shiftKey; 19946 const hasModifier = isShift || event.ctrlKey || event.altKey || event.metaKey; 19947 const isNavEdge = isVertical ? external_wp_dom_namespaceObject.isVerticalEdge : external_wp_dom_namespaceObject.isHorizontalEdge; 19948 const { 19949 ownerDocument 19950 } = node; 19951 const { 19952 defaultView 19953 } = ownerDocument; 19954 19955 if (hasMultiSelection()) { 19956 return; 19957 } // When presing any key other than up or down, the initial vertical 19958 // position must ALWAYS be reset. The vertical position is saved so 19959 // it can be restored as well as possible on sebsequent vertical 19960 // arrow key presses. It may not always be possible to restore the 19961 // exact same position (such as at an empty line), so it wouldn't be 19962 // good to compute the position right before any vertical arrow key 19963 // press. 19964 19965 19966 if (!isVertical) { 19967 verticalRect = null; 19968 } else if (!verticalRect) { 19969 verticalRect = (0,external_wp_dom_namespaceObject.computeCaretRect)(defaultView); 19970 } // Abort if navigation has already been handled (e.g. RichText 19971 // inline boundaries). 19972 19973 19974 if (event.defaultPrevented) { 19975 return; 19976 } 19977 19978 if (!isNav) { 19979 return; 19980 } // Abort if our current target is not a candidate for navigation 19981 // (e.g. preserve native input behaviors). 19982 19983 19984 if (!isNavigationCandidate(target, keyCode, hasModifier)) { 19985 return; 19986 } // In the case of RTL scripts, right means previous and left means 19987 // next, which is the exact reverse of LTR. 19988 19989 19990 const isReverseDir = (0,external_wp_dom_namespaceObject.isRTL)(target) ? !isReverse : isReverse; 19991 const { 19992 keepCaretInsideBlock 19993 } = getSettings(); 19994 const selectedBlockClientId = getSelectedBlockClientId(); 19995 19996 if (isShift) { 19997 const selectionEndClientId = getMultiSelectedBlocksEndClientId(); 19998 const selectionBeforeEndClientId = getPreviousBlockClientId(selectionEndClientId || selectedBlockClientId); 19999 const selectionAfterEndClientId = getNextBlockClientId(selectionEndClientId || selectedBlockClientId); 20000 20001 if ( // Ensure that there is a target block. 20002 (isReverse && selectionBeforeEndClientId || !isReverse && selectionAfterEndClientId) && isTabbableEdge(target, isReverse) && isNavEdge(target, isReverse)) { 20003 node.contentEditable = true; // Firefox doesn't automatically move focus. 20004 20005 node.focus(); 20006 } 20007 } else if (isVertical && (0,external_wp_dom_namespaceObject.isVerticalEdge)(target, isReverse) && !keepCaretInsideBlock) { 20008 const closestTabbable = getClosestTabbable(target, isReverse, node, true); 20009 20010 if (closestTabbable) { 20011 (0,external_wp_dom_namespaceObject.placeCaretAtVerticalEdge)(closestTabbable, isReverse, verticalRect); 20012 event.preventDefault(); 20013 } 20014 } else if (isHorizontal && defaultView.getSelection().isCollapsed && (0,external_wp_dom_namespaceObject.isHorizontalEdge)(target, isReverseDir) && !keepCaretInsideBlock) { 20015 const closestTabbable = getClosestTabbable(target, isReverseDir, node); 20016 (0,external_wp_dom_namespaceObject.placeCaretAtHorizontalEdge)(closestTabbable, isReverse); 20017 event.preventDefault(); 20018 } 20019 } 20020 20021 node.addEventListener('mousedown', onMouseDown); 20022 node.addEventListener('keydown', onKeyDown); 20023 return () => { 20024 node.removeEventListener('mousedown', onMouseDown); 20025 node.removeEventListener('keydown', onKeyDown); 20026 }; 20027 }, []); 20028 } 20029 20030 ;// CONCATENATED MODULE: external ["wp","keyboardShortcuts"] 20031 var external_wp_keyboardShortcuts_namespaceObject = window["wp"]["keyboardShortcuts"]; 20032 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/writing-flow/use-select-all.js 20033 /** 20034 * External dependencies 20035 */ 20036 20037 /** 20038 * WordPress dependencies 20039 */ 20040 20041 20042 20043 20044 20045 /** 20046 * Internal dependencies 20047 */ 20048 20049 20050 function useSelectAll() { 20051 const { 20052 getBlockOrder, 20053 getSelectedBlockClientIds, 20054 getBlockRootClientId 20055 } = (0,external_wp_data_namespaceObject.useSelect)(store); 20056 const { 20057 multiSelect 20058 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 20059 const isMatch = (0,external_wp_keyboardShortcuts_namespaceObject.__unstableUseShortcutEventMatch)(); 20060 return (0,external_wp_compose_namespaceObject.useRefEffect)(node => { 20061 function onKeyDown(event) { 20062 if (!isMatch('core/block-editor/select-all', event)) { 20063 return; 20064 } 20065 20066 const selectedClientIds = getSelectedBlockClientIds(); 20067 20068 if (selectedClientIds.length < 2 && !(0,external_wp_dom_namespaceObject.isEntirelySelected)(event.target)) { 20069 return; 20070 } 20071 20072 const [firstSelectedClientId] = selectedClientIds; 20073 const rootClientId = getBlockRootClientId(firstSelectedClientId); 20074 let blockClientIds = getBlockOrder(rootClientId); // If we have selected all sibling nested blocks, try selecting up a 20075 // level. See: https://github.com/WordPress/gutenberg/pull/31859/ 20076 20077 if (selectedClientIds.length === blockClientIds.length) { 20078 blockClientIds = getBlockOrder(getBlockRootClientId(rootClientId)); 20079 } 20080 20081 const firstClientId = (0,external_lodash_namespaceObject.first)(blockClientIds); 20082 const lastClientId = (0,external_lodash_namespaceObject.last)(blockClientIds); 20083 20084 if (firstClientId === lastClientId) { 20085 return; 20086 } 20087 20088 multiSelect(firstClientId, lastClientId); 20089 event.preventDefault(); 20090 } 20091 20092 node.addEventListener('keydown', onKeyDown); 20093 return () => { 20094 node.removeEventListener('keydown', onKeyDown); 20095 }; 20096 }, []); 20097 } 20098 20099 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/writing-flow/use-drag-selection.js 20100 /** 20101 * WordPress dependencies 20102 */ 20103 20104 20105 /** 20106 * Internal dependencies 20107 */ 20108 20109 20110 /** 20111 * Sets the `contenteditable` wrapper element to `value`. 20112 * 20113 * @param {HTMLElement} node Block element. 20114 * @param {boolean} value `contentEditable` value (true or false) 20115 */ 20116 20117 function setContentEditableWrapper(node, value) { 20118 node.contentEditable = value; // Firefox doesn't automatically move focus. 20119 20120 if (value) node.focus(); 20121 } 20122 /** 20123 * Sets a multi-selection based on the native selection across blocks. 20124 */ 20125 20126 20127 function useDragSelection() { 20128 const { 20129 startMultiSelect, 20130 stopMultiSelect 20131 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 20132 const { 20133 isSelectionEnabled, 20134 hasMultiSelection 20135 } = (0,external_wp_data_namespaceObject.useSelect)(store); 20136 return (0,external_wp_compose_namespaceObject.useRefEffect)(node => { 20137 const { 20138 ownerDocument 20139 } = node; 20140 const { 20141 defaultView 20142 } = ownerDocument; 20143 let anchorElement; 20144 let rafId; 20145 20146 function onMouseUp() { 20147 stopMultiSelect(); // Equivalent to attaching the listener once. 20148 20149 defaultView.removeEventListener('mouseup', onMouseUp); // The browser selection won't have updated yet at this point, 20150 // so wait until the next animation frame to get the browser 20151 // selection. 20152 20153 rafId = defaultView.requestAnimationFrame(() => { 20154 if (hasMultiSelection()) { 20155 return; 20156 } // If the selection is complete (on mouse up), and no 20157 // multiple blocks have been selected, set focus back to the 20158 // anchor element. if the anchor element contains the 20159 // selection. Additionally, the contentEditable wrapper can 20160 // now be disabled again. 20161 20162 20163 setContentEditableWrapper(node, false); 20164 const selection = defaultView.getSelection(); 20165 20166 if (selection.rangeCount) { 20167 const { 20168 commonAncestorContainer 20169 } = selection.getRangeAt(0); 20170 20171 if (anchorElement.contains(commonAncestorContainer)) { 20172 anchorElement.focus(); 20173 } 20174 } 20175 }); 20176 } 20177 20178 function onMouseLeave(_ref) { 20179 let { 20180 buttons, 20181 target 20182 } = _ref; 20183 20184 // The primary button must be pressed to initiate selection. 20185 // See https://developer.mozilla.org/en-US/docs/Web/API/MouseEvent/buttons 20186 if (buttons !== 1) { 20187 return; 20188 } // Check the attribute, not the contentEditable attribute. All 20189 // child elements of the content editable wrapper are editable 20190 // and return true for this property. We only want to start 20191 // multi selecting when the mouse leaves the wrapper. 20192 20193 20194 if (!target.getAttribute('contenteditable')) { 20195 return; 20196 } 20197 20198 if (!isSelectionEnabled()) { 20199 return; 20200 } 20201 20202 anchorElement = ownerDocument.activeElement; 20203 startMultiSelect(); // `onSelectionStart` is called after `mousedown` and 20204 // `mouseleave` (from a block). The selection ends when 20205 // `mouseup` happens anywhere in the window. 20206 20207 defaultView.addEventListener('mouseup', onMouseUp); // Allow cross contentEditable selection by temporarily making 20208 // all content editable. We can't rely on using the store and 20209 // React because re-rending happens too slowly. We need to be 20210 // able to select across instances immediately. 20211 20212 setContentEditableWrapper(node, true); 20213 } 20214 20215 node.addEventListener('mouseout', onMouseLeave); 20216 return () => { 20217 node.removeEventListener('mouseout', onMouseLeave); 20218 defaultView.removeEventListener('mouseup', onMouseUp); 20219 defaultView.cancelAnimationFrame(rafId); 20220 }; 20221 }, [startMultiSelect, stopMultiSelect, isSelectionEnabled, hasMultiSelection]); 20222 } 20223 20224 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/writing-flow/use-selection-observer.js 20225 /** 20226 * WordPress dependencies 20227 */ 20228 20229 20230 /** 20231 * Internal dependencies 20232 */ 20233 20234 20235 20236 /** 20237 * Extract the selection start node from the selection. When the anchor node is 20238 * not a text node, the selection offset is the index of a child node. 20239 * 20240 * @param {Selection} selection The selection. 20241 * 20242 * @return {Element} The selection start node. 20243 */ 20244 20245 function extractSelectionStartNode(selection) { 20246 const { 20247 anchorNode, 20248 anchorOffset 20249 } = selection; 20250 20251 if (anchorNode.nodeType === anchorNode.TEXT_NODE) { 20252 return anchorNode; 20253 } 20254 20255 return anchorNode.childNodes[anchorOffset]; 20256 } 20257 /** 20258 * Extract the selection end node from the selection. When the focus node is not 20259 * a text node, the selection offset is the index of a child node. The selection 20260 * reaches up to but excluding that child node. 20261 * 20262 * @param {Selection} selection The selection. 20263 * 20264 * @return {Element} The selection start node. 20265 */ 20266 20267 20268 function extractSelectionEndNode(selection) { 20269 const { 20270 focusNode, 20271 focusOffset 20272 } = selection; 20273 20274 if (focusNode.nodeType === focusNode.TEXT_NODE) { 20275 return focusNode; 20276 } 20277 20278 return focusNode.childNodes[focusOffset - 1]; 20279 } 20280 20281 function findDepth(a, b) { 20282 let depth = 0; 20283 20284 while (a[depth] === b[depth]) { 20285 depth++; 20286 } 20287 20288 return depth; 20289 } 20290 /** 20291 * Sets the `contenteditable` wrapper element to `value`. 20292 * 20293 * @param {HTMLElement} node Block element. 20294 * @param {boolean} value `contentEditable` value (true or false) 20295 */ 20296 20297 20298 function use_selection_observer_setContentEditableWrapper(node, value) { 20299 node.contentEditable = value; // Firefox doesn't automatically move focus. 20300 20301 if (value) node.focus(); 20302 } 20303 /** 20304 * Sets a multi-selection based on the native selection across blocks. 20305 */ 20306 20307 20308 function useSelectionObserver() { 20309 const { 20310 multiSelect, 20311 selectBlock, 20312 selectionChange 20313 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 20314 const { 20315 getBlockParents, 20316 getBlockSelectionStart 20317 } = (0,external_wp_data_namespaceObject.useSelect)(store); 20318 return (0,external_wp_compose_namespaceObject.useRefEffect)(node => { 20319 const { 20320 ownerDocument 20321 } = node; 20322 const { 20323 defaultView 20324 } = ownerDocument; 20325 20326 function onSelectionChange(event) { 20327 const selection = defaultView.getSelection(); // If no selection is found, end multi selection and disable the 20328 // contentEditable wrapper. 20329 20330 if (!selection.rangeCount) { 20331 use_selection_observer_setContentEditableWrapper(node, false); 20332 return; 20333 } // If selection is collapsed and we haven't used `shift+click`, 20334 // end multi selection and disable the contentEditable wrapper. 20335 // We have to check about `shift+click` case because elements 20336 // that don't support text selection might be involved, and we might 20337 // update the clientIds to multi-select blocks. 20338 // For now we check if the event is a `mouse` event. 20339 20340 20341 const isClickShift = event.shiftKey && event.type === 'mouseup'; 20342 20343 if (selection.isCollapsed && !isClickShift) { 20344 use_selection_observer_setContentEditableWrapper(node, false); 20345 return; 20346 } 20347 20348 let startClientId = getBlockClientId(extractSelectionStartNode(selection)); 20349 let endClientId = getBlockClientId(extractSelectionEndNode(selection)); // If the selection has changed and we had pressed `shift+click`, 20350 // we need to check if in an element that doesn't support 20351 // text selection has been clicked. 20352 20353 if (isClickShift) { 20354 const selectedClientId = getBlockSelectionStart(); 20355 const clickedClientId = getBlockClientId(event.target); // `endClientId` is not defined if we end the selection by clicking a non-selectable block. 20356 // We need to check if there was already a selection with a non-selectable focusNode. 20357 20358 const focusNodeIsNonSelectable = clickedClientId !== endClientId; 20359 20360 if (startClientId === endClientId && selection.isCollapsed || !endClientId || focusNodeIsNonSelectable) { 20361 endClientId = clickedClientId; 20362 } // Handle the case when we have a non-selectable block 20363 // selected and click another one. 20364 20365 20366 if (startClientId !== selectedClientId) { 20367 startClientId = selectedClientId; 20368 } 20369 } // If the selection did not involve a block, return. 20370 20371 20372 if (startClientId === undefined && endClientId === undefined) { 20373 use_selection_observer_setContentEditableWrapper(node, false); 20374 return; 20375 } 20376 20377 const isSingularSelection = startClientId === endClientId; 20378 20379 if (isSingularSelection) { 20380 selectBlock(startClientId); 20381 } else { 20382 const startPath = [...getBlockParents(startClientId), startClientId]; 20383 const endPath = [...getBlockParents(endClientId), endClientId]; 20384 const depth = findDepth(startPath, endPath); 20385 multiSelect(startPath[depth], endPath[depth]); 20386 } 20387 } 20388 20389 function addListeners() { 20390 ownerDocument.addEventListener('selectionchange', onSelectionChange); 20391 defaultView.addEventListener('mouseup', onSelectionChange); 20392 } 20393 20394 function removeListeners() { 20395 ownerDocument.removeEventListener('selectionchange', onSelectionChange); 20396 defaultView.removeEventListener('mouseup', onSelectionChange); 20397 } 20398 20399 function resetListeners() { 20400 removeListeners(); 20401 addListeners(); 20402 } 20403 20404 addListeners(); // We must allow rich text to set selection first. This ensures that 20405 // our `selectionchange` listener is always reset to be called after 20406 // the rich text one. 20407 20408 node.addEventListener('focusin', resetListeners); 20409 return () => { 20410 removeListeners(); 20411 node.removeEventListener('focusin', resetListeners); 20412 }; 20413 }, [multiSelect, selectBlock, selectionChange, getBlockParents]); 20414 } 20415 20416 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/writing-flow/use-click-selection.js 20417 /** 20418 * WordPress dependencies 20419 */ 20420 20421 20422 /** 20423 * Internal dependencies 20424 */ 20425 20426 20427 20428 function useClickSelection() { 20429 const { 20430 selectBlock 20431 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 20432 const { 20433 isSelectionEnabled, 20434 getBlockSelectionStart, 20435 hasMultiSelection 20436 } = (0,external_wp_data_namespaceObject.useSelect)(store); 20437 return (0,external_wp_compose_namespaceObject.useRefEffect)(node => { 20438 function onMouseDown(event) { 20439 // The main button. 20440 // https://developer.mozilla.org/en-US/docs/Web/API/MouseEvent/button 20441 if (!isSelectionEnabled() || event.button !== 0) { 20442 return; 20443 } 20444 20445 const startClientId = getBlockSelectionStart(); 20446 const clickedClientId = getBlockClientId(event.target); 20447 20448 if (event.shiftKey) { 20449 if (startClientId !== clickedClientId) { 20450 node.contentEditable = true; // Firefox doesn't automatically move focus. 20451 20452 node.focus(); 20453 } 20454 } else if (hasMultiSelection()) { 20455 // Allow user to escape out of a multi-selection to a 20456 // singular selection of a block via click. This is handled 20457 // here since focus handling excludes blocks when there is 20458 // multiselection, as focus can be incurred by starting a 20459 // multiselection (focus moved to first block's multi- 20460 // controls). 20461 selectBlock(clickedClientId); 20462 } 20463 } 20464 20465 node.addEventListener('mousedown', onMouseDown); 20466 return () => { 20467 node.removeEventListener('mousedown', onMouseDown); 20468 }; 20469 }, [selectBlock, isSelectionEnabled, getBlockSelectionStart, hasMultiSelection]); 20470 } 20471 20472 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/writing-flow/use-input.js 20473 /** 20474 * WordPress dependencies 20475 */ 20476 20477 20478 20479 20480 /** 20481 * Internal dependencies 20482 */ 20483 20484 20485 /** 20486 * Handles input for selections across blocks. 20487 */ 20488 20489 function useInput() { 20490 const { 20491 __unstableIsFullySelected, 20492 getSelectedBlockClientIds, 20493 __unstableIsSelectionMergeable, 20494 hasMultiSelection 20495 } = (0,external_wp_data_namespaceObject.useSelect)(store); 20496 const { 20497 replaceBlocks, 20498 __unstableSplitSelection, 20499 removeBlocks, 20500 __unstableDeleteSelection, 20501 __unstableExpandSelection 20502 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 20503 return (0,external_wp_compose_namespaceObject.useRefEffect)(node => { 20504 function onKeyDown(event) { 20505 if (event.defaultPrevented) { 20506 return; 20507 } 20508 20509 if (!hasMultiSelection()) { 20510 return; 20511 } 20512 20513 if (event.keyCode === external_wp_keycodes_namespaceObject.ENTER) { 20514 node.contentEditable = false; 20515 event.preventDefault(); 20516 20517 if (__unstableIsFullySelected()) { 20518 replaceBlocks(getSelectedBlockClientIds(), (0,external_wp_blocks_namespaceObject.createBlock)((0,external_wp_blocks_namespaceObject.getDefaultBlockName)())); 20519 } else { 20520 __unstableSplitSelection(); 20521 } 20522 } else if (event.keyCode === external_wp_keycodes_namespaceObject.BACKSPACE || event.keyCode === external_wp_keycodes_namespaceObject.DELETE) { 20523 node.contentEditable = false; 20524 event.preventDefault(); 20525 20526 if (__unstableIsFullySelected()) { 20527 removeBlocks(getSelectedBlockClientIds()); 20528 } else if (__unstableIsSelectionMergeable()) { 20529 __unstableDeleteSelection(event.keyCode === external_wp_keycodes_namespaceObject.DELETE); 20530 } else { 20531 __unstableExpandSelection(); 20532 } 20533 } else if ( // If key.length is longer than 1, it's a control key that doesn't 20534 // input anything. 20535 event.key.length === 1 && !(event.metaKey || event.ctrlKey)) { 20536 node.contentEditable = false; 20537 20538 if (__unstableIsSelectionMergeable()) { 20539 __unstableDeleteSelection(event.keyCode === external_wp_keycodes_namespaceObject.DELETE); 20540 } else { 20541 event.preventDefault(); // Safari does not stop default behaviour with either 20542 // event.preventDefault() or node.contentEditable = false, so 20543 // remove the selection to stop browser manipulation. 20544 20545 node.ownerDocument.defaultView.getSelection().removeAllRanges(); 20546 } 20547 } 20548 } 20549 20550 function onCompositionStart(event) { 20551 if (!hasMultiSelection()) { 20552 return; 20553 } 20554 20555 node.contentEditable = false; 20556 20557 if (__unstableIsSelectionMergeable()) { 20558 __unstableDeleteSelection(); 20559 } else { 20560 event.preventDefault(); // Safari does not stop default behaviour with either 20561 // event.preventDefault() or node.contentEditable = false, so 20562 // remove the selection to stop browser manipulation. 20563 20564 node.ownerDocument.defaultView.getSelection().removeAllRanges(); 20565 } 20566 } 20567 20568 node.addEventListener('keydown', onKeyDown); 20569 node.addEventListener('compositionstart', onCompositionStart); 20570 return () => { 20571 node.removeEventListener('keydown', onKeyDown); 20572 node.removeEventListener('compositionstart', onCompositionStart); 20573 }; 20574 }, []); 20575 } 20576 20577 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/writing-flow/index.js 20578 20579 20580 20581 /** 20582 * External dependencies 20583 */ 20584 20585 /** 20586 * WordPress dependencies 20587 */ 20588 20589 20590 20591 20592 20593 /** 20594 * Internal dependencies 20595 */ 20596 20597 20598 20599 20600 20601 20602 20603 20604 20605 20606 function useWritingFlow() { 20607 const [before, ref, after] = useTabNav(); 20608 const hasMultiSelection = (0,external_wp_data_namespaceObject.useSelect)(select => select(store).hasMultiSelection(), []); 20609 return [before, (0,external_wp_compose_namespaceObject.useMergeRefs)([ref, useInput(), useDragSelection(), useSelectionObserver(), useClickSelection(), useMultiSelection(), useSelectAll(), useArrowNav(), (0,external_wp_compose_namespaceObject.useRefEffect)(node => { 20610 node.tabIndex = -1; 20611 node.contentEditable = hasMultiSelection; 20612 20613 if (!hasMultiSelection) { 20614 return; 20615 } 20616 20617 node.setAttribute('aria-label', (0,external_wp_i18n_namespaceObject.__)('Multiple selected blocks')); 20618 return () => { 20619 node.removeAttribute('aria-label'); 20620 }; 20621 }, [hasMultiSelection])]), after]; 20622 } 20623 20624 function WritingFlow(_ref, forwardedRef) { 20625 let { 20626 children, 20627 ...props 20628 } = _ref; 20629 const [before, ref, after] = useWritingFlow(); 20630 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, before, (0,external_wp_element_namespaceObject.createElement)("div", _extends({}, props, { 20631 ref: (0,external_wp_compose_namespaceObject.useMergeRefs)([ref, forwardedRef]), 20632 className: classnames_default()(props.className, 'block-editor-writing-flow') 20633 }), children), after); 20634 } 20635 /** 20636 * Handles selection and navigation across blocks. This component should be 20637 * wrapped around BlockList. 20638 * 20639 * @param {Object} props Component properties. 20640 * @param {WPElement} props.children Children to be rendered. 20641 */ 20642 20643 20644 /* harmony default export */ var writing_flow = ((0,external_wp_element_namespaceObject.forwardRef)(WritingFlow)); 20645 20646 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/iframe/index.js 20647 20648 20649 20650 /** 20651 * External dependencies 20652 */ 20653 20654 /** 20655 * WordPress dependencies 20656 */ 20657 20658 20659 20660 20661 20662 /** 20663 * Internal dependencies 20664 */ 20665 20666 20667 20668 const BODY_CLASS_NAME = 'editor-styles-wrapper'; 20669 const BLOCK_PREFIX = 'wp-block'; 20670 /** 20671 * Clones stylesheets targetting the editor canvas to the given document. A 20672 * stylesheet is considered targetting the editor a canvas if it contains the 20673 * `editor-styles-wrapper`, `wp-block`, or `wp-block-*` class selectors. 20674 * 20675 * Ideally, this hook should be removed in the future and styles should be added 20676 * explicitly as editor styles. 20677 * 20678 * @param {Document} doc The document to append cloned stylesheets to. 20679 */ 20680 20681 function styleSheetsCompat(doc) { 20682 // Search the document for stylesheets targetting the editor canvas. 20683 Array.from(document.styleSheets).forEach(styleSheet => { 20684 try { 20685 // May fail for external styles. 20686 // eslint-disable-next-line no-unused-expressions 20687 styleSheet.cssRules; 20688 } catch (e) { 20689 return; 20690 } 20691 20692 const { 20693 ownerNode, 20694 cssRules 20695 } = styleSheet; 20696 20697 if (!cssRules) { 20698 return; 20699 } // Generally, ignore inline styles. We add inline styles belonging to a 20700 // stylesheet later, which may or may not match the selectors. 20701 20702 20703 if (ownerNode.tagName !== 'LINK') { 20704 return; 20705 } // Don't try to add the reset styles, which were removed as a dependency 20706 // from `edit-blocks` for the iframe since we don't need to reset admin 20707 // styles. 20708 20709 20710 if (ownerNode.id === 'wp-reset-editor-styles-css') { 20711 return; 20712 } 20713 20714 const isMatch = Array.from(cssRules).find(_ref => { 20715 let { 20716 selectorText 20717 } = _ref; 20718 return selectorText && (selectorText.includes(`.$BODY_CLASS_NAME}`) || selectorText.includes(`.$BLOCK_PREFIX}`)); 20719 }); 20720 20721 if (isMatch && !doc.getElementById(ownerNode.id)) { 20722 // Display warning once we have a way to add style dependencies to the editor. 20723 // See: https://github.com/WordPress/gutenberg/pull/37466. 20724 doc.head.appendChild(ownerNode.cloneNode(true)); // Add inline styles belonging to the stylesheet. 20725 20726 const inlineCssId = ownerNode.id.replace('-css', '-inline-css'); 20727 const inlineCssElement = document.getElementById(inlineCssId); 20728 20729 if (inlineCssElement) { 20730 doc.head.appendChild(inlineCssElement.cloneNode(true)); 20731 } 20732 } 20733 }); 20734 } 20735 /** 20736 * Bubbles some event types (keydown, keypress, and dragover) to parent document 20737 * document to ensure that the keyboard shortcuts and drag and drop work. 20738 * 20739 * Ideally, we should remove event bubbling in the future. Keyboard shortcuts 20740 * should be context dependent, e.g. actions on blocks like Cmd+A should not 20741 * work globally outside the block editor. 20742 * 20743 * @param {Document} doc Document to attach listeners to. 20744 */ 20745 20746 20747 function bubbleEvents(doc) { 20748 const { 20749 defaultView 20750 } = doc; 20751 const { 20752 frameElement 20753 } = defaultView; 20754 20755 function bubbleEvent(event) { 20756 const prototype = Object.getPrototypeOf(event); 20757 const constructorName = prototype.constructor.name; 20758 const Constructor = window[constructorName]; 20759 const init = {}; 20760 20761 for (const key in event) { 20762 init[key] = event[key]; 20763 } 20764 20765 if (event instanceof defaultView.MouseEvent) { 20766 const rect = frameElement.getBoundingClientRect(); 20767 init.clientX += rect.left; 20768 init.clientY += rect.top; 20769 } 20770 20771 const newEvent = new Constructor(event.type, init); 20772 const cancelled = !frameElement.dispatchEvent(newEvent); 20773 20774 if (cancelled) { 20775 event.preventDefault(); 20776 } 20777 } 20778 20779 const eventTypes = ['dragover']; 20780 20781 for (const name of eventTypes) { 20782 doc.addEventListener(name, bubbleEvent); 20783 } 20784 } 20785 20786 function useParsedAssets(html) { 20787 return (0,external_wp_element_namespaceObject.useMemo)(() => { 20788 const doc = document.implementation.createHTMLDocument(''); 20789 doc.body.innerHTML = html; 20790 return Array.from(doc.body.children); 20791 }, [html]); 20792 } 20793 20794 async function loadScript(head, _ref2) { 20795 let { 20796 id, 20797 src 20798 } = _ref2; 20799 return new Promise((resolve, reject) => { 20800 const script = head.ownerDocument.createElement('script'); 20801 script.id = id; 20802 20803 if (src) { 20804 script.src = src; 20805 20806 script.onload = () => resolve(); 20807 20808 script.onerror = () => reject(); 20809 } else { 20810 resolve(); 20811 } 20812 20813 head.appendChild(script); 20814 }); 20815 } 20816 20817 function Iframe(_ref3, ref) { 20818 let { 20819 contentRef, 20820 children, 20821 head, 20822 tabIndex = 0, 20823 assets, 20824 ...props 20825 } = _ref3; 20826 const [, forceRender] = (0,external_wp_element_namespaceObject.useReducer)(() => ({})); 20827 const [iframeDocument, setIframeDocument] = (0,external_wp_element_namespaceObject.useState)(); 20828 const [bodyClasses, setBodyClasses] = (0,external_wp_element_namespaceObject.useState)([]); 20829 const styles = useParsedAssets(assets === null || assets === void 0 ? void 0 : assets.styles); 20830 const scripts = useParsedAssets(assets === null || assets === void 0 ? void 0 : assets.scripts); 20831 const clearerRef = useBlockSelectionClearer(); 20832 const [before, writingFlowRef, after] = useWritingFlow(); 20833 const setRef = (0,external_wp_compose_namespaceObject.useRefEffect)(node => { 20834 function setDocumentIfReady() { 20835 const { 20836 contentDocument, 20837 ownerDocument 20838 } = node; 20839 const { 20840 readyState, 20841 documentElement 20842 } = contentDocument; 20843 20844 if (readyState !== 'interactive' && readyState !== 'complete') { 20845 return false; 20846 } 20847 20848 bubbleEvents(contentDocument); 20849 setIframeDocument(contentDocument); 20850 clearerRef(documentElement); // Ideally ALL classes that are added through get_body_class should 20851 // be added in the editor too, which we'll somehow have to get from 20852 // the server in the future (which will run the PHP filters). 20853 20854 setBodyClasses(Array.from(ownerDocument.body.classList).filter(name => name.startsWith('admin-color-') || name.startsWith('post-type-') || name === 'wp-embed-responsive')); 20855 contentDocument.dir = ownerDocument.dir; 20856 documentElement.removeChild(contentDocument.head); 20857 documentElement.removeChild(contentDocument.body); 20858 return true; 20859 } // Document set with srcDoc is not immediately ready. 20860 20861 20862 node.addEventListener('load', setDocumentIfReady); 20863 return () => node.removeEventListener('load', setDocumentIfReady); 20864 }, []); 20865 const headRef = (0,external_wp_compose_namespaceObject.useRefEffect)(element => { 20866 scripts.reduce((promise, script) => promise.then(() => loadScript(element, script)), Promise.resolve()).finally(() => { 20867 // When script are loaded, re-render blocks to allow them 20868 // to initialise. 20869 forceRender(); 20870 }); 20871 }, []); 20872 const bodyRef = (0,external_wp_compose_namespaceObject.useMergeRefs)([contentRef, clearerRef, writingFlowRef]); 20873 (0,external_wp_element_namespaceObject.useEffect)(() => { 20874 if (iframeDocument) { 20875 styleSheetsCompat(iframeDocument); 20876 } 20877 }, [iframeDocument]); 20878 head = (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("style", null, 'body{margin:0}'), styles.map(_ref4 => { 20879 let { 20880 tagName, 20881 href, 20882 id, 20883 rel, 20884 media, 20885 textContent 20886 } = _ref4; 20887 const TagName = tagName.toLowerCase(); 20888 20889 if (TagName === 'style') { 20890 return (0,external_wp_element_namespaceObject.createElement)(TagName, { 20891 id, 20892 key: id 20893 }, textContent); 20894 } 20895 20896 return (0,external_wp_element_namespaceObject.createElement)(TagName, { 20897 href, 20898 id, 20899 rel, 20900 media, 20901 key: id 20902 }); 20903 }), head); 20904 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, tabIndex >= 0 && before, (0,external_wp_element_namespaceObject.createElement)("iframe", _extends({}, props, { 20905 ref: (0,external_wp_compose_namespaceObject.useMergeRefs)([ref, setRef]), 20906 tabIndex: tabIndex // Correct doctype is required to enable rendering in standards mode 20907 , 20908 srcDoc: "<!doctype html>", 20909 title: (0,external_wp_i18n_namespaceObject.__)('Editor canvas') 20910 }), iframeDocument && (0,external_wp_element_namespaceObject.createPortal)((0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("head", { 20911 ref: headRef 20912 }, head), (0,external_wp_element_namespaceObject.createElement)("body", { 20913 ref: bodyRef, 20914 className: classnames_default()(BODY_CLASS_NAME, ...bodyClasses) 20915 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalStyleProvider, { 20916 document: iframeDocument 20917 }, children))), iframeDocument.documentElement)), tabIndex >= 0 && after); 20918 } 20919 20920 /* harmony default export */ var iframe = ((0,external_wp_element_namespaceObject.forwardRef)(Iframe)); 20921 20922 ;// CONCATENATED MODULE: ./node_modules/colord/index.mjs 20923 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()})}; 20924 20925 ;// CONCATENATED MODULE: ./node_modules/colord/plugins/names.mjs 20926 /* 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"])} 20927 20928 ;// CONCATENATED MODULE: ./node_modules/colord/plugins/a11y.mjs 20929 var a11y_o=function(o){var t=o/255;return t<.04045?t/12.92:Math.pow((t+.055)/1.055,2.4)},a11y_t=function(t){return.2126*a11y_o(t.r)+.7152*a11y_o(t.g)+.0722*a11y_o(t.b)};/* harmony default export */ function a11y(o){o.prototype.luminance=function(){return o=a11y_t(this.rgba),void 0===(r=2)&&(r=0),void 0===n&&(n=Math.pow(10,r)),Math.round(n*o)/n+0;var o,r,n},o.prototype.contrast=function(r){void 0===r&&(r="#FFF");var n,a,i,e,v,u,d,c=r instanceof o?r:new o(r);return e=this.rgba,v=c.toRgb(),u=a11y_t(e),d=a11y_t(v),n=u>d?(u+.05)/(d+.05):(d+.05)/(u+.05),void 0===(a=2)&&(a=0),void 0===i&&(i=Math.pow(10,a)),Math.floor(i*n)/i+0},o.prototype.isReadable=function(o,t){return void 0===o&&(o="#FFF"),void 0===t&&(t={}),this.contrast(o)>=(e=void 0===(i=(r=t).size)?"normal":i,"AAA"===(a=void 0===(n=r.level)?"AA":n)&&"normal"===e?7:"AA"===a&&"large"===e?3:4.5);var r,n,a,i,e}} 20930 20931 // EXTERNAL MODULE: ./node_modules/traverse/index.js 20932 var traverse = __webpack_require__(3124); 20933 var traverse_default = /*#__PURE__*/__webpack_require__.n(traverse); 20934 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/utils/transform-styles/ast/parse.js 20935 /* eslint-disable @wordpress/no-unused-vars-before-return */ 20936 // Adapted from https://github.com/reworkcss/css 20937 // because we needed to remove source map support. 20938 // http://www.w3.org/TR/CSS21/grammar.htm 20939 // https://github.com/visionmedia/css-parse/pull/49#issuecomment-30088027 20940 const commentre = /\/\*[^*]*\*+([^/*][^*]*\*+)*\//g; 20941 /* harmony default export */ function parse(css, options) { 20942 options = options || {}; 20943 /** 20944 * Positional. 20945 */ 20946 20947 let lineno = 1; 20948 let column = 1; 20949 /** 20950 * Update lineno and column based on `str`. 20951 */ 20952 20953 function updatePosition(str) { 20954 const lines = str.match(/\n/g); 20955 20956 if (lines) { 20957 lineno += lines.length; 20958 } 20959 20960 const i = str.lastIndexOf('\n'); // eslint-disable-next-line no-bitwise 20961 20962 column = ~i ? str.length - i : column + str.length; 20963 } 20964 /** 20965 * Mark position and patch `node.position`. 20966 */ 20967 20968 20969 function position() { 20970 const start = { 20971 line: lineno, 20972 column 20973 }; 20974 return function (node) { 20975 node.position = new Position(start); 20976 whitespace(); 20977 return node; 20978 }; 20979 } 20980 /** 20981 * Store position information for a node 20982 */ 20983 20984 20985 function Position(start) { 20986 this.start = start; 20987 this.end = { 20988 line: lineno, 20989 column 20990 }; 20991 this.source = options.source; 20992 } 20993 /** 20994 * Non-enumerable source string 20995 */ 20996 20997 20998 Position.prototype.content = css; 20999 /** 21000 * Error `msg`. 21001 */ 21002 21003 const errorsList = []; 21004 21005 function error(msg) { 21006 const err = new Error(options.source + ':' + lineno + ':' + column + ': ' + msg); 21007 err.reason = msg; 21008 err.filename = options.source; 21009 err.line = lineno; 21010 err.column = column; 21011 err.source = css; 21012 21013 if (options.silent) { 21014 errorsList.push(err); 21015 } else { 21016 throw err; 21017 } 21018 } 21019 /** 21020 * Parse stylesheet. 21021 */ 21022 21023 21024 function stylesheet() { 21025 const rulesList = rules(); 21026 return { 21027 type: 'stylesheet', 21028 stylesheet: { 21029 source: options.source, 21030 rules: rulesList, 21031 parsingErrors: errorsList 21032 } 21033 }; 21034 } 21035 /** 21036 * Opening brace. 21037 */ 21038 21039 21040 function open() { 21041 return match(/^{\s*/); 21042 } 21043 /** 21044 * Closing brace. 21045 */ 21046 21047 21048 function close() { 21049 return match(/^}/); 21050 } 21051 /** 21052 * Parse ruleset. 21053 */ 21054 21055 21056 function rules() { 21057 let node; 21058 const accumulator = []; 21059 whitespace(); 21060 comments(accumulator); 21061 21062 while (css.length && css.charAt(0) !== '}' && (node = atrule() || rule())) { 21063 if (node !== false) { 21064 accumulator.push(node); 21065 comments(accumulator); 21066 } 21067 } 21068 21069 return accumulator; 21070 } 21071 /** 21072 * Match `re` and return captures. 21073 */ 21074 21075 21076 function match(re) { 21077 const m = re.exec(css); 21078 21079 if (!m) { 21080 return; 21081 } 21082 21083 const str = m[0]; 21084 updatePosition(str); 21085 css = css.slice(str.length); 21086 return m; 21087 } 21088 /** 21089 * Parse whitespace. 21090 */ 21091 21092 21093 function whitespace() { 21094 match(/^\s*/); 21095 } 21096 /** 21097 * Parse comments; 21098 */ 21099 21100 21101 function comments(accumulator) { 21102 let c; 21103 accumulator = accumulator || []; // eslint-disable-next-line no-cond-assign 21104 21105 while (c = comment()) { 21106 if (c !== false) { 21107 accumulator.push(c); 21108 } 21109 } 21110 21111 return accumulator; 21112 } 21113 /** 21114 * Parse comment. 21115 */ 21116 21117 21118 function comment() { 21119 const pos = position(); 21120 21121 if ('/' !== css.charAt(0) || '*' !== css.charAt(1)) { 21122 return; 21123 } 21124 21125 let i = 2; 21126 21127 while ('' !== css.charAt(i) && ('*' !== css.charAt(i) || '/' !== css.charAt(i + 1))) { 21128 ++i; 21129 } 21130 21131 i += 2; 21132 21133 if ('' === css.charAt(i - 1)) { 21134 return error('End of comment missing'); 21135 } 21136 21137 const str = css.slice(2, i - 2); 21138 column += 2; 21139 updatePosition(str); 21140 css = css.slice(i); 21141 column += 2; 21142 return pos({ 21143 type: 'comment', 21144 comment: str 21145 }); 21146 } 21147 /** 21148 * Parse selector. 21149 */ 21150 21151 21152 function selector() { 21153 const m = match(/^([^{]+)/); 21154 21155 if (!m) { 21156 return; 21157 } // FIXME: Remove all comments from selectors http://ostermiller.org/findcomment.html 21158 21159 21160 return trim(m[0]).replace(/\/\*([^*]|[\r\n]|(\*+([^*/]|[\r\n])))*\*\/+/g, '').replace(/"(?:\\"|[^"])*"|'(?:\\'|[^'])*'/g, function (matched) { 21161 return matched.replace(/,/g, '\u200C'); 21162 }).split(/\s*(?![^(]*\)),\s*/).map(function (s) { 21163 return s.replace(/\u200C/g, ','); 21164 }); 21165 } 21166 /** 21167 * Parse declaration. 21168 */ 21169 21170 21171 function declaration() { 21172 const pos = position(); // prop. 21173 21174 let prop = match(/^(\*?[-#\/\*\\\w]+(\[[0-9a-z_-]+\])?)\s*/); 21175 21176 if (!prop) { 21177 return; 21178 } 21179 21180 prop = trim(prop[0]); // : 21181 21182 if (!match(/^:\s*/)) { 21183 return error("property missing ':'"); 21184 } // val. 21185 21186 21187 const val = match(/^((?:'(?:\\'|.)*?'|"(?:\\"|.)*?"|\([^\)]*?\)|[^};])+)/); 21188 const ret = pos({ 21189 type: 'declaration', 21190 property: prop.replace(commentre, ''), 21191 value: val ? trim(val[0]).replace(commentre, '') : '' 21192 }); // ; 21193 21194 match(/^[;\s]*/); 21195 return ret; 21196 } 21197 /** 21198 * Parse declarations. 21199 */ 21200 21201 21202 function declarations() { 21203 const decls = []; 21204 21205 if (!open()) { 21206 return error("missing '{'"); 21207 } 21208 21209 comments(decls); // declarations. 21210 21211 let decl; // eslint-disable-next-line no-cond-assign 21212 21213 while (decl = declaration()) { 21214 if (decl !== false) { 21215 decls.push(decl); 21216 comments(decls); 21217 } 21218 } 21219 21220 if (!close()) { 21221 return error("missing '}'"); 21222 } 21223 21224 return decls; 21225 } 21226 /** 21227 * Parse keyframe. 21228 */ 21229 21230 21231 function keyframe() { 21232 let m; 21233 const vals = []; 21234 const pos = position(); // eslint-disable-next-line no-cond-assign 21235 21236 while (m = match(/^((\d+\.\d+|\.\d+|\d+)%?|[a-z]+)\s*/)) { 21237 vals.push(m[1]); 21238 match(/^,\s*/); 21239 } 21240 21241 if (!vals.length) { 21242 return; 21243 } 21244 21245 return pos({ 21246 type: 'keyframe', 21247 values: vals, 21248 declarations: declarations() 21249 }); 21250 } 21251 /** 21252 * Parse keyframes. 21253 */ 21254 21255 21256 function atkeyframes() { 21257 const pos = position(); 21258 let m = match(/^@([-\w]+)?keyframes\s*/); 21259 21260 if (!m) { 21261 return; 21262 } 21263 21264 const vendor = m[1]; // identifier 21265 21266 m = match(/^([-\w]+)\s*/); 21267 21268 if (!m) { 21269 return error('@keyframes missing name'); 21270 } 21271 21272 const name = m[1]; 21273 21274 if (!open()) { 21275 return error("@keyframes missing '{'"); 21276 } 21277 21278 let frame; 21279 let frames = comments(); // eslint-disable-next-line no-cond-assign 21280 21281 while (frame = keyframe()) { 21282 frames.push(frame); 21283 frames = frames.concat(comments()); 21284 } 21285 21286 if (!close()) { 21287 return error("@keyframes missing '}'"); 21288 } 21289 21290 return pos({ 21291 type: 'keyframes', 21292 name, 21293 vendor, 21294 keyframes: frames 21295 }); 21296 } 21297 /** 21298 * Parse supports. 21299 */ 21300 21301 21302 function atsupports() { 21303 const pos = position(); 21304 const m = match(/^@supports *([^{]+)/); 21305 21306 if (!m) { 21307 return; 21308 } 21309 21310 const supports = trim(m[1]); 21311 21312 if (!open()) { 21313 return error("@supports missing '{'"); 21314 } 21315 21316 const style = comments().concat(rules()); 21317 21318 if (!close()) { 21319 return error("@supports missing '}'"); 21320 } 21321 21322 return pos({ 21323 type: 'supports', 21324 supports, 21325 rules: style 21326 }); 21327 } 21328 /** 21329 * Parse host. 21330 */ 21331 21332 21333 function athost() { 21334 const pos = position(); 21335 const m = match(/^@host\s*/); 21336 21337 if (!m) { 21338 return; 21339 } 21340 21341 if (!open()) { 21342 return error("@host missing '{'"); 21343 } 21344 21345 const style = comments().concat(rules()); 21346 21347 if (!close()) { 21348 return error("@host missing '}'"); 21349 } 21350 21351 return pos({ 21352 type: 'host', 21353 rules: style 21354 }); 21355 } 21356 /** 21357 * Parse media. 21358 */ 21359 21360 21361 function atmedia() { 21362 const pos = position(); 21363 const m = match(/^@media *([^{]+)/); 21364 21365 if (!m) { 21366 return; 21367 } 21368 21369 const media = trim(m[1]); 21370 21371 if (!open()) { 21372 return error("@media missing '{'"); 21373 } 21374 21375 const style = comments().concat(rules()); 21376 21377 if (!close()) { 21378 return error("@media missing '}'"); 21379 } 21380 21381 return pos({ 21382 type: 'media', 21383 media, 21384 rules: style 21385 }); 21386 } 21387 /** 21388 * Parse custom-media. 21389 */ 21390 21391 21392 function atcustommedia() { 21393 const pos = position(); 21394 const m = match(/^@custom-media\s+(--[^\s]+)\s*([^{;]+);/); 21395 21396 if (!m) { 21397 return; 21398 } 21399 21400 return pos({ 21401 type: 'custom-media', 21402 name: trim(m[1]), 21403 media: trim(m[2]) 21404 }); 21405 } 21406 /** 21407 * Parse paged media. 21408 */ 21409 21410 21411 function atpage() { 21412 const pos = position(); 21413 const m = match(/^@page */); 21414 21415 if (!m) { 21416 return; 21417 } 21418 21419 const sel = selector() || []; 21420 21421 if (!open()) { 21422 return error("@page missing '{'"); 21423 } 21424 21425 let decls = comments(); // declarations. 21426 21427 let decl; // eslint-disable-next-line no-cond-assign 21428 21429 while (decl = declaration()) { 21430 decls.push(decl); 21431 decls = decls.concat(comments()); 21432 } 21433 21434 if (!close()) { 21435 return error("@page missing '}'"); 21436 } 21437 21438 return pos({ 21439 type: 'page', 21440 selectors: sel, 21441 declarations: decls 21442 }); 21443 } 21444 /** 21445 * Parse document. 21446 */ 21447 21448 21449 function atdocument() { 21450 const pos = position(); 21451 const m = match(/^@([-\w]+)?document *([^{]+)/); 21452 21453 if (!m) { 21454 return; 21455 } 21456 21457 const vendor = trim(m[1]); 21458 const doc = trim(m[2]); 21459 21460 if (!open()) { 21461 return error("@document missing '{'"); 21462 } 21463 21464 const style = comments().concat(rules()); 21465 21466 if (!close()) { 21467 return error("@document missing '}'"); 21468 } 21469 21470 return pos({ 21471 type: 'document', 21472 document: doc, 21473 vendor, 21474 rules: style 21475 }); 21476 } 21477 /** 21478 * Parse font-face. 21479 */ 21480 21481 21482 function atfontface() { 21483 const pos = position(); 21484 const m = match(/^@font-face\s*/); 21485 21486 if (!m) { 21487 return; 21488 } 21489 21490 if (!open()) { 21491 return error("@font-face missing '{'"); 21492 } 21493 21494 let decls = comments(); // declarations. 21495 21496 let decl; // eslint-disable-next-line no-cond-assign 21497 21498 while (decl = declaration()) { 21499 decls.push(decl); 21500 decls = decls.concat(comments()); 21501 } 21502 21503 if (!close()) { 21504 return error("@font-face missing '}'"); 21505 } 21506 21507 return pos({ 21508 type: 'font-face', 21509 declarations: decls 21510 }); 21511 } 21512 /** 21513 * Parse import 21514 */ 21515 21516 21517 const atimport = _compileAtrule('import'); 21518 /** 21519 * Parse charset 21520 */ 21521 21522 21523 const atcharset = _compileAtrule('charset'); 21524 /** 21525 * Parse namespace 21526 */ 21527 21528 21529 const atnamespace = _compileAtrule('namespace'); 21530 /** 21531 * Parse non-block at-rules 21532 */ 21533 21534 21535 function _compileAtrule(name) { 21536 const re = new RegExp('^@' + name + '\\s*([^;]+);'); 21537 return function () { 21538 const pos = position(); 21539 const m = match(re); 21540 21541 if (!m) { 21542 return; 21543 } 21544 21545 const ret = { 21546 type: name 21547 }; 21548 ret[name] = m[1].trim(); 21549 return pos(ret); 21550 }; 21551 } 21552 /** 21553 * Parse at rule. 21554 */ 21555 21556 21557 function atrule() { 21558 if (css[0] !== '@') { 21559 return; 21560 } 21561 21562 return atkeyframes() || atmedia() || atcustommedia() || atsupports() || atimport() || atcharset() || atnamespace() || atdocument() || atpage() || athost() || atfontface(); 21563 } 21564 /** 21565 * Parse rule. 21566 */ 21567 21568 21569 function rule() { 21570 const pos = position(); 21571 const sel = selector(); 21572 21573 if (!sel) { 21574 return error('selector missing'); 21575 } 21576 21577 comments(); 21578 return pos({ 21579 type: 'rule', 21580 selectors: sel, 21581 declarations: declarations() 21582 }); 21583 } 21584 21585 return addParent(stylesheet()); 21586 } 21587 /** 21588 * Trim `str`. 21589 */ 21590 21591 function trim(str) { 21592 return str ? str.replace(/^\s+|\s+$/g, '') : ''; 21593 } 21594 /** 21595 * Adds non-enumerable parent node reference to each node. 21596 */ 21597 21598 21599 function addParent(obj, parent) { 21600 const isNode = obj && typeof obj.type === 'string'; 21601 const childParent = isNode ? obj : parent; 21602 21603 for (const k in obj) { 21604 const value = obj[k]; 21605 21606 if (Array.isArray(value)) { 21607 value.forEach(function (v) { 21608 addParent(v, childParent); 21609 }); 21610 } else if (value && typeof value === 'object') { 21611 addParent(value, childParent); 21612 } 21613 } 21614 21615 if (isNode) { 21616 Object.defineProperty(obj, 'parent', { 21617 configurable: true, 21618 writable: true, 21619 enumerable: false, 21620 value: parent || null 21621 }); 21622 } 21623 21624 return obj; 21625 } 21626 /* eslint-enable @wordpress/no-unused-vars-before-return */ 21627 21628 // EXTERNAL MODULE: ./node_modules/inherits/inherits_browser.js 21629 var inherits_browser = __webpack_require__(8575); 21630 var inherits_browser_default = /*#__PURE__*/__webpack_require__.n(inherits_browser); 21631 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/utils/transform-styles/ast/stringify/compiler.js 21632 // Adapted from https://github.com/reworkcss/css 21633 // because we needed to remove source map support. 21634 21635 /** 21636 * Expose `Compiler`. 21637 */ 21638 /* harmony default export */ var compiler = (Compiler); 21639 /** 21640 * Initialize a compiler. 21641 */ 21642 21643 function Compiler(opts) { 21644 this.options = opts || {}; 21645 } 21646 /** 21647 * Emit `str` 21648 */ 21649 21650 21651 Compiler.prototype.emit = function (str) { 21652 return str; 21653 }; 21654 /** 21655 * Visit `node`. 21656 */ 21657 21658 21659 Compiler.prototype.visit = function (node) { 21660 return this[node.type](node); 21661 }; 21662 /** 21663 * Map visit over array of `nodes`, optionally using a `delim` 21664 */ 21665 21666 21667 Compiler.prototype.mapVisit = function (nodes, delim) { 21668 let buf = ''; 21669 delim = delim || ''; 21670 21671 for (let i = 0, length = nodes.length; i < length; i++) { 21672 buf += this.visit(nodes[i]); 21673 21674 if (delim && i < length - 1) { 21675 buf += this.emit(delim); 21676 } 21677 } 21678 21679 return buf; 21680 }; 21681 21682 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/utils/transform-styles/ast/stringify/compress.js 21683 // Adapted from https://github.com/reworkcss/css 21684 // because we needed to remove source map support. 21685 21686 /** 21687 * External dependencies 21688 */ 21689 21690 /** 21691 * Internal dependencies 21692 */ 21693 21694 21695 /** 21696 * Expose compiler. 21697 */ 21698 21699 /* harmony default export */ var compress = (compress_Compiler); 21700 /** 21701 * Initialize a new `Compiler`. 21702 */ 21703 21704 function compress_Compiler(options) { 21705 compiler.call(this, options); 21706 } 21707 /** 21708 * Inherit from `Base.prototype`. 21709 */ 21710 21711 21712 inherits_browser_default()(compress_Compiler, compiler); 21713 /** 21714 * Compile `node`. 21715 */ 21716 21717 compress_Compiler.prototype.compile = function (node) { 21718 return node.stylesheet.rules.map(this.visit, this).join(''); 21719 }; 21720 /** 21721 * Visit comment node. 21722 */ 21723 21724 21725 compress_Compiler.prototype.comment = function (node) { 21726 return this.emit('', node.position); 21727 }; 21728 /** 21729 * Visit import node. 21730 */ 21731 21732 21733 compress_Compiler.prototype.import = function (node) { 21734 return this.emit('@import ' + node.import + ';', node.position); 21735 }; 21736 /** 21737 * Visit media node. 21738 */ 21739 21740 21741 compress_Compiler.prototype.media = function (node) { 21742 return this.emit('@media ' + node.media, node.position) + this.emit('{') + this.mapVisit(node.rules) + this.emit('}'); 21743 }; 21744 /** 21745 * Visit document node. 21746 */ 21747 21748 21749 compress_Compiler.prototype.document = function (node) { 21750 const doc = '@' + (node.vendor || '') + 'document ' + node.document; 21751 return this.emit(doc, node.position) + this.emit('{') + this.mapVisit(node.rules) + this.emit('}'); 21752 }; 21753 /** 21754 * Visit charset node. 21755 */ 21756 21757 21758 compress_Compiler.prototype.charset = function (node) { 21759 return this.emit('@charset ' + node.charset + ';', node.position); 21760 }; 21761 /** 21762 * Visit namespace node. 21763 */ 21764 21765 21766 compress_Compiler.prototype.namespace = function (node) { 21767 return this.emit('@namespace ' + node.namespace + ';', node.position); 21768 }; 21769 /** 21770 * Visit supports node. 21771 */ 21772 21773 21774 compress_Compiler.prototype.supports = function (node) { 21775 return this.emit('@supports ' + node.supports, node.position) + this.emit('{') + this.mapVisit(node.rules) + this.emit('}'); 21776 }; 21777 /** 21778 * Visit keyframes node. 21779 */ 21780 21781 21782 compress_Compiler.prototype.keyframes = function (node) { 21783 return this.emit('@' + (node.vendor || '') + 'keyframes ' + node.name, node.position) + this.emit('{') + this.mapVisit(node.keyframes) + this.emit('}'); 21784 }; 21785 /** 21786 * Visit keyframe node. 21787 */ 21788 21789 21790 compress_Compiler.prototype.keyframe = function (node) { 21791 const decls = node.declarations; 21792 return this.emit(node.values.join(','), node.position) + this.emit('{') + this.mapVisit(decls) + this.emit('}'); 21793 }; 21794 /** 21795 * Visit page node. 21796 */ 21797 21798 21799 compress_Compiler.prototype.page = function (node) { 21800 const sel = node.selectors.length ? node.selectors.join(', ') : ''; 21801 return this.emit('@page ' + sel, node.position) + this.emit('{') + this.mapVisit(node.declarations) + this.emit('}'); 21802 }; 21803 /** 21804 * Visit font-face node. 21805 */ 21806 21807 21808 compress_Compiler.prototype['font-face'] = function (node) { 21809 return this.emit('@font-face', node.position) + this.emit('{') + this.mapVisit(node.declarations) + this.emit('}'); 21810 }; 21811 /** 21812 * Visit host node. 21813 */ 21814 21815 21816 compress_Compiler.prototype.host = function (node) { 21817 return this.emit('@host', node.position) + this.emit('{') + this.mapVisit(node.rules) + this.emit('}'); 21818 }; 21819 /** 21820 * Visit custom-media node. 21821 */ 21822 21823 21824 compress_Compiler.prototype['custom-media'] = function (node) { 21825 return this.emit('@custom-media ' + node.name + ' ' + node.media + ';', node.position); 21826 }; 21827 /** 21828 * Visit rule node. 21829 */ 21830 21831 21832 compress_Compiler.prototype.rule = function (node) { 21833 const decls = node.declarations; 21834 21835 if (!decls.length) { 21836 return ''; 21837 } 21838 21839 return this.emit(node.selectors.join(','), node.position) + this.emit('{') + this.mapVisit(decls) + this.emit('}'); 21840 }; 21841 /** 21842 * Visit declaration node. 21843 */ 21844 21845 21846 compress_Compiler.prototype.declaration = function (node) { 21847 return this.emit(node.property + ':' + node.value, node.position) + this.emit(';'); 21848 }; 21849 21850 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/utils/transform-styles/ast/stringify/identity.js 21851 /* eslint-disable @wordpress/no-unused-vars-before-return */ 21852 // Adapted from https://github.com/reworkcss/css 21853 // because we needed to remove source map support. 21854 21855 /** 21856 * External dependencies 21857 */ 21858 21859 /** 21860 * Internal dependencies 21861 */ 21862 21863 21864 /** 21865 * Expose compiler. 21866 */ 21867 21868 /* harmony default export */ var identity = (identity_Compiler); 21869 /** 21870 * Initialize a new `Compiler`. 21871 */ 21872 21873 function identity_Compiler(options) { 21874 options = options || {}; 21875 compiler.call(this, options); 21876 this.indentation = options.indent; 21877 } 21878 /** 21879 * Inherit from `Base.prototype`. 21880 */ 21881 21882 21883 inherits_browser_default()(identity_Compiler, compiler); 21884 /** 21885 * Compile `node`. 21886 */ 21887 21888 identity_Compiler.prototype.compile = function (node) { 21889 return this.stylesheet(node); 21890 }; 21891 /** 21892 * Visit stylesheet node. 21893 */ 21894 21895 21896 identity_Compiler.prototype.stylesheet = function (node) { 21897 return this.mapVisit(node.stylesheet.rules, '\n\n'); 21898 }; 21899 /** 21900 * Visit comment node. 21901 */ 21902 21903 21904 identity_Compiler.prototype.comment = function (node) { 21905 return this.emit(this.indent() + '/*' + node.comment + '*/', node.position); 21906 }; 21907 /** 21908 * Visit import node. 21909 */ 21910 21911 21912 identity_Compiler.prototype.import = function (node) { 21913 return this.emit('@import ' + node.import + ';', node.position); 21914 }; 21915 /** 21916 * Visit media node. 21917 */ 21918 21919 21920 identity_Compiler.prototype.media = function (node) { 21921 return this.emit('@media ' + node.media, node.position) + this.emit(' {\n' + this.indent(1)) + this.mapVisit(node.rules, '\n\n') + this.emit(this.indent(-1) + '\n}'); 21922 }; 21923 /** 21924 * Visit document node. 21925 */ 21926 21927 21928 identity_Compiler.prototype.document = function (node) { 21929 const doc = '@' + (node.vendor || '') + 'document ' + node.document; 21930 return this.emit(doc, node.position) + this.emit(' ' + ' {\n' + this.indent(1)) + this.mapVisit(node.rules, '\n\n') + this.emit(this.indent(-1) + '\n}'); 21931 }; 21932 /** 21933 * Visit charset node. 21934 */ 21935 21936 21937 identity_Compiler.prototype.charset = function (node) { 21938 return this.emit('@charset ' + node.charset + ';', node.position); 21939 }; 21940 /** 21941 * Visit namespace node. 21942 */ 21943 21944 21945 identity_Compiler.prototype.namespace = function (node) { 21946 return this.emit('@namespace ' + node.namespace + ';', node.position); 21947 }; 21948 /** 21949 * Visit supports node. 21950 */ 21951 21952 21953 identity_Compiler.prototype.supports = function (node) { 21954 return this.emit('@supports ' + node.supports, node.position) + this.emit(' {\n' + this.indent(1)) + this.mapVisit(node.rules, '\n\n') + this.emit(this.indent(-1) + '\n}'); 21955 }; 21956 /** 21957 * Visit keyframes node. 21958 */ 21959 21960 21961 identity_Compiler.prototype.keyframes = function (node) { 21962 return this.emit('@' + (node.vendor || '') + 'keyframes ' + node.name, node.position) + this.emit(' {\n' + this.indent(1)) + this.mapVisit(node.keyframes, '\n') + this.emit(this.indent(-1) + '}'); 21963 }; 21964 /** 21965 * Visit keyframe node. 21966 */ 21967 21968 21969 identity_Compiler.prototype.keyframe = function (node) { 21970 const decls = node.declarations; 21971 return this.emit(this.indent()) + this.emit(node.values.join(', '), node.position) + this.emit(' {\n' + this.indent(1)) + this.mapVisit(decls, '\n') + this.emit(this.indent(-1) + '\n' + this.indent() + '}\n'); 21972 }; 21973 /** 21974 * Visit page node. 21975 */ 21976 21977 21978 identity_Compiler.prototype.page = function (node) { 21979 const sel = node.selectors.length ? node.selectors.join(', ') + ' ' : ''; 21980 return this.emit('@page ' + sel, node.position) + this.emit('{\n') + this.emit(this.indent(1)) + this.mapVisit(node.declarations, '\n') + this.emit(this.indent(-1)) + this.emit('\n}'); 21981 }; 21982 /** 21983 * Visit font-face node. 21984 */ 21985 21986 21987 identity_Compiler.prototype['font-face'] = function (node) { 21988 return this.emit('@font-face ', node.position) + this.emit('{\n') + this.emit(this.indent(1)) + this.mapVisit(node.declarations, '\n') + this.emit(this.indent(-1)) + this.emit('\n}'); 21989 }; 21990 /** 21991 * Visit host node. 21992 */ 21993 21994 21995 identity_Compiler.prototype.host = function (node) { 21996 return this.emit('@host', node.position) + this.emit(' {\n' + this.indent(1)) + this.mapVisit(node.rules, '\n\n') + this.emit(this.indent(-1) + '\n}'); 21997 }; 21998 /** 21999 * Visit custom-media node. 22000 */ 22001 22002 22003 identity_Compiler.prototype['custom-media'] = function (node) { 22004 return this.emit('@custom-media ' + node.name + ' ' + node.media + ';', node.position); 22005 }; 22006 /** 22007 * Visit rule node. 22008 */ 22009 22010 22011 identity_Compiler.prototype.rule = function (node) { 22012 const indent = this.indent(); 22013 const decls = node.declarations; 22014 22015 if (!decls.length) { 22016 return ''; 22017 } 22018 22019 return this.emit(node.selectors.map(function (s) { 22020 return indent + s; 22021 }).join(',\n'), node.position) + this.emit(' {\n') + this.emit(this.indent(1)) + this.mapVisit(decls, '\n') + this.emit(this.indent(-1)) + this.emit('\n' + this.indent() + '}'); 22022 }; 22023 /** 22024 * Visit declaration node. 22025 */ 22026 22027 22028 identity_Compiler.prototype.declaration = function (node) { 22029 return this.emit(this.indent()) + this.emit(node.property + ': ' + node.value, node.position) + this.emit(';'); 22030 }; 22031 /** 22032 * Increase, decrease or return current indentation. 22033 */ 22034 22035 22036 identity_Compiler.prototype.indent = function (level) { 22037 this.level = this.level || 1; 22038 22039 if (null !== level) { 22040 this.level += level; 22041 return ''; 22042 } 22043 22044 return Array(this.level).join(this.indentation || ' '); 22045 }; 22046 /* eslint-enable @wordpress/no-unused-vars-before-return */ 22047 22048 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/utils/transform-styles/ast/stringify/index.js 22049 // Adapted from https://github.com/reworkcss/css 22050 // because we needed to remove source map support. 22051 22052 /** 22053 * Internal dependencies 22054 */ 22055 22056 22057 /** 22058 * Stringfy the given AST `node`. 22059 * 22060 * Options: 22061 * 22062 * - `compress` space-optimized output 22063 * - `sourcemap` return an object with `.code` and `.map` 22064 * 22065 * @param {Object} node 22066 * @param {Object} [options] 22067 * @return {string} 22068 */ 22069 22070 /* harmony default export */ function stringify(node, options) { 22071 options = options || {}; 22072 const compiler = options.compress ? new compress(options) : new identity(options); 22073 const code = compiler.compile(node); 22074 return code; 22075 } 22076 22077 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/utils/transform-styles/traverse.js 22078 /** 22079 * External dependencies 22080 */ 22081 22082 /** 22083 * Internal dependencies 22084 */ 22085 22086 22087 22088 function traverseCSS(css, callback) { 22089 try { 22090 const parsed = parse(css); 22091 const updated = traverse_default().map(parsed, function (node) { 22092 if (!node) { 22093 return node; 22094 } 22095 22096 const updatedNode = callback(node); 22097 return this.update(updatedNode); 22098 }); 22099 return stringify(updated); 22100 } catch (err) { 22101 // eslint-disable-next-line no-console 22102 console.warn('Error while traversing the CSS: ' + err); 22103 return null; 22104 } 22105 } 22106 22107 /* harmony default export */ var transform_styles_traverse = (traverseCSS); 22108 22109 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/utils/transform-styles/transforms/url-rewrite.js 22110 /** 22111 * Return `true` if the given path is http/https. 22112 * 22113 * @param {string} filePath path 22114 * 22115 * @return {boolean} is remote path. 22116 */ 22117 function isRemotePath(filePath) { 22118 return /^(?:https?:)?\/\//.test(filePath); 22119 } 22120 /** 22121 * Return `true` if the given filePath is an absolute url. 22122 * 22123 * @param {string} filePath path 22124 * 22125 * @return {boolean} is absolute path. 22126 */ 22127 22128 22129 function isAbsolutePath(filePath) { 22130 return /^\/(?!\/)/.test(filePath); 22131 } 22132 /** 22133 * Whether or not the url should be inluded. 22134 * 22135 * @param {Object} meta url meta info 22136 * 22137 * @return {boolean} is valid. 22138 */ 22139 22140 22141 function isValidURL(meta) { 22142 // Ignore hashes or data uris. 22143 if (meta.value.indexOf('data:') === 0 || meta.value.indexOf('#') === 0) { 22144 return false; 22145 } 22146 22147 if (isAbsolutePath(meta.value)) { 22148 return false; 22149 } // Do not handle the http/https urls if `includeRemote` is false. 22150 22151 22152 if (isRemotePath(meta.value)) { 22153 return false; 22154 } 22155 22156 return true; 22157 } 22158 /** 22159 * Get the absolute path of the url, relative to the basePath 22160 * 22161 * @param {string} str the url 22162 * @param {string} baseURL base URL 22163 * 22164 * @return {string} the full path to the file 22165 */ 22166 22167 22168 function getResourcePath(str, baseURL) { 22169 return new URL(str, baseURL).toString(); 22170 } 22171 /** 22172 * Process the single `url()` pattern 22173 * 22174 * @param {string} baseURL the base URL for relative URLs. 22175 * 22176 * @return {Promise} the Promise. 22177 */ 22178 22179 22180 function processURL(baseURL) { 22181 return meta => ({ ...meta, 22182 newUrl: 'url(' + meta.before + meta.quote + getResourcePath(meta.value, baseURL) + meta.quote + meta.after + ')' 22183 }); 22184 } 22185 /** 22186 * Get all `url()`s, and return the meta info 22187 * 22188 * @param {string} value decl.value. 22189 * 22190 * @return {Array} the urls. 22191 */ 22192 22193 22194 function getURLs(value) { 22195 const reg = /url\((\s*)(['"]?)(.+?)\2(\s*)\)/g; 22196 let match; 22197 const URLs = []; 22198 22199 while ((match = reg.exec(value)) !== null) { 22200 const meta = { 22201 source: match[0], 22202 before: match[1], 22203 quote: match[2], 22204 value: match[3], 22205 after: match[4] 22206 }; 22207 22208 if (isValidURL(meta)) { 22209 URLs.push(meta); 22210 } 22211 } 22212 22213 return URLs; 22214 } 22215 /** 22216 * Replace the raw value's `url()` segment to the new value 22217 * 22218 * @param {string} raw the raw value. 22219 * @param {Array} URLs the URLs to replace. 22220 * 22221 * @return {string} the new value. 22222 */ 22223 22224 22225 function replaceURLs(raw, URLs) { 22226 URLs.forEach(item => { 22227 raw = raw.replace(item.source, item.newUrl); 22228 }); 22229 return raw; 22230 } 22231 22232 const rewrite = rootURL => node => { 22233 if (node.type === 'declaration') { 22234 const updatedURLs = getURLs(node.value).map(processURL(rootURL)); 22235 return { ...node, 22236 value: replaceURLs(node.value, updatedURLs) 22237 }; 22238 } 22239 22240 return node; 22241 }; 22242 22243 /* harmony default export */ var url_rewrite = (rewrite); 22244 22245 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/utils/transform-styles/transforms/wrap.js 22246 /** 22247 * @constant string IS_ROOT_TAG Regex to check if the selector is a root tag selector. 22248 */ 22249 const IS_ROOT_TAG = /^(body|html|:root).*$/; 22250 /** 22251 * Creates a callback to modify selectors so they only apply within a certain 22252 * namespace. 22253 * 22254 * @param {string} namespace Namespace to prefix selectors with. 22255 * @param {string[]} ignore Selectors to not prefix. 22256 * 22257 * @return {(node: Object) => Object} Callback to wrap selectors. 22258 */ 22259 22260 const wrap = function (namespace) { 22261 let ignore = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : []; 22262 return node => { 22263 /** 22264 * Updates selector if necessary. 22265 * 22266 * @param {string} selector Selector to modify. 22267 * 22268 * @return {string} Updated selector. 22269 */ 22270 const updateSelector = selector => { 22271 if (ignore.includes(selector.trim())) { 22272 return selector; 22273 } // Anything other than a root tag is always prefixed. 22274 22275 22276 { 22277 if (!selector.match(IS_ROOT_TAG)) { 22278 return namespace + ' ' + selector; 22279 } 22280 } // HTML and Body elements cannot be contained within our container so lets extract their styles. 22281 22282 return selector.replace(/^(body|html|:root)/, namespace); 22283 }; 22284 22285 if (node.type === 'rule') { 22286 return { ...node, 22287 selectors: node.selectors.map(updateSelector) 22288 }; 22289 } 22290 22291 return node; 22292 }; 22293 }; 22294 22295 /* harmony default export */ var transforms_wrap = (wrap); 22296 22297 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/utils/transform-styles/index.js 22298 /** 22299 * External dependencies 22300 */ 22301 22302 /** 22303 * WordPress dependencies 22304 */ 22305 22306 22307 /** 22308 * Internal dependencies 22309 */ 22310 22311 22312 22313 22314 /** 22315 * Applies a series of CSS rule transforms to wrap selectors inside a given class and/or rewrite URLs depending on the parameters passed. 22316 * 22317 * @param {Array} styles CSS rules. 22318 * @param {string} wrapperClassName Wrapper Class Name. 22319 * @return {Array} converted rules. 22320 */ 22321 22322 const transform_styles_transformStyles = function (styles) { 22323 let wrapperClassName = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : ''; 22324 return (0,external_lodash_namespaceObject.map)(styles, _ref => { 22325 let { 22326 css, 22327 baseURL 22328 } = _ref; 22329 const transforms = []; 22330 22331 if (wrapperClassName) { 22332 transforms.push(transforms_wrap(wrapperClassName)); 22333 } 22334 22335 if (baseURL) { 22336 transforms.push(url_rewrite(baseURL)); 22337 } 22338 22339 if (transforms.length) { 22340 return transform_styles_traverse(css, (0,external_wp_compose_namespaceObject.compose)(transforms)); 22341 } 22342 22343 return css; 22344 }); 22345 }; 22346 22347 /* harmony default export */ var transform_styles = (transform_styles_transformStyles); 22348 22349 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/editor-styles/index.js 22350 22351 22352 /** 22353 * External dependencies 22354 */ 22355 22356 22357 22358 /** 22359 * WordPress dependencies 22360 */ 22361 22362 22363 /** 22364 * Internal dependencies 22365 */ 22366 22367 22368 const EDITOR_STYLES_SELECTOR = '.editor-styles-wrapper'; 22369 k([names, a11y]); 22370 22371 function useDarkThemeBodyClassName(styles) { 22372 return (0,external_wp_element_namespaceObject.useCallback)(node => { 22373 if (!node) { 22374 return; 22375 } 22376 22377 const { 22378 ownerDocument 22379 } = node; 22380 const { 22381 defaultView, 22382 body 22383 } = ownerDocument; 22384 const canvas = ownerDocument.querySelector(EDITOR_STYLES_SELECTOR); 22385 let backgroundColor; 22386 22387 if (!canvas) { 22388 // The real .editor-styles-wrapper element might not exist in the 22389 // DOM, so calculate the background color by creating a fake 22390 // wrapper. 22391 const tempCanvas = ownerDocument.createElement('div'); 22392 tempCanvas.classList.add('editor-styles-wrapper'); 22393 body.appendChild(tempCanvas); 22394 backgroundColor = defaultView.getComputedStyle(tempCanvas, null).getPropertyValue('background-color'); 22395 body.removeChild(tempCanvas); 22396 } else { 22397 backgroundColor = defaultView.getComputedStyle(canvas, null).getPropertyValue('background-color'); 22398 } 22399 22400 const colordBackgroundColor = w(backgroundColor); // If background is transparent, it should be treated as light color. 22401 22402 if (colordBackgroundColor.luminance() > 0.5 || colordBackgroundColor.alpha() === 0) { 22403 body.classList.remove('is-dark-theme'); 22404 } else { 22405 body.classList.add('is-dark-theme'); 22406 } 22407 }, [styles]); 22408 } 22409 22410 function EditorStyles(_ref) { 22411 let { 22412 styles 22413 } = _ref; 22414 const transformedStyles = (0,external_wp_element_namespaceObject.useMemo)(() => transform_styles(styles, EDITOR_STYLES_SELECTOR), [styles]); 22415 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("style", { 22416 ref: useDarkThemeBodyClassName(styles) 22417 }), transformedStyles.map((css, index) => (0,external_wp_element_namespaceObject.createElement)("style", { 22418 key: index 22419 }, css))); 22420 } 22421 22422 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-preview/auto.js 22423 22424 22425 /** 22426 * WordPress dependencies 22427 */ 22428 22429 22430 22431 22432 /** 22433 * Internal dependencies 22434 */ 22435 22436 22437 22438 22439 // This is used to avoid rendering the block list if the sizes change. 22440 22441 let MemoizedBlockList; 22442 const MAX_HEIGHT = 2000; 22443 22444 function AutoBlockPreview(_ref) { 22445 let { 22446 viewportWidth, 22447 __experimentalPadding, 22448 __experimentalMinHeight 22449 } = _ref; 22450 const [containerResizeListener, { 22451 width: containerWidth 22452 }] = (0,external_wp_compose_namespaceObject.useResizeObserver)(); 22453 const [contentResizeListener, { 22454 height: contentHeight 22455 }] = (0,external_wp_compose_namespaceObject.useResizeObserver)(); 22456 const { 22457 styles, 22458 assets 22459 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 22460 const settings = select(store).getSettings(); 22461 return { 22462 styles: settings.styles, 22463 assets: settings.__unstableResolvedAssets 22464 }; 22465 }, []); // Avoid scrollbars for pattern previews. 22466 22467 const editorStyles = (0,external_wp_element_namespaceObject.useMemo)(() => { 22468 if (styles) { 22469 return [...styles, { 22470 css: 'body{height:auto;overflow:hidden;}', 22471 __unstableType: 'presets' 22472 }]; 22473 } 22474 22475 return styles; 22476 }, [styles]); // Initialize on render instead of module top level, to avoid circular dependency issues. 22477 22478 MemoizedBlockList = MemoizedBlockList || (0,external_wp_compose_namespaceObject.pure)(BlockList); 22479 const scale = containerWidth / viewportWidth; 22480 return (0,external_wp_element_namespaceObject.createElement)("div", { 22481 className: "block-editor-block-preview__container" 22482 }, containerResizeListener, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Disabled, { 22483 className: "block-editor-block-preview__content", 22484 style: { 22485 transform: `scale($scale})`, 22486 height: contentHeight * scale, 22487 maxHeight: contentHeight > MAX_HEIGHT ? MAX_HEIGHT * scale : undefined, 22488 minHeight: __experimentalMinHeight 22489 } 22490 }, (0,external_wp_element_namespaceObject.createElement)(iframe, { 22491 head: (0,external_wp_element_namespaceObject.createElement)(EditorStyles, { 22492 styles: editorStyles 22493 }), 22494 assets: assets, 22495 contentRef: (0,external_wp_compose_namespaceObject.useRefEffect)(bodyElement => { 22496 const { 22497 ownerDocument: { 22498 documentElement 22499 } 22500 } = bodyElement; 22501 documentElement.classList.add('block-editor-block-preview__content-iframe'); 22502 documentElement.style.position = 'absolute'; 22503 documentElement.style.width = '100%'; 22504 bodyElement.style.padding = __experimentalPadding + 'px'; // necessary for contentResizeListener to work. 22505 22506 bodyElement.style.position = 'relative'; 22507 }, []), 22508 "aria-hidden": true, 22509 tabIndex: -1, 22510 style: { 22511 position: 'absolute', 22512 width: viewportWidth, 22513 height: contentHeight, 22514 pointerEvents: 'none', 22515 // This is a catch-all max-height for patterns. 22516 // See: https://github.com/WordPress/gutenberg/pull/38175. 22517 maxHeight: MAX_HEIGHT, 22518 minHeight: scale < 1 && __experimentalMinHeight ? __experimentalMinHeight / scale : __experimentalMinHeight 22519 } 22520 }, contentResizeListener, (0,external_wp_element_namespaceObject.createElement)(MemoizedBlockList, { 22521 renderAppender: false 22522 })))); 22523 } 22524 22525 /* harmony default export */ var auto = (AutoBlockPreview); 22526 22527 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-preview/index.js 22528 22529 22530 /** 22531 * External dependencies 22532 */ 22533 22534 22535 /** 22536 * WordPress dependencies 22537 */ 22538 22539 22540 22541 22542 /** 22543 * Internal dependencies 22544 */ 22545 22546 22547 22548 22549 22550 22551 function BlockPreview(_ref) { 22552 let { 22553 blocks, 22554 __experimentalPadding = 0, 22555 viewportWidth = 1200, 22556 __experimentalLive = false, 22557 __experimentalOnClick, 22558 __experimentalMinHeight 22559 } = _ref; 22560 const originalSettings = (0,external_wp_data_namespaceObject.useSelect)(select => select(store).getSettings(), []); 22561 const settings = (0,external_wp_element_namespaceObject.useMemo)(() => { 22562 const _settings = { ...originalSettings 22563 }; 22564 _settings.__experimentalBlockPatterns = []; 22565 return _settings; 22566 }, [originalSettings]); 22567 const renderedBlocks = (0,external_wp_element_namespaceObject.useMemo)(() => (0,external_lodash_namespaceObject.castArray)(blocks), [blocks]); 22568 22569 if (!blocks || blocks.length === 0) { 22570 return null; 22571 } 22572 22573 return (0,external_wp_element_namespaceObject.createElement)(provider, { 22574 value: renderedBlocks, 22575 settings: settings 22576 }, __experimentalLive ? (0,external_wp_element_namespaceObject.createElement)(LiveBlockPreview, { 22577 onClick: __experimentalOnClick 22578 }) : (0,external_wp_element_namespaceObject.createElement)(auto, { 22579 viewportWidth: viewportWidth, 22580 __experimentalPadding: __experimentalPadding, 22581 __experimentalMinHeight: __experimentalMinHeight 22582 })); 22583 } 22584 /** 22585 * BlockPreview renders a preview of a block or array of blocks. 22586 * 22587 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/block-preview/README.md 22588 * 22589 * @param {Object} preview options for how the preview should be shown 22590 * @param {Array|Object} preview.blocks A block instance (object) or an array of blocks to be previewed. 22591 * @param {number} preview.viewportWidth Width of the preview container in pixels. Controls at what size the blocks will be rendered inside the preview. Default: 700. 22592 * 22593 * @return {WPComponent} The component to be rendered. 22594 */ 22595 22596 /* harmony default export */ var block_preview = ((0,external_wp_element_namespaceObject.memo)(BlockPreview)); 22597 /** 22598 * This hook is used to lightly mark an element as a block preview wrapper 22599 * element. Call this hook and pass the returned props to the element to mark as 22600 * a block preview wrapper, automatically rendering inner blocks as children. If 22601 * you define a ref for the element, it is important to pass the ref to this 22602 * hook, which the hook in turn will pass to the component through the props it 22603 * returns. Optionally, you can also pass any other props through this hook, and 22604 * they will be merged and returned. 22605 * 22606 * @param {Object} options Preview options. 22607 * @param {WPBlock[]} options.blocks Block objects. 22608 * @param {Object} options.props Optional. Props to pass to the element. Must contain 22609 * the ref if one is defined. 22610 * @param {Object} options.__experimentalLayout Layout settings to be used in the preview. 22611 * 22612 */ 22613 22614 function useBlockPreview(_ref2) { 22615 let { 22616 blocks, 22617 props = {}, 22618 __experimentalLayout 22619 } = _ref2; 22620 const originalSettings = (0,external_wp_data_namespaceObject.useSelect)(select => select(store).getSettings(), []); 22621 const disabledRef = (0,external_wp_compose_namespaceObject.__experimentalUseDisabled)(); 22622 const ref = (0,external_wp_compose_namespaceObject.useMergeRefs)([props.ref, disabledRef]); 22623 const settings = (0,external_wp_element_namespaceObject.useMemo)(() => ({ ...originalSettings, 22624 __experimentalBlockPatterns: [] 22625 }), [originalSettings]); 22626 const renderedBlocks = (0,external_wp_element_namespaceObject.useMemo)(() => (0,external_lodash_namespaceObject.castArray)(blocks), [blocks]); 22627 const children = (0,external_wp_element_namespaceObject.createElement)(provider, { 22628 value: renderedBlocks, 22629 settings: settings 22630 }, (0,external_wp_element_namespaceObject.createElement)(BlockListItems, { 22631 renderAppender: false, 22632 __experimentalLayout: __experimentalLayout 22633 })); 22634 return { ...props, 22635 ref, 22636 className: classnames_default()(props.className, 'block-editor-block-preview__live-content', 'components-disabled'), 22637 children: blocks !== null && blocks !== void 0 && blocks.length ? children : null 22638 }; 22639 } 22640 22641 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inserter/preview-panel.js 22642 22643 22644 /** 22645 * WordPress dependencies 22646 */ 22647 22648 22649 /** 22650 * Internal dependencies 22651 */ 22652 22653 22654 22655 22656 function InserterPreviewPanel(_ref) { 22657 var _hoveredItemBlockType, _hoveredItemBlockType2; 22658 22659 let { 22660 item 22661 } = _ref; 22662 const { 22663 name, 22664 title, 22665 icon, 22666 description, 22667 initialAttributes 22668 } = item; 22669 const hoveredItemBlockType = (0,external_wp_blocks_namespaceObject.getBlockType)(name); 22670 const isReusable = (0,external_wp_blocks_namespaceObject.isReusableBlock)(item); 22671 return (0,external_wp_element_namespaceObject.createElement)("div", { 22672 className: "block-editor-inserter__preview-container" 22673 }, (0,external_wp_element_namespaceObject.createElement)("div", { 22674 className: "block-editor-inserter__preview" 22675 }, isReusable || hoveredItemBlockType !== null && hoveredItemBlockType !== void 0 && hoveredItemBlockType.example ? (0,external_wp_element_namespaceObject.createElement)("div", { 22676 className: "block-editor-inserter__preview-content" 22677 }, (0,external_wp_element_namespaceObject.createElement)(block_preview, { 22678 __experimentalPadding: 16, 22679 viewportWidth: (_hoveredItemBlockType = (_hoveredItemBlockType2 = hoveredItemBlockType.example) === null || _hoveredItemBlockType2 === void 0 ? void 0 : _hoveredItemBlockType2.viewportWidth) !== null && _hoveredItemBlockType !== void 0 ? _hoveredItemBlockType : 500, 22680 blocks: hoveredItemBlockType.example ? (0,external_wp_blocks_namespaceObject.getBlockFromExample)(item.name, { 22681 attributes: { ...hoveredItemBlockType.example.attributes, 22682 ...initialAttributes 22683 }, 22684 innerBlocks: hoveredItemBlockType.example.innerBlocks 22685 }) : (0,external_wp_blocks_namespaceObject.createBlock)(name, initialAttributes) 22686 })) : (0,external_wp_element_namespaceObject.createElement)("div", { 22687 className: "block-editor-inserter__preview-content-missing" 22688 }, (0,external_wp_i18n_namespaceObject.__)('No Preview Available.'))), !isReusable && (0,external_wp_element_namespaceObject.createElement)(block_card, { 22689 title: title, 22690 icon: icon, 22691 description: description 22692 })); 22693 } 22694 22695 /* harmony default export */ var preview_panel = (InserterPreviewPanel); 22696 22697 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inserter-listbox/context.js 22698 /** 22699 * WordPress dependencies 22700 */ 22701 22702 const InserterListboxContext = (0,external_wp_element_namespaceObject.createContext)(); 22703 /* harmony default export */ var context = (InserterListboxContext); 22704 22705 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inserter-listbox/item.js 22706 22707 22708 22709 /** 22710 * WordPress dependencies 22711 */ 22712 22713 22714 /** 22715 * Internal dependencies 22716 */ 22717 22718 22719 22720 function InserterListboxItem(_ref, ref) { 22721 let { 22722 isFirst, 22723 as: Component, 22724 children, 22725 ...props 22726 } = _ref; 22727 const state = (0,external_wp_element_namespaceObject.useContext)(context); 22728 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__unstableCompositeItem, _extends({ 22729 ref: ref, 22730 state: state, 22731 role: "option" // Use the CompositeItem `focusable` prop over Button's 22732 // isFocusable. The latter was shown to cause an issue 22733 // with tab order in the inserter list. 22734 , 22735 focusable: true 22736 }, props), htmlProps => { 22737 const propsWithTabIndex = { ...htmlProps, 22738 tabIndex: isFirst ? 0 : htmlProps.tabIndex 22739 }; 22740 22741 if (Component) { 22742 return (0,external_wp_element_namespaceObject.createElement)(Component, propsWithTabIndex, children); 22743 } 22744 22745 if (typeof children === 'function') { 22746 return children(propsWithTabIndex); 22747 } 22748 22749 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, propsWithTabIndex, children); 22750 }); 22751 } 22752 22753 /* harmony default export */ var inserter_listbox_item = ((0,external_wp_element_namespaceObject.forwardRef)(InserterListboxItem)); 22754 22755 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/drag-handle.js 22756 22757 22758 /** 22759 * WordPress dependencies 22760 */ 22761 22762 const dragHandle = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 22763 width: "24", 22764 height: "24", 22765 xmlns: "http://www.w3.org/2000/svg", 22766 viewBox: "0 0 24 24" 22767 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 22768 d: "M8 7h2V5H8v2zm0 6h2v-2H8v2zm0 6h2v-2H8v2zm6-14v2h2V5h-2zm0 8h2v-2h-2v2zm0 6h2v-2h-2v2z" 22769 })); 22770 /* harmony default export */ var drag_handle = (dragHandle); 22771 22772 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-draggable/draggable-chip.js 22773 22774 22775 /** 22776 * WordPress dependencies 22777 */ 22778 22779 22780 22781 /** 22782 * Internal dependencies 22783 */ 22784 22785 22786 function BlockDraggableChip(_ref) { 22787 let { 22788 count, 22789 icon 22790 } = _ref; 22791 return (0,external_wp_element_namespaceObject.createElement)("div", { 22792 className: "block-editor-block-draggable-chip-wrapper" 22793 }, (0,external_wp_element_namespaceObject.createElement)("div", { 22794 className: "block-editor-block-draggable-chip" 22795 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Flex, { 22796 justify: "center", 22797 className: "block-editor-block-draggable-chip__content" 22798 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FlexItem, null, icon ? (0,external_wp_element_namespaceObject.createElement)(block_icon, { 22799 icon: icon 22800 }) : (0,external_wp_i18n_namespaceObject.sprintf)( 22801 /* translators: %d: Number of blocks. */ 22802 (0,external_wp_i18n_namespaceObject._n)('%d block', '%d blocks', count), count)), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FlexItem, null, (0,external_wp_element_namespaceObject.createElement)(block_icon, { 22803 icon: drag_handle 22804 }))))); 22805 } 22806 22807 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inserter-draggable-blocks/index.js 22808 22809 22810 /** 22811 * WordPress dependencies 22812 */ 22813 22814 /** 22815 * Internal dependencies 22816 */ 22817 22818 22819 22820 const InserterDraggableBlocks = _ref => { 22821 let { 22822 isEnabled, 22823 blocks, 22824 icon, 22825 children 22826 } = _ref; 22827 const transferData = { 22828 type: 'inserter', 22829 blocks 22830 }; 22831 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Draggable, { 22832 __experimentalTransferDataType: "wp-blocks", 22833 transferData: transferData, 22834 __experimentalDragComponent: (0,external_wp_element_namespaceObject.createElement)(BlockDraggableChip, { 22835 count: blocks.length, 22836 icon: icon 22837 }) 22838 }, _ref2 => { 22839 let { 22840 onDraggableStart, 22841 onDraggableEnd 22842 } = _ref2; 22843 return children({ 22844 draggable: isEnabled, 22845 onDragStart: isEnabled ? onDraggableStart : undefined, 22846 onDragEnd: isEnabled ? onDraggableEnd : undefined 22847 }); 22848 }); 22849 }; 22850 22851 /* harmony default export */ var inserter_draggable_blocks = (InserterDraggableBlocks); 22852 22853 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inserter-list-item/index.js 22854 22855 22856 22857 /** 22858 * External dependencies 22859 */ 22860 22861 /** 22862 * WordPress dependencies 22863 */ 22864 22865 22866 22867 22868 /** 22869 * Internal dependencies 22870 */ 22871 22872 22873 22874 22875 /** 22876 * Return true if platform is MacOS. 22877 * 22878 * @param {Object} _window window object by default; used for DI testing. 22879 * 22880 * @return {boolean} True if MacOS; false otherwise. 22881 */ 22882 22883 function isAppleOS() { 22884 let _window = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : window; 22885 22886 const { 22887 platform 22888 } = _window.navigator; 22889 return platform.indexOf('Mac') !== -1 || ['iPad', 'iPhone'].includes(platform); 22890 } 22891 22892 function InserterListItem(_ref) { 22893 let { 22894 className, 22895 isFirst, 22896 item, 22897 onSelect, 22898 onHover, 22899 isDraggable, 22900 ...props 22901 } = _ref; 22902 const isDragging = (0,external_wp_element_namespaceObject.useRef)(false); 22903 const itemIconStyle = item.icon ? { 22904 backgroundColor: item.icon.background, 22905 color: item.icon.foreground 22906 } : {}; 22907 const blocks = (0,external_wp_element_namespaceObject.useMemo)(() => { 22908 return [(0,external_wp_blocks_namespaceObject.createBlock)(item.name, item.initialAttributes, (0,external_wp_blocks_namespaceObject.createBlocksFromInnerBlocksTemplate)(item.innerBlocks))]; 22909 }, [item.name, item.initialAttributes, item.initialAttributes]); 22910 return (0,external_wp_element_namespaceObject.createElement)(inserter_draggable_blocks, { 22911 isEnabled: isDraggable && !item.disabled, 22912 blocks: blocks, 22913 icon: item.icon 22914 }, _ref2 => { 22915 let { 22916 draggable, 22917 onDragStart, 22918 onDragEnd 22919 } = _ref2; 22920 return (0,external_wp_element_namespaceObject.createElement)("div", { 22921 className: "block-editor-block-types-list__list-item", 22922 draggable: draggable, 22923 onDragStart: event => { 22924 isDragging.current = true; 22925 22926 if (onDragStart) { 22927 onHover(null); 22928 onDragStart(event); 22929 } 22930 }, 22931 onDragEnd: event => { 22932 isDragging.current = false; 22933 22934 if (onDragEnd) { 22935 onDragEnd(event); 22936 } 22937 } 22938 }, (0,external_wp_element_namespaceObject.createElement)(inserter_listbox_item, _extends({ 22939 isFirst: isFirst, 22940 className: classnames_default()('block-editor-block-types-list__item', className), 22941 disabled: item.isDisabled, 22942 onClick: event => { 22943 event.preventDefault(); 22944 onSelect(item, isAppleOS() ? event.metaKey : event.ctrlKey); 22945 onHover(null); 22946 }, 22947 onKeyDown: event => { 22948 const { 22949 keyCode 22950 } = event; 22951 22952 if (keyCode === external_wp_keycodes_namespaceObject.ENTER) { 22953 event.preventDefault(); 22954 onSelect(item, isAppleOS() ? event.metaKey : event.ctrlKey); 22955 onHover(null); 22956 } 22957 }, 22958 onFocus: () => { 22959 if (isDragging.current) { 22960 return; 22961 } 22962 22963 onHover(item); 22964 }, 22965 onMouseEnter: () => { 22966 if (isDragging.current) { 22967 return; 22968 } 22969 22970 onHover(item); 22971 }, 22972 onMouseLeave: () => onHover(null), 22973 onBlur: () => onHover(null) 22974 }, props), (0,external_wp_element_namespaceObject.createElement)("span", { 22975 className: "block-editor-block-types-list__item-icon", 22976 style: itemIconStyle 22977 }, (0,external_wp_element_namespaceObject.createElement)(block_icon, { 22978 icon: item.icon, 22979 showColors: true 22980 })), (0,external_wp_element_namespaceObject.createElement)("span", { 22981 className: "block-editor-block-types-list__item-title" 22982 }, item.title))); 22983 }); 22984 } 22985 22986 /* harmony default export */ var inserter_list_item = ((0,external_wp_element_namespaceObject.memo)(InserterListItem)); 22987 22988 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inserter-listbox/group.js 22989 22990 22991 22992 /** 22993 * WordPress dependencies 22994 */ 22995 22996 22997 22998 22999 function InserterListboxGroup(props, ref) { 23000 const [shouldSpeak, setShouldSpeak] = (0,external_wp_element_namespaceObject.useState)(false); 23001 (0,external_wp_element_namespaceObject.useEffect)(() => { 23002 if (shouldSpeak) { 23003 (0,external_wp_a11y_namespaceObject.speak)((0,external_wp_i18n_namespaceObject.__)('Use left and right arrow keys to move through blocks')); 23004 } 23005 }, [shouldSpeak]); 23006 return (0,external_wp_element_namespaceObject.createElement)("div", _extends({ 23007 ref: ref, 23008 role: "listbox", 23009 "aria-orientation": "horizontal", 23010 onFocus: () => { 23011 setShouldSpeak(true); 23012 }, 23013 onBlur: event => { 23014 const focusingOutsideGroup = !event.currentTarget.contains(event.relatedTarget); 23015 23016 if (focusingOutsideGroup) { 23017 setShouldSpeak(false); 23018 } 23019 } 23020 }, props)); 23021 } 23022 23023 /* harmony default export */ var group = ((0,external_wp_element_namespaceObject.forwardRef)(InserterListboxGroup)); 23024 23025 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inserter-listbox/row.js 23026 23027 23028 23029 /** 23030 * WordPress dependencies 23031 */ 23032 23033 23034 /** 23035 * Internal dependencies 23036 */ 23037 23038 23039 23040 function InserterListboxRow(props, ref) { 23041 const state = (0,external_wp_element_namespaceObject.useContext)(context); 23042 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__unstableCompositeGroup, _extends({ 23043 state: state, 23044 role: "presentation", 23045 ref: ref 23046 }, props)); 23047 } 23048 23049 /* harmony default export */ var inserter_listbox_row = ((0,external_wp_element_namespaceObject.forwardRef)(InserterListboxRow)); 23050 23051 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-types-list/index.js 23052 23053 23054 /** 23055 * WordPress dependencies 23056 */ 23057 23058 /** 23059 * Internal dependencies 23060 */ 23061 23062 23063 23064 23065 function chunk(array, size) { 23066 const chunks = []; 23067 23068 for (let i = 0, j = array.length; i < j; i += size) { 23069 chunks.push(array.slice(i, i + size)); 23070 } 23071 23072 return chunks; 23073 } 23074 23075 function BlockTypesList(_ref) { 23076 let { 23077 items = [], 23078 onSelect, 23079 onHover = () => {}, 23080 children, 23081 label, 23082 isDraggable = true 23083 } = _ref; 23084 return (0,external_wp_element_namespaceObject.createElement)(group, { 23085 className: "block-editor-block-types-list", 23086 "aria-label": label 23087 }, chunk(items, 3).map((row, i) => (0,external_wp_element_namespaceObject.createElement)(inserter_listbox_row, { 23088 key: i 23089 }, row.map((item, j) => (0,external_wp_element_namespaceObject.createElement)(inserter_list_item, { 23090 key: item.id, 23091 item: item, 23092 className: (0,external_wp_blocks_namespaceObject.getBlockMenuDefaultClassName)(item.id), 23093 onSelect: onSelect, 23094 onHover: onHover, 23095 isDraggable: isDraggable, 23096 isFirst: i === 0 && j === 0 23097 })))), children); 23098 } 23099 23100 /* harmony default export */ var block_types_list = (BlockTypesList); 23101 23102 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inserter/panel.js 23103 23104 23105 /** 23106 * WordPress dependencies 23107 */ 23108 23109 23110 function InserterPanel(_ref) { 23111 let { 23112 title, 23113 icon, 23114 children 23115 } = _ref; 23116 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("div", { 23117 className: "block-editor-inserter__panel-header" 23118 }, (0,external_wp_element_namespaceObject.createElement)("h2", { 23119 className: "block-editor-inserter__panel-title" 23120 }, title), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Icon, { 23121 icon: icon 23122 })), (0,external_wp_element_namespaceObject.createElement)("div", { 23123 className: "block-editor-inserter__panel-content" 23124 }, children)); 23125 } 23126 23127 /* harmony default export */ var panel = (InserterPanel); 23128 23129 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inserter/hooks/use-block-types-state.js 23130 /** 23131 * WordPress dependencies 23132 */ 23133 23134 23135 23136 /** 23137 * Internal dependencies 23138 */ 23139 23140 23141 /** 23142 * Retrieves the block types inserter state. 23143 * 23144 * @param {string=} rootClientId Insertion's root client ID. 23145 * @param {Function} onInsert function called when inserter a list of blocks. 23146 * @return {Array} Returns the block types state. (block types, categories, collections, onSelect handler) 23147 */ 23148 23149 const useBlockTypesState = (rootClientId, onInsert) => { 23150 const { 23151 categories, 23152 collections, 23153 items 23154 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 23155 const { 23156 getInserterItems 23157 } = select(store); 23158 const { 23159 getCategories, 23160 getCollections 23161 } = select(external_wp_blocks_namespaceObject.store); 23162 return { 23163 categories: getCategories(), 23164 collections: getCollections(), 23165 items: getInserterItems(rootClientId) 23166 }; 23167 }, [rootClientId]); 23168 const onSelectItem = (0,external_wp_element_namespaceObject.useCallback)((_ref, shouldFocusBlock) => { 23169 let { 23170 name, 23171 initialAttributes, 23172 innerBlocks 23173 } = _ref; 23174 const insertedBlock = (0,external_wp_blocks_namespaceObject.createBlock)(name, initialAttributes, (0,external_wp_blocks_namespaceObject.createBlocksFromInnerBlocksTemplate)(innerBlocks)); 23175 onInsert(insertedBlock, undefined, shouldFocusBlock); 23176 }, [onInsert]); 23177 return [items, categories, collections, onSelectItem]; 23178 }; 23179 23180 /* harmony default export */ var use_block_types_state = (useBlockTypesState); 23181 23182 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inserter-listbox/index.js 23183 23184 23185 /** 23186 * WordPress dependencies 23187 */ 23188 23189 /** 23190 * Internal dependencies 23191 */ 23192 23193 23194 23195 23196 23197 23198 function InserterListbox(_ref) { 23199 let { 23200 children 23201 } = _ref; 23202 const compositeState = (0,external_wp_components_namespaceObject.__unstableUseCompositeState)({ 23203 shift: true, 23204 wrap: 'horizontal' 23205 }); 23206 return (0,external_wp_element_namespaceObject.createElement)(context.Provider, { 23207 value: compositeState 23208 }, children); 23209 } 23210 23211 /* harmony default export */ var inserter_listbox = (InserterListbox); 23212 23213 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inserter/block-types-tab.js 23214 23215 23216 /** 23217 * External dependencies 23218 */ 23219 23220 /** 23221 * WordPress dependencies 23222 */ 23223 23224 23225 23226 23227 /** 23228 * Internal dependencies 23229 */ 23230 23231 23232 23233 23234 23235 23236 const getBlockNamespace = item => item.name.split('/')[0]; 23237 23238 const MAX_SUGGESTED_ITEMS = 6; 23239 /** 23240 * Shared reference to an empty array for cases where it is important to avoid 23241 * returning a new array reference on every invocation and rerendering the component. 23242 * 23243 * @type {Array} 23244 */ 23245 23246 const block_types_tab_EMPTY_ARRAY = []; 23247 function BlockTypesTab(_ref) { 23248 let { 23249 rootClientId, 23250 onInsert, 23251 onHover, 23252 showMostUsedBlocks 23253 } = _ref; 23254 const [items, categories, collections, onSelectItem] = use_block_types_state(rootClientId, onInsert); 23255 const suggestedItems = (0,external_wp_element_namespaceObject.useMemo)(() => { 23256 return (0,external_lodash_namespaceObject.orderBy)(items, ['frecency'], ['desc']).slice(0, MAX_SUGGESTED_ITEMS); 23257 }, [items]); 23258 const uncategorizedItems = (0,external_wp_element_namespaceObject.useMemo)(() => { 23259 return items.filter(item => !item.category); 23260 }, [items]); 23261 const itemsPerCategory = (0,external_wp_element_namespaceObject.useMemo)(() => { 23262 return (0,external_lodash_namespaceObject.flow)(itemList => itemList.filter(item => item.category && item.category !== 'reusable'), itemList => (0,external_lodash_namespaceObject.groupBy)(itemList, 'category'))(items); 23263 }, [items]); 23264 const itemsPerCollection = (0,external_wp_element_namespaceObject.useMemo)(() => { 23265 // Create a new Object to avoid mutating collection. 23266 const result = { ...collections 23267 }; 23268 Object.keys(collections).forEach(namespace => { 23269 result[namespace] = items.filter(item => getBlockNamespace(item) === namespace); 23270 23271 if (result[namespace].length === 0) { 23272 delete result[namespace]; 23273 } 23274 }); 23275 return result; 23276 }, [items, collections]); // Hide block preview on unmount. 23277 23278 (0,external_wp_element_namespaceObject.useEffect)(() => () => onHover(null), []); 23279 /** 23280 * The inserter contains a big number of blocks and opening it is a costful operation. 23281 * The rendering is the most costful part of it, in order to improve the responsiveness 23282 * of the "opening" action, these lazy lists allow us to render the inserter category per category, 23283 * once all the categories are rendered, we start rendering the collections and the uncategorized block types. 23284 */ 23285 23286 const currentlyRenderedCategories = (0,external_wp_compose_namespaceObject.useAsyncList)(categories); 23287 const didRenderAllCategories = categories.length === currentlyRenderedCategories.length; // Async List requires an array. 23288 23289 const collectionEntries = (0,external_wp_element_namespaceObject.useMemo)(() => { 23290 return Object.entries(collections); 23291 }, [collections]); 23292 const currentlyRenderedCollections = (0,external_wp_compose_namespaceObject.useAsyncList)(didRenderAllCategories ? collectionEntries : block_types_tab_EMPTY_ARRAY); 23293 return (0,external_wp_element_namespaceObject.createElement)(inserter_listbox, null, (0,external_wp_element_namespaceObject.createElement)("div", null, showMostUsedBlocks && !!suggestedItems.length && (0,external_wp_element_namespaceObject.createElement)(panel, { 23294 title: (0,external_wp_i18n_namespaceObject._x)('Most used', 'blocks') 23295 }, (0,external_wp_element_namespaceObject.createElement)(block_types_list, { 23296 items: suggestedItems, 23297 onSelect: onSelectItem, 23298 onHover: onHover, 23299 label: (0,external_wp_i18n_namespaceObject._x)('Most used', 'blocks') 23300 })), (0,external_lodash_namespaceObject.map)(currentlyRenderedCategories, category => { 23301 const categoryItems = itemsPerCategory[category.slug]; 23302 23303 if (!categoryItems || !categoryItems.length) { 23304 return null; 23305 } 23306 23307 return (0,external_wp_element_namespaceObject.createElement)(panel, { 23308 key: category.slug, 23309 title: category.title, 23310 icon: category.icon 23311 }, (0,external_wp_element_namespaceObject.createElement)(block_types_list, { 23312 items: categoryItems, 23313 onSelect: onSelectItem, 23314 onHover: onHover, 23315 label: category.title 23316 })); 23317 }), didRenderAllCategories && uncategorizedItems.length > 0 && (0,external_wp_element_namespaceObject.createElement)(panel, { 23318 className: "block-editor-inserter__uncategorized-blocks-panel", 23319 title: (0,external_wp_i18n_namespaceObject.__)('Uncategorized') 23320 }, (0,external_wp_element_namespaceObject.createElement)(block_types_list, { 23321 items: uncategorizedItems, 23322 onSelect: onSelectItem, 23323 onHover: onHover, 23324 label: (0,external_wp_i18n_namespaceObject.__)('Uncategorized') 23325 })), (0,external_lodash_namespaceObject.map)(currentlyRenderedCollections, _ref2 => { 23326 let [namespace, collection] = _ref2; 23327 const collectionItems = itemsPerCollection[namespace]; 23328 23329 if (!collectionItems || !collectionItems.length) { 23330 return null; 23331 } 23332 23333 return (0,external_wp_element_namespaceObject.createElement)(panel, { 23334 key: namespace, 23335 title: collection.title, 23336 icon: collection.icon 23337 }, (0,external_wp_element_namespaceObject.createElement)(block_types_list, { 23338 items: collectionItems, 23339 onSelect: onSelectItem, 23340 onHover: onHover, 23341 label: collection.title 23342 })); 23343 }))); 23344 } 23345 /* harmony default export */ var block_types_tab = (BlockTypesTab); 23346 23347 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inserter/pattern-panel.js 23348 23349 23350 /** 23351 * External dependencies 23352 */ 23353 23354 /** 23355 * WordPress dependencies 23356 */ 23357 23358 23359 23360 23361 23362 function PatternInserterPanel(_ref) { 23363 let { 23364 selectedCategory, 23365 patternCategories, 23366 onClickCategory, 23367 openPatternExplorer 23368 } = _ref; 23369 const isMobile = (0,external_wp_compose_namespaceObject.useViewportMatch)('medium', '<'); 23370 23371 const categoryOptions = () => { 23372 const options = []; 23373 patternCategories.map(patternCategory => { 23374 return options.push({ 23375 value: patternCategory.name, 23376 label: patternCategory.label 23377 }); 23378 }); 23379 return options; 23380 }; 23381 23382 const onChangeSelect = selected => { 23383 onClickCategory(patternCategories.find(patternCategory => selected === patternCategory.name)); 23384 }; 23385 23386 const className = classnames_default()('block-editor-inserter__panel-header', 'block-editor-inserter__panel-header-patterns'); // In iOS-based mobile devices, the onBlur will fire when selecting an option 23387 // from a Select element. To prevent closing the useDialog on iOS devices, we 23388 // stop propagating the onBlur event if there is no relatedTarget, which means 23389 // that the user most likely did not click on an element within the editor canvas. 23390 23391 const onBlur = event => { 23392 if (!(event !== null && event !== void 0 && event.relatedTarget)) { 23393 event.stopPropagation(); 23394 } 23395 }; 23396 23397 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Flex, { 23398 justify: "space-between", 23399 align: "start", 23400 gap: "4", 23401 className: className 23402 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FlexItem, { 23403 isBlock: true 23404 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SelectControl, { 23405 className: "block-editor-inserter__panel-dropdown", 23406 label: (0,external_wp_i18n_namespaceObject.__)('Filter patterns'), 23407 hideLabelFromVision: true, 23408 value: selectedCategory.name, 23409 onChange: onChangeSelect, 23410 onBlur: onBlur, 23411 options: categoryOptions() 23412 })), !isMobile && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FlexItem, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 23413 variant: "secondary", 23414 className: "block-editor-inserter__patterns-explorer-expand", 23415 label: (0,external_wp_i18n_namespaceObject.__)('Explore all patterns'), 23416 onClick: () => openPatternExplorer() 23417 }, (0,external_wp_i18n_namespaceObject._x)('Explore', 'Label for showing all block patterns')))); 23418 } 23419 23420 /* harmony default export */ var pattern_panel = (PatternInserterPanel); 23421 23422 ;// CONCATENATED MODULE: external ["wp","notices"] 23423 var external_wp_notices_namespaceObject = window["wp"]["notices"]; 23424 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inserter/hooks/use-patterns-state.js 23425 /** 23426 * External dependencies 23427 */ 23428 23429 /** 23430 * WordPress dependencies 23431 */ 23432 23433 23434 23435 23436 23437 23438 /** 23439 * Internal dependencies 23440 */ 23441 23442 23443 /** 23444 * Retrieves the block patterns inserter state. 23445 * 23446 * @param {Function} onInsert function called when inserter a list of blocks. 23447 * @param {string=} rootClientId Insertion's root client ID. 23448 * 23449 * @return {Array} Returns the patterns state. (patterns, categories, onSelect handler) 23450 */ 23451 23452 const usePatternsState = (onInsert, rootClientId) => { 23453 const { 23454 patternCategories, 23455 patterns 23456 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 23457 const { 23458 __experimentalGetAllowedPatterns, 23459 getSettings 23460 } = select(store); 23461 return { 23462 patterns: __experimentalGetAllowedPatterns(rootClientId), 23463 patternCategories: getSettings().__experimentalBlockPatternCategories 23464 }; 23465 }, [rootClientId]); 23466 const { 23467 createSuccessNotice 23468 } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_notices_namespaceObject.store); 23469 const onClickPattern = (0,external_wp_element_namespaceObject.useCallback)((pattern, blocks) => { 23470 onInsert((0,external_lodash_namespaceObject.map)(blocks, block => (0,external_wp_blocks_namespaceObject.cloneBlock)(block)), pattern.name); 23471 createSuccessNotice((0,external_wp_i18n_namespaceObject.sprintf)( 23472 /* translators: %s: block pattern title. */ 23473 (0,external_wp_i18n_namespaceObject.__)('Block pattern "%s" inserted.'), pattern.title), { 23474 type: 'snackbar' 23475 }); 23476 }, []); 23477 return [patterns, patternCategories, onClickPattern]; 23478 }; 23479 23480 /* harmony default export */ var use_patterns_state = (usePatternsState); 23481 23482 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-patterns-list/index.js 23483 23484 23485 23486 /** 23487 * WordPress dependencies 23488 */ 23489 23490 23491 23492 /** 23493 * Internal dependencies 23494 */ 23495 23496 23497 23498 23499 function BlockPattern(_ref) { 23500 let { 23501 isDraggable, 23502 pattern, 23503 onClick, 23504 composite 23505 } = _ref; 23506 const { 23507 blocks, 23508 viewportWidth 23509 } = pattern; 23510 const instanceId = (0,external_wp_compose_namespaceObject.useInstanceId)(BlockPattern); 23511 const descriptionId = `block-editor-block-patterns-list__item-description-$instanceId}`; 23512 return (0,external_wp_element_namespaceObject.createElement)(inserter_draggable_blocks, { 23513 isEnabled: isDraggable, 23514 blocks: blocks 23515 }, _ref2 => { 23516 let { 23517 draggable, 23518 onDragStart, 23519 onDragEnd 23520 } = _ref2; 23521 return (0,external_wp_element_namespaceObject.createElement)("div", { 23522 className: "block-editor-block-patterns-list__list-item", 23523 "aria-label": pattern.title, 23524 "aria-describedby": pattern.description ? descriptionId : undefined, 23525 draggable: draggable, 23526 onDragStart: onDragStart, 23527 onDragEnd: onDragEnd 23528 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__unstableCompositeItem, _extends({ 23529 role: "option", 23530 as: "div" 23531 }, composite, { 23532 className: "block-editor-block-patterns-list__item", 23533 onClick: () => onClick(pattern, blocks) 23534 }), (0,external_wp_element_namespaceObject.createElement)(block_preview, { 23535 blocks: blocks, 23536 viewportWidth: viewportWidth 23537 }), (0,external_wp_element_namespaceObject.createElement)("div", { 23538 className: "block-editor-block-patterns-list__item-title" 23539 }, pattern.title), !!pattern.description && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.VisuallyHidden, { 23540 id: descriptionId 23541 }, pattern.description))); 23542 }); 23543 } 23544 23545 function BlockPatternPlaceholder() { 23546 return (0,external_wp_element_namespaceObject.createElement)("div", { 23547 className: "block-editor-block-patterns-list__item is-placeholder" 23548 }); 23549 } 23550 23551 function BlockPatternList(_ref3) { 23552 let { 23553 isDraggable, 23554 blockPatterns, 23555 shownPatterns, 23556 onClickPattern, 23557 orientation, 23558 label = (0,external_wp_i18n_namespaceObject.__)('Block Patterns') 23559 } = _ref3; 23560 const composite = (0,external_wp_components_namespaceObject.__unstableUseCompositeState)({ 23561 orientation 23562 }); 23563 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__unstableComposite, _extends({}, composite, { 23564 role: "listbox", 23565 className: "block-editor-block-patterns-list", 23566 "aria-label": label 23567 }), blockPatterns.map(pattern => { 23568 const isShown = shownPatterns.includes(pattern); 23569 return isShown ? (0,external_wp_element_namespaceObject.createElement)(BlockPattern, { 23570 key: pattern.name, 23571 pattern: pattern, 23572 onClick: onClickPattern, 23573 isDraggable: isDraggable, 23574 composite: composite 23575 }) : (0,external_wp_element_namespaceObject.createElement)(BlockPatternPlaceholder, { 23576 key: pattern.name 23577 }); 23578 })); 23579 } 23580 23581 /* harmony default export */ var block_patterns_list = (BlockPatternList); 23582 23583 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inserter/block-patterns-explorer/sidebar.js 23584 23585 23586 /** 23587 * WordPress dependencies 23588 */ 23589 23590 23591 23592 function PatternCategoriesList(_ref) { 23593 let { 23594 selectedCategory, 23595 patternCategories, 23596 onClickCategory 23597 } = _ref; 23598 const baseClassName = 'block-editor-block-patterns-explorer__sidebar'; 23599 return (0,external_wp_element_namespaceObject.createElement)("div", { 23600 className: `$baseClassName}__categories-list` 23601 }, patternCategories.map(_ref2 => { 23602 let { 23603 name, 23604 label 23605 } = _ref2; 23606 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 23607 key: name, 23608 label: label, 23609 className: `$baseClassName}__categories-list__item`, 23610 isPressed: selectedCategory === name, 23611 onClick: () => { 23612 onClickCategory(name); 23613 } 23614 }, label); 23615 })); 23616 } 23617 23618 function PatternsExplorerSearch(_ref3) { 23619 let { 23620 filterValue, 23621 setFilterValue 23622 } = _ref3; 23623 const baseClassName = 'block-editor-block-patterns-explorer__search'; 23624 return (0,external_wp_element_namespaceObject.createElement)("div", { 23625 className: baseClassName 23626 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SearchControl, { 23627 onChange: setFilterValue, 23628 value: filterValue, 23629 label: (0,external_wp_i18n_namespaceObject.__)('Search for patterns'), 23630 placeholder: (0,external_wp_i18n_namespaceObject.__)('Search') 23631 })); 23632 } 23633 23634 function PatternExplorerSidebar(_ref4) { 23635 let { 23636 selectedCategory, 23637 patternCategories, 23638 onClickCategory, 23639 filterValue, 23640 setFilterValue 23641 } = _ref4; 23642 const baseClassName = 'block-editor-block-patterns-explorer__sidebar'; 23643 return (0,external_wp_element_namespaceObject.createElement)("div", { 23644 className: baseClassName 23645 }, (0,external_wp_element_namespaceObject.createElement)(PatternsExplorerSearch, { 23646 filterValue: filterValue, 23647 setFilterValue: setFilterValue 23648 }), !filterValue && (0,external_wp_element_namespaceObject.createElement)(PatternCategoriesList, { 23649 selectedCategory: selectedCategory, 23650 patternCategories: patternCategories, 23651 onClickCategory: onClickCategory 23652 })); 23653 } 23654 23655 /* harmony default export */ var sidebar = (PatternExplorerSidebar); 23656 23657 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inserter/no-results.js 23658 23659 23660 /** 23661 * WordPress dependencies 23662 */ 23663 23664 23665 23666 function InserterNoResults() { 23667 return (0,external_wp_element_namespaceObject.createElement)("div", { 23668 className: "block-editor-inserter__no-results" 23669 }, (0,external_wp_element_namespaceObject.createElement)(build_module_icon, { 23670 className: "block-editor-inserter__no-results-icon", 23671 icon: block_default 23672 }), (0,external_wp_element_namespaceObject.createElement)("p", null, (0,external_wp_i18n_namespaceObject.__)('No results found.'))); 23673 } 23674 23675 /* harmony default export */ var no_results = (InserterNoResults); 23676 23677 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inserter/hooks/use-insertion-point.js 23678 /** 23679 * External dependencies 23680 */ 23681 23682 /** 23683 * WordPress dependencies 23684 */ 23685 23686 23687 23688 23689 23690 23691 /** 23692 * Internal dependencies 23693 */ 23694 23695 23696 /** 23697 * @typedef WPInserterConfig 23698 * 23699 * @property {string=} rootClientId If set, insertion will be into the 23700 * block with this ID. 23701 * @property {number=} insertionIndex If set, insertion will be into this 23702 * explicit position. 23703 * @property {string=} clientId If set, insertion will be after the 23704 * block with this ID. 23705 * @property {boolean=} isAppender Whether the inserter is an appender 23706 * or not. 23707 * @property {Function=} onSelect Called after insertion. 23708 */ 23709 23710 /** 23711 * Returns the insertion point state given the inserter config. 23712 * 23713 * @param {WPInserterConfig} config Inserter Config. 23714 * @return {Array} Insertion Point State (rootClientID, onInsertBlocks and onToggle). 23715 */ 23716 23717 function useInsertionPoint(_ref) { 23718 let { 23719 rootClientId = '', 23720 insertionIndex, 23721 clientId, 23722 isAppender, 23723 onSelect, 23724 shouldFocusBlock = true 23725 } = _ref; 23726 const { 23727 getSelectedBlock 23728 } = (0,external_wp_data_namespaceObject.useSelect)(store); 23729 const { 23730 destinationRootClientId, 23731 destinationIndex 23732 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 23733 const { 23734 getSelectedBlockClientId, 23735 getBlockRootClientId, 23736 getBlockIndex, 23737 getBlockOrder 23738 } = select(store); 23739 const selectedBlockClientId = getSelectedBlockClientId(); 23740 let _destinationRootClientId = rootClientId; 23741 23742 let _destinationIndex; 23743 23744 if (insertionIndex !== undefined) { 23745 // Insert into a specific index. 23746 _destinationIndex = insertionIndex; 23747 } else if (clientId) { 23748 // Insert after a specific client ID. 23749 _destinationIndex = getBlockIndex(clientId); 23750 } else if (!isAppender && selectedBlockClientId) { 23751 _destinationRootClientId = getBlockRootClientId(selectedBlockClientId); 23752 _destinationIndex = getBlockIndex(selectedBlockClientId) + 1; 23753 } else { 23754 // Insert at the end of the list. 23755 _destinationIndex = getBlockOrder(_destinationRootClientId).length; 23756 } 23757 23758 return { 23759 destinationRootClientId: _destinationRootClientId, 23760 destinationIndex: _destinationIndex 23761 }; 23762 }, [rootClientId, insertionIndex, clientId, isAppender]); 23763 const { 23764 replaceBlocks, 23765 insertBlocks, 23766 showInsertionPoint, 23767 hideInsertionPoint 23768 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 23769 const onInsertBlocks = (0,external_wp_element_namespaceObject.useCallback)(function (blocks, meta) { 23770 let shouldForceFocusBlock = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; 23771 const selectedBlock = getSelectedBlock(); 23772 23773 if (!isAppender && selectedBlock && (0,external_wp_blocks_namespaceObject.isUnmodifiedDefaultBlock)(selectedBlock)) { 23774 replaceBlocks(selectedBlock.clientId, blocks, null, shouldFocusBlock || shouldForceFocusBlock ? 0 : null, meta); 23775 } else { 23776 insertBlocks(blocks, destinationIndex, destinationRootClientId, true, shouldFocusBlock || shouldForceFocusBlock ? 0 : null, meta); 23777 } 23778 23779 const message = (0,external_wp_i18n_namespaceObject.sprintf)( // translators: %d: the name of the block that has been added 23780 (0,external_wp_i18n_namespaceObject._n)('%d block added.', '%d blocks added.', (0,external_lodash_namespaceObject.castArray)(blocks).length), (0,external_lodash_namespaceObject.castArray)(blocks).length); 23781 (0,external_wp_a11y_namespaceObject.speak)(message); 23782 23783 if (onSelect) { 23784 onSelect(); 23785 } 23786 }, [isAppender, getSelectedBlock, replaceBlocks, insertBlocks, destinationRootClientId, destinationIndex, onSelect, shouldFocusBlock]); 23787 const onToggleInsertionPoint = (0,external_wp_element_namespaceObject.useCallback)(show => { 23788 if (show) { 23789 showInsertionPoint(destinationRootClientId, destinationIndex); 23790 } else { 23791 hideInsertionPoint(); 23792 } 23793 }, [showInsertionPoint, hideInsertionPoint, destinationRootClientId, destinationIndex]); 23794 return [destinationRootClientId, onInsertBlocks, onToggleInsertionPoint]; 23795 } 23796 23797 /* harmony default export */ var use_insertion_point = (useInsertionPoint); 23798 23799 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inserter/search-items.js 23800 /** 23801 * External dependencies 23802 */ 23803 // Default search helpers. 23804 23805 const defaultGetName = item => item.name || ''; 23806 23807 const defaultGetTitle = item => item.title; 23808 23809 const defaultGetDescription = item => item.description || ''; 23810 23811 const defaultGetKeywords = item => item.keywords || []; 23812 23813 const defaultGetCategory = item => item.category; 23814 23815 const defaultGetCollection = () => null; 23816 /** 23817 * Sanitizes the search input string. 23818 * 23819 * @param {string} input The search input to normalize. 23820 * 23821 * @return {string} The normalized search input. 23822 */ 23823 23824 23825 function normalizeSearchInput() { 23826 let input = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : ''; 23827 // Disregard diacritics. 23828 // Input: "média" 23829 input = (0,external_lodash_namespaceObject.deburr)(input); // Accommodate leading slash, matching autocomplete expectations. 23830 // Input: "/media" 23831 23832 input = input.replace(/^\//, ''); // Lowercase. 23833 // Input: "MEDIA" 23834 23835 input = input.toLowerCase(); 23836 return input; 23837 } 23838 /** 23839 * Converts the search term into a list of normalized terms. 23840 * 23841 * @param {string} input The search term to normalize. 23842 * 23843 * @return {string[]} The normalized list of search terms. 23844 */ 23845 23846 23847 const getNormalizedSearchTerms = function () { 23848 let input = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : ''; 23849 // Extract words. 23850 return (0,external_lodash_namespaceObject.words)(normalizeSearchInput(input)); 23851 }; 23852 23853 const removeMatchingTerms = (unmatchedTerms, unprocessedTerms) => { 23854 return (0,external_lodash_namespaceObject.differenceWith)(unmatchedTerms, getNormalizedSearchTerms(unprocessedTerms), (unmatchedTerm, unprocessedTerm) => unprocessedTerm.includes(unmatchedTerm)); 23855 }; 23856 23857 const searchBlockItems = (items, categories, collections, searchInput) => { 23858 const normalizedSearchTerms = getNormalizedSearchTerms(searchInput); 23859 23860 if (normalizedSearchTerms.length === 0) { 23861 return items; 23862 } 23863 23864 const config = { 23865 getCategory: item => { 23866 var _find; 23867 23868 return (_find = (0,external_lodash_namespaceObject.find)(categories, { 23869 slug: item.category 23870 })) === null || _find === void 0 ? void 0 : _find.title; 23871 }, 23872 getCollection: item => { 23873 var _collections$item$nam; 23874 23875 return (_collections$item$nam = collections[item.name.split('/')[0]]) === null || _collections$item$nam === void 0 ? void 0 : _collections$item$nam.title; 23876 } 23877 }; 23878 return searchItems(items, searchInput, config); 23879 }; 23880 /** 23881 * Filters an item list given a search term. 23882 * 23883 * @param {Array} items Item list 23884 * @param {string} searchInput Search input. 23885 * @param {Object} config Search Config. 23886 * 23887 * @return {Array} Filtered item list. 23888 */ 23889 23890 const searchItems = function () { 23891 let items = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : []; 23892 let searchInput = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : ''; 23893 let config = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; 23894 const normalizedSearchTerms = getNormalizedSearchTerms(searchInput); 23895 23896 if (normalizedSearchTerms.length === 0) { 23897 return items; 23898 } 23899 23900 const rankedItems = items.map(item => { 23901 return [item, getItemSearchRank(item, searchInput, config)]; 23902 }).filter(_ref => { 23903 let [, rank] = _ref; 23904 return rank > 0; 23905 }); 23906 rankedItems.sort((_ref2, _ref3) => { 23907 let [, rank1] = _ref2; 23908 let [, rank2] = _ref3; 23909 return rank2 - rank1; 23910 }); 23911 return rankedItems.map(_ref4 => { 23912 let [item] = _ref4; 23913 return item; 23914 }); 23915 }; 23916 /** 23917 * Get the search rank for a given item and a specific search term. 23918 * The better the match, the higher the rank. 23919 * If the rank equals 0, it should be excluded from the results. 23920 * 23921 * @param {Object} item Item to filter. 23922 * @param {string} searchTerm Search term. 23923 * @param {Object} config Search Config. 23924 * 23925 * @return {number} Search Rank. 23926 */ 23927 23928 function getItemSearchRank(item, searchTerm) { 23929 let config = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; 23930 const { 23931 getName = defaultGetName, 23932 getTitle = defaultGetTitle, 23933 getDescription = defaultGetDescription, 23934 getKeywords = defaultGetKeywords, 23935 getCategory = defaultGetCategory, 23936 getCollection = defaultGetCollection 23937 } = config; 23938 const name = getName(item); 23939 const title = getTitle(item); 23940 const description = getDescription(item); 23941 const keywords = getKeywords(item); 23942 const category = getCategory(item); 23943 const collection = getCollection(item); 23944 const normalizedSearchInput = normalizeSearchInput(searchTerm); 23945 const normalizedTitle = normalizeSearchInput(title); 23946 let rank = 0; // Prefers exact matches 23947 // Then prefers if the beginning of the title matches the search term 23948 // name, keywords, categories, collection, variations match come later. 23949 23950 if (normalizedSearchInput === normalizedTitle) { 23951 rank += 30; 23952 } else if (normalizedTitle.startsWith(normalizedSearchInput)) { 23953 rank += 20; 23954 } else { 23955 const terms = [name, title, description, ...keywords, category, collection].join(' '); 23956 const normalizedSearchTerms = (0,external_lodash_namespaceObject.words)(normalizedSearchInput); 23957 const unmatchedTerms = removeMatchingTerms(normalizedSearchTerms, terms); 23958 23959 if (unmatchedTerms.length === 0) { 23960 rank += 10; 23961 } 23962 } // Give a better rank to "core" namespaced items. 23963 23964 23965 if (rank !== 0 && name.startsWith('core/')) { 23966 const isCoreBlockVariation = name !== item.id; // Give a bit better rank to "core" blocks over "core" block variations. 23967 23968 rank += isCoreBlockVariation ? 1 : 2; 23969 } 23970 23971 return rank; 23972 } 23973 23974 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inserter/block-patterns-explorer/patterns-list.js 23975 23976 23977 /** 23978 * WordPress dependencies 23979 */ 23980 23981 23982 23983 23984 23985 /** 23986 * Internal dependencies 23987 */ 23988 23989 23990 23991 23992 23993 23994 23995 const INITIAL_INSERTER_RESULTS = 2; 23996 23997 function PatternsListHeader(_ref) { 23998 let { 23999 filterValue, 24000 filteredBlockPatternsLength 24001 } = _ref; 24002 24003 if (!filterValue) { 24004 return null; 24005 } 24006 24007 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalHeading, { 24008 level: 2, 24009 lineHeight: '48px', 24010 className: "block-editor-block-patterns-explorer__search-results-count" 24011 }, (0,external_wp_i18n_namespaceObject.sprintf)( 24012 /* translators: %d: number of patterns. %s: block pattern search query */ 24013 (0,external_wp_i18n_namespaceObject._n)('%1$d pattern found for "%2$s"', '%1$d patterns found for "%2$s"', filteredBlockPatternsLength), filteredBlockPatternsLength, filterValue)); 24014 } 24015 24016 function PatternList(_ref2) { 24017 let { 24018 filterValue, 24019 selectedCategory, 24020 patternCategories 24021 } = _ref2; 24022 const debouncedSpeak = (0,external_wp_compose_namespaceObject.useDebounce)(external_wp_a11y_namespaceObject.speak, 500); 24023 const [destinationRootClientId, onInsertBlocks] = use_insertion_point({ 24024 shouldFocusBlock: true 24025 }); 24026 const [allPatterns,, onSelectBlockPattern] = use_patterns_state(onInsertBlocks, destinationRootClientId); 24027 const registeredPatternCategories = (0,external_wp_element_namespaceObject.useMemo)(() => patternCategories.map(patternCategory => patternCategory.name), [patternCategories]); 24028 const filteredBlockPatterns = (0,external_wp_element_namespaceObject.useMemo)(() => { 24029 if (!filterValue) { 24030 return allPatterns.filter(pattern => { 24031 var _pattern$categories, _pattern$categories2; 24032 24033 return selectedCategory === 'uncategorized' ? !((_pattern$categories = pattern.categories) !== null && _pattern$categories !== void 0 && _pattern$categories.length) || pattern.categories.every(category => !registeredPatternCategories.includes(category)) : (_pattern$categories2 = pattern.categories) === null || _pattern$categories2 === void 0 ? void 0 : _pattern$categories2.includes(selectedCategory); 24034 }); 24035 } 24036 24037 return searchItems(allPatterns, filterValue); 24038 }, [filterValue, selectedCategory, allPatterns]); // Announce search results on change. 24039 24040 (0,external_wp_element_namespaceObject.useEffect)(() => { 24041 if (!filterValue) { 24042 return; 24043 } 24044 24045 const count = filteredBlockPatterns.length; 24046 const resultsFoundMessage = (0,external_wp_i18n_namespaceObject.sprintf)( 24047 /* translators: %d: number of results. */ 24048 (0,external_wp_i18n_namespaceObject._n)('%d result found.', '%d results found.', count), count); 24049 debouncedSpeak(resultsFoundMessage); 24050 }, [filterValue, debouncedSpeak]); 24051 const currentShownPatterns = (0,external_wp_compose_namespaceObject.useAsyncList)(filteredBlockPatterns, { 24052 step: INITIAL_INSERTER_RESULTS 24053 }); 24054 const hasItems = !!(filteredBlockPatterns !== null && filteredBlockPatterns !== void 0 && filteredBlockPatterns.length); 24055 return (0,external_wp_element_namespaceObject.createElement)("div", { 24056 className: "block-editor-block-patterns-explorer__list" 24057 }, hasItems && (0,external_wp_element_namespaceObject.createElement)(PatternsListHeader, { 24058 filterValue: filterValue, 24059 filteredBlockPatternsLength: filteredBlockPatterns.length 24060 }), (0,external_wp_element_namespaceObject.createElement)(inserter_listbox, null, !hasItems && (0,external_wp_element_namespaceObject.createElement)(no_results, null), hasItems && (0,external_wp_element_namespaceObject.createElement)(block_patterns_list, { 24061 shownPatterns: currentShownPatterns, 24062 blockPatterns: filteredBlockPatterns, 24063 onClickPattern: onSelectBlockPattern, 24064 isDraggable: false 24065 }))); 24066 } 24067 24068 /* harmony default export */ var patterns_list = (PatternList); 24069 24070 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inserter/block-patterns-explorer/explorer.js 24071 24072 24073 /** 24074 * WordPress dependencies 24075 */ 24076 24077 24078 24079 /** 24080 * Internal dependencies 24081 */ 24082 24083 24084 24085 24086 function PatternsExplorer(_ref) { 24087 let { 24088 initialCategory, 24089 patternCategories 24090 } = _ref; 24091 const [filterValue, setFilterValue] = (0,external_wp_element_namespaceObject.useState)(''); 24092 const [selectedCategory, setSelectedCategory] = (0,external_wp_element_namespaceObject.useState)(initialCategory === null || initialCategory === void 0 ? void 0 : initialCategory.name); 24093 return (0,external_wp_element_namespaceObject.createElement)("div", { 24094 className: "block-editor-block-patterns-explorer" 24095 }, (0,external_wp_element_namespaceObject.createElement)(sidebar, { 24096 selectedCategory: selectedCategory, 24097 patternCategories: patternCategories, 24098 onClickCategory: setSelectedCategory, 24099 filterValue: filterValue, 24100 setFilterValue: setFilterValue 24101 }), (0,external_wp_element_namespaceObject.createElement)(patterns_list, { 24102 filterValue: filterValue, 24103 selectedCategory: selectedCategory, 24104 patternCategories: patternCategories 24105 })); 24106 } 24107 24108 function PatternsExplorerModal(_ref2) { 24109 let { 24110 onModalClose, 24111 ...restProps 24112 } = _ref2; 24113 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Modal, { 24114 title: (0,external_wp_i18n_namespaceObject.__)('Patterns'), 24115 closeLabel: (0,external_wp_i18n_namespaceObject.__)('Close'), 24116 onRequestClose: onModalClose, 24117 isFullScreen: true 24118 }, (0,external_wp_element_namespaceObject.createElement)(PatternsExplorer, restProps)); 24119 } 24120 24121 /* harmony default export */ var explorer = (PatternsExplorerModal); 24122 24123 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inserter/block-patterns-tab.js 24124 24125 24126 /** 24127 * WordPress dependencies 24128 */ 24129 24130 24131 24132 /** 24133 * Internal dependencies 24134 */ 24135 24136 24137 24138 24139 24140 24141 function BlockPatternsCategory(_ref) { 24142 let { 24143 rootClientId, 24144 onInsert, 24145 selectedCategory, 24146 populatedCategories 24147 } = _ref; 24148 const [allPatterns,, onClick] = use_patterns_state(onInsert, rootClientId); 24149 const getPatternIndex = (0,external_wp_element_namespaceObject.useCallback)(pattern => { 24150 var _pattern$categories; 24151 24152 if (!((_pattern$categories = pattern.categories) !== null && _pattern$categories !== void 0 && _pattern$categories.length)) { 24153 return Infinity; 24154 } 24155 24156 const indexedCategories = populatedCategories.reduce((accumulator, _ref2, index) => { 24157 let { 24158 name 24159 } = _ref2; 24160 accumulator[name] = index; 24161 return accumulator; 24162 }, {}); 24163 return Math.min(...pattern.categories.map(cat => indexedCategories[cat] !== undefined ? indexedCategories[cat] : Infinity)); 24164 }, [populatedCategories]); 24165 const currentCategoryPatterns = (0,external_wp_element_namespaceObject.useMemo)(() => allPatterns.filter(pattern => { 24166 var _pattern$categories2; 24167 24168 return selectedCategory.name === 'uncategorized' ? getPatternIndex(pattern) === Infinity : (_pattern$categories2 = pattern.categories) === null || _pattern$categories2 === void 0 ? void 0 : _pattern$categories2.includes(selectedCategory.name); 24169 }), [allPatterns, selectedCategory]); // Ordering the patterns is important for the async rendering. 24170 24171 const orderedPatterns = (0,external_wp_element_namespaceObject.useMemo)(() => { 24172 return currentCategoryPatterns.sort((a, b) => { 24173 return getPatternIndex(a) - getPatternIndex(b); 24174 }); 24175 }, [currentCategoryPatterns, getPatternIndex]); 24176 const currentShownPatterns = (0,external_wp_compose_namespaceObject.useAsyncList)(orderedPatterns); 24177 24178 if (!currentCategoryPatterns.length) { 24179 return null; 24180 } 24181 24182 return (0,external_wp_element_namespaceObject.createElement)("div", { 24183 className: "block-editor-inserter__panel-content" 24184 }, (0,external_wp_element_namespaceObject.createElement)(block_patterns_list, { 24185 shownPatterns: currentShownPatterns, 24186 blockPatterns: currentCategoryPatterns, 24187 onClickPattern: onClick, 24188 label: selectedCategory.label, 24189 orientation: "vertical", 24190 isDraggable: true 24191 })); 24192 } 24193 24194 function BlockPatternsTabs(_ref3) { 24195 let { 24196 rootClientId, 24197 onInsert, 24198 onClickCategory, 24199 selectedCategory 24200 } = _ref3; 24201 const [showPatternsExplorer, setShowPatternsExplorer] = (0,external_wp_element_namespaceObject.useState)(false); 24202 const [allPatterns, allCategories] = use_patterns_state(); 24203 const hasRegisteredCategory = (0,external_wp_element_namespaceObject.useCallback)(pattern => { 24204 if (!pattern.categories || !pattern.categories.length) { 24205 return false; 24206 } 24207 24208 return pattern.categories.some(cat => allCategories.some(category => category.name === cat)); 24209 }, [allCategories]); // Remove any empty categories. 24210 24211 const populatedCategories = (0,external_wp_element_namespaceObject.useMemo)(() => { 24212 const categories = allCategories.filter(category => allPatterns.some(pattern => { 24213 var _pattern$categories3; 24214 24215 return (_pattern$categories3 = pattern.categories) === null || _pattern$categories3 === void 0 ? void 0 : _pattern$categories3.includes(category.name); 24216 })).sort((_ref4, _ref5) => { 24217 let { 24218 name: currentName 24219 } = _ref4; 24220 let { 24221 name: nextName 24222 } = _ref5; 24223 24224 if (![currentName, nextName].includes('featured')) { 24225 return 0; 24226 } 24227 24228 return currentName === 'featured' ? -1 : 1; 24229 }); 24230 24231 if (allPatterns.some(pattern => !hasRegisteredCategory(pattern)) && !categories.find(category => category.name === 'uncategorized')) { 24232 categories.push({ 24233 name: 'uncategorized', 24234 label: (0,external_wp_i18n_namespaceObject._x)('Uncategorized') 24235 }); 24236 } 24237 24238 return categories; 24239 }, [allPatterns, allCategories]); 24240 const patternCategory = selectedCategory ? selectedCategory : populatedCategories[0]; 24241 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(pattern_panel, { 24242 selectedCategory: patternCategory, 24243 patternCategories: populatedCategories, 24244 onClickCategory: onClickCategory, 24245 openPatternExplorer: () => setShowPatternsExplorer(true) 24246 }), !showPatternsExplorer && (0,external_wp_element_namespaceObject.createElement)(BlockPatternsCategory, { 24247 rootClientId: rootClientId, 24248 onInsert: onInsert, 24249 selectedCategory: patternCategory, 24250 populatedCategories: populatedCategories 24251 }), showPatternsExplorer && (0,external_wp_element_namespaceObject.createElement)(explorer, { 24252 initialCategory: patternCategory, 24253 patternCategories: populatedCategories, 24254 onModalClose: () => setShowPatternsExplorer(false) 24255 })); 24256 } 24257 24258 /* harmony default export */ var block_patterns_tab = (BlockPatternsTabs); 24259 24260 ;// CONCATENATED MODULE: external ["wp","url"] 24261 var external_wp_url_namespaceObject = window["wp"]["url"]; 24262 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inserter/reusable-blocks-tab.js 24263 24264 24265 /** 24266 * WordPress dependencies 24267 */ 24268 24269 24270 24271 /** 24272 * Internal dependencies 24273 */ 24274 24275 24276 24277 24278 24279 24280 function ReusableBlocksList(_ref) { 24281 let { 24282 onHover, 24283 onInsert, 24284 rootClientId 24285 } = _ref; 24286 const [items,,, onSelectItem] = use_block_types_state(rootClientId, onInsert); 24287 const filteredItems = (0,external_wp_element_namespaceObject.useMemo)(() => { 24288 return items.filter(_ref2 => { 24289 let { 24290 category 24291 } = _ref2; 24292 return category === 'reusable'; 24293 }); 24294 }, [items]); 24295 24296 if (filteredItems.length === 0) { 24297 return (0,external_wp_element_namespaceObject.createElement)(no_results, null); 24298 } 24299 24300 return (0,external_wp_element_namespaceObject.createElement)(panel, { 24301 title: (0,external_wp_i18n_namespaceObject.__)('Reusable blocks') 24302 }, (0,external_wp_element_namespaceObject.createElement)(block_types_list, { 24303 items: filteredItems, 24304 onSelect: onSelectItem, 24305 onHover: onHover, 24306 label: (0,external_wp_i18n_namespaceObject.__)('Reusable blocks') 24307 })); 24308 } // The unwrapped component is only exported for use by unit tests. 24309 24310 /** 24311 * List of reusable blocks shown in the "Reusable" tab of the inserter. 24312 * 24313 * @param {Object} props Component props. 24314 * @param {?string} props.rootClientId Client id of block to insert into. 24315 * @param {Function} props.onInsert Callback to run when item is inserted. 24316 * @param {Function} props.onHover Callback to run when item is hovered. 24317 * 24318 * @return {WPComponent} The component. 24319 */ 24320 24321 24322 function ReusableBlocksTab(_ref3) { 24323 let { 24324 rootClientId, 24325 onInsert, 24326 onHover 24327 } = _ref3; 24328 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(ReusableBlocksList, { 24329 onHover: onHover, 24330 onInsert: onInsert, 24331 rootClientId: rootClientId 24332 }), (0,external_wp_element_namespaceObject.createElement)("div", { 24333 className: "block-editor-inserter__manage-reusable-blocks-container" 24334 }, (0,external_wp_element_namespaceObject.createElement)("a", { 24335 className: "block-editor-inserter__manage-reusable-blocks", 24336 href: (0,external_wp_url_namespaceObject.addQueryArgs)('edit.php', { 24337 post_type: 'wp_block' 24338 }) 24339 }, (0,external_wp_i18n_namespaceObject.__)('Manage Reusable blocks')))); 24340 } 24341 /* harmony default export */ var reusable_blocks_tab = (ReusableBlocksTab); 24342 24343 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inserter-menu-extension/index.js 24344 /** 24345 * WordPress dependencies 24346 */ 24347 24348 const { 24349 Fill: __unstableInserterMenuExtension, 24350 Slot 24351 } = (0,external_wp_components_namespaceObject.createSlotFill)('__unstableInserterMenuExtension'); 24352 __unstableInserterMenuExtension.Slot = Slot; 24353 /* harmony default export */ var inserter_menu_extension = (__unstableInserterMenuExtension); 24354 24355 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inserter/search-results.js 24356 24357 24358 /** 24359 * External dependencies 24360 */ 24361 24362 /** 24363 * WordPress dependencies 24364 */ 24365 24366 24367 24368 24369 24370 24371 /** 24372 * Internal dependencies 24373 */ 24374 24375 24376 24377 24378 24379 24380 24381 24382 24383 24384 24385 const search_results_INITIAL_INSERTER_RESULTS = 9; 24386 /** 24387 * Shared reference to an empty array for cases where it is important to avoid 24388 * returning a new array reference on every invocation and rerendering the component. 24389 * 24390 * @type {Array} 24391 */ 24392 24393 const search_results_EMPTY_ARRAY = []; 24394 24395 function InserterSearchResults(_ref) { 24396 let { 24397 filterValue, 24398 onSelect, 24399 onHover, 24400 rootClientId, 24401 clientId, 24402 isAppender, 24403 __experimentalInsertionIndex, 24404 maxBlockPatterns, 24405 maxBlockTypes, 24406 showBlockDirectory = false, 24407 isDraggable = true, 24408 shouldFocusBlock = true, 24409 prioritizePatterns 24410 } = _ref; 24411 const debouncedSpeak = (0,external_wp_compose_namespaceObject.useDebounce)(external_wp_a11y_namespaceObject.speak, 500); 24412 const [destinationRootClientId, onInsertBlocks] = use_insertion_point({ 24413 onSelect, 24414 rootClientId, 24415 clientId, 24416 isAppender, 24417 insertionIndex: __experimentalInsertionIndex, 24418 shouldFocusBlock 24419 }); 24420 const [blockTypes, blockTypeCategories, blockTypeCollections, onSelectBlockType] = use_block_types_state(destinationRootClientId, onInsertBlocks); 24421 const [patterns,, onSelectBlockPattern] = use_patterns_state(onInsertBlocks, destinationRootClientId); 24422 const filteredBlockPatterns = (0,external_wp_element_namespaceObject.useMemo)(() => { 24423 if (maxBlockPatterns === 0) { 24424 return []; 24425 } 24426 24427 const results = searchItems(patterns, filterValue); 24428 return maxBlockPatterns !== undefined ? results.slice(0, maxBlockPatterns) : results; 24429 }, [filterValue, patterns, maxBlockPatterns]); 24430 let maxBlockTypesToShow = maxBlockTypes; 24431 24432 if (prioritizePatterns && filteredBlockPatterns.length > 2) { 24433 maxBlockTypesToShow = 0; 24434 } 24435 24436 const filteredBlockTypes = (0,external_wp_element_namespaceObject.useMemo)(() => { 24437 if (maxBlockTypesToShow === 0) { 24438 return []; 24439 } 24440 24441 const results = searchBlockItems((0,external_lodash_namespaceObject.orderBy)(blockTypes, ['frecency'], ['desc']), blockTypeCategories, blockTypeCollections, filterValue); 24442 return maxBlockTypesToShow !== undefined ? results.slice(0, maxBlockTypesToShow) : results; 24443 }, [filterValue, blockTypes, blockTypeCategories, blockTypeCollections, maxBlockTypes]); // Announce search results on change. 24444 24445 (0,external_wp_element_namespaceObject.useEffect)(() => { 24446 if (!filterValue) { 24447 return; 24448 } 24449 24450 const count = filteredBlockTypes.length + filteredBlockPatterns.length; 24451 const resultsFoundMessage = (0,external_wp_i18n_namespaceObject.sprintf)( 24452 /* translators: %d: number of results. */ 24453 (0,external_wp_i18n_namespaceObject._n)('%d result found.', '%d results found.', count), count); 24454 debouncedSpeak(resultsFoundMessage); 24455 }, [filterValue, debouncedSpeak]); 24456 const currentShownBlockTypes = (0,external_wp_compose_namespaceObject.useAsyncList)(filteredBlockTypes, { 24457 step: search_results_INITIAL_INSERTER_RESULTS 24458 }); 24459 const currentShownPatterns = (0,external_wp_compose_namespaceObject.useAsyncList)(currentShownBlockTypes.length === filteredBlockTypes.length ? filteredBlockPatterns : search_results_EMPTY_ARRAY); 24460 const hasItems = !(0,external_lodash_namespaceObject.isEmpty)(filteredBlockTypes) || !(0,external_lodash_namespaceObject.isEmpty)(filteredBlockPatterns); 24461 const blocksUI = !!filteredBlockTypes.length && (0,external_wp_element_namespaceObject.createElement)(panel, { 24462 title: (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.VisuallyHidden, null, (0,external_wp_i18n_namespaceObject.__)('Blocks')) 24463 }, (0,external_wp_element_namespaceObject.createElement)(block_types_list, { 24464 items: currentShownBlockTypes, 24465 onSelect: onSelectBlockType, 24466 onHover: onHover, 24467 label: (0,external_wp_i18n_namespaceObject.__)('Blocks'), 24468 isDraggable: isDraggable 24469 })); 24470 const patternsUI = !!filteredBlockPatterns.length && (0,external_wp_element_namespaceObject.createElement)(panel, { 24471 title: (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.VisuallyHidden, null, (0,external_wp_i18n_namespaceObject.__)('Block Patterns')) 24472 }, (0,external_wp_element_namespaceObject.createElement)("div", { 24473 className: "block-editor-inserter__quick-inserter-patterns" 24474 }, (0,external_wp_element_namespaceObject.createElement)(block_patterns_list, { 24475 shownPatterns: currentShownPatterns, 24476 blockPatterns: filteredBlockPatterns, 24477 onClickPattern: onSelectBlockPattern, 24478 isDraggable: isDraggable 24479 }))); 24480 return (0,external_wp_element_namespaceObject.createElement)(inserter_listbox, null, !showBlockDirectory && !hasItems && (0,external_wp_element_namespaceObject.createElement)(no_results, null), prioritizePatterns ? patternsUI : blocksUI, !!filteredBlockTypes.length && !!filteredBlockPatterns.length && (0,external_wp_element_namespaceObject.createElement)("div", { 24481 className: "block-editor-inserter__quick-inserter-separator" 24482 }), prioritizePatterns ? blocksUI : patternsUI, showBlockDirectory && (0,external_wp_element_namespaceObject.createElement)(inserter_menu_extension.Slot, { 24483 fillProps: { 24484 onSelect: onSelectBlockType, 24485 onHover, 24486 filterValue, 24487 hasItems, 24488 rootClientId: destinationRootClientId 24489 } 24490 }, fills => { 24491 if (fills.length) { 24492 return fills; 24493 } 24494 24495 if (!hasItems) { 24496 return (0,external_wp_element_namespaceObject.createElement)(no_results, null); 24497 } 24498 24499 return null; 24500 })); 24501 } 24502 24503 /* harmony default export */ var search_results = (InserterSearchResults); 24504 24505 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inserter/tabs.js 24506 24507 24508 /** 24509 * WordPress dependencies 24510 */ 24511 24512 24513 24514 const blocksTab = { 24515 name: 'blocks', 24516 24517 /* translators: Blocks tab title in the block inserter. */ 24518 title: (0,external_wp_i18n_namespaceObject.__)('Blocks') 24519 }; 24520 const patternsTab = { 24521 name: 'patterns', 24522 24523 /* translators: Patterns tab title in the block inserter. */ 24524 title: (0,external_wp_i18n_namespaceObject.__)('Patterns') 24525 }; 24526 const reusableBlocksTab = { 24527 name: 'reusable', 24528 24529 /* translators: Reusable blocks tab title in the block inserter. */ 24530 title: (0,external_wp_i18n_namespaceObject.__)('Reusable') 24531 }; 24532 24533 function InserterTabs(_ref) { 24534 let { 24535 children, 24536 showPatterns = false, 24537 showReusableBlocks = false, 24538 onSelect 24539 } = _ref; 24540 const tabs = (0,external_wp_element_namespaceObject.useMemo)(() => { 24541 const tempTabs = [blocksTab]; 24542 24543 if (showPatterns) { 24544 tempTabs.push(patternsTab); 24545 } 24546 24547 if (showReusableBlocks) { 24548 tempTabs.push(reusableBlocksTab); 24549 } 24550 24551 return tempTabs; 24552 }, [blocksTab, showPatterns, patternsTab, showReusableBlocks, reusableBlocksTab]); 24553 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TabPanel, { 24554 className: "block-editor-inserter__tabs", 24555 tabs: tabs, 24556 onSelect: onSelect 24557 }, children); 24558 } 24559 24560 /* harmony default export */ var tabs = (InserterTabs); 24561 24562 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inserter/menu.js 24563 24564 24565 /** 24566 * WordPress dependencies 24567 */ 24568 24569 24570 24571 24572 /** 24573 * Internal dependencies 24574 */ 24575 24576 24577 24578 24579 24580 24581 24582 24583 24584 24585 24586 function InserterMenu(_ref, ref) { 24587 let { 24588 rootClientId, 24589 clientId, 24590 isAppender, 24591 __experimentalInsertionIndex, 24592 onSelect, 24593 showInserterHelpPanel, 24594 showMostUsedBlocks, 24595 __experimentalFilterValue = '', 24596 shouldFocusBlock = true 24597 } = _ref; 24598 const [filterValue, setFilterValue] = (0,external_wp_element_namespaceObject.useState)(__experimentalFilterValue); 24599 const [hoveredItem, setHoveredItem] = (0,external_wp_element_namespaceObject.useState)(null); 24600 const [selectedPatternCategory, setSelectedPatternCategory] = (0,external_wp_element_namespaceObject.useState)(null); 24601 const [destinationRootClientId, onInsertBlocks, onToggleInsertionPoint] = use_insertion_point({ 24602 rootClientId, 24603 clientId, 24604 isAppender, 24605 insertionIndex: __experimentalInsertionIndex, 24606 shouldFocusBlock 24607 }); 24608 const { 24609 showPatterns, 24610 hasReusableBlocks 24611 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 24612 var _getSettings$__experi; 24613 24614 const { 24615 __experimentalGetAllowedPatterns, 24616 getSettings 24617 } = select(store); 24618 return { 24619 showPatterns: !!__experimentalGetAllowedPatterns(destinationRootClientId).length, 24620 hasReusableBlocks: !!((_getSettings$__experi = getSettings().__experimentalReusableBlocks) !== null && _getSettings$__experi !== void 0 && _getSettings$__experi.length) 24621 }; 24622 }, [destinationRootClientId]); 24623 const onInsert = (0,external_wp_element_namespaceObject.useCallback)((blocks, meta, shouldForceFocusBlock) => { 24624 onInsertBlocks(blocks, meta, shouldForceFocusBlock); 24625 onSelect(); 24626 }, [onInsertBlocks, onSelect]); 24627 const onInsertPattern = (0,external_wp_element_namespaceObject.useCallback)((blocks, patternName) => { 24628 onInsertBlocks(blocks, { 24629 patternName 24630 }); 24631 onSelect(); 24632 }, [onInsertBlocks, onSelect]); 24633 const onHover = (0,external_wp_element_namespaceObject.useCallback)(item => { 24634 onToggleInsertionPoint(!!item); 24635 setHoveredItem(item); 24636 }, [onToggleInsertionPoint, setHoveredItem]); 24637 const onClickPatternCategory = (0,external_wp_element_namespaceObject.useCallback)(patternCategory => { 24638 setSelectedPatternCategory(patternCategory); 24639 }, [setSelectedPatternCategory]); 24640 const blocksTab = (0,external_wp_element_namespaceObject.useMemo)(() => (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("div", { 24641 className: "block-editor-inserter__block-list" 24642 }, (0,external_wp_element_namespaceObject.createElement)(block_types_tab, { 24643 rootClientId: destinationRootClientId, 24644 onInsert: onInsert, 24645 onHover: onHover, 24646 showMostUsedBlocks: showMostUsedBlocks 24647 })), showInserterHelpPanel && (0,external_wp_element_namespaceObject.createElement)("div", { 24648 className: "block-editor-inserter__tips" 24649 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.VisuallyHidden, { 24650 as: "h2" 24651 }, (0,external_wp_i18n_namespaceObject.__)('A tip for using the block editor')), (0,external_wp_element_namespaceObject.createElement)(tips, null))), [destinationRootClientId, onInsert, onHover, filterValue, showMostUsedBlocks, showInserterHelpPanel]); 24652 const patternsTab = (0,external_wp_element_namespaceObject.useMemo)(() => (0,external_wp_element_namespaceObject.createElement)(block_patterns_tab, { 24653 rootClientId: destinationRootClientId, 24654 onInsert: onInsertPattern, 24655 onClickCategory: onClickPatternCategory, 24656 selectedCategory: selectedPatternCategory 24657 }), [destinationRootClientId, onInsertPattern, onClickPatternCategory, selectedPatternCategory]); 24658 const reusableBlocksTab = (0,external_wp_element_namespaceObject.useMemo)(() => (0,external_wp_element_namespaceObject.createElement)(reusable_blocks_tab, { 24659 rootClientId: destinationRootClientId, 24660 onInsert: onInsert, 24661 onHover: onHover 24662 }), [destinationRootClientId, onInsert, onHover]); 24663 const getCurrentTab = (0,external_wp_element_namespaceObject.useCallback)(tab => { 24664 if (tab.name === 'blocks') { 24665 return blocksTab; 24666 } else if (tab.name === 'patterns') { 24667 return patternsTab; 24668 } 24669 24670 return reusableBlocksTab; 24671 }, [blocksTab, patternsTab, reusableBlocksTab]); 24672 const searchRef = (0,external_wp_element_namespaceObject.useRef)(); 24673 (0,external_wp_element_namespaceObject.useImperativeHandle)(ref, () => ({ 24674 focusSearch: () => { 24675 searchRef.current.focus(); 24676 } 24677 })); 24678 return (0,external_wp_element_namespaceObject.createElement)("div", { 24679 className: "block-editor-inserter__menu" 24680 }, (0,external_wp_element_namespaceObject.createElement)("div", { 24681 className: "block-editor-inserter__main-area" 24682 }, (0,external_wp_element_namespaceObject.createElement)("div", { 24683 className: "block-editor-inserter__content" 24684 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SearchControl, { 24685 className: "block-editor-inserter__search", 24686 onChange: value => { 24687 if (hoveredItem) setHoveredItem(null); 24688 setFilterValue(value); 24689 }, 24690 value: filterValue, 24691 label: (0,external_wp_i18n_namespaceObject.__)('Search for blocks and patterns'), 24692 placeholder: (0,external_wp_i18n_namespaceObject.__)('Search'), 24693 ref: searchRef 24694 }), !!filterValue && (0,external_wp_element_namespaceObject.createElement)(search_results, { 24695 filterValue: filterValue, 24696 onSelect: onSelect, 24697 onHover: onHover, 24698 rootClientId: rootClientId, 24699 clientId: clientId, 24700 isAppender: isAppender, 24701 __experimentalInsertionIndex: __experimentalInsertionIndex, 24702 showBlockDirectory: true, 24703 shouldFocusBlock: shouldFocusBlock 24704 }), !filterValue && (showPatterns || hasReusableBlocks) && (0,external_wp_element_namespaceObject.createElement)(tabs, { 24705 showPatterns: showPatterns, 24706 showReusableBlocks: hasReusableBlocks 24707 }, getCurrentTab), !filterValue && !showPatterns && !hasReusableBlocks && blocksTab)), showInserterHelpPanel && hoveredItem && (0,external_wp_element_namespaceObject.createElement)(preview_panel, { 24708 item: hoveredItem 24709 })); 24710 } 24711 24712 /* harmony default export */ var menu = ((0,external_wp_element_namespaceObject.forwardRef)(InserterMenu)); 24713 24714 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inserter/quick-inserter.js 24715 24716 24717 /** 24718 * External dependencies 24719 */ 24720 24721 /** 24722 * WordPress dependencies 24723 */ 24724 24725 24726 24727 24728 24729 /** 24730 * Internal dependencies 24731 */ 24732 24733 24734 24735 24736 24737 24738 const SEARCH_THRESHOLD = 6; 24739 const SHOWN_BLOCK_TYPES = 6; 24740 const SHOWN_BLOCK_PATTERNS = 2; 24741 const SHOWN_BLOCK_PATTERNS_WITH_PRIORITIZATION = 4; 24742 function QuickInserter(_ref) { 24743 let { 24744 onSelect, 24745 rootClientId, 24746 clientId, 24747 isAppender, 24748 prioritizePatterns 24749 } = _ref; 24750 const [filterValue, setFilterValue] = (0,external_wp_element_namespaceObject.useState)(''); 24751 const [destinationRootClientId, onInsertBlocks] = use_insertion_point({ 24752 onSelect, 24753 rootClientId, 24754 clientId, 24755 isAppender 24756 }); 24757 const [blockTypes] = use_block_types_state(destinationRootClientId, onInsertBlocks); 24758 const [patterns] = use_patterns_state(onInsertBlocks, destinationRootClientId); 24759 const { 24760 setInserterIsOpened, 24761 insertionIndex 24762 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 24763 const { 24764 getSettings, 24765 getBlockIndex, 24766 getBlockCount 24767 } = select(store); 24768 const settings = getSettings(); 24769 const index = getBlockIndex(clientId); 24770 const blockCount = getBlockCount(); 24771 return { 24772 setInserterIsOpened: settings.__experimentalSetIsInserterOpened, 24773 insertionIndex: index === -1 ? blockCount : index 24774 }; 24775 }, [clientId]); 24776 const showPatterns = patterns.length && (!!filterValue || prioritizePatterns); 24777 const showSearch = showPatterns && patterns.length > SEARCH_THRESHOLD || blockTypes.length > SEARCH_THRESHOLD; 24778 (0,external_wp_element_namespaceObject.useEffect)(() => { 24779 if (setInserterIsOpened) { 24780 setInserterIsOpened(false); 24781 } 24782 }, [setInserterIsOpened]); // When clicking Browse All select the appropriate block so as 24783 // the insertion point can work as expected. 24784 24785 const onBrowseAll = () => { 24786 setInserterIsOpened({ 24787 rootClientId, 24788 insertionIndex, 24789 filterValue 24790 }); 24791 }; 24792 24793 let maxBlockPatterns = 0; 24794 24795 if (showPatterns) { 24796 maxBlockPatterns = prioritizePatterns ? SHOWN_BLOCK_PATTERNS_WITH_PRIORITIZATION : SHOWN_BLOCK_PATTERNS; 24797 } 24798 24799 return (0,external_wp_element_namespaceObject.createElement)("div", { 24800 className: classnames_default()('block-editor-inserter__quick-inserter', { 24801 'has-search': showSearch, 24802 'has-expand': setInserterIsOpened 24803 }) 24804 }, showSearch && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SearchControl, { 24805 className: "block-editor-inserter__search", 24806 value: filterValue, 24807 onChange: value => { 24808 setFilterValue(value); 24809 }, 24810 label: (0,external_wp_i18n_namespaceObject.__)('Search for blocks and patterns'), 24811 placeholder: (0,external_wp_i18n_namespaceObject.__)('Search') 24812 }), (0,external_wp_element_namespaceObject.createElement)("div", { 24813 className: "block-editor-inserter__quick-inserter-results" 24814 }, (0,external_wp_element_namespaceObject.createElement)(search_results, { 24815 filterValue: filterValue, 24816 onSelect: onSelect, 24817 rootClientId: rootClientId, 24818 clientId: clientId, 24819 isAppender: isAppender, 24820 maxBlockPatterns: maxBlockPatterns, 24821 maxBlockTypes: SHOWN_BLOCK_TYPES, 24822 isDraggable: false, 24823 prioritizePatterns: prioritizePatterns 24824 })), setInserterIsOpened && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 24825 className: "block-editor-inserter__quick-inserter-expand", 24826 onClick: onBrowseAll, 24827 "aria-label": (0,external_wp_i18n_namespaceObject.__)('Browse all. This will open the main inserter panel in the editor toolbar.') 24828 }, (0,external_wp_i18n_namespaceObject.__)('Browse all'))); 24829 } 24830 24831 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inserter/index.js 24832 24833 24834 24835 /** 24836 * External dependencies 24837 */ 24838 24839 24840 /** 24841 * WordPress dependencies 24842 */ 24843 24844 24845 24846 24847 24848 24849 24850 24851 24852 /** 24853 * Internal dependencies 24854 */ 24855 24856 24857 24858 24859 24860 const defaultRenderToggle = _ref => { 24861 let { 24862 onToggle, 24863 disabled, 24864 isOpen, 24865 blockTitle, 24866 hasSingleBlockType, 24867 toggleProps = {}, 24868 prioritizePatterns 24869 } = _ref; 24870 let label; 24871 24872 if (hasSingleBlockType) { 24873 label = (0,external_wp_i18n_namespaceObject.sprintf)( // translators: %s: the name of the block when there is only one 24874 (0,external_wp_i18n_namespaceObject._x)('Add %s', 'directly add the only allowed block'), blockTitle); 24875 } else if (prioritizePatterns) { 24876 label = (0,external_wp_i18n_namespaceObject.__)('Add pattern'); 24877 } else { 24878 label = (0,external_wp_i18n_namespaceObject._x)('Add block', 'Generic label for block inserter button'); 24879 } 24880 24881 const { 24882 onClick, 24883 ...rest 24884 } = toggleProps; // Handle both onClick functions from the toggle and the parent component. 24885 24886 function handleClick(event) { 24887 if (onToggle) { 24888 onToggle(event); 24889 } 24890 24891 if (onClick) { 24892 onClick(event); 24893 } 24894 } 24895 24896 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, _extends({ 24897 icon: library_plus, 24898 label: label, 24899 tooltipPosition: "bottom", 24900 onClick: handleClick, 24901 className: "block-editor-inserter__toggle", 24902 "aria-haspopup": !hasSingleBlockType ? 'true' : false, 24903 "aria-expanded": !hasSingleBlockType ? isOpen : false, 24904 disabled: disabled 24905 }, rest)); 24906 }; 24907 24908 class Inserter extends external_wp_element_namespaceObject.Component { 24909 constructor() { 24910 super(...arguments); 24911 this.onToggle = this.onToggle.bind(this); 24912 this.renderToggle = this.renderToggle.bind(this); 24913 this.renderContent = this.renderContent.bind(this); 24914 } 24915 24916 onToggle(isOpen) { 24917 const { 24918 onToggle 24919 } = this.props; // Surface toggle callback to parent component. 24920 24921 if (onToggle) { 24922 onToggle(isOpen); 24923 } 24924 } 24925 /** 24926 * Render callback to display Dropdown toggle element. 24927 * 24928 * @param {Object} options 24929 * @param {Function} options.onToggle Callback to invoke when toggle is 24930 * pressed. 24931 * @param {boolean} options.isOpen Whether dropdown is currently open. 24932 * 24933 * @return {WPElement} Dropdown toggle element. 24934 */ 24935 24936 24937 renderToggle(_ref2) { 24938 let { 24939 onToggle, 24940 isOpen 24941 } = _ref2; 24942 const { 24943 disabled, 24944 blockTitle, 24945 hasSingleBlockType, 24946 directInsertBlock, 24947 toggleProps, 24948 hasItems, 24949 renderToggle = defaultRenderToggle, 24950 prioritizePatterns 24951 } = this.props; 24952 return renderToggle({ 24953 onToggle, 24954 isOpen, 24955 disabled: disabled || !hasItems, 24956 blockTitle, 24957 hasSingleBlockType, 24958 directInsertBlock, 24959 toggleProps, 24960 prioritizePatterns 24961 }); 24962 } 24963 /** 24964 * Render callback to display Dropdown content element. 24965 * 24966 * @param {Object} options 24967 * @param {Function} options.onClose Callback to invoke when dropdown is 24968 * closed. 24969 * 24970 * @return {WPElement} Dropdown content element. 24971 */ 24972 24973 24974 renderContent(_ref3) { 24975 let { 24976 onClose 24977 } = _ref3; 24978 const { 24979 rootClientId, 24980 clientId, 24981 isAppender, 24982 showInserterHelpPanel, 24983 // This prop is experimental to give some time for the quick inserter to mature 24984 // Feel free to make them stable after a few releases. 24985 __experimentalIsQuick: isQuick, 24986 prioritizePatterns 24987 } = this.props; 24988 24989 if (isQuick) { 24990 return (0,external_wp_element_namespaceObject.createElement)(QuickInserter, { 24991 onSelect: () => { 24992 onClose(); 24993 }, 24994 rootClientId: rootClientId, 24995 clientId: clientId, 24996 isAppender: isAppender, 24997 prioritizePatterns: prioritizePatterns 24998 }); 24999 } 25000 25001 return (0,external_wp_element_namespaceObject.createElement)(menu, { 25002 onSelect: () => { 25003 onClose(); 25004 }, 25005 rootClientId: rootClientId, 25006 clientId: clientId, 25007 isAppender: isAppender, 25008 showInserterHelpPanel: showInserterHelpPanel 25009 }); 25010 } 25011 25012 render() { 25013 const { 25014 position, 25015 hasSingleBlockType, 25016 directInsertBlock, 25017 insertOnlyAllowedBlock, 25018 __experimentalIsQuick: isQuick, 25019 onSelectOrClose 25020 } = this.props; 25021 25022 if (hasSingleBlockType || directInsertBlock) { 25023 return this.renderToggle({ 25024 onToggle: insertOnlyAllowedBlock 25025 }); 25026 } 25027 25028 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Dropdown, { 25029 className: "block-editor-inserter", 25030 contentClassName: classnames_default()('block-editor-inserter__popover', { 25031 'is-quick': isQuick 25032 }), 25033 position: position, 25034 onToggle: this.onToggle, 25035 expandOnMobile: true, 25036 headerTitle: (0,external_wp_i18n_namespaceObject.__)('Add a block'), 25037 renderToggle: this.renderToggle, 25038 renderContent: this.renderContent, 25039 onClose: onSelectOrClose 25040 }); 25041 } 25042 25043 } 25044 25045 /* harmony default export */ var inserter = ((0,external_wp_compose_namespaceObject.compose)([(0,external_wp_data_namespaceObject.withSelect)((select, _ref4) => { 25046 let { 25047 clientId, 25048 rootClientId 25049 } = _ref4; 25050 const { 25051 getBlockRootClientId, 25052 hasInserterItems, 25053 __experimentalGetAllowedBlocks, 25054 __experimentalGetDirectInsertBlock, 25055 getBlockIndex, 25056 getBlockCount, 25057 getSettings 25058 } = select(store); 25059 const { 25060 getBlockVariations 25061 } = select(external_wp_blocks_namespaceObject.store); 25062 rootClientId = rootClientId || getBlockRootClientId(clientId) || undefined; 25063 25064 const allowedBlocks = __experimentalGetAllowedBlocks(rootClientId); 25065 25066 const directInsertBlock = __experimentalGetDirectInsertBlock(rootClientId); 25067 25068 const index = getBlockIndex(clientId); 25069 const blockCount = getBlockCount(); 25070 const settings = getSettings(); 25071 const hasSingleBlockType = (0,external_lodash_namespaceObject.size)(allowedBlocks) === 1 && (0,external_lodash_namespaceObject.size)(getBlockVariations(allowedBlocks[0].name, 'inserter')) === 0; 25072 let allowedBlockType = false; 25073 25074 if (hasSingleBlockType) { 25075 allowedBlockType = allowedBlocks[0]; 25076 } 25077 25078 return { 25079 hasItems: hasInserterItems(rootClientId), 25080 hasSingleBlockType, 25081 blockTitle: allowedBlockType ? allowedBlockType.title : '', 25082 allowedBlockType, 25083 directInsertBlock, 25084 rootClientId, 25085 prioritizePatterns: settings.__experimentalPreferPatternsOnRoot && !rootClientId && index > 0 && (index < blockCount || blockCount === 0) 25086 }; 25087 }), (0,external_wp_data_namespaceObject.withDispatch)((dispatch, ownProps, _ref5) => { 25088 let { 25089 select 25090 } = _ref5; 25091 return { 25092 insertOnlyAllowedBlock() { 25093 const { 25094 rootClientId, 25095 clientId, 25096 isAppender, 25097 hasSingleBlockType, 25098 allowedBlockType, 25099 directInsertBlock, 25100 onSelectOrClose 25101 } = ownProps; 25102 25103 if (!hasSingleBlockType && !directInsertBlock) { 25104 return; 25105 } 25106 25107 function getAdjacentBlockAttributes(attributesToCopy) { 25108 const { 25109 getBlock, 25110 getPreviousBlockClientId 25111 } = select(store); 25112 25113 if (!attributesToCopy || !clientId && !rootClientId) { 25114 return {}; 25115 } 25116 25117 const result = {}; 25118 let adjacentAttributes = {}; // If there is no clientId, then attempt to get attributes 25119 // from the last block within innerBlocks of the root block. 25120 25121 if (!clientId) { 25122 var _parentBlock$innerBlo; 25123 25124 const parentBlock = getBlock(rootClientId); 25125 25126 if (parentBlock !== null && parentBlock !== void 0 && (_parentBlock$innerBlo = parentBlock.innerBlocks) !== null && _parentBlock$innerBlo !== void 0 && _parentBlock$innerBlo.length) { 25127 const lastInnerBlock = parentBlock.innerBlocks[parentBlock.innerBlocks.length - 1]; 25128 25129 if (directInsertBlock && (directInsertBlock === null || directInsertBlock === void 0 ? void 0 : directInsertBlock.name) === lastInnerBlock.name) { 25130 adjacentAttributes = lastInnerBlock.attributes; 25131 } 25132 } 25133 } else { 25134 // Otherwise, attempt to get attributes from the 25135 // previous block relative to the current clientId. 25136 const currentBlock = getBlock(clientId); 25137 const previousBlock = getBlock(getPreviousBlockClientId(clientId)); 25138 25139 if ((currentBlock === null || currentBlock === void 0 ? void 0 : currentBlock.name) === (previousBlock === null || previousBlock === void 0 ? void 0 : previousBlock.name)) { 25140 adjacentAttributes = (previousBlock === null || previousBlock === void 0 ? void 0 : previousBlock.attributes) || {}; 25141 } 25142 } // Copy over only those attributes flagged to be copied. 25143 25144 25145 attributesToCopy.forEach(attribute => { 25146 if (adjacentAttributes.hasOwnProperty(attribute)) { 25147 result[attribute] = adjacentAttributes[attribute]; 25148 } 25149 }); 25150 return result; 25151 } 25152 25153 function getInsertionIndex() { 25154 const { 25155 getBlockIndex, 25156 getBlockSelectionEnd, 25157 getBlockOrder, 25158 getBlockRootClientId 25159 } = select(store); // If the clientId is defined, we insert at the position of the block. 25160 25161 if (clientId) { 25162 return getBlockIndex(clientId); 25163 } // If there a selected block, we insert after the selected block. 25164 25165 25166 const end = getBlockSelectionEnd(); 25167 25168 if (!isAppender && end && getBlockRootClientId(end) === rootClientId) { 25169 return getBlockIndex(end) + 1; 25170 } // Otherwise, we insert at the end of the current rootClientId. 25171 25172 25173 return getBlockOrder(rootClientId).length; 25174 } 25175 25176 const { 25177 insertBlock 25178 } = dispatch(store); 25179 let blockToInsert; // Attempt to augment the directInsertBlock with attributes from an adjacent block. 25180 // This ensures styling from nearby blocks is preserved in the newly inserted block. 25181 // See: https://github.com/WordPress/gutenberg/issues/37904 25182 25183 if (directInsertBlock) { 25184 const newAttributes = getAdjacentBlockAttributes(directInsertBlock.attributesToCopy); 25185 blockToInsert = (0,external_wp_blocks_namespaceObject.createBlock)(directInsertBlock.name, { ...(directInsertBlock.attributes || {}), 25186 ...newAttributes 25187 }); 25188 } else { 25189 blockToInsert = (0,external_wp_blocks_namespaceObject.createBlock)(allowedBlockType.name); 25190 } 25191 25192 insertBlock(blockToInsert, getInsertionIndex(), rootClientId); 25193 25194 if (onSelectOrClose) { 25195 onSelectOrClose(); 25196 } 25197 25198 const message = (0,external_wp_i18n_namespaceObject.sprintf)( // translators: %s: the name of the block that has been added 25199 (0,external_wp_i18n_namespaceObject.__)('%s block added'), allowedBlockType.title); 25200 (0,external_wp_a11y_namespaceObject.speak)(message); 25201 } 25202 25203 }; 25204 }), // The global inserter should always be visible, we are using ( ! isAppender && ! rootClientId && ! clientId ) as 25205 // a way to detect the global Inserter. 25206 (0,external_wp_compose_namespaceObject.ifCondition)(_ref6 => { 25207 let { 25208 hasItems, 25209 isAppender, 25210 rootClientId, 25211 clientId 25212 } = _ref6; 25213 return hasItems || !isAppender && !rootClientId && !clientId; 25214 })])(Inserter)); 25215 25216 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/default-block-appender/index.js 25217 25218 25219 /** 25220 * External dependencies 25221 */ 25222 25223 /** 25224 * WordPress dependencies 25225 */ 25226 25227 25228 25229 25230 25231 25232 /** 25233 * Internal dependencies 25234 */ 25235 25236 25237 25238 /** 25239 * Zero width non-breaking space, used as padding for the paragraph when it is 25240 * empty. 25241 */ 25242 25243 const ZWNBSP = '\ufeff'; 25244 function DefaultBlockAppender(_ref) { 25245 let { 25246 isLocked, 25247 onAppend, 25248 showPrompt, 25249 placeholder, 25250 rootClientId 25251 } = _ref; 25252 25253 if (isLocked) { 25254 return null; 25255 } 25256 25257 const value = (0,external_wp_htmlEntities_namespaceObject.decodeEntities)(placeholder) || (0,external_wp_i18n_namespaceObject.__)('Type / to choose a block'); 25258 25259 return (0,external_wp_element_namespaceObject.createElement)("div", { 25260 "data-root-client-id": rootClientId || '', 25261 className: classnames_default()('block-editor-default-block-appender', { 25262 'has-visible-prompt': showPrompt 25263 }) 25264 }, (0,external_wp_element_namespaceObject.createElement)("p", { 25265 tabIndex: "0" // We want this element to be styled as a paragraph by themes. 25266 // eslint-disable-next-line jsx-a11y/no-noninteractive-element-to-interactive-role 25267 , 25268 role: "button", 25269 "aria-label": (0,external_wp_i18n_namespaceObject.__)('Add default block') // A wrapping container for this one already has the wp-block className. 25270 , 25271 className: "block-editor-default-block-appender__content", 25272 onKeyDown: event => { 25273 if (external_wp_keycodes_namespaceObject.ENTER === event.keyCode || external_wp_keycodes_namespaceObject.SPACE === event.keyCode) { 25274 onAppend(); 25275 } 25276 }, 25277 onClick: () => onAppend(), 25278 onFocus: () => { 25279 if (showPrompt) { 25280 onAppend(); 25281 } 25282 } 25283 }, showPrompt ? value : ZWNBSP), (0,external_wp_element_namespaceObject.createElement)(inserter, { 25284 rootClientId: rootClientId, 25285 position: "bottom right", 25286 isAppender: true, 25287 __experimentalIsQuick: true 25288 })); 25289 } 25290 /* harmony default export */ var default_block_appender = ((0,external_wp_compose_namespaceObject.compose)((0,external_wp_data_namespaceObject.withSelect)((select, ownProps) => { 25291 const { 25292 getBlockCount, 25293 getSettings, 25294 getTemplateLock 25295 } = select(store); 25296 const isEmpty = !getBlockCount(ownProps.rootClientId); 25297 const { 25298 bodyPlaceholder 25299 } = getSettings(); 25300 return { 25301 showPrompt: isEmpty, 25302 isLocked: !!getTemplateLock(ownProps.rootClientId), 25303 placeholder: bodyPlaceholder 25304 }; 25305 }), (0,external_wp_data_namespaceObject.withDispatch)((dispatch, ownProps) => { 25306 const { 25307 insertDefaultBlock, 25308 startTyping 25309 } = dispatch(store); 25310 return { 25311 onAppend() { 25312 const { 25313 rootClientId 25314 } = ownProps; 25315 insertDefaultBlock(undefined, rootClientId); 25316 startTyping(); 25317 } 25318 25319 }; 25320 }))(DefaultBlockAppender)); 25321 25322 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/button-block-appender/index.js 25323 25324 25325 /** 25326 * External dependencies 25327 */ 25328 25329 /** 25330 * WordPress dependencies 25331 */ 25332 25333 25334 25335 25336 25337 25338 /** 25339 * Internal dependencies 25340 */ 25341 25342 25343 25344 function ButtonBlockAppender(_ref, ref) { 25345 let { 25346 rootClientId, 25347 className, 25348 onFocus, 25349 tabIndex 25350 } = _ref; 25351 return (0,external_wp_element_namespaceObject.createElement)(inserter, { 25352 position: "bottom center", 25353 rootClientId: rootClientId, 25354 __experimentalIsQuick: true, 25355 renderToggle: _ref2 => { 25356 let { 25357 onToggle, 25358 disabled, 25359 isOpen, 25360 blockTitle, 25361 hasSingleBlockType 25362 } = _ref2; 25363 let label; 25364 25365 if (hasSingleBlockType) { 25366 label = (0,external_wp_i18n_namespaceObject.sprintf)( // translators: %s: the name of the block when there is only one 25367 (0,external_wp_i18n_namespaceObject._x)('Add %s', 'directly add the only allowed block'), blockTitle); 25368 } else { 25369 label = (0,external_wp_i18n_namespaceObject._x)('Add block', 'Generic label for block inserter button'); 25370 } 25371 25372 const isToggleButton = !hasSingleBlockType; 25373 let inserterButton = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 25374 ref: ref, 25375 onFocus: onFocus, 25376 tabIndex: tabIndex, 25377 className: classnames_default()(className, 'block-editor-button-block-appender'), 25378 onClick: onToggle, 25379 "aria-haspopup": isToggleButton ? 'true' : undefined, 25380 "aria-expanded": isToggleButton ? isOpen : undefined, 25381 disabled: disabled, 25382 label: label 25383 }, !hasSingleBlockType && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.VisuallyHidden, { 25384 as: "span" 25385 }, label), (0,external_wp_element_namespaceObject.createElement)(build_module_icon, { 25386 icon: library_plus 25387 })); 25388 25389 if (isToggleButton || hasSingleBlockType) { 25390 inserterButton = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Tooltip, { 25391 text: label 25392 }, inserterButton); 25393 } 25394 25395 return inserterButton; 25396 }, 25397 isAppender: true 25398 }); 25399 } 25400 /** 25401 * Use `ButtonBlockAppender` instead. 25402 * 25403 * @deprecated 25404 */ 25405 25406 25407 const ButtonBlockerAppender = (0,external_wp_element_namespaceObject.forwardRef)((props, ref) => { 25408 external_wp_deprecated_default()(`wp.blockEditor.ButtonBlockerAppender`, { 25409 alternative: 'wp.blockEditor.ButtonBlockAppender', 25410 since: '5.9' 25411 }); 25412 return ButtonBlockAppender(props, ref); 25413 }); 25414 /** 25415 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/button-block-appender/README.md 25416 */ 25417 25418 /* harmony default export */ var button_block_appender = ((0,external_wp_element_namespaceObject.forwardRef)(ButtonBlockAppender)); 25419 25420 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-list-appender/index.js 25421 25422 25423 /** 25424 * External dependencies 25425 */ 25426 25427 /** 25428 * WordPress dependencies 25429 */ 25430 25431 25432 25433 /** 25434 * Internal dependencies 25435 */ 25436 25437 25438 25439 25440 25441 function BlockListAppender(_ref) { 25442 let { 25443 rootClientId, 25444 canInsertDefaultBlock, 25445 isLocked, 25446 renderAppender: CustomAppender, 25447 className, 25448 selectedBlockClientId, 25449 tagName: TagName = 'div' 25450 } = _ref; 25451 25452 if (isLocked || CustomAppender === false) { 25453 return null; 25454 } 25455 25456 let appender; 25457 25458 if (CustomAppender) { 25459 // Prefer custom render prop if provided. 25460 appender = (0,external_wp_element_namespaceObject.createElement)(CustomAppender, null); 25461 } else { 25462 const isParentSelected = selectedBlockClientId === rootClientId || !rootClientId && !selectedBlockClientId; 25463 25464 if (!isParentSelected) { 25465 return null; 25466 } 25467 25468 if (canInsertDefaultBlock) { 25469 // Render the default block appender when renderAppender has not been 25470 // provided and the context supports use of the default appender. 25471 appender = (0,external_wp_element_namespaceObject.createElement)(default_block_appender, { 25472 rootClientId: rootClientId 25473 }); 25474 } else { 25475 // Fallback in the case no renderAppender has been provided and the 25476 // default block can't be inserted. 25477 appender = (0,external_wp_element_namespaceObject.createElement)(button_block_appender, { 25478 rootClientId: rootClientId, 25479 className: "block-list-appender__toggle" 25480 }); 25481 } 25482 } 25483 25484 return (0,external_wp_element_namespaceObject.createElement)(TagName // A `tabIndex` is used on the wrapping `div` element in order to 25485 // force a focus event to occur when an appender `button` element 25486 // is clicked. In some browsers (Firefox, Safari), button clicks do 25487 // not emit a focus event, which could cause this event to propagate 25488 // unexpectedly. The `tabIndex` ensures that the interaction is 25489 // captured as a focus, without also adding an extra tab stop. 25490 // 25491 // See: https://developer.mozilla.org/en-US/docs/Web/HTML/Element/button#Clicking_and_focus 25492 , { 25493 tabIndex: -1, 25494 className: classnames_default()('block-list-appender wp-block', className) // Needed in case the whole editor is content editable (for multi 25495 // selection). It fixes an edge case where ArrowDown and ArrowRight 25496 // should collapse the selection to the end of that selection and 25497 // not into the appender. 25498 , 25499 contentEditable: false // The appender exists to let you add the first Paragraph before 25500 // any is inserted. To that end, this appender should visually be 25501 // presented as a block. That means theme CSS should style it as if 25502 // it were an empty paragraph block. That means a `wp-block` class to 25503 // ensure the width is correct, and a [data-block] attribute to ensure 25504 // the correct margin is applied, especially for classic themes which 25505 // have commonly targeted that attribute for margins. 25506 , 25507 "data-block": true 25508 }, appender); 25509 } 25510 25511 /* harmony default export */ var block_list_appender = ((0,external_wp_data_namespaceObject.withSelect)((select, _ref2) => { 25512 let { 25513 rootClientId 25514 } = _ref2; 25515 const { 25516 canInsertBlockType, 25517 getTemplateLock, 25518 getSelectedBlockClientId 25519 } = select(store); 25520 return { 25521 isLocked: !!getTemplateLock(rootClientId), 25522 canInsertDefaultBlock: canInsertBlockType((0,external_wp_blocks_namespaceObject.getDefaultBlockName)(), rootClientId), 25523 selectedBlockClientId: getSelectedBlockClientId() 25524 }; 25525 })(BlockListAppender)); 25526 25527 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-tools/use-popover-scroll.js 25528 /** 25529 * WordPress dependencies 25530 */ 25531 25532 /** 25533 * Allow scrolling "through" popovers over the canvas. This is only called for 25534 * as long as the pointer is over a popover. Do not use React events because it 25535 * will bubble through portals. 25536 * 25537 * @param {Object} scrollableRef 25538 */ 25539 25540 function usePopoverScroll(scrollableRef) { 25541 return (0,external_wp_compose_namespaceObject.useRefEffect)(node => { 25542 if (!scrollableRef) { 25543 return; 25544 } 25545 25546 function onWheel(event) { 25547 const { 25548 deltaX, 25549 deltaY 25550 } = event; 25551 scrollableRef.current.scrollBy(deltaX, deltaY); 25552 } // Tell the browser that we do not call event.preventDefault 25553 // See https://developer.mozilla.org/en-US/docs/Web/API/EventTarget/addEventListener#improving_scrolling_performance_with_passive_listeners 25554 25555 25556 const options = { 25557 passive: true 25558 }; 25559 node.addEventListener('wheel', onWheel, options); 25560 return () => { 25561 node.removeEventListener('wheel', onWheel, options); 25562 }; 25563 }, [scrollableRef]); 25564 } 25565 25566 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-tools/insertion-point.js 25567 25568 25569 /** 25570 * External dependencies 25571 */ 25572 25573 /** 25574 * WordPress dependencies 25575 */ 25576 25577 25578 25579 25580 25581 25582 /** 25583 * Internal dependencies 25584 */ 25585 25586 25587 25588 25589 25590 const InsertionPointOpenRef = (0,external_wp_element_namespaceObject.createContext)(); 25591 25592 function InsertionPointPopover(_ref) { 25593 let { 25594 __unstablePopoverSlot, 25595 __unstableContentRef 25596 } = _ref; 25597 const { 25598 selectBlock, 25599 hideInsertionPoint 25600 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 25601 const openRef = (0,external_wp_element_namespaceObject.useContext)(InsertionPointOpenRef); 25602 const ref = (0,external_wp_element_namespaceObject.useRef)(); 25603 const { 25604 orientation, 25605 previousClientId, 25606 nextClientId, 25607 rootClientId, 25608 isInserterShown 25609 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 25610 var _getBlockListSettings; 25611 25612 const { 25613 getBlockOrder, 25614 getBlockListSettings, 25615 getBlockInsertionPoint, 25616 isBlockBeingDragged, 25617 getPreviousBlockClientId, 25618 getNextBlockClientId 25619 } = select(store); 25620 const insertionPoint = getBlockInsertionPoint(); 25621 const order = getBlockOrder(insertionPoint.rootClientId); 25622 25623 if (!order.length) { 25624 return {}; 25625 } 25626 25627 let _previousClientId = order[insertionPoint.index - 1]; 25628 let _nextClientId = order[insertionPoint.index]; 25629 25630 while (isBlockBeingDragged(_previousClientId)) { 25631 _previousClientId = getPreviousBlockClientId(_previousClientId); 25632 } 25633 25634 while (isBlockBeingDragged(_nextClientId)) { 25635 _nextClientId = getNextBlockClientId(_nextClientId); 25636 } 25637 25638 return { 25639 previousClientId: _previousClientId, 25640 nextClientId: _nextClientId, 25641 orientation: ((_getBlockListSettings = getBlockListSettings(insertionPoint.rootClientId)) === null || _getBlockListSettings === void 0 ? void 0 : _getBlockListSettings.orientation) || 'vertical', 25642 rootClientId: insertionPoint.rootClientId, 25643 isInserterShown: insertionPoint === null || insertionPoint === void 0 ? void 0 : insertionPoint.__unstableWithInserter 25644 }; 25645 }, []); 25646 const previousElement = useBlockElement(previousClientId); 25647 const nextElement = useBlockElement(nextClientId); 25648 const isVertical = orientation === 'vertical'; 25649 const style = (0,external_wp_element_namespaceObject.useMemo)(() => { 25650 if (!previousElement && !nextElement) { 25651 return {}; 25652 } 25653 25654 const previousRect = previousElement ? previousElement.getBoundingClientRect() : null; 25655 const nextRect = nextElement ? nextElement.getBoundingClientRect() : null; 25656 25657 if (isVertical) { 25658 return { 25659 width: previousElement ? previousElement.offsetWidth : nextElement.offsetWidth, 25660 height: nextRect && previousRect ? nextRect.top - previousRect.bottom : 0 25661 }; 25662 } 25663 25664 let width = 0; 25665 25666 if (previousRect && nextRect) { 25667 width = (0,external_wp_i18n_namespaceObject.isRTL)() ? previousRect.left - nextRect.right : nextRect.left - previousRect.right; 25668 } 25669 25670 return { 25671 width, 25672 height: previousElement ? previousElement.offsetHeight : nextElement.offsetHeight 25673 }; 25674 }, [previousElement, nextElement]); 25675 const getAnchorRect = (0,external_wp_element_namespaceObject.useCallback)(() => { 25676 if (!previousElement && !nextElement) { 25677 return {}; 25678 } 25679 25680 const { 25681 ownerDocument 25682 } = previousElement || nextElement; 25683 const previousRect = previousElement ? previousElement.getBoundingClientRect() : null; 25684 const nextRect = nextElement ? nextElement.getBoundingClientRect() : null; 25685 25686 if (isVertical) { 25687 if ((0,external_wp_i18n_namespaceObject.isRTL)()) { 25688 return { 25689 top: previousRect ? previousRect.bottom : nextRect.top, 25690 left: previousRect ? previousRect.right : nextRect.right, 25691 right: previousRect ? previousRect.left : nextRect.left, 25692 bottom: nextRect ? nextRect.top : previousRect.bottom, 25693 ownerDocument 25694 }; 25695 } 25696 25697 return { 25698 top: previousRect ? previousRect.bottom : nextRect.top, 25699 left: previousRect ? previousRect.left : nextRect.left, 25700 right: previousRect ? previousRect.right : nextRect.right, 25701 bottom: nextRect ? nextRect.top : previousRect.bottom, 25702 ownerDocument 25703 }; 25704 } 25705 25706 if ((0,external_wp_i18n_namespaceObject.isRTL)()) { 25707 return { 25708 top: previousRect ? previousRect.top : nextRect.top, 25709 left: previousRect ? previousRect.left : nextRect.right, 25710 right: nextRect ? nextRect.right : previousRect.left, 25711 bottom: previousRect ? previousRect.bottom : nextRect.bottom, 25712 ownerDocument 25713 }; 25714 } 25715 25716 return { 25717 top: previousRect ? previousRect.top : nextRect.top, 25718 left: previousRect ? previousRect.right : nextRect.left, 25719 right: nextRect ? nextRect.left : previousRect.right, 25720 bottom: previousRect ? previousRect.bottom : nextRect.bottom, 25721 ownerDocument 25722 }; 25723 }, [previousElement, nextElement]); 25724 const popoverScrollRef = usePopoverScroll(__unstableContentRef); 25725 const disableMotion = (0,external_wp_compose_namespaceObject.useReducedMotion)(); 25726 const className = classnames_default()('block-editor-block-list__insertion-point', 'is-' + orientation); 25727 25728 function onClick(event) { 25729 if (event.target === ref.current && nextClientId) { 25730 selectBlock(nextClientId, -1); 25731 } 25732 } 25733 25734 function onFocus(event) { 25735 // Only handle click on the wrapper specifically, and not an event 25736 // bubbled from the inserter itself. 25737 if (event.target !== ref.current) { 25738 openRef.current = true; 25739 } 25740 } 25741 25742 function maybeHideInserterPoint(event) { 25743 // Only hide the inserter if it's triggered on the wrapper, 25744 // and the inserter is not open. 25745 if (event.target === ref.current && !openRef.current) { 25746 hideInsertionPoint(); 25747 } 25748 } // Only show the in-between inserter between blocks, so when there's a 25749 // previous and a next element. 25750 25751 25752 const showInsertionPointInserter = previousElement && nextElement && isInserterShown; // Define animation variants for the line element. 25753 25754 const horizontalLine = { 25755 start: { 25756 width: 0, 25757 top: '50%', 25758 bottom: '50%', 25759 x: 0 25760 }, 25761 rest: { 25762 width: 4, 25763 top: 0, 25764 bottom: 0, 25765 x: -2 25766 }, 25767 hover: { 25768 width: 4, 25769 top: 0, 25770 bottom: 0, 25771 x: -2 25772 } 25773 }; 25774 const verticalLine = { 25775 start: { 25776 height: 0, 25777 left: '50%', 25778 right: '50%', 25779 y: 0 25780 }, 25781 rest: { 25782 height: 4, 25783 left: 0, 25784 right: 0, 25785 y: -2 25786 }, 25787 hover: { 25788 height: 4, 25789 left: 0, 25790 right: 0, 25791 y: -2 25792 } 25793 }; 25794 const lineVariants = { 25795 // Initial position starts from the center and invisible. 25796 start: { ...(!isVertical ? horizontalLine.start : verticalLine.start), 25797 opacity: 0 25798 }, 25799 // The line expands to fill the container. If the inserter is visible it 25800 // is delayed so it appears orchestrated. 25801 rest: { ...(!isVertical ? horizontalLine.rest : verticalLine.rest), 25802 opacity: 1, 25803 borderRadius: '2px', 25804 transition: { 25805 delay: showInsertionPointInserter ? 0.4 : 0 25806 } 25807 }, 25808 hover: { ...(!isVertical ? horizontalLine.hover : verticalLine.hover), 25809 opacity: 1, 25810 borderRadius: '2px', 25811 transition: { 25812 delay: 0.4 25813 } 25814 } 25815 }; 25816 const inserterVariants = { 25817 start: { 25818 scale: disableMotion ? 1 : 0 25819 }, 25820 rest: { 25821 scale: 1, 25822 transition: { 25823 delay: 0.2 25824 } 25825 } 25826 }; 25827 /* eslint-disable jsx-a11y/no-static-element-interactions, jsx-a11y/click-events-have-key-events */ 25828 // While ideally it would be enough to capture the 25829 // bubbling focus event from the Inserter, due to the 25830 // characteristics of click focusing of `button`s in 25831 // Firefox and Safari, it is not reliable. 25832 // 25833 // See: https://developer.mozilla.org/en-US/docs/Web/HTML/Element/button#Clicking_and_focus 25834 25835 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Popover, { 25836 ref: popoverScrollRef, 25837 noArrow: true, 25838 animate: false, 25839 getAnchorRect: getAnchorRect, 25840 focusOnMount: false, 25841 className: "block-editor-block-list__insertion-point-popover" // Render in the old slot if needed for backward compatibility, 25842 // otherwise render in place (not in the the default popover slot). 25843 , 25844 __unstableSlotName: __unstablePopoverSlot || null // Forces a remount of the popover when its position changes 25845 // This makes sure the popover doesn't animate from its previous position. 25846 , 25847 key: nextClientId + '--' + rootClientId 25848 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__unstableMotion.div, { 25849 layout: !disableMotion, 25850 initial: disableMotion ? 'rest' : 'start', 25851 animate: "rest", 25852 whileHover: "hover", 25853 whileTap: "pressed", 25854 exit: "start", 25855 ref: ref, 25856 tabIndex: -1, 25857 onClick: onClick, 25858 onFocus: onFocus, 25859 className: classnames_default()(className, { 25860 'is-with-inserter': showInsertionPointInserter 25861 }), 25862 onHoverEnd: maybeHideInserterPoint, 25863 style: style 25864 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__unstableMotion.div, { 25865 variants: lineVariants, 25866 className: "block-editor-block-list__insertion-point-indicator" 25867 }), showInsertionPointInserter && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__unstableMotion.div, { 25868 variants: inserterVariants, 25869 className: classnames_default()('block-editor-block-list__insertion-point-inserter') 25870 }, (0,external_wp_element_namespaceObject.createElement)(inserter, { 25871 position: "bottom center", 25872 clientId: nextClientId, 25873 rootClientId: rootClientId, 25874 __experimentalIsQuick: true, 25875 onToggle: isOpen => { 25876 openRef.current = isOpen; 25877 }, 25878 onSelectOrClose: () => { 25879 openRef.current = false; 25880 } 25881 })))); 25882 /* eslint-enable jsx-a11y/no-static-element-interactions, jsx-a11y/click-events-have-key-events */ 25883 } 25884 25885 function InsertionPoint(_ref2) { 25886 let { 25887 children, 25888 __unstablePopoverSlot, 25889 __unstableContentRef 25890 } = _ref2; 25891 const isVisible = (0,external_wp_data_namespaceObject.useSelect)(select => { 25892 return select(store).isBlockInsertionPointVisible(); 25893 }, []); 25894 return (0,external_wp_element_namespaceObject.createElement)(InsertionPointOpenRef.Provider, { 25895 value: (0,external_wp_element_namespaceObject.useRef)(false) 25896 }, isVisible && (0,external_wp_element_namespaceObject.createElement)(InsertionPointPopover, { 25897 __unstablePopoverSlot: __unstablePopoverSlot, 25898 __unstableContentRef: __unstableContentRef 25899 }), children); 25900 } 25901 25902 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-list/use-in-between-inserter.js 25903 /** 25904 * WordPress dependencies 25905 */ 25906 25907 25908 25909 /** 25910 * Internal dependencies 25911 */ 25912 25913 25914 25915 function useInBetweenInserter() { 25916 const openRef = (0,external_wp_element_namespaceObject.useContext)(InsertionPointOpenRef); 25917 const hasReducedUI = (0,external_wp_data_namespaceObject.useSelect)(select => select(store).getSettings().hasReducedUI, []); 25918 const { 25919 getBlockListSettings, 25920 getBlockRootClientId, 25921 getBlockIndex, 25922 isBlockInsertionPointVisible, 25923 isMultiSelecting, 25924 getSelectedBlockClientIds, 25925 getTemplateLock 25926 } = (0,external_wp_data_namespaceObject.useSelect)(store); 25927 const { 25928 showInsertionPoint, 25929 hideInsertionPoint 25930 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 25931 return (0,external_wp_compose_namespaceObject.useRefEffect)(node => { 25932 if (hasReducedUI) { 25933 return; 25934 } 25935 25936 function onMouseMove(event) { 25937 var _getBlockListSettings, _element$parentElemen; 25938 25939 if (openRef.current) { 25940 return; 25941 } 25942 25943 if (isMultiSelecting()) { 25944 return; 25945 } 25946 25947 if (!event.target.classList.contains('block-editor-block-list__layout')) { 25948 if (isBlockInsertionPointVisible()) { 25949 hideInsertionPoint(); 25950 } 25951 25952 return; 25953 } 25954 25955 let rootClientId; 25956 25957 if (!event.target.classList.contains('is-root-container')) { 25958 const blockElement = !!event.target.getAttribute('data-block') ? event.target : event.target.closest('[data-block]'); 25959 rootClientId = blockElement.getAttribute('data-block'); 25960 } // Don't set the insertion point if the template is locked. 25961 25962 25963 if (getTemplateLock(rootClientId)) { 25964 return; 25965 } 25966 25967 const orientation = ((_getBlockListSettings = getBlockListSettings(rootClientId)) === null || _getBlockListSettings === void 0 ? void 0 : _getBlockListSettings.orientation) || 'vertical'; 25968 const rect = event.target.getBoundingClientRect(); 25969 const offsetTop = event.clientY - rect.top; 25970 const offsetLeft = event.clientX - rect.left; 25971 const children = Array.from(event.target.children); 25972 let element = children.find(blockEl => { 25973 return blockEl.classList.contains('wp-block') && orientation === 'vertical' && blockEl.offsetTop > offsetTop || blockEl.classList.contains('wp-block') && orientation === 'horizontal' && blockEl.offsetLeft > offsetLeft; 25974 }); 25975 25976 if (!element) { 25977 return; 25978 } // The block may be in an alignment wrapper, so check the first direct 25979 // child if the element has no ID. 25980 25981 25982 if (!element.id) { 25983 element = element.firstElementChild; 25984 25985 if (!element) { 25986 return; 25987 } 25988 } // Don't show the insertion point if a parent block has an "overlay" 25989 // See https://github.com/WordPress/gutenberg/pull/34012#pullrequestreview-727762337 25990 25991 25992 const parentOverlay = (_element$parentElemen = element.parentElement) === null || _element$parentElemen === void 0 ? void 0 : _element$parentElemen.closest('.block-editor-block-content-overlay.overlay-active'); 25993 25994 if (parentOverlay) { 25995 return; 25996 } 25997 25998 const clientId = element.id.slice('block-'.length); 25999 26000 if (!clientId) { 26001 return; 26002 } // Don't show the inserter when hovering above (conflicts with 26003 // block toolbar) or inside selected block(s). 26004 26005 26006 if (getSelectedBlockClientIds().includes(clientId)) { 26007 return; 26008 } 26009 26010 const elementRect = element.getBoundingClientRect(); 26011 26012 if (orientation === 'horizontal' && (event.clientY > elementRect.bottom || event.clientY < elementRect.top) || orientation === 'vertical' && (event.clientX > elementRect.right || event.clientX < elementRect.left)) { 26013 if (isBlockInsertionPointVisible()) { 26014 hideInsertionPoint(); 26015 } 26016 26017 return; 26018 } 26019 26020 const index = getBlockIndex(clientId); // Don't show the in-between inserter before the first block in 26021 // the list (preserves the original behaviour). 26022 26023 if (index === 0) { 26024 if (isBlockInsertionPointVisible()) { 26025 hideInsertionPoint(); 26026 } 26027 26028 return; 26029 } 26030 26031 showInsertionPoint(rootClientId, index, { 26032 __unstableWithInserter: true 26033 }); 26034 } 26035 26036 node.addEventListener('mousemove', onMouseMove); 26037 return () => { 26038 node.removeEventListener('mousemove', onMouseMove); 26039 }; 26040 }, [openRef, getBlockListSettings, getBlockRootClientId, getBlockIndex, isBlockInsertionPointVisible, isMultiSelecting, showInsertionPoint, hideInsertionPoint, getSelectedBlockClientIds]); 26041 } 26042 26043 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/utils/pre-parse-patterns.js 26044 /** 26045 * WordPress dependencies 26046 */ 26047 26048 26049 /** 26050 * Internal dependencies 26051 */ 26052 26053 26054 26055 const requestIdleCallback = (() => { 26056 if (typeof window === 'undefined') { 26057 return callback => { 26058 setTimeout(() => callback(Date.now()), 0); 26059 }; 26060 } 26061 26062 return window.requestIdleCallback || window.requestAnimationFrame; 26063 })(); 26064 26065 const cancelIdleCallback = (() => { 26066 if (typeof window === 'undefined') { 26067 return clearTimeout; 26068 } 26069 26070 return window.cancelIdleCallback || window.cancelAnimationFrame; 26071 })(); 26072 26073 function usePreParsePatterns() { 26074 const patterns = (0,external_wp_data_namespaceObject.useSelect)(_select => _select(store).getSettings().__experimentalBlockPatterns, []); 26075 (0,external_wp_element_namespaceObject.useEffect)(() => { 26076 if (!(patterns !== null && patterns !== void 0 && patterns.length)) { 26077 return; 26078 } 26079 26080 let handle; 26081 let index = -1; 26082 26083 const callback = () => { 26084 index++; 26085 26086 if (index >= patterns.length) { 26087 return; 26088 } 26089 26090 (0,external_wp_data_namespaceObject.select)(store).__experimentalGetParsedPattern(patterns[index].name); 26091 26092 handle = requestIdleCallback(callback); 26093 }; 26094 26095 handle = requestIdleCallback(callback); 26096 return () => cancelIdleCallback(handle); 26097 }, [patterns]); 26098 return null; 26099 } 26100 26101 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/use-block-display-information/index.js 26102 /** 26103 * WordPress dependencies 26104 */ 26105 26106 26107 /** 26108 * Internal dependencies 26109 */ 26110 26111 26112 /** @typedef {import('@wordpress/blocks').WPIcon} WPIcon */ 26113 26114 /** 26115 * Contains basic block's information for display reasons. 26116 * 26117 * @typedef {Object} WPBlockDisplayInformation 26118 * 26119 * @property {string} title Human-readable block type label. 26120 * @property {WPIcon} icon Block type icon. 26121 * @property {string} description A detailed block type description. 26122 */ 26123 26124 /** 26125 * Hook used to try to find a matching block variation and return 26126 * the appropriate information for display reasons. In order to 26127 * to try to find a match we need to things: 26128 * 1. Block's client id to extract it's current attributes. 26129 * 2. A block variation should have set `isActive` prop to a proper function. 26130 * 26131 * If for any reason a block variaton match cannot be found, 26132 * the returned information come from the Block Type. 26133 * If no blockType is found with the provided clientId, returns null. 26134 * 26135 * @param {string} clientId Block's client id. 26136 * @return {?WPBlockDisplayInformation} Block's display information, or `null` when the block or its type not found. 26137 */ 26138 26139 function useBlockDisplayInformation(clientId) { 26140 return (0,external_wp_data_namespaceObject.useSelect)(select => { 26141 if (!clientId) return null; 26142 const { 26143 getBlockName, 26144 getBlockAttributes 26145 } = select(store); 26146 const { 26147 getBlockType, 26148 getActiveBlockVariation 26149 } = select(external_wp_blocks_namespaceObject.store); 26150 const blockName = getBlockName(clientId); 26151 const blockType = getBlockType(blockName); 26152 if (!blockType) return null; 26153 const attributes = getBlockAttributes(clientId); 26154 const match = getActiveBlockVariation(blockName, attributes); 26155 const blockTypeInfo = { 26156 title: blockType.title, 26157 icon: blockType.icon, 26158 description: blockType.description, 26159 anchor: attributes === null || attributes === void 0 ? void 0 : attributes.anchor 26160 }; 26161 if (!match) return blockTypeInfo; 26162 return { 26163 title: match.title || blockType.title, 26164 icon: match.icon || blockType.icon, 26165 description: match.description || blockType.description 26166 }; 26167 }, [clientId]); 26168 } 26169 26170 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-title/use-block-display-title.js 26171 /** 26172 * External dependencies 26173 */ 26174 26175 /** 26176 * WordPress dependencies 26177 */ 26178 26179 26180 26181 /** 26182 * Internal dependencies 26183 */ 26184 26185 26186 26187 /** 26188 * Returns the block's configured title as a string, or empty if the title 26189 * cannot be determined. 26190 * 26191 * @example 26192 * 26193 * ```js 26194 * useBlockDisplayTitle( 'afd1cb17-2c08-4e7a-91be-007ba7ddc3a1', 17 ); 26195 * ``` 26196 * 26197 * @param {string} clientId Client ID of block. 26198 * @param {number|undefined} maximumLength The maximum length that the block title string may be before truncated. 26199 * @return {?string} Block title. 26200 */ 26201 26202 function useBlockDisplayTitle(clientId, maximumLength) { 26203 const { 26204 attributes, 26205 name, 26206 reusableBlockTitle 26207 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 26208 if (!clientId) { 26209 return {}; 26210 } 26211 26212 const { 26213 getBlockName, 26214 getBlockAttributes, 26215 __experimentalGetReusableBlockTitle 26216 } = select(store); 26217 const blockName = getBlockName(clientId); 26218 26219 if (!blockName) { 26220 return {}; 26221 } 26222 26223 const isReusable = (0,external_wp_blocks_namespaceObject.isReusableBlock)((0,external_wp_blocks_namespaceObject.getBlockType)(blockName)); 26224 return { 26225 attributes: getBlockAttributes(clientId), 26226 name: blockName, 26227 reusableBlockTitle: isReusable && __experimentalGetReusableBlockTitle(getBlockAttributes(clientId).ref) 26228 }; 26229 }, [clientId]); 26230 const blockInformation = useBlockDisplayInformation(clientId); 26231 26232 if (!name || !blockInformation) { 26233 return null; 26234 } 26235 26236 const blockType = (0,external_wp_blocks_namespaceObject.getBlockType)(name); 26237 const blockLabel = blockType ? (0,external_wp_blocks_namespaceObject.__experimentalGetBlockLabel)(blockType, attributes) : null; 26238 const label = reusableBlockTitle || blockLabel; // Label will fallback to the title if no label is defined for the current 26239 // label context. If the label is defined we prioritize it over a 26240 // possible block variation title match. 26241 26242 const blockTitle = label && label !== blockType.title ? label : blockInformation.title; 26243 26244 if (maximumLength && maximumLength > 0) { 26245 return (0,external_lodash_namespaceObject.truncate)(blockTitle, { 26246 length: maximumLength 26247 }); 26248 } 26249 26250 return blockTitle; 26251 } 26252 26253 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-title/index.js 26254 /** 26255 * Internal dependencies 26256 */ 26257 26258 /** 26259 * Renders the block's configured title as a string, or empty if the title 26260 * cannot be determined. 26261 * 26262 * @example 26263 * 26264 * ```jsx 26265 * <BlockTitle clientId="afd1cb17-2c08-4e7a-91be-007ba7ddc3a1" maximumLength={ 17 }/> 26266 * ``` 26267 * 26268 * @param {Object} props 26269 * @param {string} props.clientId Client ID of block. 26270 * @param {number|undefined} props.maximumLength The maximum length that the block title string may be before truncated. 26271 * 26272 * @return {JSX.Element} Block title. 26273 */ 26274 26275 function BlockTitle(_ref) { 26276 let { 26277 clientId, 26278 maximumLength 26279 } = _ref; 26280 return useBlockDisplayTitle(clientId, maximumLength); 26281 } 26282 26283 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-draggable/use-scroll-when-dragging.js 26284 /** 26285 * WordPress dependencies 26286 */ 26287 26288 26289 const SCROLL_INACTIVE_DISTANCE_PX = 50; 26290 const SCROLL_INTERVAL_MS = 25; 26291 const PIXELS_PER_SECOND_PER_PERCENTAGE = 1000; 26292 const VELOCITY_MULTIPLIER = PIXELS_PER_SECOND_PER_PERCENTAGE * (SCROLL_INTERVAL_MS / 1000); 26293 /** 26294 * React hook that scrolls the scroll container when a block is being dragged. 26295 * 26296 * @return {Function[]} `startScrolling`, `scrollOnDragOver`, `stopScrolling` 26297 * functions to be called in `onDragStart`, `onDragOver` 26298 * and `onDragEnd` events respectively. 26299 */ 26300 26301 function useScrollWhenDragging() { 26302 const dragStartY = (0,external_wp_element_namespaceObject.useRef)(null); 26303 const velocityY = (0,external_wp_element_namespaceObject.useRef)(null); 26304 const scrollParentY = (0,external_wp_element_namespaceObject.useRef)(null); 26305 const scrollEditorInterval = (0,external_wp_element_namespaceObject.useRef)(null); // Clear interval when unmounting. 26306 26307 (0,external_wp_element_namespaceObject.useEffect)(() => () => { 26308 if (scrollEditorInterval.current) { 26309 clearInterval(scrollEditorInterval.current); 26310 scrollEditorInterval.current = null; 26311 } 26312 }, []); 26313 const startScrolling = (0,external_wp_element_namespaceObject.useCallback)(event => { 26314 dragStartY.current = event.clientY; // Find nearest parent(s) to scroll. 26315 26316 scrollParentY.current = (0,external_wp_dom_namespaceObject.getScrollContainer)(event.target); 26317 scrollEditorInterval.current = setInterval(() => { 26318 if (scrollParentY.current && velocityY.current) { 26319 const newTop = scrollParentY.current.scrollTop + velocityY.current; // Setting `behavior: 'smooth'` as a scroll property seems to hurt performance. 26320 // Better to use a small scroll interval. 26321 26322 scrollParentY.current.scroll({ 26323 top: newTop 26324 }); 26325 } 26326 }, SCROLL_INTERVAL_MS); 26327 }, []); 26328 const scrollOnDragOver = (0,external_wp_element_namespaceObject.useCallback)(event => { 26329 if (!scrollParentY.current) { 26330 return; 26331 } 26332 26333 const scrollParentHeight = scrollParentY.current.offsetHeight; 26334 const offsetDragStartPosition = dragStartY.current - scrollParentY.current.offsetTop; 26335 const offsetDragPosition = event.clientY - scrollParentY.current.offsetTop; 26336 26337 if (event.clientY > offsetDragStartPosition) { 26338 // User is dragging downwards. 26339 const moveableDistance = Math.max(scrollParentHeight - offsetDragStartPosition - SCROLL_INACTIVE_DISTANCE_PX, 0); 26340 const dragDistance = Math.max(offsetDragPosition - offsetDragStartPosition - SCROLL_INACTIVE_DISTANCE_PX, 0); 26341 const distancePercentage = dragDistance / moveableDistance; 26342 velocityY.current = VELOCITY_MULTIPLIER * distancePercentage; 26343 } else if (event.clientY < offsetDragStartPosition) { 26344 // User is dragging upwards. 26345 const moveableDistance = Math.max(offsetDragStartPosition - SCROLL_INACTIVE_DISTANCE_PX, 0); 26346 const dragDistance = Math.max(offsetDragStartPosition - offsetDragPosition - SCROLL_INACTIVE_DISTANCE_PX, 0); 26347 const distancePercentage = dragDistance / moveableDistance; 26348 velocityY.current = -VELOCITY_MULTIPLIER * distancePercentage; 26349 } else { 26350 velocityY.current = 0; 26351 } 26352 }, []); 26353 26354 const stopScrolling = () => { 26355 dragStartY.current = null; 26356 scrollParentY.current = null; 26357 26358 if (scrollEditorInterval.current) { 26359 clearInterval(scrollEditorInterval.current); 26360 scrollEditorInterval.current = null; 26361 } 26362 }; 26363 26364 return [startScrolling, scrollOnDragOver, stopScrolling]; 26365 } 26366 26367 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-draggable/index.js 26368 26369 26370 /** 26371 * WordPress dependencies 26372 */ 26373 26374 26375 26376 26377 /** 26378 * Internal dependencies 26379 */ 26380 26381 26382 26383 26384 26385 const BlockDraggable = _ref => { 26386 let { 26387 children, 26388 clientIds, 26389 cloneClassname, 26390 onDragStart, 26391 onDragEnd 26392 } = _ref; 26393 const { 26394 srcRootClientId, 26395 isDraggable, 26396 icon 26397 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 26398 var _getBlockType; 26399 26400 const { 26401 canMoveBlocks, 26402 getBlockRootClientId, 26403 getBlockName 26404 } = select(store); 26405 const rootClientId = getBlockRootClientId(clientIds[0]); 26406 const blockName = getBlockName(clientIds[0]); 26407 return { 26408 srcRootClientId: rootClientId, 26409 isDraggable: canMoveBlocks(clientIds, rootClientId), 26410 icon: (_getBlockType = (0,external_wp_blocks_namespaceObject.getBlockType)(blockName)) === null || _getBlockType === void 0 ? void 0 : _getBlockType.icon 26411 }; 26412 }, [clientIds]); 26413 const isDragging = (0,external_wp_element_namespaceObject.useRef)(false); 26414 const [startScrolling, scrollOnDragOver, stopScrolling] = useScrollWhenDragging(); 26415 const { 26416 startDraggingBlocks, 26417 stopDraggingBlocks 26418 } = (0,external_wp_data_namespaceObject.useDispatch)(store); // Stop dragging blocks if the block draggable is unmounted. 26419 26420 (0,external_wp_element_namespaceObject.useEffect)(() => { 26421 return () => { 26422 if (isDragging.current) { 26423 stopDraggingBlocks(); 26424 } 26425 }; 26426 }, []); 26427 26428 if (!isDraggable) { 26429 return children({ 26430 isDraggable: false 26431 }); 26432 } 26433 26434 const transferData = { 26435 type: 'block', 26436 srcClientIds: clientIds, 26437 srcRootClientId 26438 }; 26439 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Draggable, { 26440 cloneClassname: cloneClassname, 26441 __experimentalTransferDataType: "wp-blocks", 26442 transferData: transferData, 26443 onDragStart: event => { 26444 startDraggingBlocks(clientIds); 26445 isDragging.current = true; 26446 startScrolling(event); 26447 26448 if (onDragStart) { 26449 onDragStart(); 26450 } 26451 }, 26452 onDragOver: scrollOnDragOver, 26453 onDragEnd: () => { 26454 stopDraggingBlocks(); 26455 isDragging.current = false; 26456 stopScrolling(); 26457 26458 if (onDragEnd) { 26459 onDragEnd(); 26460 } 26461 }, 26462 __experimentalDragComponent: (0,external_wp_element_namespaceObject.createElement)(BlockDraggableChip, { 26463 count: clientIds.length, 26464 icon: icon 26465 }) 26466 }, _ref2 => { 26467 let { 26468 onDraggableStart, 26469 onDraggableEnd 26470 } = _ref2; 26471 return children({ 26472 draggable: true, 26473 onDragStart: onDraggableStart, 26474 onDragEnd: onDraggableEnd 26475 }); 26476 }); 26477 }; 26478 26479 /* harmony default export */ var block_draggable = (BlockDraggable); 26480 26481 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-tools/block-selection-button.js 26482 26483 26484 26485 /** 26486 * External dependencies 26487 */ 26488 26489 /** 26490 * WordPress dependencies 26491 */ 26492 26493 26494 26495 26496 26497 26498 26499 26500 26501 26502 /** 26503 * Internal dependencies 26504 */ 26505 26506 26507 26508 26509 26510 26511 /** 26512 * Block selection button component, displaying the label of the block. If the block 26513 * descends from a root block, a button is displayed enabling the user to select 26514 * the root block. 26515 * 26516 * @param {string} props Component props. 26517 * @param {string} props.clientId Client ID of block. 26518 * 26519 * @return {WPComponent} The component to be rendered. 26520 */ 26521 26522 function BlockSelectionButton(_ref) { 26523 let { 26524 clientId, 26525 rootClientId, 26526 blockElement 26527 } = _ref; 26528 const blockInformation = useBlockDisplayInformation(clientId); 26529 const selected = (0,external_wp_data_namespaceObject.useSelect)(select => { 26530 var _getBlockListSettings; 26531 26532 const { 26533 getBlock, 26534 getBlockIndex, 26535 hasBlockMovingClientId, 26536 getBlockListSettings 26537 } = select(store); 26538 const index = getBlockIndex(clientId); 26539 const { 26540 name, 26541 attributes 26542 } = getBlock(clientId); 26543 const blockMovingMode = hasBlockMovingClientId(); 26544 return { 26545 index, 26546 name, 26547 attributes, 26548 blockMovingMode, 26549 orientation: (_getBlockListSettings = getBlockListSettings(rootClientId)) === null || _getBlockListSettings === void 0 ? void 0 : _getBlockListSettings.orientation 26550 }; 26551 }, [clientId, rootClientId]); 26552 const { 26553 index, 26554 name, 26555 attributes, 26556 blockMovingMode, 26557 orientation 26558 } = selected; 26559 const { 26560 setNavigationMode, 26561 removeBlock 26562 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 26563 const ref = (0,external_wp_element_namespaceObject.useRef)(); 26564 const blockType = (0,external_wp_blocks_namespaceObject.getBlockType)(name); 26565 const label = (0,external_wp_blocks_namespaceObject.__experimentalGetAccessibleBlockLabel)(blockType, attributes, index + 1, orientation); // Focus the breadcrumb in navigation mode. 26566 26567 (0,external_wp_element_namespaceObject.useEffect)(() => { 26568 ref.current.focus(); 26569 (0,external_wp_a11y_namespaceObject.speak)(label); 26570 }, [label]); 26571 const { 26572 hasBlockMovingClientId, 26573 getBlockIndex, 26574 getBlockRootClientId, 26575 getClientIdsOfDescendants, 26576 getSelectedBlockClientId, 26577 getMultiSelectedBlocksEndClientId, 26578 getPreviousBlockClientId, 26579 getNextBlockClientId, 26580 isNavigationMode 26581 } = (0,external_wp_data_namespaceObject.useSelect)(store); 26582 const { 26583 selectBlock, 26584 clearSelectedBlock, 26585 setBlockMovingClientId, 26586 moveBlockToPosition 26587 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 26588 26589 function onKeyDown(event) { 26590 const { 26591 keyCode 26592 } = event; 26593 const isUp = keyCode === external_wp_keycodes_namespaceObject.UP; 26594 const isDown = keyCode === external_wp_keycodes_namespaceObject.DOWN; 26595 const isLeft = keyCode === external_wp_keycodes_namespaceObject.LEFT; 26596 const isRight = keyCode === external_wp_keycodes_namespaceObject.RIGHT; 26597 const isTab = keyCode === external_wp_keycodes_namespaceObject.TAB; 26598 const isEscape = keyCode === external_wp_keycodes_namespaceObject.ESCAPE; 26599 const isEnter = keyCode === external_wp_keycodes_namespaceObject.ENTER; 26600 const isSpace = keyCode === external_wp_keycodes_namespaceObject.SPACE; 26601 const isShift = event.shiftKey; 26602 26603 if (keyCode === external_wp_keycodes_namespaceObject.BACKSPACE || keyCode === external_wp_keycodes_namespaceObject.DELETE) { 26604 removeBlock(clientId); 26605 event.preventDefault(); 26606 return; 26607 } 26608 26609 const selectedBlockClientId = getSelectedBlockClientId(); 26610 const selectionEndClientId = getMultiSelectedBlocksEndClientId(); 26611 const selectionBeforeEndClientId = getPreviousBlockClientId(selectionEndClientId || selectedBlockClientId); 26612 const selectionAfterEndClientId = getNextBlockClientId(selectionEndClientId || selectedBlockClientId); 26613 const navigateUp = isTab && isShift || isUp; 26614 const navigateDown = isTab && !isShift || isDown; // Move out of current nesting level (no effect if at root level). 26615 26616 const navigateOut = isLeft; // Move into next nesting level (no effect if the current block has no innerBlocks). 26617 26618 const navigateIn = isRight; 26619 let focusedBlockUid; 26620 26621 if (navigateUp) { 26622 focusedBlockUid = selectionBeforeEndClientId; 26623 } else if (navigateDown) { 26624 focusedBlockUid = selectionAfterEndClientId; 26625 } else if (navigateOut) { 26626 var _getBlockRootClientId; 26627 26628 focusedBlockUid = (_getBlockRootClientId = getBlockRootClientId(selectedBlockClientId)) !== null && _getBlockRootClientId !== void 0 ? _getBlockRootClientId : selectedBlockClientId; 26629 } else if (navigateIn) { 26630 var _getClientIdsOfDescen; 26631 26632 focusedBlockUid = (_getClientIdsOfDescen = getClientIdsOfDescendants([selectedBlockClientId])[0]) !== null && _getClientIdsOfDescen !== void 0 ? _getClientIdsOfDescen : selectedBlockClientId; 26633 } 26634 26635 const startingBlockClientId = hasBlockMovingClientId(); 26636 26637 if (isEscape && isNavigationMode()) { 26638 clearSelectedBlock(); 26639 event.preventDefault(); 26640 } 26641 26642 if (isEscape && startingBlockClientId && !event.defaultPrevented) { 26643 setBlockMovingClientId(null); 26644 event.preventDefault(); 26645 } 26646 26647 if ((isEnter || isSpace) && startingBlockClientId) { 26648 const sourceRoot = getBlockRootClientId(startingBlockClientId); 26649 const destRoot = getBlockRootClientId(selectedBlockClientId); 26650 const sourceBlockIndex = getBlockIndex(startingBlockClientId); 26651 let destinationBlockIndex = getBlockIndex(selectedBlockClientId); 26652 26653 if (sourceBlockIndex < destinationBlockIndex && sourceRoot === destRoot) { 26654 destinationBlockIndex -= 1; 26655 } 26656 26657 moveBlockToPosition(startingBlockClientId, sourceRoot, destRoot, destinationBlockIndex); 26658 selectBlock(startingBlockClientId); 26659 setBlockMovingClientId(null); 26660 } 26661 26662 if (navigateDown || navigateUp || navigateOut || navigateIn) { 26663 if (focusedBlockUid) { 26664 event.preventDefault(); 26665 selectBlock(focusedBlockUid); 26666 } else if (isTab && selectedBlockClientId) { 26667 let nextTabbable; 26668 26669 if (navigateDown) { 26670 nextTabbable = blockElement; 26671 26672 do { 26673 nextTabbable = external_wp_dom_namespaceObject.focus.tabbable.findNext(nextTabbable); 26674 } while (nextTabbable && blockElement.contains(nextTabbable)); 26675 26676 if (!nextTabbable) { 26677 nextTabbable = blockElement.ownerDocument.defaultView.frameElement; 26678 nextTabbable = external_wp_dom_namespaceObject.focus.tabbable.findNext(nextTabbable); 26679 } 26680 } else { 26681 nextTabbable = external_wp_dom_namespaceObject.focus.tabbable.findPrevious(blockElement); 26682 } 26683 26684 if (nextTabbable) { 26685 event.preventDefault(); 26686 nextTabbable.focus(); 26687 clearSelectedBlock(); 26688 } 26689 } 26690 } 26691 } 26692 26693 const classNames = classnames_default()('block-editor-block-list__block-selection-button', { 26694 'is-block-moving-mode': !!blockMovingMode 26695 }); 26696 26697 const dragHandleLabel = (0,external_wp_i18n_namespaceObject.__)('Drag'); 26698 26699 return (0,external_wp_element_namespaceObject.createElement)("div", { 26700 className: classNames 26701 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Flex, { 26702 justify: "center", 26703 className: "block-editor-block-list__block-selection-button__content" 26704 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FlexItem, null, (0,external_wp_element_namespaceObject.createElement)(block_icon, { 26705 icon: blockInformation === null || blockInformation === void 0 ? void 0 : blockInformation.icon, 26706 showColors: true 26707 })), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FlexItem, null, (0,external_wp_element_namespaceObject.createElement)(block_draggable, { 26708 clientIds: [clientId] 26709 }, draggableProps => (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, _extends({ 26710 icon: drag_handle, 26711 className: "block-selection-button_drag-handle", 26712 "aria-hidden": "true", 26713 label: dragHandleLabel // Should not be able to tab to drag handle as this 26714 // button can only be used with a pointer device. 26715 , 26716 tabIndex: "-1" 26717 }, draggableProps)))), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FlexItem, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 26718 ref: ref, 26719 onClick: () => setNavigationMode(false), 26720 onKeyDown: onKeyDown, 26721 label: label, 26722 className: "block-selection-button_select-button" 26723 }, (0,external_wp_element_namespaceObject.createElement)(BlockTitle, { 26724 clientId: clientId, 26725 maximumLength: 35 26726 }))))); 26727 } 26728 26729 /* harmony default export */ var block_selection_button = (BlockSelectionButton); 26730 26731 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/navigable-toolbar/index.js 26732 26733 26734 26735 /** 26736 * WordPress dependencies 26737 */ 26738 26739 26740 26741 26742 26743 26744 function hasOnlyToolbarItem(elements) { 26745 const dataProp = 'toolbarItem'; 26746 return !elements.some(element => !(dataProp in element.dataset)); 26747 } 26748 26749 function getAllToolbarItemsIn(container) { 26750 return Array.from(container.querySelectorAll('[data-toolbar-item]')); 26751 } 26752 26753 function hasFocusWithin(container) { 26754 return container.contains(container.ownerDocument.activeElement); 26755 } 26756 26757 function focusFirstTabbableIn(container) { 26758 const [firstTabbable] = external_wp_dom_namespaceObject.focus.tabbable.find(container); 26759 26760 if (firstTabbable) { 26761 firstTabbable.focus(); 26762 } 26763 } 26764 26765 function useIsAccessibleToolbar(ref) { 26766 /* 26767 * By default, we'll assume the starting accessible state of the Toolbar 26768 * is true, as it seems to be the most common case. 26769 * 26770 * Transitioning from an (initial) false to true state causes the 26771 * <Toolbar /> component to mount twice, which is causing undesired 26772 * side-effects. These side-effects appear to only affect certain 26773 * E2E tests. 26774 * 26775 * This was initial discovered in this pull-request: 26776 * https://github.com/WordPress/gutenberg/pull/23425 26777 */ 26778 const initialAccessibleToolbarState = true; // By default, it's gonna render NavigableMenu. If all the tabbable elements 26779 // inside the toolbar are ToolbarItem components (or derived components like 26780 // ToolbarButton), then we can wrap them with the accessible Toolbar 26781 // component. 26782 26783 const [isAccessibleToolbar, setIsAccessibleToolbar] = (0,external_wp_element_namespaceObject.useState)(initialAccessibleToolbarState); 26784 const determineIsAccessibleToolbar = (0,external_wp_element_namespaceObject.useCallback)(() => { 26785 const tabbables = external_wp_dom_namespaceObject.focus.tabbable.find(ref.current); 26786 const onlyToolbarItem = hasOnlyToolbarItem(tabbables); 26787 26788 if (!onlyToolbarItem) { 26789 external_wp_deprecated_default()('Using custom components as toolbar controls', { 26790 since: '5.6', 26791 alternative: 'ToolbarItem, ToolbarButton or ToolbarDropdownMenu components', 26792 link: 'https://developer.wordpress.org/block-editor/components/toolbar-button/#inside-blockcontrols' 26793 }); 26794 } 26795 26796 setIsAccessibleToolbar(onlyToolbarItem); 26797 }, []); 26798 (0,external_wp_element_namespaceObject.useLayoutEffect)(() => { 26799 // Toolbar buttons may be rendered asynchronously, so we use 26800 // MutationObserver to check if the toolbar subtree has been modified. 26801 const observer = new window.MutationObserver(determineIsAccessibleToolbar); 26802 observer.observe(ref.current, { 26803 childList: true, 26804 subtree: true 26805 }); 26806 return () => observer.disconnect(); 26807 }, [isAccessibleToolbar]); 26808 return isAccessibleToolbar; 26809 } 26810 26811 function useToolbarFocus(ref, focusOnMount, isAccessibleToolbar, defaultIndex, onIndexChange) { 26812 // Make sure we don't use modified versions of this prop. 26813 const [initialFocusOnMount] = (0,external_wp_element_namespaceObject.useState)(focusOnMount); 26814 const [initialIndex] = (0,external_wp_element_namespaceObject.useState)(defaultIndex); 26815 const focusToolbar = (0,external_wp_element_namespaceObject.useCallback)(() => { 26816 focusFirstTabbableIn(ref.current); 26817 }, []); // Focus on toolbar when pressing alt+F10 when the toolbar is visible. 26818 26819 (0,external_wp_keyboardShortcuts_namespaceObject.useShortcut)('core/block-editor/focus-toolbar', focusToolbar); 26820 (0,external_wp_element_namespaceObject.useEffect)(() => { 26821 if (initialFocusOnMount) { 26822 focusToolbar(); 26823 } 26824 }, [isAccessibleToolbar, initialFocusOnMount, focusToolbar]); 26825 (0,external_wp_element_namespaceObject.useEffect)(() => { 26826 // If initialIndex is passed, we focus on that toolbar item when the 26827 // toolbar gets mounted and initial focus is not forced. 26828 // We have to wait for the next browser paint because block controls aren't 26829 // rendered right away when the toolbar gets mounted. 26830 let raf = 0; 26831 26832 if (initialIndex && !initialFocusOnMount) { 26833 raf = window.requestAnimationFrame(() => { 26834 const items = getAllToolbarItemsIn(ref.current); 26835 const index = initialIndex || 0; 26836 26837 if (items[index] && hasFocusWithin(ref.current)) { 26838 items[index].focus(); 26839 } 26840 }); 26841 } 26842 26843 return () => { 26844 window.cancelAnimationFrame(raf); 26845 if (!onIndexChange || !ref.current) return; // When the toolbar element is unmounted and onIndexChange is passed, we 26846 // pass the focused toolbar item index so it can be hydrated later. 26847 26848 const items = getAllToolbarItemsIn(ref.current); 26849 const index = items.findIndex(item => item.tabIndex === 0); 26850 onIndexChange(index); 26851 }; 26852 }, [initialIndex, initialFocusOnMount]); 26853 } 26854 26855 function NavigableToolbar(_ref) { 26856 let { 26857 children, 26858 focusOnMount, 26859 __experimentalInitialIndex: initialIndex, 26860 __experimentalOnIndexChange: onIndexChange, 26861 ...props 26862 } = _ref; 26863 const ref = (0,external_wp_element_namespaceObject.useRef)(); 26864 const isAccessibleToolbar = useIsAccessibleToolbar(ref); 26865 useToolbarFocus(ref, focusOnMount, isAccessibleToolbar, initialIndex, onIndexChange); 26866 26867 if (isAccessibleToolbar) { 26868 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Toolbar, _extends({ 26869 label: props['aria-label'], 26870 ref: ref 26871 }, props), children); 26872 } 26873 26874 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.NavigableMenu, _extends({ 26875 orientation: "horizontal", 26876 role: "toolbar", 26877 ref: ref 26878 }, props), children); 26879 } 26880 26881 /* harmony default export */ var navigable_toolbar = (NavigableToolbar); 26882 26883 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/chevron-right.js 26884 26885 26886 /** 26887 * WordPress dependencies 26888 */ 26889 26890 const chevronRight = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 26891 xmlns: "http://www.w3.org/2000/svg", 26892 viewBox: "0 0 24 24" 26893 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 26894 d: "M10.6 6L9.4 7l4.6 5-4.6 5 1.2 1 5.4-6z" 26895 })); 26896 /* harmony default export */ var chevron_right = (chevronRight); 26897 26898 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/chevron-left.js 26899 26900 26901 /** 26902 * WordPress dependencies 26903 */ 26904 26905 const chevronLeft = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 26906 xmlns: "http://www.w3.org/2000/svg", 26907 viewBox: "0 0 24 24" 26908 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 26909 d: "M14.6 7l-1.2-1L8 12l5.4 6 1.2-1-4.6-5z" 26910 })); 26911 /* harmony default export */ var chevron_left = (chevronLeft); 26912 26913 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/chevron-up.js 26914 26915 26916 /** 26917 * WordPress dependencies 26918 */ 26919 26920 const chevronUp = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 26921 viewBox: "0 0 24 24", 26922 xmlns: "http://www.w3.org/2000/svg" 26923 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 26924 d: "M6.5 12.4L12 8l5.5 4.4-.9 1.2L12 10l-4.5 3.6-1-1.2z" 26925 })); 26926 /* harmony default export */ var chevron_up = (chevronUp); 26927 26928 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/chevron-down.js 26929 26930 26931 /** 26932 * WordPress dependencies 26933 */ 26934 26935 const chevronDown = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 26936 viewBox: "0 0 24 24", 26937 xmlns: "http://www.w3.org/2000/svg" 26938 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 26939 d: "M17.5 11.6L12 16l-5.5-4.4.9-1.2L12 14l4.5-3.6 1 1.2z" 26940 })); 26941 /* harmony default export */ var chevron_down = (chevronDown); 26942 26943 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-mover/mover-description.js 26944 /** 26945 * WordPress dependencies 26946 */ 26947 26948 /** 26949 * Return a label for the block movement controls depending on block position. 26950 * 26951 * @param {number} selectedCount Number of blocks selected. 26952 * @param {string} type Block type - in the case of a single block, should 26953 * define its 'type'. I.e. 'Text', 'Heading', 'Image' etc. 26954 * @param {number} firstIndex The index (position - 1) of the first block selected. 26955 * @param {boolean} isFirst This is the first block. 26956 * @param {boolean} isLast This is the last block. 26957 * @param {number} dir Direction of movement (> 0 is considered to be going 26958 * down, < 0 is up). 26959 * @param {string} orientation The orientation of the block movers, vertical or 26960 * horizontal. 26961 * 26962 * @return {string} Label for the block movement controls. 26963 */ 26964 26965 function getBlockMoverDescription(selectedCount, type, firstIndex, isFirst, isLast, dir, orientation) { 26966 const position = firstIndex + 1; 26967 26968 const getMovementDirection = moveDirection => { 26969 if (moveDirection === 'up') { 26970 if (orientation === 'horizontal') { 26971 return (0,external_wp_i18n_namespaceObject.isRTL)() ? 'right' : 'left'; 26972 } 26973 26974 return 'up'; 26975 } else if (moveDirection === 'down') { 26976 if (orientation === 'horizontal') { 26977 return (0,external_wp_i18n_namespaceObject.isRTL)() ? 'left' : 'right'; 26978 } 26979 26980 return 'down'; 26981 } 26982 26983 return null; 26984 }; 26985 26986 if (selectedCount > 1) { 26987 return getMultiBlockMoverDescription(selectedCount, firstIndex, isFirst, isLast, dir); 26988 } 26989 26990 if (isFirst && isLast) { 26991 return (0,external_wp_i18n_namespaceObject.sprintf)( // translators: %s: Type of block (i.e. Text, Image etc) 26992 (0,external_wp_i18n_namespaceObject.__)('Block %s is the only block, and cannot be moved'), type); 26993 } 26994 26995 if (dir > 0 && !isLast) { 26996 // Moving down. 26997 const movementDirection = getMovementDirection('down'); 26998 26999 if (movementDirection === 'down') { 27000 return (0,external_wp_i18n_namespaceObject.sprintf)( // translators: 1: Type of block (i.e. Text, Image etc), 2: Position of selected block, 3: New position 27001 (0,external_wp_i18n_namespaceObject.__)('Move %1$s block from position %2$d down to position %3$d'), type, position, position + 1); 27002 } 27003 27004 if (movementDirection === 'left') { 27005 return (0,external_wp_i18n_namespaceObject.sprintf)( // translators: 1: Type of block (i.e. Text, Image etc), 2: Position of selected block, 3: New position 27006 (0,external_wp_i18n_namespaceObject.__)('Move %1$s block from position %2$d left to position %3$d'), type, position, position + 1); 27007 } 27008 27009 if (movementDirection === 'right') { 27010 return (0,external_wp_i18n_namespaceObject.sprintf)( // translators: 1: Type of block (i.e. Text, Image etc), 2: Position of selected block, 3: New position 27011 (0,external_wp_i18n_namespaceObject.__)('Move %1$s block from position %2$d right to position %3$d'), type, position, position + 1); 27012 } 27013 } 27014 27015 if (dir > 0 && isLast) { 27016 // Moving down, and is the last item. 27017 const movementDirection = getMovementDirection('down'); 27018 27019 if (movementDirection === 'down') { 27020 return (0,external_wp_i18n_namespaceObject.sprintf)( // translators: 1: Type of block (i.e. Text, Image etc) 27021 (0,external_wp_i18n_namespaceObject.__)('Block %1$s is at the end of the content and can’t be moved down'), type); 27022 } 27023 27024 if (movementDirection === 'left') { 27025 return (0,external_wp_i18n_namespaceObject.sprintf)( // translators: 1: Type of block (i.e. Text, Image etc) 27026 (0,external_wp_i18n_namespaceObject.__)('Block %1$s is at the end of the content and can’t be moved left'), type); 27027 } 27028 27029 if (movementDirection === 'right') { 27030 return (0,external_wp_i18n_namespaceObject.sprintf)( // translators: 1: Type of block (i.e. Text, Image etc) 27031 (0,external_wp_i18n_namespaceObject.__)('Block %1$s is at the end of the content and can’t be moved right'), type); 27032 } 27033 } 27034 27035 if (dir < 0 && !isFirst) { 27036 // Moving up. 27037 const movementDirection = getMovementDirection('up'); 27038 27039 if (movementDirection === 'up') { 27040 return (0,external_wp_i18n_namespaceObject.sprintf)( // translators: 1: Type of block (i.e. Text, Image etc), 2: Position of selected block, 3: New position 27041 (0,external_wp_i18n_namespaceObject.__)('Move %1$s block from position %2$d up to position %3$d'), type, position, position - 1); 27042 } 27043 27044 if (movementDirection === 'left') { 27045 return (0,external_wp_i18n_namespaceObject.sprintf)( // translators: 1: Type of block (i.e. Text, Image etc), 2: Position of selected block, 3: New position 27046 (0,external_wp_i18n_namespaceObject.__)('Move %1$s block from position %2$d left to position %3$d'), type, position, position - 1); 27047 } 27048 27049 if (movementDirection === 'right') { 27050 return (0,external_wp_i18n_namespaceObject.sprintf)( // translators: 1: Type of block (i.e. Text, Image etc), 2: Position of selected block, 3: New position 27051 (0,external_wp_i18n_namespaceObject.__)('Move %1$s block from position %2$d right to position %3$d'), type, position, position - 1); 27052 } 27053 } 27054 27055 if (dir < 0 && isFirst) { 27056 // Moving up, and is the first item. 27057 const movementDirection = getMovementDirection('up'); 27058 27059 if (movementDirection === 'up') { 27060 return (0,external_wp_i18n_namespaceObject.sprintf)( // translators: 1: Type of block (i.e. Text, Image etc) 27061 (0,external_wp_i18n_namespaceObject.__)('Block %1$s is at the beginning of the content and can’t be moved up'), type); 27062 } 27063 27064 if (movementDirection === 'left') { 27065 return (0,external_wp_i18n_namespaceObject.sprintf)( // translators: 1: Type of block (i.e. Text, Image etc) 27066 (0,external_wp_i18n_namespaceObject.__)('Block %1$s is at the beginning of the content and can’t be moved left'), type); 27067 } 27068 27069 if (movementDirection === 'right') { 27070 return (0,external_wp_i18n_namespaceObject.sprintf)( // translators: 1: Type of block (i.e. Text, Image etc) 27071 (0,external_wp_i18n_namespaceObject.__)('Block %1$s is at the beginning of the content and can’t be moved right'), type); 27072 } 27073 } 27074 } 27075 /** 27076 * Return a label for the block movement controls depending on block position. 27077 * 27078 * @param {number} selectedCount Number of blocks selected. 27079 * @param {number} firstIndex The index (position - 1) of the first block selected. 27080 * @param {boolean} isFirst This is the first block. 27081 * @param {boolean} isLast This is the last block. 27082 * @param {number} dir Direction of movement (> 0 is considered to be going 27083 * down, < 0 is up). 27084 * 27085 * @return {string} Label for the block movement controls. 27086 */ 27087 27088 function getMultiBlockMoverDescription(selectedCount, firstIndex, isFirst, isLast, dir) { 27089 const position = firstIndex + 1; 27090 27091 if (dir < 0 && isFirst) { 27092 return (0,external_wp_i18n_namespaceObject.__)('Blocks cannot be moved up as they are already at the top'); 27093 } 27094 27095 if (dir > 0 && isLast) { 27096 return (0,external_wp_i18n_namespaceObject.__)('Blocks cannot be moved down as they are already at the bottom'); 27097 } 27098 27099 if (dir < 0 && !isFirst) { 27100 return (0,external_wp_i18n_namespaceObject.sprintf)( // translators: 1: Number of selected blocks, 2: Position of selected blocks 27101 (0,external_wp_i18n_namespaceObject._n)('Move %1$d block from position %2$d up by one place', 'Move %1$d blocks from position %2$d up by one place', selectedCount), selectedCount, position); 27102 } 27103 27104 if (dir > 0 && !isLast) { 27105 return (0,external_wp_i18n_namespaceObject.sprintf)( // translators: 1: Number of selected blocks, 2: Position of selected blocks 27106 (0,external_wp_i18n_namespaceObject._n)('Move %1$d block from position %2$d down by one place', 'Move %1$d blocks from position %2$d down by one place', selectedCount), selectedCount, position); 27107 } 27108 } 27109 27110 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-mover/button.js 27111 27112 27113 27114 /** 27115 * External dependencies 27116 */ 27117 27118 27119 /** 27120 * WordPress dependencies 27121 */ 27122 27123 27124 27125 27126 27127 27128 27129 /** 27130 * Internal dependencies 27131 */ 27132 27133 27134 27135 27136 27137 const getArrowIcon = (direction, orientation) => { 27138 if (direction === 'up') { 27139 if (orientation === 'horizontal') { 27140 return (0,external_wp_i18n_namespaceObject.isRTL)() ? chevron_right : chevron_left; 27141 } 27142 27143 return chevron_up; 27144 } else if (direction === 'down') { 27145 if (orientation === 'horizontal') { 27146 return (0,external_wp_i18n_namespaceObject.isRTL)() ? chevron_left : chevron_right; 27147 } 27148 27149 return chevron_down; 27150 } 27151 27152 return null; 27153 }; 27154 27155 const getMovementDirectionLabel = (moveDirection, orientation) => { 27156 if (moveDirection === 'up') { 27157 if (orientation === 'horizontal') { 27158 return (0,external_wp_i18n_namespaceObject.isRTL)() ? (0,external_wp_i18n_namespaceObject.__)('Move right') : (0,external_wp_i18n_namespaceObject.__)('Move left'); 27159 } 27160 27161 return (0,external_wp_i18n_namespaceObject.__)('Move up'); 27162 } else if (moveDirection === 'down') { 27163 if (orientation === 'horizontal') { 27164 return (0,external_wp_i18n_namespaceObject.isRTL)() ? (0,external_wp_i18n_namespaceObject.__)('Move left') : (0,external_wp_i18n_namespaceObject.__)('Move right'); 27165 } 27166 27167 return (0,external_wp_i18n_namespaceObject.__)('Move down'); 27168 } 27169 27170 return null; 27171 }; 27172 27173 const BlockMoverButton = (0,external_wp_element_namespaceObject.forwardRef)((_ref, ref) => { 27174 let { 27175 clientIds, 27176 direction, 27177 orientation: moverOrientation, 27178 ...props 27179 } = _ref; 27180 const instanceId = (0,external_wp_compose_namespaceObject.useInstanceId)(BlockMoverButton); 27181 const blocksCount = (0,external_lodash_namespaceObject.castArray)(clientIds).length; 27182 const { 27183 blockType, 27184 isDisabled, 27185 rootClientId, 27186 isFirst, 27187 isLast, 27188 firstIndex, 27189 orientation = 'vertical' 27190 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 27191 const { 27192 getBlockIndex, 27193 getBlockRootClientId, 27194 getBlockOrder, 27195 getBlock, 27196 getBlockListSettings 27197 } = select(store); 27198 const normalizedClientIds = (0,external_lodash_namespaceObject.castArray)(clientIds); 27199 const firstClientId = (0,external_lodash_namespaceObject.first)(normalizedClientIds); 27200 const blockRootClientId = getBlockRootClientId(firstClientId); 27201 const firstBlockIndex = getBlockIndex(firstClientId); 27202 const lastBlockIndex = getBlockIndex((0,external_lodash_namespaceObject.last)(normalizedClientIds)); 27203 const blockOrder = getBlockOrder(blockRootClientId); 27204 const block = getBlock(firstClientId); 27205 const isFirstBlock = firstBlockIndex === 0; 27206 const isLastBlock = lastBlockIndex === blockOrder.length - 1; 27207 const { 27208 orientation: blockListOrientation 27209 } = getBlockListSettings(blockRootClientId) || {}; 27210 return { 27211 blockType: block ? (0,external_wp_blocks_namespaceObject.getBlockType)(block.name) : null, 27212 isDisabled: direction === 'up' ? isFirstBlock : isLastBlock, 27213 rootClientId: blockRootClientId, 27214 firstIndex: firstBlockIndex, 27215 isFirst: isFirstBlock, 27216 isLast: isLastBlock, 27217 orientation: moverOrientation || blockListOrientation 27218 }; 27219 }, [clientIds, direction]); 27220 const { 27221 moveBlocksDown, 27222 moveBlocksUp 27223 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 27224 const moverFunction = direction === 'up' ? moveBlocksUp : moveBlocksDown; 27225 27226 const onClick = event => { 27227 moverFunction(clientIds, rootClientId); 27228 27229 if (props.onClick) { 27230 props.onClick(event); 27231 } 27232 }; 27233 27234 const descriptionId = `block-editor-block-mover-button__description-$instanceId}`; 27235 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, _extends({ 27236 ref: ref, 27237 className: classnames_default()('block-editor-block-mover-button', `is-$direction}-button`), 27238 icon: getArrowIcon(direction, orientation), 27239 label: getMovementDirectionLabel(direction, orientation), 27240 "aria-describedby": descriptionId 27241 }, props, { 27242 onClick: isDisabled ? null : onClick, 27243 "aria-disabled": isDisabled 27244 })), (0,external_wp_element_namespaceObject.createElement)("span", { 27245 id: descriptionId, 27246 className: "block-editor-block-mover-button__description" 27247 }, getBlockMoverDescription(blocksCount, blockType && blockType.title, firstIndex, isFirst, isLast, direction === 'up' ? -1 : 1, orientation))); 27248 }); 27249 const BlockMoverUpButton = (0,external_wp_element_namespaceObject.forwardRef)((props, ref) => { 27250 return (0,external_wp_element_namespaceObject.createElement)(BlockMoverButton, _extends({ 27251 direction: "up", 27252 ref: ref 27253 }, props)); 27254 }); 27255 const BlockMoverDownButton = (0,external_wp_element_namespaceObject.forwardRef)((props, ref) => { 27256 return (0,external_wp_element_namespaceObject.createElement)(BlockMoverButton, _extends({ 27257 direction: "down", 27258 ref: ref 27259 }, props)); 27260 }); 27261 27262 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-mover/index.js 27263 27264 27265 27266 /** 27267 * External dependencies 27268 */ 27269 27270 27271 /** 27272 * WordPress dependencies 27273 */ 27274 27275 27276 27277 27278 27279 27280 27281 /** 27282 * Internal dependencies 27283 */ 27284 27285 27286 27287 27288 27289 function BlockMover(_ref) { 27290 let { 27291 isFirst, 27292 isLast, 27293 clientIds, 27294 canMove, 27295 isHidden, 27296 rootClientId, 27297 orientation, 27298 hideDragHandle 27299 } = _ref; 27300 const [isFocused, setIsFocused] = (0,external_wp_element_namespaceObject.useState)(false); 27301 27302 const onFocus = () => setIsFocused(true); 27303 27304 const onBlur = () => setIsFocused(false); 27305 27306 if (!canMove || isFirst && isLast && !rootClientId) { 27307 return null; 27308 } 27309 27310 const dragHandleLabel = (0,external_wp_i18n_namespaceObject.__)('Drag'); // We emulate a disabled state because forcefully applying the `disabled` 27311 // attribute on the buttons while it has focus causes the screen to change 27312 // to an unfocused state (body as active element) without firing blur on, 27313 // the rendering parent, leaving it unable to react to focus out. 27314 27315 27316 return (0,external_wp_element_namespaceObject.createElement)("div", { 27317 className: classnames_default()('block-editor-block-mover', { 27318 'is-visible': isFocused || !isHidden, 27319 'is-horizontal': orientation === 'horizontal' 27320 }) 27321 }, !hideDragHandle && (0,external_wp_element_namespaceObject.createElement)(block_draggable, { 27322 clientIds: clientIds, 27323 cloneClassname: "block-editor-block-mover__drag-clone" 27324 }, draggableProps => (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, _extends({ 27325 icon: drag_handle, 27326 className: "block-editor-block-mover__drag-handle", 27327 "aria-hidden": "true", 27328 label: dragHandleLabel // Should not be able to tab to drag handle as this 27329 // button can only be used with a pointer device. 27330 , 27331 tabIndex: "-1" 27332 }, draggableProps))), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarGroup, { 27333 className: "block-editor-block-mover__move-button-container" 27334 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarItem, { 27335 onFocus: onFocus, 27336 onBlur: onBlur 27337 }, itemProps => (0,external_wp_element_namespaceObject.createElement)(BlockMoverUpButton, _extends({ 27338 clientIds: clientIds 27339 }, itemProps))), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarItem, { 27340 onFocus: onFocus, 27341 onBlur: onBlur 27342 }, itemProps => (0,external_wp_element_namespaceObject.createElement)(BlockMoverDownButton, _extends({ 27343 clientIds: clientIds 27344 }, itemProps))))); 27345 } 27346 /** 27347 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/block-mover/README.md 27348 */ 27349 27350 27351 /* harmony default export */ var block_mover = ((0,external_wp_data_namespaceObject.withSelect)((select, _ref2) => { 27352 var _getBlockListSettings; 27353 27354 let { 27355 clientIds 27356 } = _ref2; 27357 const { 27358 getBlock, 27359 getBlockIndex, 27360 getBlockListSettings, 27361 canMoveBlocks, 27362 getBlockOrder, 27363 getBlockRootClientId 27364 } = select(store); 27365 const normalizedClientIds = (0,external_lodash_namespaceObject.castArray)(clientIds); 27366 const firstClientId = (0,external_lodash_namespaceObject.first)(normalizedClientIds); 27367 const block = getBlock(firstClientId); 27368 const rootClientId = getBlockRootClientId((0,external_lodash_namespaceObject.first)(normalizedClientIds)); 27369 const firstIndex = getBlockIndex(firstClientId); 27370 const lastIndex = getBlockIndex((0,external_lodash_namespaceObject.last)(normalizedClientIds)); 27371 const blockOrder = getBlockOrder(rootClientId); 27372 const isFirst = firstIndex === 0; 27373 const isLast = lastIndex === blockOrder.length - 1; 27374 return { 27375 blockType: block ? (0,external_wp_blocks_namespaceObject.getBlockType)(block.name) : null, 27376 canMove: canMoveBlocks(clientIds, rootClientId), 27377 rootClientId, 27378 firstIndex, 27379 isFirst, 27380 isLast, 27381 orientation: (_getBlockListSettings = getBlockListSettings(rootClientId)) === null || _getBlockListSettings === void 0 ? void 0 : _getBlockListSettings.orientation 27382 }; 27383 })(BlockMover)); 27384 27385 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-toolbar/utils.js 27386 /** 27387 * External dependencies 27388 */ 27389 27390 /** 27391 * WordPress dependencies 27392 */ 27393 27394 27395 const { 27396 clearTimeout: utils_clearTimeout, 27397 setTimeout: utils_setTimeout 27398 } = window; 27399 const DEBOUNCE_TIMEOUT = 200; 27400 /** 27401 * Hook that creates a showMover state, as well as debounced show/hide callbacks. 27402 * 27403 * @param {Object} props Component props. 27404 * @param {Object} props.ref Element reference. 27405 * @param {boolean} props.isFocused Whether the component has current focus. 27406 * @param {number} [props.debounceTimeout=250] Debounce timeout in milliseconds. 27407 * @param {Function} [props.onChange=noop] Callback function. 27408 */ 27409 27410 function useDebouncedShowMovers(_ref) { 27411 let { 27412 ref, 27413 isFocused, 27414 debounceTimeout = DEBOUNCE_TIMEOUT, 27415 onChange = external_lodash_namespaceObject.noop 27416 } = _ref; 27417 const [showMovers, setShowMovers] = (0,external_wp_element_namespaceObject.useState)(false); 27418 const timeoutRef = (0,external_wp_element_namespaceObject.useRef)(); 27419 27420 const handleOnChange = nextIsFocused => { 27421 if (ref !== null && ref !== void 0 && ref.current) { 27422 setShowMovers(nextIsFocused); 27423 } 27424 27425 onChange(nextIsFocused); 27426 }; 27427 27428 const getIsHovered = () => { 27429 return (ref === null || ref === void 0 ? void 0 : ref.current) && ref.current.matches(':hover'); 27430 }; 27431 27432 const shouldHideMovers = () => { 27433 const isHovered = getIsHovered(); 27434 return !isFocused && !isHovered; 27435 }; 27436 27437 const clearTimeoutRef = () => { 27438 const timeout = timeoutRef.current; 27439 27440 if (timeout && utils_clearTimeout) { 27441 utils_clearTimeout(timeout); 27442 } 27443 }; 27444 27445 const debouncedShowMovers = event => { 27446 if (event) { 27447 event.stopPropagation(); 27448 } 27449 27450 clearTimeoutRef(); 27451 27452 if (!showMovers) { 27453 handleOnChange(true); 27454 } 27455 }; 27456 27457 const debouncedHideMovers = event => { 27458 if (event) { 27459 event.stopPropagation(); 27460 } 27461 27462 clearTimeoutRef(); 27463 timeoutRef.current = utils_setTimeout(() => { 27464 if (shouldHideMovers()) { 27465 handleOnChange(false); 27466 } 27467 }, debounceTimeout); 27468 }; 27469 27470 (0,external_wp_element_namespaceObject.useEffect)(() => () => { 27471 /** 27472 * We need to call the change handler with `isFocused` 27473 * set to false on unmount because we also clear the 27474 * timeout that would handle that. 27475 */ 27476 handleOnChange(false); 27477 clearTimeoutRef(); 27478 }, []); 27479 return { 27480 showMovers, 27481 debouncedShowMovers, 27482 debouncedHideMovers 27483 }; 27484 } 27485 /** 27486 * Hook that provides a showMovers state and gesture events for DOM elements 27487 * that interact with the showMovers state. 27488 * 27489 * @param {Object} props Component props. 27490 * @param {Object} props.ref Element reference. 27491 * @param {number} [props.debounceTimeout=250] Debounce timeout in milliseconds. 27492 * @param {Function} [props.onChange=noop] Callback function. 27493 */ 27494 27495 function useShowMoversGestures(_ref2) { 27496 let { 27497 ref, 27498 debounceTimeout = DEBOUNCE_TIMEOUT, 27499 onChange = external_lodash_namespaceObject.noop 27500 } = _ref2; 27501 const [isFocused, setIsFocused] = (0,external_wp_element_namespaceObject.useState)(false); 27502 const { 27503 showMovers, 27504 debouncedShowMovers, 27505 debouncedHideMovers 27506 } = useDebouncedShowMovers({ 27507 ref, 27508 debounceTimeout, 27509 isFocused, 27510 onChange 27511 }); 27512 const registerRef = (0,external_wp_element_namespaceObject.useRef)(false); 27513 27514 const isFocusedWithin = () => { 27515 return (ref === null || ref === void 0 ? void 0 : ref.current) && ref.current.contains(ref.current.ownerDocument.activeElement); 27516 }; 27517 27518 (0,external_wp_element_namespaceObject.useEffect)(() => { 27519 const node = ref.current; 27520 27521 const handleOnFocus = () => { 27522 if (isFocusedWithin()) { 27523 setIsFocused(true); 27524 debouncedShowMovers(); 27525 } 27526 }; 27527 27528 const handleOnBlur = () => { 27529 if (!isFocusedWithin()) { 27530 setIsFocused(false); 27531 debouncedHideMovers(); 27532 } 27533 }; 27534 /** 27535 * Events are added via DOM events (vs. React synthetic events), 27536 * as the child React components swallow mouse events. 27537 */ 27538 27539 27540 if (node && !registerRef.current) { 27541 node.addEventListener('focus', handleOnFocus, true); 27542 node.addEventListener('blur', handleOnBlur, true); 27543 registerRef.current = true; 27544 } 27545 27546 return () => { 27547 if (node) { 27548 node.removeEventListener('focus', handleOnFocus); 27549 node.removeEventListener('blur', handleOnBlur); 27550 } 27551 }; 27552 }, [ref, registerRef, setIsFocused, debouncedShowMovers, debouncedHideMovers]); 27553 return { 27554 showMovers, 27555 gestures: { 27556 onMouseMove: debouncedShowMovers, 27557 onMouseLeave: debouncedHideMovers 27558 } 27559 }; 27560 } 27561 27562 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-parent-selector/index.js 27563 27564 27565 27566 /** 27567 * WordPress dependencies 27568 */ 27569 27570 27571 27572 27573 27574 /** 27575 * Internal dependencies 27576 */ 27577 27578 27579 27580 27581 27582 /** 27583 * Block parent selector component, displaying the hierarchy of the 27584 * current block selection as a single icon to "go up" a level. 27585 * 27586 * @return {WPComponent} Parent block selector. 27587 */ 27588 27589 function BlockParentSelector() { 27590 const { 27591 selectBlock, 27592 toggleBlockHighlight 27593 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 27594 const { 27595 firstParentClientId, 27596 shouldHide, 27597 hasReducedUI 27598 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 27599 const { 27600 getBlockName, 27601 getBlockParents, 27602 getSelectedBlockClientId, 27603 getSettings 27604 } = select(store); 27605 const { 27606 hasBlockSupport 27607 } = select(external_wp_blocks_namespaceObject.store); 27608 const selectedBlockClientId = getSelectedBlockClientId(); 27609 const parents = getBlockParents(selectedBlockClientId); 27610 const _firstParentClientId = parents[parents.length - 1]; 27611 const parentBlockName = getBlockName(_firstParentClientId); 27612 27613 const _parentBlockType = (0,external_wp_blocks_namespaceObject.getBlockType)(parentBlockName); 27614 27615 const settings = getSettings(); 27616 return { 27617 firstParentClientId: _firstParentClientId, 27618 shouldHide: !hasBlockSupport(_parentBlockType, '__experimentalParentSelector', true), 27619 hasReducedUI: settings.hasReducedUI 27620 }; 27621 }, []); 27622 const blockInformation = useBlockDisplayInformation(firstParentClientId); // Allows highlighting the parent block outline when focusing or hovering 27623 // the parent block selector within the child. 27624 27625 const nodeRef = (0,external_wp_element_namespaceObject.useRef)(); 27626 const { 27627 gestures: showMoversGestures 27628 } = useShowMoversGestures({ 27629 ref: nodeRef, 27630 27631 onChange(isFocused) { 27632 if (isFocused && hasReducedUI) { 27633 return; 27634 } 27635 27636 toggleBlockHighlight(firstParentClientId, isFocused); 27637 } 27638 27639 }); 27640 27641 if (shouldHide || firstParentClientId === undefined) { 27642 return null; 27643 } 27644 27645 return (0,external_wp_element_namespaceObject.createElement)("div", _extends({ 27646 className: "block-editor-block-parent-selector", 27647 key: firstParentClientId, 27648 ref: nodeRef 27649 }, showMoversGestures), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, { 27650 className: "block-editor-block-parent-selector__button", 27651 onClick: () => selectBlock(firstParentClientId), 27652 label: (0,external_wp_i18n_namespaceObject.sprintf)( 27653 /* translators: %s: Name of the block's parent. */ 27654 (0,external_wp_i18n_namespaceObject.__)('Select %s'), blockInformation.title), 27655 showTooltip: true, 27656 icon: (0,external_wp_element_namespaceObject.createElement)(block_icon, { 27657 icon: blockInformation.icon 27658 }) 27659 })); 27660 } 27661 27662 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/copy.js 27663 27664 27665 /** 27666 * WordPress dependencies 27667 */ 27668 27669 const copy = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 27670 xmlns: "http://www.w3.org/2000/svg", 27671 viewBox: "0 0 24 24" 27672 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 27673 d: "M20.2 8v11c0 .7-.6 1.2-1.2 1.2H6v1.5h13c1.5 0 2.7-1.2 2.7-2.8V8zM18 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.6zm-13.5 0V4.6c0-.1.1-.1.1-.1h11.8c.1 0 .1.1.1.1v11.8c0 .1-.1.1-.1.1H4.6l-.1-.1z" 27674 })); 27675 /* harmony default export */ var library_copy = (copy); 27676 27677 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-switcher/preview-block-popover.js 27678 27679 27680 /** 27681 * WordPress dependencies 27682 */ 27683 27684 27685 /** 27686 * Internal dependencies 27687 */ 27688 27689 27690 function PreviewBlockPopover(_ref) { 27691 let { 27692 blocks 27693 } = _ref; 27694 return (0,external_wp_element_namespaceObject.createElement)("div", { 27695 className: "block-editor-block-switcher__popover__preview__parent" 27696 }, (0,external_wp_element_namespaceObject.createElement)("div", { 27697 className: "block-editor-block-switcher__popover__preview__container" 27698 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Popover, { 27699 className: "block-editor-block-switcher__preview__popover", 27700 position: "bottom right", 27701 focusOnMount: false 27702 }, (0,external_wp_element_namespaceObject.createElement)("div", { 27703 className: "block-editor-block-switcher__preview" 27704 }, (0,external_wp_element_namespaceObject.createElement)("div", { 27705 className: "block-editor-block-switcher__preview-title" 27706 }, (0,external_wp_i18n_namespaceObject.__)('Preview')), (0,external_wp_element_namespaceObject.createElement)(block_preview, { 27707 viewportWidth: 500, 27708 blocks: blocks 27709 }))))); 27710 } 27711 27712 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-switcher/block-transformations-menu.js 27713 27714 27715 /** 27716 * WordPress dependencies 27717 */ 27718 27719 27720 27721 27722 /** 27723 * Internal dependencies 27724 */ 27725 27726 27727 27728 27729 const BlockTransformationsMenu = _ref => { 27730 let { 27731 className, 27732 possibleBlockTransformations, 27733 onSelect, 27734 blocks 27735 } = _ref; 27736 const [hoveredTransformItemName, setHoveredTransformItemName] = (0,external_wp_element_namespaceObject.useState)(); 27737 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuGroup, { 27738 label: (0,external_wp_i18n_namespaceObject.__)('Transform to'), 27739 className: className 27740 }, hoveredTransformItemName && (0,external_wp_element_namespaceObject.createElement)(PreviewBlockPopover, { 27741 blocks: (0,external_wp_blocks_namespaceObject.switchToBlockType)(blocks, hoveredTransformItemName) 27742 }), possibleBlockTransformations.map(item => { 27743 const { 27744 name, 27745 icon, 27746 title, 27747 isDisabled 27748 } = item; 27749 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, { 27750 key: name, 27751 className: (0,external_wp_blocks_namespaceObject.getBlockMenuDefaultClassName)(name), 27752 onClick: event => { 27753 event.preventDefault(); 27754 onSelect(name); 27755 }, 27756 disabled: isDisabled, 27757 onMouseLeave: () => setHoveredTransformItemName(null), 27758 onMouseEnter: () => setHoveredTransformItemName(name) 27759 }, (0,external_wp_element_namespaceObject.createElement)(block_icon, { 27760 icon: icon, 27761 showColors: true 27762 }), title); 27763 })); 27764 }; 27765 27766 /* harmony default export */ var block_transformations_menu = (BlockTransformationsMenu); 27767 27768 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/check.js 27769 27770 27771 /** 27772 * WordPress dependencies 27773 */ 27774 27775 const check = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 27776 xmlns: "http://www.w3.org/2000/svg", 27777 viewBox: "0 0 24 24" 27778 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 27779 d: "M16.7 7.1l-6.3 8.5-3.3-2.5-.9 1.2 4.5 3.4L17.9 8z" 27780 })); 27781 /* harmony default export */ var library_check = (check); 27782 27783 ;// CONCATENATED MODULE: external ["wp","tokenList"] 27784 var external_wp_tokenList_namespaceObject = window["wp"]["tokenList"]; 27785 var external_wp_tokenList_default = /*#__PURE__*/__webpack_require__.n(external_wp_tokenList_namespaceObject); 27786 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-styles/utils.js 27787 /** 27788 * External dependencies 27789 */ 27790 27791 /** 27792 * WordPress dependencies 27793 */ 27794 27795 27796 27797 /** 27798 * Returns the active style from the given className. 27799 * 27800 * @param {Array} styles Block style variations. 27801 * @param {string} className Class name 27802 * 27803 * @return {Object?} The active style. 27804 */ 27805 27806 function getActiveStyle(styles, className) { 27807 for (const style of new (external_wp_tokenList_default())(className).values()) { 27808 if (style.indexOf('is-style-') === -1) { 27809 continue; 27810 } 27811 27812 const potentialStyleName = style.substring(9); 27813 const activeStyle = (0,external_lodash_namespaceObject.find)(styles, { 27814 name: potentialStyleName 27815 }); 27816 27817 if (activeStyle) { 27818 return activeStyle; 27819 } 27820 } 27821 27822 return (0,external_lodash_namespaceObject.find)(styles, 'isDefault'); 27823 } 27824 /** 27825 * Replaces the active style in the block's className. 27826 * 27827 * @param {string} className Class name. 27828 * @param {Object?} activeStyle The replaced style. 27829 * @param {Object} newStyle The replacing style. 27830 * 27831 * @return {string} The updated className. 27832 */ 27833 27834 function replaceActiveStyle(className, activeStyle, newStyle) { 27835 const list = new (external_wp_tokenList_default())(className); 27836 27837 if (activeStyle) { 27838 list.remove('is-style-' + activeStyle.name); 27839 } 27840 27841 list.add('is-style-' + newStyle.name); 27842 return list.value; 27843 } 27844 /** 27845 * Returns a collection of styles that can be represented on the frontend. 27846 * The function checks a style collection for a default style. If none is found, it adds one to 27847 * act as a fallback for when there is no active style applied to a block. The default item also serves 27848 * as a switch on the frontend to deactivate non-default styles. 27849 * 27850 * @param {Array} styles Block style variations. 27851 * 27852 * @return {Array<Object?>} The style collection. 27853 */ 27854 27855 function getRenderedStyles(styles) { 27856 if (!styles || styles.length === 0) { 27857 return []; 27858 } 27859 27860 return getDefaultStyle(styles) ? styles : [{ 27861 name: 'default', 27862 label: (0,external_wp_i18n_namespaceObject._x)('Default', 'block style'), 27863 isDefault: true 27864 }, ...styles]; 27865 } 27866 /** 27867 * Returns a style object from a collection of styles where that style object is the default block style. 27868 * 27869 * @param {Array} styles Block style variations. 27870 * 27871 * @return {Object?} The default style object, if found. 27872 */ 27873 27874 function getDefaultStyle(styles) { 27875 return (0,external_lodash_namespaceObject.find)(styles, 'isDefault'); 27876 } 27877 27878 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-styles/use-styles-for-block.js 27879 /** 27880 * WordPress dependencies 27881 */ 27882 27883 27884 27885 /** 27886 * Internal dependencies 27887 */ 27888 27889 27890 27891 /** 27892 * 27893 * @param {WPBlock} block Block object. 27894 * @param {WPBlockType} type Block type settings. 27895 * @return {WPBlock} A generic block ready for styles preview. 27896 */ 27897 27898 function useGenericPreviewBlock(block, type) { 27899 return (0,external_wp_element_namespaceObject.useMemo)(() => { 27900 const example = type === null || type === void 0 ? void 0 : type.example; 27901 const blockName = type === null || type === void 0 ? void 0 : type.name; 27902 27903 if (example && blockName) { 27904 return (0,external_wp_blocks_namespaceObject.getBlockFromExample)(blockName, { 27905 attributes: example.attributes, 27906 innerBlocks: example.innerBlocks 27907 }); 27908 } 27909 27910 if (block) { 27911 return (0,external_wp_blocks_namespaceObject.cloneBlock)(block); 27912 } 27913 }, [type !== null && type !== void 0 && type.example ? block === null || block === void 0 ? void 0 : block.name : block, type]); 27914 } 27915 /** 27916 * @typedef useStylesForBlocksArguments 27917 * @property {string} clientId Block client ID. 27918 * @property {() => void} onSwitch Block style switch callback function. 27919 */ 27920 27921 /** 27922 * 27923 * @param {useStylesForBlocksArguments} useStylesForBlocks arguments. 27924 * @return {Object} Results of the select methods. 27925 */ 27926 27927 27928 function useStylesForBlocks(_ref) { 27929 let { 27930 clientId, 27931 onSwitch 27932 } = _ref; 27933 27934 const selector = select => { 27935 const { 27936 getBlock 27937 } = select(store); 27938 const block = getBlock(clientId); 27939 27940 if (!block) { 27941 return {}; 27942 } 27943 27944 const blockType = (0,external_wp_blocks_namespaceObject.getBlockType)(block.name); 27945 const { 27946 getBlockStyles 27947 } = select(external_wp_blocks_namespaceObject.store); 27948 return { 27949 block, 27950 blockType, 27951 styles: getBlockStyles(block.name), 27952 className: block.attributes.className || '' 27953 }; 27954 }; 27955 27956 const { 27957 styles, 27958 block, 27959 blockType, 27960 className 27961 } = (0,external_wp_data_namespaceObject.useSelect)(selector, [clientId]); 27962 const { 27963 updateBlockAttributes 27964 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 27965 const stylesToRender = getRenderedStyles(styles); 27966 const activeStyle = getActiveStyle(stylesToRender, className); 27967 const genericPreviewBlock = useGenericPreviewBlock(block, blockType); 27968 27969 const onSelect = style => { 27970 const styleClassName = replaceActiveStyle(className, activeStyle, style); 27971 updateBlockAttributes(clientId, { 27972 className: styleClassName 27973 }); 27974 onSwitch(); 27975 }; 27976 27977 return { 27978 onSelect, 27979 stylesToRender, 27980 activeStyle, 27981 genericPreviewBlock, 27982 className 27983 }; 27984 } 27985 27986 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-styles/menu-items.js 27987 27988 27989 /** 27990 * External dependencies 27991 */ 27992 27993 /** 27994 * WordPress dependencies 27995 */ 27996 27997 27998 27999 /** 28000 * Internal dependencies 28001 */ 28002 28003 28004 function BlockStylesMenuItems(_ref) { 28005 let { 28006 clientId, 28007 onSwitch = external_lodash_namespaceObject.noop 28008 } = _ref; 28009 const { 28010 onSelect, 28011 stylesToRender, 28012 activeStyle 28013 } = useStylesForBlocks({ 28014 clientId, 28015 onSwitch 28016 }); 28017 28018 if (!stylesToRender || stylesToRender.length === 0) { 28019 return null; 28020 } 28021 28022 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, stylesToRender.map(style => { 28023 const menuItemText = style.label || style.name; 28024 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, { 28025 key: style.name, 28026 icon: activeStyle.name === style.name ? library_check : null, 28027 onClick: () => onSelect(style) 28028 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalText, { 28029 as: "span", 28030 limit: 18, 28031 ellipsizeMode: "tail", 28032 truncate: true 28033 }, menuItemText)); 28034 })); 28035 } 28036 28037 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-switcher/block-styles-menu.js 28038 28039 28040 /** 28041 * WordPress dependencies 28042 */ 28043 28044 28045 /** 28046 * Internal dependencies 28047 */ 28048 28049 28050 function BlockStylesMenu(_ref) { 28051 let { 28052 hoveredBlock, 28053 onSwitch 28054 } = _ref; 28055 const { 28056 clientId 28057 } = hoveredBlock; 28058 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuGroup, { 28059 label: (0,external_wp_i18n_namespaceObject.__)('Styles'), 28060 className: "block-editor-block-switcher__styles__menugroup" 28061 }, (0,external_wp_element_namespaceObject.createElement)(BlockStylesMenuItems, { 28062 clientId: clientId, 28063 onSwitch: onSwitch 28064 })); 28065 } 28066 28067 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-switcher/utils.js 28068 /** 28069 * WordPress dependencies 28070 */ 28071 28072 /** 28073 * Try to find a matching block by a block's name in a provided 28074 * block. We recurse through InnerBlocks and return the reference 28075 * of the matched block (it could be an InnerBlock). 28076 * If no match is found return nothing. 28077 * 28078 * @param {WPBlock} block The block to try to find a match. 28079 * @param {string} selectedBlockName The block's name to use for matching condition. 28080 * @param {Set} consumedBlocks A set holding the previously matched/consumed blocks. 28081 * 28082 * @return {WPBlock?} The matched block if found or nothing(`undefined`). 28083 */ 28084 28085 const getMatchingBlockByName = function (block, selectedBlockName) { 28086 let consumedBlocks = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : new Set(); 28087 const { 28088 clientId, 28089 name, 28090 innerBlocks = [] 28091 } = block; // Check if block has been consumed already. 28092 28093 if (consumedBlocks.has(clientId)) return; 28094 if (name === selectedBlockName) return block; // Try to find a matching block from InnerBlocks recursively. 28095 28096 for (const innerBlock of innerBlocks) { 28097 const match = getMatchingBlockByName(innerBlock, selectedBlockName, consumedBlocks); 28098 if (match) return match; 28099 } 28100 }; 28101 /** 28102 * Find and return the block attributes to retain through 28103 * the transformation, based on Block Type's `role:content` 28104 * attributes. If no `role:content` attributes exist, 28105 * return selected block's attributes. 28106 * 28107 * @param {string} name Block type's namespaced name. 28108 * @param {Object} attributes Selected block's attributes. 28109 * @return {Object} The block's attributes to retain. 28110 */ 28111 28112 const getRetainedBlockAttributes = (name, attributes) => { 28113 const contentAttributes = (0,external_wp_blocks_namespaceObject.__experimentalGetBlockAttributesNamesByRole)(name, 'content'); 28114 if (!(contentAttributes !== null && contentAttributes !== void 0 && contentAttributes.length)) return attributes; 28115 return contentAttributes.reduce((_accumulator, attribute) => { 28116 if (attributes[attribute]) _accumulator[attribute] = attributes[attribute]; 28117 return _accumulator; 28118 }, {}); 28119 }; 28120 28121 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-switcher/use-transformed-patterns.js 28122 /** 28123 * WordPress dependencies 28124 */ 28125 28126 28127 /** 28128 * Internal dependencies 28129 */ 28130 28131 28132 /** 28133 * Mutate the matched block's attributes by getting 28134 * which block type's attributes to retain and prioritize 28135 * them in the merging of the attributes. 28136 * 28137 * @param {WPBlock} match The matched block. 28138 * @param {WPBlock} selectedBlock The selected block. 28139 * @return {void} 28140 */ 28141 28142 const transformMatchingBlock = (match, selectedBlock) => { 28143 // Get the block attributes to retain through the transformation. 28144 const retainedBlockAttributes = getRetainedBlockAttributes(selectedBlock.name, selectedBlock.attributes); 28145 match.attributes = { ...match.attributes, 28146 ...retainedBlockAttributes 28147 }; 28148 }; 28149 /** 28150 * By providing the selected blocks and pattern's blocks 28151 * find the matching blocks, transform them and return them. 28152 * If not all selected blocks are matched, return nothing. 28153 * 28154 * @param {WPBlock[]} selectedBlocks The selected blocks. 28155 * @param {WPBlock[]} patternBlocks The pattern's blocks. 28156 * @return {WPBlock[]|void} The transformed pattern's blocks or undefined if not all selected blocks have been matched. 28157 */ 28158 28159 const getPatternTransformedBlocks = (selectedBlocks, patternBlocks) => { 28160 // Clone Pattern's blocks to produce new clientIds and be able to mutate the matches. 28161 const _patternBlocks = patternBlocks.map(block => (0,external_wp_blocks_namespaceObject.cloneBlock)(block)); 28162 /** 28163 * Keep track of the consumed pattern blocks. 28164 * This is needed because we loop the selected blocks 28165 * and for example we may have selected two paragraphs and 28166 * the pattern's blocks could have more `paragraphs`. 28167 */ 28168 28169 28170 const consumedBlocks = new Set(); 28171 28172 for (const selectedBlock of selectedBlocks) { 28173 let isMatch = false; 28174 28175 for (const patternBlock of _patternBlocks) { 28176 const match = getMatchingBlockByName(patternBlock, selectedBlock.name, consumedBlocks); 28177 if (!match) continue; 28178 isMatch = true; 28179 consumedBlocks.add(match.clientId); // We update (mutate) the matching pattern block. 28180 28181 transformMatchingBlock(match, selectedBlock); // No need to loop through other pattern's blocks. 28182 28183 break; 28184 } // Bail eary if a selected block has not been matched. 28185 28186 28187 if (!isMatch) return; 28188 } 28189 28190 return _patternBlocks; 28191 }; 28192 /** 28193 * @typedef {WPBlockPattern & {transformedBlocks: WPBlock[]}} TransformedBlockPattern 28194 */ 28195 28196 /** 28197 * Custom hook that accepts patterns from state and the selected 28198 * blocks and tries to match these with the pattern's blocks. 28199 * If all selected blocks are matched with a Pattern's block, 28200 * we transform them by retaining block's attributes with `role:content`. 28201 * The transformed pattern's blocks are set to a new pattern 28202 * property `transformedBlocks`. 28203 * 28204 * @param {WPBlockPattern[]} patterns Patterns from state. 28205 * @param {WPBlock[]} selectedBlocks The currently selected blocks. 28206 * @return {TransformedBlockPattern[]} Returns the eligible matched patterns with all the selected blocks. 28207 */ 28208 28209 const useTransformedPatterns = (patterns, selectedBlocks) => { 28210 return (0,external_wp_element_namespaceObject.useMemo)(() => patterns.reduce((accumulator, _pattern) => { 28211 const transformedBlocks = getPatternTransformedBlocks(selectedBlocks, _pattern.blocks); 28212 28213 if (transformedBlocks) { 28214 accumulator.push({ ..._pattern, 28215 transformedBlocks 28216 }); 28217 } 28218 28219 return accumulator; 28220 }, []), [patterns, selectedBlocks]); 28221 }; 28222 28223 /* harmony default export */ var use_transformed_patterns = (useTransformedPatterns); 28224 28225 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-switcher/pattern-transformations-menu.js 28226 28227 28228 28229 /** 28230 * WordPress dependencies 28231 */ 28232 28233 28234 28235 28236 28237 /** 28238 * Internal dependencies 28239 */ 28240 28241 28242 28243 28244 function PatternTransformationsMenu(_ref) { 28245 let { 28246 blocks, 28247 patterns: statePatterns, 28248 onSelect 28249 } = _ref; 28250 const [showTransforms, setShowTransforms] = (0,external_wp_element_namespaceObject.useState)(false); 28251 const patterns = use_transformed_patterns(statePatterns, blocks); 28252 if (!patterns.length) return null; 28253 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuGroup, { 28254 className: "block-editor-block-switcher__pattern__transforms__menugroup" 28255 }, showTransforms && (0,external_wp_element_namespaceObject.createElement)(PreviewPatternsPopover, { 28256 patterns: patterns, 28257 onSelect: onSelect 28258 }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, { 28259 onClick: event => { 28260 event.preventDefault(); 28261 setShowTransforms(!showTransforms); 28262 }, 28263 icon: chevron_right 28264 }, (0,external_wp_i18n_namespaceObject.__)('Patterns'))); 28265 } 28266 28267 function PreviewPatternsPopover(_ref2) { 28268 let { 28269 patterns, 28270 onSelect 28271 } = _ref2; 28272 return (0,external_wp_element_namespaceObject.createElement)("div", { 28273 className: "block-editor-block-switcher__popover__preview__parent" 28274 }, (0,external_wp_element_namespaceObject.createElement)("div", { 28275 className: "block-editor-block-switcher__popover__preview__container" 28276 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Popover, { 28277 className: "block-editor-block-switcher__preview__popover", 28278 position: "bottom right" 28279 }, (0,external_wp_element_namespaceObject.createElement)("div", { 28280 className: "block-editor-block-switcher__preview" 28281 }, (0,external_wp_element_namespaceObject.createElement)("div", { 28282 className: "block-editor-block-switcher__preview-title" 28283 }, (0,external_wp_i18n_namespaceObject.__)('Preview')), (0,external_wp_element_namespaceObject.createElement)(BlockPatternsList, { 28284 patterns: patterns, 28285 onSelect: onSelect 28286 }))))); 28287 } 28288 28289 function BlockPatternsList(_ref3) { 28290 let { 28291 patterns, 28292 onSelect 28293 } = _ref3; 28294 const composite = (0,external_wp_components_namespaceObject.__unstableUseCompositeState)(); 28295 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__unstableComposite, _extends({}, composite, { 28296 role: "listbox", 28297 className: "block-editor-block-switcher__preview-patterns-container", 28298 "aria-label": (0,external_wp_i18n_namespaceObject.__)('Patterns list') 28299 }), patterns.map(pattern => (0,external_wp_element_namespaceObject.createElement)(pattern_transformations_menu_BlockPattern, { 28300 key: pattern.name, 28301 pattern: pattern, 28302 onSelect: onSelect, 28303 composite: composite 28304 }))); 28305 } 28306 28307 function pattern_transformations_menu_BlockPattern(_ref4) { 28308 let { 28309 pattern, 28310 onSelect, 28311 composite 28312 } = _ref4; 28313 // TODO check pattern/preview width... 28314 const baseClassName = 'block-editor-block-switcher__preview-patterns-container'; 28315 const descriptionId = (0,external_wp_compose_namespaceObject.useInstanceId)(pattern_transformations_menu_BlockPattern, `$baseClassName}-list__item-description`); 28316 return (0,external_wp_element_namespaceObject.createElement)("div", { 28317 className: `$baseClassName}-list__list-item`, 28318 "aria-label": pattern.title, 28319 "aria-describedby": pattern.description ? descriptionId : undefined 28320 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__unstableCompositeItem, _extends({ 28321 role: "option", 28322 as: "div" 28323 }, composite, { 28324 className: `$baseClassName}-list__item`, 28325 onClick: () => onSelect(pattern.transformedBlocks) 28326 }), (0,external_wp_element_namespaceObject.createElement)(block_preview, { 28327 blocks: pattern.transformedBlocks, 28328 viewportWidth: pattern.viewportWidth || 500 28329 }), (0,external_wp_element_namespaceObject.createElement)("div", { 28330 className: `$baseClassName}-list__item-title` 28331 }, pattern.title)), !!pattern.description && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.VisuallyHidden, { 28332 id: descriptionId 28333 }, pattern.description)); 28334 } 28335 28336 /* harmony default export */ var pattern_transformations_menu = (PatternTransformationsMenu); 28337 28338 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-switcher/index.js 28339 28340 28341 /** 28342 * External dependencies 28343 */ 28344 28345 /** 28346 * WordPress dependencies 28347 */ 28348 28349 28350 28351 28352 28353 28354 /** 28355 * Internal dependencies 28356 */ 28357 28358 28359 28360 28361 28362 28363 28364 28365 const BlockSwitcherDropdownMenu = _ref => { 28366 let { 28367 clientIds, 28368 blocks 28369 } = _ref; 28370 const { 28371 replaceBlocks 28372 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 28373 const blockInformation = useBlockDisplayInformation(blocks[0].clientId); 28374 const { 28375 possibleBlockTransformations, 28376 canRemove, 28377 hasBlockStyles, 28378 icon, 28379 blockTitle, 28380 patterns 28381 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 28382 var _getBlockType2; 28383 28384 const { 28385 getBlockRootClientId, 28386 getBlockTransformItems, 28387 __experimentalGetPatternTransformItems 28388 } = select(store); 28389 const { 28390 getBlockStyles, 28391 getBlockType 28392 } = select(external_wp_blocks_namespaceObject.store); 28393 const { 28394 canRemoveBlocks 28395 } = select(store); 28396 const rootClientId = getBlockRootClientId((0,external_lodash_namespaceObject.castArray)(clientIds)[0]); 28397 const [{ 28398 name: firstBlockName 28399 }] = blocks; 28400 28401 const _isSingleBlockSelected = blocks.length === 1; 28402 28403 const styles = _isSingleBlockSelected && getBlockStyles(firstBlockName); 28404 28405 let _icon; 28406 28407 if (_isSingleBlockSelected) { 28408 _icon = blockInformation === null || blockInformation === void 0 ? void 0 : blockInformation.icon; // Take into account active block variations. 28409 } else { 28410 var _getBlockType; 28411 28412 const isSelectionOfSameType = (0,external_lodash_namespaceObject.uniq)(blocks.map(_ref2 => { 28413 let { 28414 name 28415 } = _ref2; 28416 return name; 28417 })).length === 1; // When selection consists of blocks of multiple types, display an 28418 // appropriate icon to communicate the non-uniformity. 28419 28420 _icon = isSelectionOfSameType ? (_getBlockType = getBlockType(firstBlockName)) === null || _getBlockType === void 0 ? void 0 : _getBlockType.icon : library_copy; 28421 } 28422 28423 return { 28424 possibleBlockTransformations: getBlockTransformItems(blocks, rootClientId), 28425 canRemove: canRemoveBlocks(clientIds, rootClientId), 28426 hasBlockStyles: !!(styles !== null && styles !== void 0 && styles.length), 28427 icon: _icon, 28428 blockTitle: (_getBlockType2 = getBlockType(firstBlockName)) === null || _getBlockType2 === void 0 ? void 0 : _getBlockType2.title, 28429 patterns: __experimentalGetPatternTransformItems(blocks, rootClientId) 28430 }; 28431 }, [clientIds, blocks, blockInformation === null || blockInformation === void 0 ? void 0 : blockInformation.icon]); 28432 const isReusable = blocks.length === 1 && (0,external_wp_blocks_namespaceObject.isReusableBlock)(blocks[0]); 28433 const isTemplate = blocks.length === 1 && (0,external_wp_blocks_namespaceObject.isTemplatePart)(blocks[0]); // Simple block tranformation based on the `Block Transforms` API. 28434 28435 const onBlockTransform = name => replaceBlocks(clientIds, (0,external_wp_blocks_namespaceObject.switchToBlockType)(blocks, name)); // Pattern transformation through the `Patterns` API. 28436 28437 28438 const onPatternTransform = transformedBlocks => replaceBlocks(clientIds, transformedBlocks); 28439 28440 const hasPossibleBlockTransformations = !!possibleBlockTransformations.length && canRemove; 28441 const hasPatternTransformation = !!(patterns !== null && patterns !== void 0 && patterns.length) && canRemove; 28442 28443 if (!hasBlockStyles && !hasPossibleBlockTransformations) { 28444 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarGroup, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, { 28445 disabled: true, 28446 className: "block-editor-block-switcher__no-switcher-icon", 28447 title: blockTitle, 28448 icon: (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(block_icon, { 28449 icon: icon, 28450 showColors: true 28451 }), (isReusable || isTemplate) && (0,external_wp_element_namespaceObject.createElement)("span", { 28452 className: "block-editor-block-switcher__toggle-text" 28453 }, (0,external_wp_element_namespaceObject.createElement)(BlockTitle, { 28454 clientId: clientIds, 28455 maximumLength: 35 28456 }))) 28457 })); 28458 } 28459 28460 const blockSwitcherLabel = blockTitle; 28461 const blockSwitcherDescription = 1 === blocks.length ? (0,external_wp_i18n_namespaceObject.sprintf)( 28462 /* translators: %s: block title. */ 28463 (0,external_wp_i18n_namespaceObject.__)('%s: Change block type or style'), blockTitle) : (0,external_wp_i18n_namespaceObject.sprintf)( 28464 /* translators: %d: number of blocks. */ 28465 (0,external_wp_i18n_namespaceObject._n)('Change type of %d block', 'Change type of %d blocks', blocks.length), blocks.length); 28466 const showDropDown = hasBlockStyles || hasPossibleBlockTransformations || hasPatternTransformation; 28467 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarGroup, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarItem, null, toggleProps => (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.DropdownMenu, { 28468 className: "block-editor-block-switcher", 28469 label: blockSwitcherLabel, 28470 popoverProps: { 28471 position: 'bottom right', 28472 isAlternate: true, 28473 className: 'block-editor-block-switcher__popover' 28474 }, 28475 icon: (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(block_icon, { 28476 icon: icon, 28477 className: "block-editor-block-switcher__toggle", 28478 showColors: true 28479 }), (isReusable || isTemplate) && (0,external_wp_element_namespaceObject.createElement)("span", { 28480 className: "block-editor-block-switcher__toggle-text" 28481 }, (0,external_wp_element_namespaceObject.createElement)(BlockTitle, { 28482 clientId: clientIds, 28483 maximumLength: 35 28484 }))), 28485 toggleProps: { 28486 describedBy: blockSwitcherDescription, 28487 ...toggleProps 28488 }, 28489 menuProps: { 28490 orientation: 'both' 28491 } 28492 }, _ref3 => { 28493 let { 28494 onClose 28495 } = _ref3; 28496 return showDropDown && (0,external_wp_element_namespaceObject.createElement)("div", { 28497 className: "block-editor-block-switcher__container" 28498 }, hasPatternTransformation && (0,external_wp_element_namespaceObject.createElement)(pattern_transformations_menu, { 28499 blocks: blocks, 28500 patterns: patterns, 28501 onSelect: transformedBlocks => { 28502 onPatternTransform(transformedBlocks); 28503 onClose(); 28504 } 28505 }), hasPossibleBlockTransformations && (0,external_wp_element_namespaceObject.createElement)(block_transformations_menu, { 28506 className: "block-editor-block-switcher__transforms__menugroup", 28507 possibleBlockTransformations: possibleBlockTransformations, 28508 blocks: blocks, 28509 onSelect: name => { 28510 onBlockTransform(name); 28511 onClose(); 28512 } 28513 }), hasBlockStyles && (0,external_wp_element_namespaceObject.createElement)(BlockStylesMenu, { 28514 hoveredBlock: blocks[0], 28515 onSwitch: onClose 28516 })); 28517 }))); 28518 }; 28519 const BlockSwitcher = _ref4 => { 28520 let { 28521 clientIds 28522 } = _ref4; 28523 const blocks = (0,external_wp_data_namespaceObject.useSelect)(select => select(store).getBlocksByClientId(clientIds), [clientIds]); 28524 28525 if (!blocks.length || blocks.some(block => !block)) { 28526 return null; 28527 } 28528 28529 return (0,external_wp_element_namespaceObject.createElement)(BlockSwitcherDropdownMenu, { 28530 clientIds: clientIds, 28531 blocks: blocks 28532 }); 28533 }; 28534 /* harmony default export */ var block_switcher = (BlockSwitcher); 28535 28536 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-toolbar/block-toolbar-last-item.js 28537 /** 28538 * WordPress dependencies 28539 */ 28540 28541 const { 28542 Fill: __unstableBlockToolbarLastItem, 28543 Slot: block_toolbar_last_item_Slot 28544 } = (0,external_wp_components_namespaceObject.createSlotFill)('__unstableBlockToolbarLastItem'); 28545 __unstableBlockToolbarLastItem.Slot = block_toolbar_last_item_Slot; 28546 /* harmony default export */ var block_toolbar_last_item = (__unstableBlockToolbarLastItem); 28547 28548 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/more-vertical.js 28549 28550 28551 /** 28552 * WordPress dependencies 28553 */ 28554 28555 const moreVertical = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 28556 xmlns: "http://www.w3.org/2000/svg", 28557 viewBox: "0 0 24 24" 28558 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 28559 d: "M13 19h-2v-2h2v2zm0-6h-2v-2h2v2zm0-6h-2V5h2v2z" 28560 })); 28561 /* harmony default export */ var more_vertical = (moreVertical); 28562 28563 ;// CONCATENATED MODULE: external ["wp","blob"] 28564 var external_wp_blob_namespaceObject = window["wp"]["blob"]; 28565 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/utils/pasting.js 28566 /** 28567 * WordPress dependencies 28568 */ 28569 28570 28571 function getPasteEventData(_ref) { 28572 let { 28573 clipboardData 28574 } = _ref; 28575 let plainText = ''; 28576 let html = ''; // IE11 only supports `Text` as an argument for `getData` and will 28577 // otherwise throw an invalid argument error, so we try the standard 28578 // arguments first, then fallback to `Text` if they fail. 28579 28580 try { 28581 plainText = clipboardData.getData('text/plain'); 28582 html = clipboardData.getData('text/html'); 28583 } catch (error1) { 28584 try { 28585 html = clipboardData.getData('Text'); 28586 } catch (error2) { 28587 // Some browsers like UC Browser paste plain text by default and 28588 // don't support clipboardData at all, so allow default 28589 // behaviour. 28590 return; 28591 } 28592 } 28593 28594 const files = (0,external_wp_dom_namespaceObject.getFilesFromDataTransfer)(clipboardData).filter(_ref2 => { 28595 let { 28596 type 28597 } = _ref2; 28598 return /^image\/(?:jpe?g|png|gif|webp)$/.test(type); 28599 }); 28600 28601 if (files.length && !shouldDismissPastedFiles(files, html, plainText)) { 28602 html = files.map(file => `<img src="${(0,external_wp_blob_namespaceObject.createBlobURL)(file)}">`).join(''); 28603 plainText = ''; 28604 } 28605 28606 return { 28607 html, 28608 plainText 28609 }; 28610 } 28611 /** 28612 * Given a collection of DataTransfer files and HTML and plain text strings, 28613 * determine whether the files are to be dismissed in favor of the HTML. 28614 * 28615 * Certain office-type programs, like Microsoft Word or Apple Numbers, 28616 * will, upon copy, generate a screenshot of the content being copied and 28617 * attach it to the clipboard alongside the actual rich text that the user 28618 * sought to copy. In those cases, we should let Gutenberg handle the rich text 28619 * content and not the screenshot, since this allows Gutenberg to insert 28620 * meaningful blocks, like paragraphs, lists or even tables. 28621 * 28622 * @param {File[]} files File objects obtained from a paste event 28623 * @param {string} html HTML content obtained from a paste event 28624 * @return {boolean} True if the files should be dismissed 28625 */ 28626 28627 function shouldDismissPastedFiles(files, html 28628 /*, plainText */ 28629 ) { 28630 // The question is only relevant when there is actual HTML content and when 28631 // there is exactly one image file. 28632 if (html && (files === null || files === void 0 ? void 0 : files.length) === 1 && files[0].type.indexOf('image/') === 0) { 28633 var _html$match; 28634 28635 // A single <img> tag found in the HTML source suggests that the 28636 // content being pasted revolves around an image. Sometimes there are 28637 // other elements found, like <figure>, but we assume that the user's 28638 // intention is to paste the actual image file. 28639 const IMAGE_TAG = /<\s*img\b/gi; 28640 return ((_html$match = html.match(IMAGE_TAG)) === null || _html$match === void 0 ? void 0 : _html$match.length) !== 1; 28641 } 28642 28643 return false; 28644 } 28645 28646 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/copy-handler/index.js 28647 28648 28649 /** 28650 * WordPress dependencies 28651 */ 28652 28653 28654 28655 28656 28657 28658 28659 /** 28660 * Internal dependencies 28661 */ 28662 28663 28664 28665 function useNotifyCopy() { 28666 const { 28667 getBlockName 28668 } = (0,external_wp_data_namespaceObject.useSelect)(store); 28669 const { 28670 getBlockType 28671 } = (0,external_wp_data_namespaceObject.useSelect)(external_wp_blocks_namespaceObject.store); 28672 const { 28673 createSuccessNotice 28674 } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_notices_namespaceObject.store); 28675 return (0,external_wp_element_namespaceObject.useCallback)((eventType, selectedBlockClientIds) => { 28676 let notice = ''; 28677 28678 if (selectedBlockClientIds.length === 1) { 28679 var _getBlockType; 28680 28681 const clientId = selectedBlockClientIds[0]; 28682 const title = (_getBlockType = getBlockType(getBlockName(clientId))) === null || _getBlockType === void 0 ? void 0 : _getBlockType.title; 28683 notice = eventType === 'copy' ? (0,external_wp_i18n_namespaceObject.sprintf)( // Translators: Name of the block being copied, e.g. "Paragraph". 28684 (0,external_wp_i18n_namespaceObject.__)('Copied "%s" to clipboard.'), title) : (0,external_wp_i18n_namespaceObject.sprintf)( // Translators: Name of the block being cut, e.g. "Paragraph". 28685 (0,external_wp_i18n_namespaceObject.__)('Moved "%s" to clipboard.'), title); 28686 } else { 28687 notice = eventType === 'copy' ? (0,external_wp_i18n_namespaceObject.sprintf)( // Translators: %d: Number of blocks being copied. 28688 (0,external_wp_i18n_namespaceObject._n)('Copied %d block to clipboard.', 'Copied %d blocks to clipboard.', selectedBlockClientIds.length), selectedBlockClientIds.length) : (0,external_wp_i18n_namespaceObject.sprintf)( // Translators: %d: Number of blocks being cut. 28689 (0,external_wp_i18n_namespaceObject._n)('Moved %d block to clipboard.', 'Moved %d blocks to clipboard.', selectedBlockClientIds.length), selectedBlockClientIds.length); 28690 } 28691 28692 createSuccessNotice(notice, { 28693 type: 'snackbar' 28694 }); 28695 }, []); 28696 } 28697 function useClipboardHandler() { 28698 const { 28699 getBlocksByClientId, 28700 getSelectedBlockClientIds, 28701 hasMultiSelection, 28702 getSettings, 28703 __unstableIsFullySelected, 28704 __unstableIsSelectionCollapsed, 28705 __unstableIsSelectionMergeable, 28706 __unstableGetSelectedBlocksWithPartialSelection 28707 } = (0,external_wp_data_namespaceObject.useSelect)(store); 28708 const { 28709 flashBlock, 28710 removeBlocks, 28711 replaceBlocks, 28712 __unstableDeleteSelection, 28713 __unstableExpandSelection 28714 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 28715 const notifyCopy = useNotifyCopy(); 28716 return (0,external_wp_compose_namespaceObject.useRefEffect)(node => { 28717 function handler(event) { 28718 const selectedBlockClientIds = getSelectedBlockClientIds(); 28719 28720 if (selectedBlockClientIds.length === 0) { 28721 return; 28722 } // Always handle multiple selected blocks. 28723 28724 28725 if (!hasMultiSelection()) { 28726 const { 28727 target 28728 } = event; 28729 const { 28730 ownerDocument 28731 } = target; // If copying, only consider actual text selection as selection. 28732 // Otherwise, any focus on an input field is considered. 28733 28734 const hasSelection = event.type === 'copy' || event.type === 'cut' ? (0,external_wp_dom_namespaceObject.documentHasUncollapsedSelection)(ownerDocument) : (0,external_wp_dom_namespaceObject.documentHasSelection)(ownerDocument); // Let native copy behaviour take over in input fields. 28735 28736 if (hasSelection) { 28737 return; 28738 } 28739 } 28740 28741 if (!node.contains(event.target.ownerDocument.activeElement)) { 28742 return; 28743 } 28744 28745 const eventDefaultPrevented = event.defaultPrevented; 28746 event.preventDefault(); 28747 28748 const isSelectionMergeable = __unstableIsSelectionMergeable(); 28749 28750 const shouldHandleWholeBlocks = __unstableIsSelectionCollapsed() || __unstableIsFullySelected(); 28751 28752 const expandSelectionIsNeeded = !shouldHandleWholeBlocks && !isSelectionMergeable; 28753 28754 if (event.type === 'copy' || event.type === 'cut') { 28755 if (selectedBlockClientIds.length === 1) { 28756 flashBlock(selectedBlockClientIds[0]); 28757 } // If we have a partial selection that is not mergeable, just 28758 // expand the selection to the whole blocks. 28759 28760 28761 if (expandSelectionIsNeeded) { 28762 __unstableExpandSelection(); 28763 } else { 28764 notifyCopy(event.type, selectedBlockClientIds); 28765 let blocks; // Check if we have partial selection. 28766 28767 if (shouldHandleWholeBlocks) { 28768 blocks = getBlocksByClientId(selectedBlockClientIds); 28769 } else { 28770 const [head, tail] = __unstableGetSelectedBlocksWithPartialSelection(); 28771 28772 const inBetweenBlocks = getBlocksByClientId(selectedBlockClientIds.slice(1, selectedBlockClientIds.length - 1)); 28773 blocks = [head, ...inBetweenBlocks, tail]; 28774 } 28775 28776 const serialized = (0,external_wp_blocks_namespaceObject.serialize)(blocks); 28777 event.clipboardData.setData('text/plain', serialized); 28778 event.clipboardData.setData('text/html', serialized); 28779 } 28780 } 28781 28782 if (event.type === 'cut') { 28783 // We need to also check if at the start we needed to 28784 // expand the selection, as in this point we might have 28785 // programmatically fully selected the blocks above. 28786 if (shouldHandleWholeBlocks && !expandSelectionIsNeeded) { 28787 removeBlocks(selectedBlockClientIds); 28788 } else { 28789 __unstableDeleteSelection(); 28790 } 28791 } else if (event.type === 'paste') { 28792 if (eventDefaultPrevented) { 28793 // This was likely already handled in rich-text/use-paste-handler.js. 28794 return; 28795 } 28796 28797 const { 28798 __experimentalCanUserUseUnfilteredHTML: canUserUseUnfilteredHTML 28799 } = getSettings(); 28800 const { 28801 plainText, 28802 html 28803 } = getPasteEventData(event); 28804 const blocks = (0,external_wp_blocks_namespaceObject.pasteHandler)({ 28805 HTML: html, 28806 plainText, 28807 mode: 'BLOCKS', 28808 canUserUseUnfilteredHTML 28809 }); 28810 replaceBlocks(selectedBlockClientIds, blocks, blocks.length - 1, -1); 28811 } 28812 } 28813 28814 node.ownerDocument.addEventListener('copy', handler); 28815 node.ownerDocument.addEventListener('cut', handler); 28816 node.ownerDocument.addEventListener('paste', handler); 28817 return () => { 28818 node.ownerDocument.removeEventListener('copy', handler); 28819 node.ownerDocument.removeEventListener('cut', handler); 28820 node.ownerDocument.removeEventListener('paste', handler); 28821 }; 28822 }, []); 28823 } 28824 28825 function CopyHandler(_ref) { 28826 let { 28827 children 28828 } = _ref; 28829 return (0,external_wp_element_namespaceObject.createElement)("div", { 28830 ref: useClipboardHandler() 28831 }, children); 28832 } 28833 /** 28834 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/copy-handler/README.md 28835 */ 28836 28837 28838 /* harmony default export */ var copy_handler = (CopyHandler); 28839 28840 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-actions/index.js 28841 /** 28842 * External dependencies 28843 */ 28844 28845 /** 28846 * WordPress dependencies 28847 */ 28848 28849 28850 28851 /** 28852 * Internal dependencies 28853 */ 28854 28855 28856 28857 function BlockActions(_ref) { 28858 let { 28859 clientIds, 28860 children, 28861 __experimentalUpdateSelection: updateSelection 28862 } = _ref; 28863 const { 28864 canInsertBlockType, 28865 getBlockRootClientId, 28866 getBlocksByClientId, 28867 canMoveBlocks, 28868 canRemoveBlocks 28869 } = (0,external_wp_data_namespaceObject.useSelect)(store); 28870 const { 28871 getDefaultBlockName, 28872 getGroupingBlockName 28873 } = (0,external_wp_data_namespaceObject.useSelect)(external_wp_blocks_namespaceObject.store); 28874 const blocks = getBlocksByClientId(clientIds); 28875 const rootClientId = getBlockRootClientId(clientIds[0]); 28876 const canDuplicate = (0,external_lodash_namespaceObject.every)(blocks, block => { 28877 return !!block && (0,external_wp_blocks_namespaceObject.hasBlockSupport)(block.name, 'multiple', true) && canInsertBlockType(block.name, rootClientId); 28878 }); 28879 const canInsertDefaultBlock = canInsertBlockType(getDefaultBlockName(), rootClientId); 28880 const canMove = canMoveBlocks(clientIds, rootClientId); 28881 const canRemove = canRemoveBlocks(clientIds, rootClientId); 28882 const { 28883 removeBlocks, 28884 replaceBlocks, 28885 duplicateBlocks, 28886 insertAfterBlock, 28887 insertBeforeBlock, 28888 flashBlock, 28889 setBlockMovingClientId, 28890 setNavigationMode, 28891 selectBlock 28892 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 28893 const notifyCopy = useNotifyCopy(); 28894 return children({ 28895 canDuplicate, 28896 canInsertDefaultBlock, 28897 canMove, 28898 canRemove, 28899 rootClientId, 28900 blocks, 28901 28902 onDuplicate() { 28903 return duplicateBlocks(clientIds, updateSelection); 28904 }, 28905 28906 onRemove() { 28907 return removeBlocks(clientIds, updateSelection); 28908 }, 28909 28910 onInsertBefore() { 28911 insertBeforeBlock((0,external_lodash_namespaceObject.first)((0,external_lodash_namespaceObject.castArray)(clientIds))); 28912 }, 28913 28914 onInsertAfter() { 28915 insertAfterBlock((0,external_lodash_namespaceObject.last)((0,external_lodash_namespaceObject.castArray)(clientIds))); 28916 }, 28917 28918 onMoveTo() { 28919 setNavigationMode(true); 28920 selectBlock(clientIds[0]); 28921 setBlockMovingClientId(clientIds[0]); 28922 }, 28923 28924 onGroup() { 28925 if (!blocks.length) { 28926 return; 28927 } 28928 28929 const groupingBlockName = getGroupingBlockName(); // Activate the `transform` on `core/group` which does the conversion. 28930 28931 const newBlocks = (0,external_wp_blocks_namespaceObject.switchToBlockType)(blocks, groupingBlockName); 28932 28933 if (!newBlocks) { 28934 return; 28935 } 28936 28937 replaceBlocks(clientIds, newBlocks); 28938 }, 28939 28940 onUngroup() { 28941 if (!blocks.length) { 28942 return; 28943 } 28944 28945 const innerBlocks = blocks[0].innerBlocks; 28946 28947 if (!innerBlocks.length) { 28948 return; 28949 } 28950 28951 replaceBlocks(clientIds, innerBlocks); 28952 }, 28953 28954 onCopy() { 28955 const selectedBlockClientIds = blocks.map(_ref2 => { 28956 let { 28957 clientId 28958 } = _ref2; 28959 return clientId; 28960 }); 28961 28962 if (blocks.length === 1) { 28963 flashBlock(selectedBlockClientIds[0]); 28964 } 28965 28966 notifyCopy('copy', selectedBlockClientIds); 28967 } 28968 28969 }); 28970 } 28971 28972 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-settings-menu/block-mode-toggle.js 28973 28974 28975 /** 28976 * External dependencies 28977 */ 28978 28979 /** 28980 * WordPress dependencies 28981 */ 28982 28983 28984 28985 28986 28987 28988 /** 28989 * Internal dependencies 28990 */ 28991 28992 28993 function BlockModeToggle(_ref) { 28994 let { 28995 blockType, 28996 mode, 28997 onToggleMode, 28998 small = false, 28999 isCodeEditingEnabled = true 29000 } = _ref; 29001 29002 if (!(0,external_wp_blocks_namespaceObject.hasBlockSupport)(blockType, 'html', true) || !isCodeEditingEnabled) { 29003 return null; 29004 } 29005 29006 const label = mode === 'visual' ? (0,external_wp_i18n_namespaceObject.__)('Edit as HTML') : (0,external_wp_i18n_namespaceObject.__)('Edit visually'); 29007 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, { 29008 onClick: onToggleMode 29009 }, !small && label); 29010 } 29011 /* harmony default export */ var block_mode_toggle = ((0,external_wp_compose_namespaceObject.compose)([(0,external_wp_data_namespaceObject.withSelect)((select, _ref2) => { 29012 let { 29013 clientId 29014 } = _ref2; 29015 const { 29016 getBlock, 29017 getBlockMode, 29018 getSettings 29019 } = select(store); 29020 const block = getBlock(clientId); 29021 const isCodeEditingEnabled = getSettings().codeEditingEnabled; 29022 return { 29023 mode: getBlockMode(clientId), 29024 blockType: block ? (0,external_wp_blocks_namespaceObject.getBlockType)(block.name) : null, 29025 isCodeEditingEnabled 29026 }; 29027 }), (0,external_wp_data_namespaceObject.withDispatch)((dispatch, _ref3) => { 29028 let { 29029 onToggle = external_lodash_namespaceObject.noop, 29030 clientId 29031 } = _ref3; 29032 return { 29033 onToggleMode() { 29034 dispatch(store).toggleBlockMode(clientId); 29035 onToggle(); 29036 } 29037 29038 }; 29039 })])(BlockModeToggle)); 29040 29041 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-settings-menu/block-convert-button.js 29042 29043 29044 /** 29045 * WordPress dependencies 29046 */ 29047 29048 29049 function BlockConvertButton(_ref) { 29050 let { 29051 shouldRender, 29052 onClick, 29053 small 29054 } = _ref; 29055 29056 if (!shouldRender) { 29057 return null; 29058 } 29059 29060 const label = (0,external_wp_i18n_namespaceObject.__)('Convert to Blocks'); 29061 29062 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, { 29063 onClick: onClick 29064 }, !small && label); 29065 } 29066 29067 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-settings-menu/block-html-convert-button.js 29068 /** 29069 * WordPress dependencies 29070 */ 29071 29072 29073 29074 /** 29075 * Internal dependencies 29076 */ 29077 29078 29079 29080 /* harmony default export */ var block_html_convert_button = ((0,external_wp_compose_namespaceObject.compose)((0,external_wp_data_namespaceObject.withSelect)((select, _ref) => { 29081 let { 29082 clientId 29083 } = _ref; 29084 const block = select(store).getBlock(clientId); 29085 return { 29086 block, 29087 shouldRender: block && block.name === 'core/html' 29088 }; 29089 }), (0,external_wp_data_namespaceObject.withDispatch)((dispatch, _ref2) => { 29090 let { 29091 block 29092 } = _ref2; 29093 return { 29094 onClick: () => dispatch(store).replaceBlocks(block.clientId, (0,external_wp_blocks_namespaceObject.rawHandler)({ 29095 HTML: (0,external_wp_blocks_namespaceObject.getBlockContent)(block) 29096 })) 29097 }; 29098 }))(BlockConvertButton)); 29099 29100 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-settings-menu/block-settings-menu-first-item.js 29101 /** 29102 * WordPress dependencies 29103 */ 29104 29105 const { 29106 Fill: __unstableBlockSettingsMenuFirstItem, 29107 Slot: block_settings_menu_first_item_Slot 29108 } = (0,external_wp_components_namespaceObject.createSlotFill)('__unstableBlockSettingsMenuFirstItem'); 29109 __unstableBlockSettingsMenuFirstItem.Slot = block_settings_menu_first_item_Slot; 29110 /* harmony default export */ var block_settings_menu_first_item = (__unstableBlockSettingsMenuFirstItem); 29111 29112 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/convert-to-group-buttons/index.js 29113 29114 29115 /** 29116 * WordPress dependencies 29117 */ 29118 29119 29120 29121 29122 /** 29123 * Internal dependencies 29124 */ 29125 29126 29127 29128 29129 29130 function ConvertToGroupButton(_ref) { 29131 let { 29132 clientIds, 29133 isGroupable, 29134 isUngroupable, 29135 blocksSelection, 29136 groupingBlockName, 29137 onClose = () => {} 29138 } = _ref; 29139 const { 29140 replaceBlocks 29141 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 29142 29143 const onConvertToGroup = () => { 29144 // Activate the `transform` on the Grouping Block which does the conversion. 29145 const newBlocks = (0,external_wp_blocks_namespaceObject.switchToBlockType)(blocksSelection, groupingBlockName); 29146 29147 if (newBlocks) { 29148 replaceBlocks(clientIds, newBlocks); 29149 } 29150 }; 29151 29152 const onConvertFromGroup = () => { 29153 const innerBlocks = blocksSelection[0].innerBlocks; 29154 29155 if (!innerBlocks.length) { 29156 return; 29157 } 29158 29159 replaceBlocks(clientIds, innerBlocks); 29160 }; 29161 29162 if (!isGroupable && !isUngroupable) { 29163 return null; 29164 } 29165 29166 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, isGroupable && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, { 29167 onClick: () => { 29168 onConvertToGroup(); 29169 onClose(); 29170 } 29171 }, (0,external_wp_i18n_namespaceObject._x)('Group', 'verb')), isUngroupable && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, { 29172 onClick: () => { 29173 onConvertFromGroup(); 29174 onClose(); 29175 } 29176 }, (0,external_wp_i18n_namespaceObject._x)('Ungroup', 'Ungrouping blocks from within a Group block back into individual blocks within the Editor '))); 29177 } 29178 29179 29180 29181 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/convert-to-group-buttons/use-convert-to-group-button-props.js 29182 /** 29183 * WordPress dependencies 29184 */ 29185 29186 29187 /** 29188 * Internal dependencies 29189 */ 29190 29191 29192 /** 29193 * Contains the properties `ConvertToGroupButton` component needs. 29194 * 29195 * @typedef {Object} ConvertToGroupButtonProps 29196 * @property {string[]} clientIds An array of the selected client ids. 29197 * @property {boolean} isGroupable Indicates if the selected blocks can be grouped. 29198 * @property {boolean} isUngroupable Indicates if the selected blocks can be ungrouped. 29199 * @property {WPBlock[]} blocksSelection An array of the selected blocks. 29200 * @property {string} groupingBlockName The name of block used for handling grouping interactions. 29201 */ 29202 29203 /** 29204 * Returns the properties `ConvertToGroupButton` component needs to work properly. 29205 * It is used in `BlockSettingsMenuControls` to know if `ConvertToGroupButton` 29206 * should be rendered, to avoid ending up with an empty MenuGroup. 29207 * 29208 * @return {ConvertToGroupButtonProps} Returns the properties needed by `ConvertToGroupButton`. 29209 */ 29210 29211 function useConvertToGroupButtonProps() { 29212 const { 29213 clientIds, 29214 isGroupable, 29215 isUngroupable, 29216 blocksSelection, 29217 groupingBlockName 29218 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 29219 var _blocksSelection$; 29220 29221 const { 29222 getBlockRootClientId, 29223 getBlocksByClientId, 29224 canInsertBlockType, 29225 getSelectedBlockClientIds 29226 } = select(store); 29227 const { 29228 getGroupingBlockName 29229 } = select(external_wp_blocks_namespaceObject.store); 29230 29231 const _clientIds = getSelectedBlockClientIds(); 29232 29233 const _groupingBlockName = getGroupingBlockName(); 29234 29235 const rootClientId = !!(_clientIds !== null && _clientIds !== void 0 && _clientIds.length) ? getBlockRootClientId(_clientIds[0]) : undefined; 29236 const groupingBlockAvailable = canInsertBlockType(_groupingBlockName, rootClientId); 29237 29238 const _blocksSelection = getBlocksByClientId(_clientIds); 29239 29240 const isSingleGroupingBlock = _blocksSelection.length === 1 && ((_blocksSelection$ = _blocksSelection[0]) === null || _blocksSelection$ === void 0 ? void 0 : _blocksSelection$.name) === _groupingBlockName; // Do we have 29241 // 1. Grouping block available to be inserted? 29242 // 2. One or more blocks selected 29243 29244 const _isGroupable = groupingBlockAvailable && _blocksSelection.length; // Do we have a single Group Block selected and does that group have inner blocks? 29245 29246 29247 const _isUngroupable = isSingleGroupingBlock && !!_blocksSelection[0].innerBlocks.length; 29248 29249 return { 29250 clientIds: _clientIds, 29251 isGroupable: _isGroupable, 29252 isUngroupable: _isUngroupable, 29253 blocksSelection: _blocksSelection, 29254 groupingBlockName: _groupingBlockName 29255 }; 29256 }, []); 29257 return { 29258 clientIds, 29259 isGroupable, 29260 isUngroupable, 29261 blocksSelection, 29262 groupingBlockName 29263 }; 29264 } 29265 29266 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/unlock.js 29267 29268 29269 /** 29270 * WordPress dependencies 29271 */ 29272 29273 const unlock = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 29274 viewBox: "0 0 24 24", 29275 xmlns: "http://www.w3.org/2000/svg" 29276 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 29277 d: "M17 10h-1.2V7c0-2.1-1.7-3.8-3.8-3.8-2.1 0-3.8 1.7-3.8 3.8h1.5c0-1.2 1-2.2 2.2-2.2s2.2 1 2.2 2.2v3H7c-.6 0-1 .4-1 1v8c0 .6.4 1 1 1h10c.6 0 1-.4 1-1v-8c0-.6-.4-1-1-1z" 29278 })); 29279 /* harmony default export */ var library_unlock = (unlock); 29280 29281 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/lock.js 29282 29283 29284 /** 29285 * WordPress dependencies 29286 */ 29287 29288 const lock = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 29289 viewBox: "0 0 24 24", 29290 xmlns: "http://www.w3.org/2000/svg" 29291 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 29292 d: "M17 10h-1.2V7c0-2.1-1.7-3.8-3.8-3.8-2.1 0-3.8 1.7-3.8 3.8v3H7c-.6 0-1 .4-1 1v8c0 .6.4 1 1 1h10c.6 0 1-.4 1-1v-8c0-.6-.4-1-1-1zm-2.8 0H9.8V7c0-1.2 1-2.2 2.2-2.2s2.2 1 2.2 2.2v3z" 29293 })); 29294 /* harmony default export */ var library_lock = (lock); 29295 29296 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-lock/use-block-lock.js 29297 /** 29298 * WordPress dependencies 29299 */ 29300 29301 /** 29302 * Internal dependencies 29303 */ 29304 29305 29306 /** 29307 * Return details about the block lock status. 29308 * 29309 * @param {string} clientId The block client Id. 29310 * 29311 * @return {Object} Block lock status 29312 */ 29313 29314 function useBlockLock(clientId) { 29315 return (0,external_wp_data_namespaceObject.useSelect)(select => { 29316 const { 29317 canMoveBlock, 29318 canRemoveBlock, 29319 canLockBlockType, 29320 getBlockName, 29321 getBlockRootClientId 29322 } = select(store); 29323 const rootClientId = getBlockRootClientId(clientId); 29324 const canMove = canMoveBlock(clientId, rootClientId); 29325 const canRemove = canRemoveBlock(clientId, rootClientId); 29326 return { 29327 canMove, 29328 canRemove, 29329 canLock: canLockBlockType(getBlockName(clientId)), 29330 isLocked: !canMove || !canRemove 29331 }; 29332 }, [clientId]); 29333 } 29334 29335 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-lock/modal.js 29336 29337 29338 /** 29339 * WordPress dependencies 29340 */ 29341 29342 29343 29344 29345 29346 29347 /** 29348 * Internal dependencies 29349 */ 29350 29351 29352 29353 29354 function BlockLockModal(_ref) { 29355 let { 29356 clientId, 29357 onClose 29358 } = _ref; 29359 const [lock, setLock] = (0,external_wp_element_namespaceObject.useState)({ 29360 move: false, 29361 remove: false 29362 }); 29363 const { 29364 canMove, 29365 canRemove 29366 } = useBlockLock(clientId); 29367 const { 29368 updateBlockAttributes 29369 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 29370 const blockInformation = useBlockDisplayInformation(clientId); 29371 const instanceId = (0,external_wp_compose_namespaceObject.useInstanceId)(BlockLockModal, 'block-editor-block-lock-modal__options-title'); 29372 (0,external_wp_element_namespaceObject.useEffect)(() => { 29373 setLock({ 29374 move: !canMove, 29375 remove: !canRemove 29376 }); 29377 }, [canMove, canRemove]); 29378 const isAllChecked = Object.values(lock).every(Boolean); 29379 const isMixed = Object.values(lock).some(Boolean) && !isAllChecked; 29380 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Modal, { 29381 title: (0,external_wp_i18n_namespaceObject.sprintf)( 29382 /* translators: %s: Name of the block. */ 29383 (0,external_wp_i18n_namespaceObject.__)('Lock %s'), blockInformation.title), 29384 overlayClassName: "block-editor-block-lock-modal", 29385 closeLabel: (0,external_wp_i18n_namespaceObject.__)('Close'), 29386 onRequestClose: onClose 29387 }, (0,external_wp_element_namespaceObject.createElement)("form", { 29388 onSubmit: event => { 29389 event.preventDefault(); 29390 updateBlockAttributes([clientId], { 29391 lock 29392 }); 29393 onClose(); 29394 } 29395 }, (0,external_wp_element_namespaceObject.createElement)("p", null, (0,external_wp_i18n_namespaceObject.__)('Choose specific attributes to restrict or lock all available options.')), (0,external_wp_element_namespaceObject.createElement)("div", { 29396 role: "group", 29397 "aria-labelledby": instanceId, 29398 className: "block-editor-block-lock-modal__options" 29399 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.CheckboxControl, { 29400 className: "block-editor-block-lock-modal__options-title", 29401 label: (0,external_wp_element_namespaceObject.createElement)("span", { 29402 id: instanceId 29403 }, (0,external_wp_i18n_namespaceObject.__)('Lock all')), 29404 checked: isAllChecked, 29405 indeterminate: isMixed, 29406 onChange: newValue => setLock({ 29407 move: newValue, 29408 remove: newValue 29409 }) 29410 }), (0,external_wp_element_namespaceObject.createElement)("ul", { 29411 className: "block-editor-block-lock-modal__checklist" 29412 }, (0,external_wp_element_namespaceObject.createElement)("li", { 29413 className: "block-editor-block-lock-modal__checklist-item" 29414 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.CheckboxControl, { 29415 label: (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_i18n_namespaceObject.__)('Disable movement'), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Icon, { 29416 icon: lock.move ? library_lock : library_unlock 29417 })), 29418 checked: lock.move, 29419 onChange: move => setLock(prevLock => ({ ...prevLock, 29420 move 29421 })) 29422 })), (0,external_wp_element_namespaceObject.createElement)("li", { 29423 className: "block-editor-block-lock-modal__checklist-item" 29424 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.CheckboxControl, { 29425 label: (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_i18n_namespaceObject.__)('Prevent removal'), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Icon, { 29426 icon: lock.remove ? library_lock : library_unlock 29427 })), 29428 checked: lock.remove, 29429 onChange: remove => setLock(prevLock => ({ ...prevLock, 29430 remove 29431 })) 29432 })))), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Flex, { 29433 className: "block-editor-block-lock-modal__actions", 29434 justify: "flex-end", 29435 expanded: false 29436 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FlexItem, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 29437 variant: "tertiary", 29438 onClick: onClose 29439 }, (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, { 29440 variant: "primary", 29441 type: "submit" 29442 }, (0,external_wp_i18n_namespaceObject.__)('Apply')))))); 29443 } 29444 29445 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-lock/menu-item.js 29446 29447 29448 /** 29449 * WordPress dependencies 29450 */ 29451 29452 29453 29454 29455 /** 29456 * Internal dependencies 29457 */ 29458 29459 29460 29461 function BlockLockMenuItem(_ref) { 29462 let { 29463 clientId 29464 } = _ref; 29465 const { 29466 canLock, 29467 isLocked 29468 } = useBlockLock(clientId); 29469 const [isModalOpen, toggleModal] = (0,external_wp_element_namespaceObject.useReducer)(isActive => !isActive, false); 29470 29471 if (!canLock) { 29472 return null; 29473 } 29474 29475 const label = isLocked ? (0,external_wp_i18n_namespaceObject.__)('Unlock') : (0,external_wp_i18n_namespaceObject.__)('Lock'); 29476 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, { 29477 icon: isLocked ? library_unlock : library_lock, 29478 onClick: toggleModal 29479 }, label), isModalOpen && (0,external_wp_element_namespaceObject.createElement)(BlockLockModal, { 29480 clientId: clientId, 29481 onClose: toggleModal 29482 })); 29483 } 29484 29485 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-settings-menu-controls/index.js 29486 29487 29488 29489 /** 29490 * External dependencies 29491 */ 29492 29493 /** 29494 * WordPress dependencies 29495 */ 29496 29497 29498 29499 /** 29500 * Internal dependencies 29501 */ 29502 29503 29504 29505 29506 const { 29507 Fill, 29508 Slot: block_settings_menu_controls_Slot 29509 } = (0,external_wp_components_namespaceObject.createSlotFill)('BlockSettingsMenuControls'); 29510 29511 const BlockSettingsMenuControlsSlot = _ref => { 29512 let { 29513 fillProps, 29514 clientIds = null 29515 } = _ref; 29516 const { 29517 selectedBlocks, 29518 selectedClientIds, 29519 canRemove 29520 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 29521 const { 29522 getBlocksByClientId, 29523 getSelectedBlockClientIds, 29524 canRemoveBlocks 29525 } = select(store); 29526 const ids = clientIds !== null ? clientIds : getSelectedBlockClientIds(); 29527 return { 29528 selectedBlocks: (0,external_lodash_namespaceObject.map)((0,external_lodash_namespaceObject.compact)(getBlocksByClientId(ids)), block => block.name), 29529 selectedClientIds: ids, 29530 canRemove: canRemoveBlocks(ids) 29531 }; 29532 }, [clientIds]); 29533 const showLockButton = selectedClientIds.length === 1; // Check if current selection of blocks is Groupable or Ungroupable 29534 // and pass this props down to ConvertToGroupButton. 29535 29536 const convertToGroupButtonProps = useConvertToGroupButtonProps(); 29537 const { 29538 isGroupable, 29539 isUngroupable 29540 } = convertToGroupButtonProps; 29541 const showConvertToGroupButton = (isGroupable || isUngroupable) && canRemove; 29542 return (0,external_wp_element_namespaceObject.createElement)(block_settings_menu_controls_Slot, { 29543 fillProps: { ...fillProps, 29544 selectedBlocks, 29545 selectedClientIds 29546 } 29547 }, fills => { 29548 if (!(fills !== null && fills !== void 0 && fills.length) > 0 && !showConvertToGroupButton && !showLockButton) { 29549 return null; 29550 } 29551 29552 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuGroup, null, showLockButton && (0,external_wp_element_namespaceObject.createElement)(BlockLockMenuItem, { 29553 clientId: selectedClientIds[0] 29554 }), fills, showConvertToGroupButton && (0,external_wp_element_namespaceObject.createElement)(ConvertToGroupButton, _extends({}, convertToGroupButtonProps, { 29555 onClose: fillProps === null || fillProps === void 0 ? void 0 : fillProps.onClose 29556 }))); 29557 }); 29558 }; 29559 /** 29560 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/block-settings-menu-controls/README.md 29561 * 29562 * @param {Object} props Fill props. 29563 * @return {WPElement} Element. 29564 */ 29565 29566 29567 function BlockSettingsMenuControls(_ref2) { 29568 let { ...props 29569 } = _ref2; 29570 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalStyleProvider, { 29571 document: document 29572 }, (0,external_wp_element_namespaceObject.createElement)(Fill, props)); 29573 } 29574 29575 BlockSettingsMenuControls.Slot = BlockSettingsMenuControlsSlot; 29576 /* harmony default export */ var block_settings_menu_controls = (BlockSettingsMenuControls); 29577 29578 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-settings-menu/block-settings-dropdown.js 29579 29580 29581 29582 /** 29583 * External dependencies 29584 */ 29585 29586 /** 29587 * WordPress dependencies 29588 */ 29589 29590 29591 29592 29593 29594 29595 29596 29597 29598 /** 29599 * Internal dependencies 29600 */ 29601 29602 29603 29604 29605 29606 29607 29608 29609 29610 29611 const block_settings_dropdown_POPOVER_PROPS = { 29612 className: 'block-editor-block-settings-menu__popover', 29613 position: 'bottom right', 29614 isAlternate: true 29615 }; 29616 29617 function CopyMenuItem(_ref) { 29618 let { 29619 blocks, 29620 onCopy 29621 } = _ref; 29622 const ref = (0,external_wp_compose_namespaceObject.useCopyToClipboard)(() => (0,external_wp_blocks_namespaceObject.serialize)(blocks), onCopy); 29623 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, { 29624 ref: ref 29625 }, (0,external_wp_i18n_namespaceObject.__)('Copy')); 29626 } 29627 29628 function BlockSettingsDropdown(_ref2) { 29629 let { 29630 clientIds, 29631 __experimentalSelectBlock, 29632 children, 29633 ...props 29634 } = _ref2; 29635 const blockClientIds = (0,external_lodash_namespaceObject.castArray)(clientIds); 29636 const count = blockClientIds.length; 29637 const firstBlockClientId = blockClientIds[0]; 29638 const { 29639 firstParentClientId, 29640 hasReducedUI, 29641 onlyBlock, 29642 parentBlockType, 29643 previousBlockClientId, 29644 nextBlockClientId, 29645 selectedBlockClientIds 29646 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 29647 const { 29648 getBlockCount, 29649 getBlockName, 29650 getBlockParents, 29651 getPreviousBlockClientId, 29652 getNextBlockClientId, 29653 getSelectedBlockClientIds, 29654 getSettings 29655 } = select(store); 29656 const parents = getBlockParents(firstBlockClientId); 29657 const _firstParentClientId = parents[parents.length - 1]; 29658 const parentBlockName = getBlockName(_firstParentClientId); 29659 return { 29660 firstParentClientId: _firstParentClientId, 29661 hasReducedUI: getSettings().hasReducedUI, 29662 onlyBlock: 1 === getBlockCount(), 29663 parentBlockType: (0,external_wp_blocks_namespaceObject.getBlockType)(parentBlockName), 29664 previousBlockClientId: getPreviousBlockClientId(firstBlockClientId), 29665 nextBlockClientId: getNextBlockClientId(firstBlockClientId), 29666 selectedBlockClientIds: getSelectedBlockClientIds() 29667 }; 29668 }, [firstBlockClientId]); 29669 const shortcuts = (0,external_wp_data_namespaceObject.useSelect)(select => { 29670 const { 29671 getShortcutRepresentation 29672 } = select(external_wp_keyboardShortcuts_namespaceObject.store); 29673 return { 29674 duplicate: getShortcutRepresentation('core/block-editor/duplicate'), 29675 remove: getShortcutRepresentation('core/block-editor/remove'), 29676 insertAfter: getShortcutRepresentation('core/block-editor/insert-after'), 29677 insertBefore: getShortcutRepresentation('core/block-editor/insert-before') 29678 }; 29679 }, []); 29680 const { 29681 selectBlock, 29682 toggleBlockHighlight 29683 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 29684 const updateSelectionAfterDuplicate = (0,external_wp_element_namespaceObject.useCallback)(__experimentalSelectBlock ? async clientIdsPromise => { 29685 const ids = await clientIdsPromise; 29686 29687 if (ids && ids[0]) { 29688 __experimentalSelectBlock(ids[0]); 29689 } 29690 } : external_lodash_namespaceObject.noop, [__experimentalSelectBlock]); 29691 const blockTitle = useBlockDisplayTitle(firstBlockClientId, 25); 29692 const updateSelectionAfterRemove = (0,external_wp_element_namespaceObject.useCallback)(__experimentalSelectBlock ? () => { 29693 const blockToSelect = previousBlockClientId || nextBlockClientId; 29694 29695 if (blockToSelect && // From the block options dropdown, it's possible to remove a block that is not selected, 29696 // in this case, it's not necessary to update the selection since the selected block wasn't removed. 29697 selectedBlockClientIds.includes(firstBlockClientId) && // Don't update selection when next/prev block also is in the selection ( and gets removed ), 29698 // In case someone selects all blocks and removes them at once. 29699 !selectedBlockClientIds.includes(blockToSelect)) { 29700 __experimentalSelectBlock(blockToSelect); 29701 } 29702 } : external_lodash_namespaceObject.noop, [__experimentalSelectBlock, previousBlockClientId, nextBlockClientId, selectedBlockClientIds]); 29703 const label = (0,external_wp_i18n_namespaceObject.sprintf)( 29704 /* translators: %s: block name */ 29705 (0,external_wp_i18n_namespaceObject.__)('Remove %s'), blockTitle); 29706 const removeBlockLabel = count === 1 ? label : (0,external_wp_i18n_namespaceObject.__)('Remove blocks'); // Allows highlighting the parent block outline when focusing or hovering 29707 // the parent block selector within the child. 29708 29709 const selectParentButtonRef = (0,external_wp_element_namespaceObject.useRef)(); 29710 const { 29711 gestures: showParentOutlineGestures 29712 } = useShowMoversGestures({ 29713 ref: selectParentButtonRef, 29714 29715 onChange(isFocused) { 29716 if (isFocused && hasReducedUI) { 29717 return; 29718 } 29719 29720 toggleBlockHighlight(firstParentClientId, isFocused); 29721 } 29722 29723 }); 29724 return (0,external_wp_element_namespaceObject.createElement)(BlockActions, { 29725 clientIds: clientIds, 29726 __experimentalUpdateSelection: !__experimentalSelectBlock 29727 }, _ref3 => { 29728 let { 29729 canDuplicate, 29730 canInsertDefaultBlock, 29731 canMove, 29732 canRemove, 29733 onDuplicate, 29734 onInsertAfter, 29735 onInsertBefore, 29736 onRemove, 29737 onCopy, 29738 onMoveTo, 29739 blocks 29740 } = _ref3; 29741 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.DropdownMenu, _extends({ 29742 icon: more_vertical, 29743 label: (0,external_wp_i18n_namespaceObject.__)('Options'), 29744 className: "block-editor-block-settings-menu", 29745 popoverProps: block_settings_dropdown_POPOVER_PROPS, 29746 noIcons: true 29747 }, props), _ref4 => { 29748 let { 29749 onClose 29750 } = _ref4; 29751 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuGroup, null, (0,external_wp_element_namespaceObject.createElement)(block_settings_menu_first_item.Slot, { 29752 fillProps: { 29753 onClose 29754 } 29755 }), firstParentClientId !== undefined && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, _extends({}, showParentOutlineGestures, { 29756 ref: selectParentButtonRef, 29757 icon: (0,external_wp_element_namespaceObject.createElement)(block_icon, { 29758 icon: parentBlockType.icon 29759 }), 29760 onClick: () => selectBlock(firstParentClientId) 29761 }), (0,external_wp_i18n_namespaceObject.sprintf)( 29762 /* translators: %s: Name of the block's parent. */ 29763 (0,external_wp_i18n_namespaceObject.__)('Select parent block (%s)'), parentBlockType.title)), count === 1 && (0,external_wp_element_namespaceObject.createElement)(block_html_convert_button, { 29764 clientId: firstBlockClientId 29765 }), (0,external_wp_element_namespaceObject.createElement)(CopyMenuItem, { 29766 blocks: blocks, 29767 onCopy: onCopy 29768 }), canDuplicate && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, { 29769 onClick: (0,external_lodash_namespaceObject.flow)(onClose, onDuplicate, updateSelectionAfterDuplicate), 29770 shortcut: shortcuts.duplicate 29771 }, (0,external_wp_i18n_namespaceObject.__)('Duplicate')), canInsertDefaultBlock && (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, { 29772 onClick: (0,external_lodash_namespaceObject.flow)(onClose, onInsertBefore), 29773 shortcut: shortcuts.insertBefore 29774 }, (0,external_wp_i18n_namespaceObject.__)('Insert before')), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, { 29775 onClick: (0,external_lodash_namespaceObject.flow)(onClose, onInsertAfter), 29776 shortcut: shortcuts.insertAfter 29777 }, (0,external_wp_i18n_namespaceObject.__)('Insert after'))), canMove && !onlyBlock && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, { 29778 onClick: (0,external_lodash_namespaceObject.flow)(onClose, onMoveTo) 29779 }, (0,external_wp_i18n_namespaceObject.__)('Move to')), count === 1 && (0,external_wp_element_namespaceObject.createElement)(block_mode_toggle, { 29780 clientId: firstBlockClientId, 29781 onToggle: onClose 29782 })), (0,external_wp_element_namespaceObject.createElement)(block_settings_menu_controls.Slot, { 29783 fillProps: { 29784 onClose 29785 }, 29786 clientIds: clientIds 29787 }), typeof children === 'function' ? children({ 29788 onClose 29789 }) : external_wp_element_namespaceObject.Children.map(child => (0,external_wp_element_namespaceObject.cloneElement)(child, { 29790 onClose 29791 })), canRemove && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuGroup, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, { 29792 onClick: (0,external_lodash_namespaceObject.flow)(onClose, onRemove, updateSelectionAfterRemove), 29793 shortcut: shortcuts.remove 29794 }, removeBlockLabel))); 29795 }); 29796 }); 29797 } 29798 /* harmony default export */ var block_settings_dropdown = (BlockSettingsDropdown); 29799 29800 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-settings-menu/index.js 29801 29802 29803 29804 /** 29805 * WordPress dependencies 29806 */ 29807 29808 /** 29809 * Internal dependencies 29810 */ 29811 29812 29813 function BlockSettingsMenu(_ref) { 29814 let { 29815 clientIds, 29816 ...props 29817 } = _ref; 29818 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarGroup, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarItem, null, toggleProps => (0,external_wp_element_namespaceObject.createElement)(block_settings_dropdown, _extends({ 29819 clientIds: clientIds, 29820 toggleProps: toggleProps 29821 }, props)))); 29822 } 29823 /* harmony default export */ var block_settings_menu = (BlockSettingsMenu); 29824 29825 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-lock/toolbar.js 29826 29827 29828 /** 29829 * WordPress dependencies 29830 */ 29831 29832 29833 29834 29835 /** 29836 * Internal dependencies 29837 */ 29838 29839 29840 29841 29842 function BlockLockToolbar(_ref) { 29843 let { 29844 clientId 29845 } = _ref; 29846 const blockInformation = useBlockDisplayInformation(clientId); 29847 const { 29848 canMove, 29849 canRemove, 29850 canLock 29851 } = useBlockLock(clientId); 29852 const [isModalOpen, toggleModal] = (0,external_wp_element_namespaceObject.useReducer)(isActive => !isActive, false); 29853 29854 if (!canLock) { 29855 return null; 29856 } 29857 29858 if (canMove && canRemove) { 29859 return null; 29860 } 29861 29862 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarGroup, { 29863 className: "block-editor-block-lock-toolbar" 29864 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, { 29865 icon: library_lock, 29866 label: (0,external_wp_i18n_namespaceObject.sprintf)( 29867 /* translators: %s: block name */ 29868 (0,external_wp_i18n_namespaceObject.__)('Unlock %s'), blockInformation.title), 29869 onClick: toggleModal 29870 })), isModalOpen && (0,external_wp_element_namespaceObject.createElement)(BlockLockModal, { 29871 clientId: clientId, 29872 onClose: toggleModal 29873 })); 29874 } 29875 29876 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/group.js 29877 29878 29879 /** 29880 * WordPress dependencies 29881 */ 29882 29883 const group_group = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 29884 viewBox: "0 0 24 24", 29885 xmlns: "http://www.w3.org/2000/svg" 29886 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 29887 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" 29888 })); 29889 /* harmony default export */ var library_group = (group_group); 29890 29891 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/row.js 29892 29893 29894 /** 29895 * WordPress dependencies 29896 */ 29897 29898 const row = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 29899 xmlns: "http://www.w3.org/2000/svg", 29900 viewBox: "0 0 24 24" 29901 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 29902 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" 29903 })); 29904 /* harmony default export */ var library_row = (row); 29905 29906 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/stack.js 29907 29908 29909 /** 29910 * WordPress dependencies 29911 */ 29912 29913 const stack = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 29914 xmlns: "http://www.w3.org/2000/svg", 29915 viewBox: "0 0 24 24" 29916 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 29917 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" 29918 })); 29919 /* harmony default export */ var library_stack = (stack); 29920 29921 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/convert-to-group-buttons/toolbar.js 29922 29923 29924 /** 29925 * WordPress dependencies 29926 */ 29927 29928 29929 29930 29931 29932 /** 29933 * Internal dependencies 29934 */ 29935 29936 29937 29938 const layouts = { 29939 group: undefined, 29940 row: { 29941 type: 'flex', 29942 flexWrap: 'nowrap' 29943 }, 29944 stack: { 29945 type: 'flex', 29946 orientation: 'vertical' 29947 } 29948 }; 29949 29950 function BlockGroupToolbar() { 29951 const { 29952 blocksSelection, 29953 clientIds, 29954 groupingBlockName, 29955 isGroupable 29956 } = useConvertToGroupButtonProps(); 29957 const { 29958 replaceBlocks 29959 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 29960 const { 29961 canRemove 29962 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 29963 const { 29964 canRemoveBlocks 29965 } = select(store); 29966 return { 29967 canRemove: canRemoveBlocks(clientIds) 29968 }; 29969 }, [clientIds]); 29970 29971 const onConvertToGroup = function () { 29972 let layout = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'group'; 29973 const newBlocks = (0,external_wp_blocks_namespaceObject.switchToBlockType)(blocksSelection, groupingBlockName); 29974 29975 if (newBlocks && newBlocks.length > 0) { 29976 // Because the block is not in the store yet we can't use 29977 // updateBlockAttributes so need to manually update attributes. 29978 newBlocks[0].attributes.layout = layouts[layout]; 29979 replaceBlocks(clientIds, newBlocks); 29980 } 29981 }; 29982 29983 const onConvertToRow = () => onConvertToGroup('row'); 29984 29985 const onConvertToStack = () => onConvertToGroup('stack'); // Don't render the button if the current selection cannot be grouped. 29986 // A good example is selecting multiple button blocks within a Buttons block: 29987 // The group block is not a valid child of Buttons, so we should not show the button. 29988 // Any blocks that are locked against removal also cannot be grouped. 29989 29990 29991 if (!isGroupable || !canRemove) { 29992 return null; 29993 } 29994 29995 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarGroup, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, { 29996 icon: library_group, 29997 label: (0,external_wp_i18n_namespaceObject._x)('Group', 'verb'), 29998 onClick: onConvertToGroup 29999 }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, { 30000 icon: library_row, 30001 label: (0,external_wp_i18n_namespaceObject._x)('Row', 'single horizontal line'), 30002 onClick: onConvertToRow 30003 }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, { 30004 icon: library_stack, 30005 label: (0,external_wp_i18n_namespaceObject._x)('Stack', 'verb'), 30006 onClick: onConvertToStack 30007 })); 30008 } 30009 30010 /* harmony default export */ var toolbar = (BlockGroupToolbar); 30011 30012 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-toolbar/block-name-context.js 30013 /** 30014 * WordPress dependencies 30015 */ 30016 30017 30018 const __unstableBlockNameContext = (0,external_wp_element_namespaceObject.createContext)(''); 30019 30020 /* harmony default export */ var block_name_context = (__unstableBlockNameContext); 30021 30022 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-toolbar/index.js 30023 30024 30025 30026 /** 30027 * External dependencies 30028 */ 30029 30030 /** 30031 * WordPress dependencies 30032 */ 30033 30034 30035 30036 30037 30038 30039 /** 30040 * Internal dependencies 30041 */ 30042 30043 30044 30045 30046 30047 30048 30049 30050 30051 30052 30053 30054 30055 const BlockToolbar = _ref => { 30056 let { 30057 hideDragHandle 30058 } = _ref; 30059 const { 30060 blockClientIds, 30061 blockClientId, 30062 blockType, 30063 hasFixedToolbar, 30064 hasReducedUI, 30065 isValid, 30066 isVisual 30067 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 30068 const { 30069 getBlockName, 30070 getBlockMode, 30071 getSelectedBlockClientIds, 30072 isBlockValid, 30073 getBlockRootClientId, 30074 getSettings 30075 } = select(store); 30076 const selectedBlockClientIds = getSelectedBlockClientIds(); 30077 const selectedBlockClientId = selectedBlockClientIds[0]; 30078 const blockRootClientId = getBlockRootClientId(selectedBlockClientId); 30079 const settings = getSettings(); 30080 return { 30081 blockClientIds: selectedBlockClientIds, 30082 blockClientId: selectedBlockClientId, 30083 blockType: selectedBlockClientId && (0,external_wp_blocks_namespaceObject.getBlockType)(getBlockName(selectedBlockClientId)), 30084 hasFixedToolbar: settings.hasFixedToolbar, 30085 hasReducedUI: settings.hasReducedUI, 30086 rootClientId: blockRootClientId, 30087 isValid: selectedBlockClientIds.every(id => isBlockValid(id)), 30088 isVisual: selectedBlockClientIds.every(id => getBlockMode(id) === 'visual') 30089 }; 30090 }, []); // Handles highlighting the current block outline on hover or focus of the 30091 // block type toolbar area. 30092 30093 const { 30094 toggleBlockHighlight 30095 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 30096 const nodeRef = (0,external_wp_element_namespaceObject.useRef)(); 30097 const { 30098 showMovers, 30099 gestures: showMoversGestures 30100 } = useShowMoversGestures({ 30101 ref: nodeRef, 30102 30103 onChange(isFocused) { 30104 if (isFocused && hasReducedUI) { 30105 return; 30106 } 30107 30108 toggleBlockHighlight(blockClientId, isFocused); 30109 } 30110 30111 }); // Account for the cases where the block toolbar is rendered within the 30112 // header area and not contextually to the block. 30113 30114 const displayHeaderToolbar = (0,external_wp_compose_namespaceObject.useViewportMatch)('medium', '<') || hasFixedToolbar; 30115 30116 if (blockType) { 30117 if (!(0,external_wp_blocks_namespaceObject.hasBlockSupport)(blockType, '__experimentalToolbar', true)) { 30118 return null; 30119 } 30120 } 30121 30122 const shouldShowMovers = displayHeaderToolbar || showMovers; 30123 30124 if (blockClientIds.length === 0) { 30125 return null; 30126 } 30127 30128 const shouldShowVisualToolbar = isValid && isVisual; 30129 const isMultiToolbar = blockClientIds.length > 1; 30130 const classes = classnames_default()('block-editor-block-toolbar', shouldShowMovers && 'is-showing-movers'); 30131 return (0,external_wp_element_namespaceObject.createElement)("div", { 30132 className: classes 30133 }, !isMultiToolbar && !displayHeaderToolbar && (0,external_wp_element_namespaceObject.createElement)(BlockParentSelector, { 30134 clientIds: blockClientIds 30135 }), (0,external_wp_element_namespaceObject.createElement)("div", _extends({ 30136 ref: nodeRef 30137 }, showMoversGestures), (shouldShowVisualToolbar || isMultiToolbar) && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarGroup, { 30138 className: "block-editor-block-toolbar__block-controls" 30139 }, (0,external_wp_element_namespaceObject.createElement)(block_switcher, { 30140 clientIds: blockClientIds 30141 }), !isMultiToolbar && (0,external_wp_element_namespaceObject.createElement)(BlockLockToolbar, { 30142 clientId: blockClientIds[0] 30143 }), (0,external_wp_element_namespaceObject.createElement)(block_mover, { 30144 clientIds: blockClientIds, 30145 hideDragHandle: hideDragHandle || hasReducedUI 30146 }))), shouldShowVisualToolbar && isMultiToolbar && (0,external_wp_element_namespaceObject.createElement)(toolbar, null), shouldShowVisualToolbar && (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(block_controls.Slot, { 30147 group: "parent", 30148 className: "block-editor-block-toolbar__slot" 30149 }), (0,external_wp_element_namespaceObject.createElement)(block_controls.Slot, { 30150 group: "block", 30151 className: "block-editor-block-toolbar__slot" 30152 }), (0,external_wp_element_namespaceObject.createElement)(block_controls.Slot, { 30153 className: "block-editor-block-toolbar__slot" 30154 }), (0,external_wp_element_namespaceObject.createElement)(block_controls.Slot, { 30155 group: "inline", 30156 className: "block-editor-block-toolbar__slot" 30157 }), (0,external_wp_element_namespaceObject.createElement)(block_controls.Slot, { 30158 group: "other", 30159 className: "block-editor-block-toolbar__slot" 30160 }), (0,external_wp_element_namespaceObject.createElement)(block_name_context.Provider, { 30161 value: blockType === null || blockType === void 0 ? void 0 : blockType.name 30162 }, (0,external_wp_element_namespaceObject.createElement)(block_toolbar_last_item.Slot, null))), (0,external_wp_element_namespaceObject.createElement)(block_settings_menu, { 30163 clientIds: blockClientIds 30164 })); 30165 }; 30166 /** 30167 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/block-toolbar/README.md 30168 */ 30169 30170 30171 /* harmony default export */ var block_toolbar = (BlockToolbar); 30172 30173 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-tools/block-contextual-toolbar.js 30174 30175 30176 30177 /** 30178 * External dependencies 30179 */ 30180 30181 /** 30182 * WordPress dependencies 30183 */ 30184 30185 30186 30187 30188 /** 30189 * Internal dependencies 30190 */ 30191 30192 30193 30194 30195 30196 function BlockContextualToolbar(_ref) { 30197 let { 30198 focusOnMount, 30199 isFixed, 30200 ...props 30201 } = _ref; 30202 const { 30203 blockType, 30204 hasParents, 30205 showParentSelector 30206 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 30207 const { 30208 getBlockName, 30209 getBlockParents, 30210 getSelectedBlockClientIds 30211 } = select(store); 30212 const { 30213 getBlockType 30214 } = select(external_wp_blocks_namespaceObject.store); 30215 const selectedBlockClientIds = getSelectedBlockClientIds(); 30216 const selectedBlockClientId = selectedBlockClientIds[0]; 30217 const parents = getBlockParents(selectedBlockClientId); 30218 const firstParentClientId = parents[parents.length - 1]; 30219 const parentBlockName = getBlockName(firstParentClientId); 30220 const parentBlockType = getBlockType(parentBlockName); 30221 return { 30222 blockType: selectedBlockClientId && getBlockType(getBlockName(selectedBlockClientId)), 30223 hasParents: parents.length, 30224 showParentSelector: (0,external_wp_blocks_namespaceObject.hasBlockSupport)(parentBlockType, '__experimentalParentSelector', true) && selectedBlockClientIds.length <= 1 30225 }; 30226 }, []); 30227 30228 if (blockType) { 30229 if (!(0,external_wp_blocks_namespaceObject.hasBlockSupport)(blockType, '__experimentalToolbar', true)) { 30230 return null; 30231 } 30232 } // Shifts the toolbar to make room for the parent block selector. 30233 30234 30235 const classes = classnames_default()('block-editor-block-contextual-toolbar', { 30236 'has-parent': hasParents && showParentSelector, 30237 'is-fixed': isFixed 30238 }); 30239 return (0,external_wp_element_namespaceObject.createElement)(navigable_toolbar, _extends({ 30240 focusOnMount: focusOnMount, 30241 className: classes 30242 /* translators: accessibility text for the block toolbar */ 30243 , 30244 "aria-label": (0,external_wp_i18n_namespaceObject.__)('Block tools') 30245 }, props), (0,external_wp_element_namespaceObject.createElement)(block_toolbar, { 30246 hideDragHandle: isFixed 30247 })); 30248 } 30249 30250 /* harmony default export */ var block_contextual_toolbar = (BlockContextualToolbar); 30251 30252 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-tools/block-popover.js 30253 30254 30255 /** 30256 * External dependencies 30257 */ 30258 30259 30260 /** 30261 * WordPress dependencies 30262 */ 30263 30264 30265 30266 30267 30268 30269 30270 30271 /** 30272 * Internal dependencies 30273 */ 30274 30275 30276 30277 30278 30279 30280 30281 30282 function block_popover_selector(select) { 30283 const { 30284 isNavigationMode, 30285 isMultiSelecting, 30286 hasMultiSelection, 30287 isTyping, 30288 isCaretWithinFormattedText, 30289 getSettings, 30290 getLastMultiSelectedBlockClientId 30291 } = select(store); 30292 return { 30293 isNavigationMode: isNavigationMode(), 30294 isMultiSelecting: isMultiSelecting(), 30295 isTyping: isTyping(), 30296 isCaretWithinFormattedText: isCaretWithinFormattedText(), 30297 hasMultiSelection: hasMultiSelection(), 30298 hasFixedToolbar: getSettings().hasFixedToolbar, 30299 lastClientId: getLastMultiSelectedBlockClientId() 30300 }; 30301 } 30302 30303 function BlockPopover(_ref) { 30304 let { 30305 clientId, 30306 rootClientId, 30307 isValid, 30308 isEmptyDefaultBlock, 30309 capturingClientId, 30310 __unstablePopoverSlot, 30311 __unstableContentRef 30312 } = _ref; 30313 const { 30314 isNavigationMode, 30315 isMultiSelecting, 30316 isTyping, 30317 isCaretWithinFormattedText, 30318 hasMultiSelection, 30319 hasFixedToolbar, 30320 lastClientId 30321 } = (0,external_wp_data_namespaceObject.useSelect)(block_popover_selector, []); 30322 const isInsertionPointVisible = (0,external_wp_data_namespaceObject.useSelect)(select => { 30323 const { 30324 isBlockInsertionPointVisible, 30325 getBlockInsertionPoint, 30326 getBlockOrder 30327 } = select(store); 30328 30329 if (!isBlockInsertionPointVisible()) { 30330 return false; 30331 } 30332 30333 const insertionPoint = getBlockInsertionPoint(); 30334 const order = getBlockOrder(insertionPoint.rootClientId); 30335 return order[insertionPoint.index] === clientId; 30336 }, [clientId]); 30337 const isLargeViewport = (0,external_wp_compose_namespaceObject.useViewportMatch)('medium'); 30338 const [isToolbarForced, setIsToolbarForced] = (0,external_wp_element_namespaceObject.useState)(false); 30339 const [isInserterShown, setIsInserterShown] = (0,external_wp_element_namespaceObject.useState)(false); 30340 const { 30341 stopTyping 30342 } = (0,external_wp_data_namespaceObject.useDispatch)(store); // Controls when the side inserter on empty lines should 30343 // be shown, including writing and selection modes. 30344 30345 const showEmptyBlockSideInserter = !isTyping && !isNavigationMode && isEmptyDefaultBlock && isValid; 30346 const shouldShowBreadcrumb = isNavigationMode; 30347 const shouldShowContextualToolbar = !isNavigationMode && !hasFixedToolbar && isLargeViewport && !showEmptyBlockSideInserter && !isMultiSelecting && (!isTyping || isCaretWithinFormattedText); 30348 const canFocusHiddenToolbar = !isNavigationMode && !shouldShowContextualToolbar && !hasFixedToolbar && !isEmptyDefaultBlock; 30349 (0,external_wp_keyboardShortcuts_namespaceObject.useShortcut)('core/block-editor/focus-toolbar', () => { 30350 setIsToolbarForced(true); 30351 stopTyping(true); 30352 }, { 30353 isDisabled: !canFocusHiddenToolbar 30354 }); 30355 (0,external_wp_element_namespaceObject.useEffect)(() => { 30356 if (!shouldShowContextualToolbar) { 30357 setIsToolbarForced(false); 30358 } 30359 }, [shouldShowContextualToolbar]); // Stores the active toolbar item index so the block toolbar can return focus 30360 // to it when re-mounting. 30361 30362 const initialToolbarItemIndexRef = (0,external_wp_element_namespaceObject.useRef)(); 30363 const selectedElement = useBlockElement(clientId); 30364 const lastSelectedElement = useBlockElement(lastClientId); 30365 const capturingElement = useBlockElement(capturingClientId); 30366 const popoverScrollRef = usePopoverScroll(__unstableContentRef); 30367 30368 if (!shouldShowBreadcrumb && !shouldShowContextualToolbar && !isToolbarForced && !showEmptyBlockSideInserter) { 30369 return null; 30370 } 30371 30372 let node = selectedElement; 30373 30374 if (!node) { 30375 return null; 30376 } 30377 30378 if (capturingClientId) { 30379 node = capturingElement; 30380 } 30381 30382 let anchorRef = node; 30383 30384 if (hasMultiSelection) { 30385 // Wait to render the popover until the bottom reference is available 30386 // as well. 30387 if (!lastSelectedElement) { 30388 return null; 30389 } 30390 30391 anchorRef = { 30392 top: node, 30393 bottom: lastSelectedElement 30394 }; 30395 } 30396 30397 function onFocus() { 30398 setIsInserterShown(true); 30399 } 30400 30401 function onBlur() { 30402 setIsInserterShown(false); 30403 } // Position above the anchor, pop out towards the right, and position in the 30404 // left corner. For the side inserter, pop out towards the left, and 30405 // position in the right corner. 30406 // To do: refactor `Popover` to make this prop clearer. 30407 30408 30409 const popoverPosition = showEmptyBlockSideInserter ? 'top left right' : 'top right left'; 30410 const { 30411 ownerDocument 30412 } = node; 30413 const stickyBoundaryElement = showEmptyBlockSideInserter ? undefined : // The sticky boundary element should be the boundary at which the 30414 // the block toolbar becomes sticky when the block scolls out of view. 30415 // In case of an iframe, this should be the iframe boundary, otherwise 30416 // the scroll container. 30417 ownerDocument.defaultView.frameElement || (0,external_wp_dom_namespaceObject.getScrollContainer)(node) || ownerDocument.body; 30418 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Popover, { 30419 ref: popoverScrollRef, 30420 noArrow: true, 30421 animate: false, 30422 position: popoverPosition, 30423 focusOnMount: false, 30424 anchorRef: anchorRef, 30425 className: classnames_default()('block-editor-block-list__block-popover', { 30426 'is-insertion-point-visible': isInsertionPointVisible 30427 }), 30428 __unstableStickyBoundaryElement: stickyBoundaryElement // Render in the old slot if needed for backward compatibility, 30429 // otherwise render in place (not in the the default popover slot). 30430 , 30431 __unstableSlotName: __unstablePopoverSlot || null, 30432 __unstableBoundaryParent: true // Observe movement for block animations (especially horizontal). 30433 , 30434 __unstableObserveElement: node, 30435 shouldAnchorIncludePadding: true // Used to safeguard sticky position behavior against cases where it would permanently 30436 // obscure specific sections of a block. 30437 , 30438 __unstableEditorCanvasWrapper: __unstableContentRef === null || __unstableContentRef === void 0 ? void 0 : __unstableContentRef.current 30439 }, (shouldShowContextualToolbar || isToolbarForced) && (0,external_wp_element_namespaceObject.createElement)("div", { 30440 onFocus: onFocus, 30441 onBlur: onBlur // While ideally it would be enough to capture the 30442 // bubbling focus event from the Inserter, due to the 30443 // characteristics of click focusing of `button`s in 30444 // Firefox and Safari, it is not reliable. 30445 // 30446 // See: https://developer.mozilla.org/en-US/docs/Web/HTML/Element/button#Clicking_and_focus 30447 , 30448 tabIndex: -1, 30449 className: classnames_default()('block-editor-block-list__block-popover-inserter', { 30450 'is-visible': isInserterShown 30451 }) 30452 }, (0,external_wp_element_namespaceObject.createElement)(inserter, { 30453 clientId: clientId, 30454 rootClientId: rootClientId, 30455 __experimentalIsQuick: true 30456 })), (shouldShowContextualToolbar || isToolbarForced) && (0,external_wp_element_namespaceObject.createElement)(block_contextual_toolbar // If the toolbar is being shown because of being forced 30457 // it should focus the toolbar right after the mount. 30458 , { 30459 focusOnMount: isToolbarForced, 30460 __experimentalInitialIndex: initialToolbarItemIndexRef.current, 30461 __experimentalOnIndexChange: index => { 30462 initialToolbarItemIndexRef.current = index; 30463 } // Resets the index whenever the active block changes so 30464 // this is not persisted. See https://github.com/WordPress/gutenberg/pull/25760#issuecomment-717906169 30465 , 30466 key: clientId 30467 }), shouldShowBreadcrumb && (0,external_wp_element_namespaceObject.createElement)(block_selection_button, { 30468 clientId: clientId, 30469 rootClientId: rootClientId, 30470 blockElement: node 30471 }), showEmptyBlockSideInserter && (0,external_wp_element_namespaceObject.createElement)("div", { 30472 className: "block-editor-block-list__empty-block-inserter" 30473 }, (0,external_wp_element_namespaceObject.createElement)(inserter, { 30474 position: "bottom right", 30475 rootClientId: rootClientId, 30476 clientId: clientId, 30477 __experimentalIsQuick: true 30478 }))); 30479 } 30480 30481 function wrapperSelector(select) { 30482 const { 30483 getSelectedBlockClientId, 30484 getFirstMultiSelectedBlockClientId, 30485 getBlockRootClientId, 30486 getBlock, 30487 getBlockParents, 30488 __experimentalGetBlockListSettingsForBlocks 30489 } = select(store); 30490 const clientId = getSelectedBlockClientId() || getFirstMultiSelectedBlockClientId(); 30491 30492 if (!clientId) { 30493 return; 30494 } 30495 30496 const { 30497 name, 30498 attributes = {}, 30499 isValid 30500 } = getBlock(clientId) || {}; 30501 const blockParentsClientIds = getBlockParents(clientId); // Get Block List Settings for all ancestors of the current Block clientId. 30502 30503 const parentBlockListSettings = __experimentalGetBlockListSettingsForBlocks(blockParentsClientIds); // Get the clientId of the topmost parent with the capture toolbars setting. 30504 30505 30506 const capturingClientId = (0,external_lodash_namespaceObject.find)(blockParentsClientIds, parentClientId => { 30507 var _parentBlockListSetti; 30508 30509 return (_parentBlockListSetti = parentBlockListSettings[parentClientId]) === null || _parentBlockListSetti === void 0 ? void 0 : _parentBlockListSetti.__experimentalCaptureToolbars; 30510 }); 30511 return { 30512 clientId, 30513 rootClientId: getBlockRootClientId(clientId), 30514 name, 30515 isValid, 30516 isEmptyDefaultBlock: name && (0,external_wp_blocks_namespaceObject.isUnmodifiedDefaultBlock)({ 30517 name, 30518 attributes 30519 }), 30520 capturingClientId 30521 }; 30522 } 30523 30524 function WrappedBlockPopover(_ref2) { 30525 let { 30526 __unstablePopoverSlot, 30527 __unstableContentRef 30528 } = _ref2; 30529 const selected = (0,external_wp_data_namespaceObject.useSelect)(wrapperSelector, []); 30530 30531 if (!selected) { 30532 return null; 30533 } 30534 30535 const { 30536 clientId, 30537 rootClientId, 30538 name, 30539 isValid, 30540 isEmptyDefaultBlock, 30541 capturingClientId 30542 } = selected; 30543 30544 if (!name) { 30545 return null; 30546 } 30547 30548 return (0,external_wp_element_namespaceObject.createElement)(BlockPopover, { 30549 clientId: clientId, 30550 rootClientId: rootClientId, 30551 isValid: isValid, 30552 isEmptyDefaultBlock: isEmptyDefaultBlock, 30553 capturingClientId: capturingClientId, 30554 __unstablePopoverSlot: __unstablePopoverSlot, 30555 __unstableContentRef: __unstableContentRef 30556 }); 30557 } 30558 30559 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-tools/back-compat.js 30560 30561 30562 /** 30563 * WordPress dependencies 30564 */ 30565 30566 30567 30568 /** 30569 * Internal dependencies 30570 */ 30571 30572 30573 30574 function BlockToolsBackCompat(_ref) { 30575 let { 30576 children 30577 } = _ref; 30578 const openRef = (0,external_wp_element_namespaceObject.useContext)(InsertionPointOpenRef); 30579 const isDisabled = (0,external_wp_element_namespaceObject.useContext)(external_wp_components_namespaceObject.Disabled.Context); // If context is set, `BlockTools` is a parent component. 30580 30581 if (openRef || isDisabled) { 30582 return children; 30583 } 30584 30585 external_wp_deprecated_default()('wp.components.Popover.Slot name="block-toolbar"', { 30586 alternative: 'wp.blockEditor.BlockTools', 30587 since: '5.8' 30588 }); 30589 return (0,external_wp_element_namespaceObject.createElement)(InsertionPoint, { 30590 __unstablePopoverSlot: "block-toolbar" 30591 }, (0,external_wp_element_namespaceObject.createElement)(WrappedBlockPopover, { 30592 __unstablePopoverSlot: "block-toolbar" 30593 }), children); 30594 } 30595 30596 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inner-blocks/with-client-id.js 30597 30598 30599 30600 /** 30601 * WordPress dependencies 30602 */ 30603 30604 /** 30605 * Internal dependencies 30606 */ 30607 30608 30609 const withClientId = (0,external_wp_compose_namespaceObject.createHigherOrderComponent)(WrappedComponent => props => { 30610 const { 30611 clientId 30612 } = useBlockEditContext(); 30613 return (0,external_wp_element_namespaceObject.createElement)(WrappedComponent, _extends({}, props, { 30614 clientId: clientId 30615 })); 30616 }, 'withClientId'); 30617 /* harmony default export */ var with_client_id = (withClientId); 30618 30619 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inner-blocks/button-block-appender.js 30620 30621 30622 /** 30623 * External dependencies 30624 */ 30625 30626 /** 30627 * Internal dependencies 30628 */ 30629 30630 30631 30632 const button_block_appender_ButtonBlockAppender = _ref => { 30633 let { 30634 clientId, 30635 showSeparator, 30636 isFloating, 30637 onAddBlock, 30638 isToggle 30639 } = _ref; 30640 return (0,external_wp_element_namespaceObject.createElement)(button_block_appender, { 30641 className: classnames_default()({ 30642 'block-list-appender__toggle': isToggle 30643 }), 30644 rootClientId: clientId, 30645 showSeparator: showSeparator, 30646 isFloating: isFloating, 30647 onAddBlock: onAddBlock 30648 }); 30649 }; 30650 /* harmony default export */ var inner_blocks_button_block_appender = (with_client_id(button_block_appender_ButtonBlockAppender)); 30651 30652 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inner-blocks/default-block-appender.js 30653 30654 30655 /** 30656 * External dependencies 30657 */ 30658 30659 /** 30660 * WordPress dependencies 30661 */ 30662 30663 30664 30665 /** 30666 * Internal dependencies 30667 */ 30668 30669 30670 30671 30672 const default_block_appender_DefaultBlockAppender = _ref => { 30673 let { 30674 clientId 30675 } = _ref; 30676 return (0,external_wp_element_namespaceObject.createElement)(default_block_appender, { 30677 rootClientId: clientId 30678 }); 30679 }; 30680 /* harmony default export */ var inner_blocks_default_block_appender = ((0,external_wp_compose_namespaceObject.compose)([with_client_id, (0,external_wp_data_namespaceObject.withSelect)((select, _ref2) => { 30681 let { 30682 clientId 30683 } = _ref2; 30684 const { 30685 getBlockOrder 30686 } = select(store); 30687 const blockClientIds = getBlockOrder(clientId); 30688 return { 30689 lastBlockClientId: (0,external_lodash_namespaceObject.last)(blockClientIds) 30690 }; 30691 })])(default_block_appender_DefaultBlockAppender)); 30692 30693 ;// CONCATENATED MODULE: external ["wp","isShallowEqual"] 30694 var external_wp_isShallowEqual_namespaceObject = window["wp"]["isShallowEqual"]; 30695 var external_wp_isShallowEqual_default = /*#__PURE__*/__webpack_require__.n(external_wp_isShallowEqual_namespaceObject); 30696 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inner-blocks/use-nested-settings-update.js 30697 /** 30698 * WordPress dependencies 30699 */ 30700 30701 30702 30703 /** 30704 * Internal dependencies 30705 */ 30706 30707 30708 30709 /** @typedef {import('../../selectors').WPDirectInsertBlock } WPDirectInsertBlock */ 30710 30711 /** 30712 * This hook is a side effect which updates the block-editor store when changes 30713 * happen to inner block settings. The given props are transformed into a 30714 * settings object, and if that is different from the current settings object in 30715 * the block-editor store, then the store is updated with the new settings which 30716 * came from props. 30717 * 30718 * @param {string} clientId The client ID of the block to update. 30719 * @param {string[]} allowedBlocks An array of block names which are permitted 30720 * in inner blocks. 30721 * @param {?WPDirectInsertBlock} __experimentalDefaultBlock The default block to insert: [ blockName, { blockAttributes } ]. 30722 * @param {?Function|boolean} __experimentalDirectInsert If a default block should be inserted directly by the 30723 * appender. 30724 * @param {string} [templateLock] The template lock specified for the inner 30725 * blocks component. (e.g. "all") 30726 * @param {boolean} captureToolbars Whether or children toolbars should be shown 30727 * in the inner blocks component rather than on 30728 * the child block. 30729 * @param {string} orientation The direction in which the block 30730 * should face. 30731 * @param {Object} layout The layout object for the block container. 30732 */ 30733 30734 function useNestedSettingsUpdate(clientId, allowedBlocks, __experimentalDefaultBlock, __experimentalDirectInsert, templateLock, captureToolbars, orientation, layout) { 30735 const { 30736 updateBlockListSettings 30737 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 30738 const { 30739 blockListSettings, 30740 parentLock 30741 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 30742 const rootClientId = select(store).getBlockRootClientId(clientId); 30743 return { 30744 blockListSettings: select(store).getBlockListSettings(clientId), 30745 parentLock: select(store).getTemplateLock(rootClientId) 30746 }; 30747 }, [clientId]); // Memoize as inner blocks implementors often pass a new array on every 30748 // render. 30749 30750 const _allowedBlocks = (0,external_wp_element_namespaceObject.useMemo)(() => allowedBlocks, allowedBlocks); 30751 30752 (0,external_wp_element_namespaceObject.useLayoutEffect)(() => { 30753 const newSettings = { 30754 allowedBlocks: _allowedBlocks, 30755 templateLock: templateLock === undefined ? parentLock : templateLock 30756 }; // These values are not defined for RN, so only include them if they 30757 // are defined. 30758 30759 if (captureToolbars !== undefined) { 30760 newSettings.__experimentalCaptureToolbars = captureToolbars; 30761 } // Orientation depends on layout, 30762 // ideally the separate orientation prop should be deprecated. 30763 30764 30765 if (orientation !== undefined) { 30766 newSettings.orientation = orientation; 30767 } else { 30768 const layoutType = getLayoutType(layout === null || layout === void 0 ? void 0 : layout.type); 30769 newSettings.orientation = layoutType.getOrientation(layout); 30770 } 30771 30772 if (__experimentalDefaultBlock !== undefined) { 30773 newSettings.__experimentalDefaultBlock = __experimentalDefaultBlock; 30774 } 30775 30776 if (__experimentalDirectInsert !== undefined) { 30777 newSettings.__experimentalDirectInsert = __experimentalDirectInsert; 30778 } 30779 30780 if (!external_wp_isShallowEqual_default()(blockListSettings, newSettings)) { 30781 updateBlockListSettings(clientId, newSettings); 30782 } 30783 }, [clientId, blockListSettings, _allowedBlocks, __experimentalDefaultBlock, __experimentalDirectInsert, templateLock, parentLock, captureToolbars, orientation, updateBlockListSettings, layout]); 30784 } 30785 30786 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inner-blocks/use-inner-block-template-sync.js 30787 /** 30788 * External dependencies 30789 */ 30790 30791 /** 30792 * WordPress dependencies 30793 */ 30794 30795 30796 30797 30798 /** 30799 * Internal dependencies 30800 */ 30801 30802 30803 /** 30804 * This hook makes sure that a block's inner blocks stay in sync with the given 30805 * block "template". The template is a block hierarchy to which inner blocks must 30806 * conform. If the blocks get "out of sync" with the template and the template 30807 * is meant to be locked (e.g. templateLock = "all"), then we replace the inner 30808 * blocks with the correct value after synchronizing it with the template. 30809 * 30810 * @param {string} clientId The block client ID. 30811 * @param {Object} template The template to match. 30812 * @param {string} templateLock The template lock state for the inner blocks. For 30813 * example, if the template lock is set to "all", 30814 * then the inner blocks will stay in sync with the 30815 * template. If not defined or set to false, then 30816 * the inner blocks will not be synchronized with 30817 * the given template. 30818 * @param {boolean} templateInsertUpdatesSelection Whether or not to update the 30819 * block-editor selection state when inner blocks 30820 * are replaced after template synchronization. 30821 */ 30822 30823 function useInnerBlockTemplateSync(clientId, template, templateLock, templateInsertUpdatesSelection) { 30824 const { 30825 getSelectedBlocksInitialCaretPosition 30826 } = (0,external_wp_data_namespaceObject.useSelect)(store); 30827 const { 30828 replaceInnerBlocks 30829 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 30830 const innerBlocks = (0,external_wp_data_namespaceObject.useSelect)(select => select(store).getBlocks(clientId), [clientId]); // Maintain a reference to the previous value so we can do a deep equality check. 30831 30832 const existingTemplate = (0,external_wp_element_namespaceObject.useRef)(null); 30833 (0,external_wp_element_namespaceObject.useLayoutEffect)(() => { 30834 // Only synchronize innerBlocks with template if innerBlocks are empty or 30835 // a locking all exists directly on the block. 30836 if (innerBlocks.length === 0 || templateLock === 'all') { 30837 const hasTemplateChanged = !(0,external_lodash_namespaceObject.isEqual)(template, existingTemplate.current); 30838 30839 if (hasTemplateChanged) { 30840 existingTemplate.current = template; 30841 const nextBlocks = (0,external_wp_blocks_namespaceObject.synchronizeBlocksWithTemplate)(innerBlocks, template); 30842 30843 if (!(0,external_lodash_namespaceObject.isEqual)(nextBlocks, innerBlocks)) { 30844 replaceInnerBlocks(clientId, nextBlocks, innerBlocks.length === 0 && templateInsertUpdatesSelection && nextBlocks.length !== 0, // This ensures the "initialPosition" doesn't change when applying the template 30845 // If we're supposed to focus the block, we'll focus the first inner block 30846 // otherwise, we won't apply any auto-focus. 30847 // This ensures for instance that the focus stays in the inserter when inserting the "buttons" block. 30848 getSelectedBlocksInitialCaretPosition()); 30849 } 30850 } 30851 } 30852 }, [innerBlocks, template, templateLock, clientId]); 30853 } 30854 30855 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inner-blocks/get-block-context.js 30856 /** 30857 * External dependencies 30858 */ 30859 30860 /** 30861 * Block context cache, implemented as a WeakMap mapping block types to a 30862 * WeakMap mapping attributes object to context value. 30863 * 30864 * @type {WeakMap<string,WeakMap<string,*>>} 30865 */ 30866 30867 const BLOCK_CONTEXT_CACHE = new WeakMap(); 30868 /** 30869 * Returns a cached context object value for a given set of attributes for the 30870 * block type. 30871 * 30872 * @param {Record<string,*>} attributes Block attributes object. 30873 * @param {WPBlockType} blockType Block type settings. 30874 * 30875 * @return {Record<string,*>} Context value. 30876 */ 30877 30878 function getBlockContext(attributes, blockType) { 30879 if (!BLOCK_CONTEXT_CACHE.has(blockType)) { 30880 BLOCK_CONTEXT_CACHE.set(blockType, new WeakMap()); 30881 } 30882 30883 const blockTypeCache = BLOCK_CONTEXT_CACHE.get(blockType); 30884 30885 if (!blockTypeCache.has(attributes)) { 30886 const context = (0,external_lodash_namespaceObject.mapValues)(blockType.providesContext, attributeName => attributes[attributeName]); 30887 blockTypeCache.set(attributes, context); 30888 } 30889 30890 return blockTypeCache.get(attributes); 30891 } 30892 30893 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/use-on-block-drop/index.js 30894 /** 30895 * WordPress dependencies 30896 */ 30897 30898 30899 30900 /** 30901 * Internal dependencies 30902 */ 30903 30904 30905 /** @typedef {import('@wordpress/element').WPSyntheticEvent} WPSyntheticEvent */ 30906 30907 /** 30908 * Retrieve the data for a block drop event. 30909 * 30910 * @param {WPSyntheticEvent} event The drop event. 30911 * 30912 * @return {Object} An object with block drag and drop data. 30913 */ 30914 30915 function parseDropEvent(event) { 30916 let result = { 30917 srcRootClientId: null, 30918 srcClientIds: null, 30919 srcIndex: null, 30920 type: null, 30921 blocks: null 30922 }; 30923 30924 if (!event.dataTransfer) { 30925 return result; 30926 } 30927 30928 try { 30929 result = Object.assign(result, JSON.parse(event.dataTransfer.getData('wp-blocks'))); 30930 } catch (err) { 30931 return result; 30932 } 30933 30934 return result; 30935 } 30936 /** 30937 * A function that returns an event handler function for block drop events. 30938 * 30939 * @param {string} targetRootClientId The root client id where the block(s) will be inserted. 30940 * @param {number} targetBlockIndex The index where the block(s) will be inserted. 30941 * @param {Function} getBlockIndex A function that gets the index of a block. 30942 * @param {Function} getClientIdsOfDescendants A function that gets the client ids of descendant blocks. 30943 * @param {Function} moveBlocksToPosition A function that moves blocks. 30944 * @param {Function} insertBlocks A function that inserts blocks. 30945 * @param {Function} clearSelectedBlock A function that clears block selection. 30946 * @return {Function} The event handler for a block drop event. 30947 */ 30948 30949 function onBlockDrop(targetRootClientId, targetBlockIndex, getBlockIndex, getClientIdsOfDescendants, moveBlocksToPosition, insertBlocks, clearSelectedBlock) { 30950 return event => { 30951 const { 30952 srcRootClientId: sourceRootClientId, 30953 srcClientIds: sourceClientIds, 30954 type: dropType, 30955 blocks 30956 } = parseDropEvent(event); // If the user is inserting a block. 30957 30958 if (dropType === 'inserter') { 30959 clearSelectedBlock(); 30960 const blocksToInsert = blocks.map(block => (0,external_wp_blocks_namespaceObject.cloneBlock)(block)); 30961 insertBlocks(blocksToInsert, targetBlockIndex, targetRootClientId, true, null); 30962 } // If the user is moving a block. 30963 30964 30965 if (dropType === 'block') { 30966 const sourceBlockIndex = getBlockIndex(sourceClientIds[0]); // If the user is dropping to the same position, return early. 30967 30968 if (sourceRootClientId === targetRootClientId && sourceBlockIndex === targetBlockIndex) { 30969 return; 30970 } // If the user is attempting to drop a block within its own 30971 // nested blocks, return early as this would create infinite 30972 // recursion. 30973 30974 30975 if (sourceClientIds.includes(targetRootClientId) || getClientIdsOfDescendants(sourceClientIds).some(id => id === targetRootClientId)) { 30976 return; 30977 } 30978 30979 const isAtSameLevel = sourceRootClientId === targetRootClientId; 30980 const draggedBlockCount = sourceClientIds.length; // If the block is kept at the same level and moved downwards, 30981 // subtract to take into account that the blocks being dragged 30982 // were removed from the block list above the insertion point. 30983 30984 const insertIndex = isAtSameLevel && sourceBlockIndex < targetBlockIndex ? targetBlockIndex - draggedBlockCount : targetBlockIndex; 30985 moveBlocksToPosition(sourceClientIds, sourceRootClientId, targetRootClientId, insertIndex); 30986 } 30987 }; 30988 } 30989 /** 30990 * A function that returns an event handler function for block-related file drop events. 30991 * 30992 * @param {string} targetRootClientId The root client id where the block(s) will be inserted. 30993 * @param {number} targetBlockIndex The index where the block(s) will be inserted. 30994 * @param {boolean} hasUploadPermissions Whether the user has upload permissions. 30995 * @param {Function} updateBlockAttributes A function that updates a block's attributes. 30996 * @param {Function} canInsertBlockType A function that returns checks whether a block type can be inserted. 30997 * @param {Function} insertBlocks A function that inserts blocks. 30998 * 30999 * @return {Function} The event handler for a block-related file drop event. 31000 */ 31001 31002 function onFilesDrop(targetRootClientId, targetBlockIndex, hasUploadPermissions, updateBlockAttributes, canInsertBlockType, insertBlocks) { 31003 return files => { 31004 if (!hasUploadPermissions) { 31005 return; 31006 } 31007 31008 const transformation = (0,external_wp_blocks_namespaceObject.findTransform)((0,external_wp_blocks_namespaceObject.getBlockTransforms)('from'), transform => transform.type === 'files' && canInsertBlockType(transform.blockName, targetRootClientId) && transform.isMatch(files)); 31009 31010 if (transformation) { 31011 const blocks = transformation.transform(files, updateBlockAttributes); 31012 insertBlocks(blocks, targetBlockIndex, targetRootClientId); 31013 } 31014 }; 31015 } 31016 /** 31017 * A function that returns an event handler function for block-related HTML drop events. 31018 * 31019 * @param {string} targetRootClientId The root client id where the block(s) will be inserted. 31020 * @param {number} targetBlockIndex The index where the block(s) will be inserted. 31021 * @param {Function} insertBlocks A function that inserts blocks. 31022 * 31023 * @return {Function} The event handler for a block-related HTML drop event. 31024 */ 31025 31026 function onHTMLDrop(targetRootClientId, targetBlockIndex, insertBlocks) { 31027 return HTML => { 31028 const blocks = (0,external_wp_blocks_namespaceObject.pasteHandler)({ 31029 HTML, 31030 mode: 'BLOCKS' 31031 }); 31032 31033 if (blocks.length) { 31034 insertBlocks(blocks, targetBlockIndex, targetRootClientId); 31035 } 31036 }; 31037 } 31038 /** 31039 * A React hook for handling block drop events. 31040 * 31041 * @param {string} targetRootClientId The root client id where the block(s) will be inserted. 31042 * @param {number} targetBlockIndex The index where the block(s) will be inserted. 31043 * 31044 * @return {Object} An object that contains the event handlers `onDrop`, `onFilesDrop` and `onHTMLDrop`. 31045 */ 31046 31047 function useOnBlockDrop(targetRootClientId, targetBlockIndex) { 31048 const hasUploadPermissions = (0,external_wp_data_namespaceObject.useSelect)(select => select(store).getSettings().mediaUpload, []); 31049 const { 31050 canInsertBlockType, 31051 getBlockIndex, 31052 getClientIdsOfDescendants 31053 } = (0,external_wp_data_namespaceObject.useSelect)(store); 31054 const { 31055 insertBlocks, 31056 moveBlocksToPosition, 31057 updateBlockAttributes, 31058 clearSelectedBlock 31059 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 31060 31061 const _onDrop = onBlockDrop(targetRootClientId, targetBlockIndex, getBlockIndex, getClientIdsOfDescendants, moveBlocksToPosition, insertBlocks, clearSelectedBlock); 31062 31063 const _onFilesDrop = onFilesDrop(targetRootClientId, targetBlockIndex, hasUploadPermissions, updateBlockAttributes, canInsertBlockType, insertBlocks); 31064 31065 const _onHTMLDrop = onHTMLDrop(targetRootClientId, targetBlockIndex, insertBlocks); 31066 31067 return event => { 31068 const files = (0,external_wp_dom_namespaceObject.getFilesFromDataTransfer)(event.dataTransfer); 31069 const html = event.dataTransfer.getData('text/html'); 31070 /** 31071 * From Windows Chrome 96, the `event.dataTransfer` returns both file object and HTML. 31072 * The order of the checks is important to recognise the HTML drop. 31073 */ 31074 31075 if (html) { 31076 _onHTMLDrop(html); 31077 } else if (files.length) { 31078 _onFilesDrop(files); 31079 } else { 31080 _onDrop(event); 31081 } 31082 }; 31083 } 31084 31085 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/utils/math.js 31086 /** 31087 * A string representing the name of an edge. 31088 * 31089 * @typedef {'top'|'right'|'bottom'|'left'} WPEdgeName 31090 */ 31091 31092 /** 31093 * @typedef {Object} WPPoint 31094 * @property {number} x The horizontal position. 31095 * @property {number} y The vertical position. 31096 */ 31097 31098 /** 31099 * Given a point, a DOMRect and the name of an edge, returns the distance to 31100 * that edge of the rect. 31101 * 31102 * This function works for edges that are horizontal or vertical (e.g. not 31103 * rotated), the following terms are used so that the function works in both 31104 * orientations: 31105 * 31106 * - Forward, meaning the axis running horizontally when an edge is vertical 31107 * and vertically when an edge is horizontal. 31108 * - Lateral, meaning the axis running vertically when an edge is vertical 31109 * and horizontally when an edge is horizontal. 31110 * 31111 * @param {WPPoint} point The point to measure distance from. 31112 * @param {DOMRect} rect A DOM Rect containing edge positions. 31113 * @param {WPEdgeName} edge The edge to measure to. 31114 */ 31115 function getDistanceFromPointToEdge(point, rect, edge) { 31116 const isHorizontal = edge === 'top' || edge === 'bottom'; 31117 const { 31118 x, 31119 y 31120 } = point; 31121 const pointLateralPosition = isHorizontal ? x : y; 31122 const pointForwardPosition = isHorizontal ? y : x; 31123 const edgeStart = isHorizontal ? rect.left : rect.top; 31124 const edgeEnd = isHorizontal ? rect.right : rect.bottom; 31125 const edgeForwardPosition = rect[edge]; // Measure the straight line distance to the edge of the rect, when the 31126 // point is adjacent to the edge. 31127 // Else, if the point is positioned diagonally to the edge of the rect, 31128 // measure diagonally to the nearest corner that the edge meets. 31129 31130 let edgeLateralPosition; 31131 31132 if (pointLateralPosition >= edgeStart && pointLateralPosition <= edgeEnd) { 31133 edgeLateralPosition = pointLateralPosition; 31134 } else if (pointLateralPosition < edgeEnd) { 31135 edgeLateralPosition = edgeStart; 31136 } else { 31137 edgeLateralPosition = edgeEnd; 31138 } 31139 31140 return Math.sqrt((pointLateralPosition - edgeLateralPosition) ** 2 + (pointForwardPosition - edgeForwardPosition) ** 2); 31141 } 31142 /** 31143 * Given a point, a DOMRect and a list of allowed edges returns the name of and 31144 * distance to the nearest edge. 31145 * 31146 * @param {WPPoint} point The point to measure distance from. 31147 * @param {DOMRect} rect A DOM Rect containing edge positions. 31148 * @param {WPEdgeName[]} allowedEdges A list of the edges included in the 31149 * calculation. Defaults to all edges. 31150 * 31151 * @return {[number, string]} An array where the first value is the distance 31152 * and a second is the edge name. 31153 */ 31154 31155 function getDistanceToNearestEdge(point, rect) { 31156 let allowedEdges = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : ['top', 'bottom', 'left', 'right']; 31157 let candidateDistance; 31158 let candidateEdge; 31159 allowedEdges.forEach(edge => { 31160 const distance = getDistanceFromPointToEdge(point, rect, edge); 31161 31162 if (candidateDistance === undefined || distance < candidateDistance) { 31163 candidateDistance = distance; 31164 candidateEdge = edge; 31165 } 31166 }); 31167 return [candidateDistance, candidateEdge]; 31168 } 31169 31170 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/use-block-drop-zone/index.js 31171 /** 31172 * WordPress dependencies 31173 */ 31174 31175 31176 31177 31178 /** 31179 * Internal dependencies 31180 */ 31181 31182 31183 31184 31185 /** @typedef {import('../../utils/math').WPPoint} WPPoint */ 31186 31187 /** 31188 * The orientation of a block list. 31189 * 31190 * @typedef {'horizontal'|'vertical'|undefined} WPBlockListOrientation 31191 */ 31192 31193 /** 31194 * Given a list of block DOM elements finds the index that a block should be dropped 31195 * at. 31196 * 31197 * @param {Element[]} elements Array of DOM elements that represent each block in a block list. 31198 * @param {WPPoint} position The position of the item being dragged. 31199 * @param {WPBlockListOrientation} orientation The orientation of a block list. 31200 * 31201 * @return {number|undefined} The block index that's closest to the drag position. 31202 */ 31203 31204 function getNearestBlockIndex(elements, position, orientation) { 31205 const allowedEdges = orientation === 'horizontal' ? ['left', 'right'] : ['top', 'bottom']; 31206 const isRightToLeft = (0,external_wp_i18n_namespaceObject.isRTL)(); 31207 let candidateIndex; 31208 let candidateDistance; 31209 elements.forEach((element, index) => { 31210 const rect = element.getBoundingClientRect(); 31211 const [distance, edge] = getDistanceToNearestEdge(position, rect, allowedEdges); 31212 31213 if (candidateDistance === undefined || distance < candidateDistance) { 31214 // If the user is dropping to the trailing edge of the block 31215 // add 1 to the index to represent dragging after. 31216 // Take RTL languages into account where the left edge is 31217 // the trailing edge. 31218 const isTrailingEdge = edge === 'bottom' || !isRightToLeft && edge === 'right' || isRightToLeft && edge === 'left'; 31219 const offset = isTrailingEdge ? 1 : 0; // Update the currently known best candidate. 31220 31221 candidateDistance = distance; 31222 candidateIndex = index + offset; 31223 } 31224 }); 31225 return candidateIndex; 31226 } 31227 /** 31228 * @typedef {Object} WPBlockDropZoneConfig 31229 * @property {string} rootClientId The root client id for the block list. 31230 */ 31231 31232 /** 31233 * A React hook that can be used to make a block list handle drag and drop. 31234 * 31235 * @param {WPBlockDropZoneConfig} dropZoneConfig configuration data for the drop zone. 31236 */ 31237 31238 function useBlockDropZone() { 31239 let { 31240 // An undefined value represents a top-level block. Default to an empty 31241 // string for this so that `targetRootClientId` can be easily compared to 31242 // values returned by the `getRootBlockClientId` selector, which also uses 31243 // an empty string to represent top-level blocks. 31244 rootClientId: targetRootClientId = '' 31245 } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; 31246 const [targetBlockIndex, setTargetBlockIndex] = (0,external_wp_element_namespaceObject.useState)(null); 31247 const isLockedAll = (0,external_wp_data_namespaceObject.useSelect)(select => { 31248 const { 31249 getTemplateLock 31250 } = select(store); 31251 return getTemplateLock(targetRootClientId) === 'all'; 31252 }, [targetRootClientId]); 31253 const { 31254 getBlockListSettings 31255 } = (0,external_wp_data_namespaceObject.useSelect)(store); 31256 const { 31257 showInsertionPoint, 31258 hideInsertionPoint 31259 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 31260 const onBlockDrop = useOnBlockDrop(targetRootClientId, targetBlockIndex); 31261 const throttled = (0,external_wp_compose_namespaceObject.useThrottle)((0,external_wp_element_namespaceObject.useCallback)((event, currentTarget) => { 31262 var _getBlockListSettings; 31263 31264 const blockElements = Array.from(currentTarget.children).filter( // Ensure the element is a block. It should have the `wp-block` class. 31265 element => element.classList.contains('wp-block')); 31266 const targetIndex = getNearestBlockIndex(blockElements, { 31267 x: event.clientX, 31268 y: event.clientY 31269 }, (_getBlockListSettings = getBlockListSettings(targetRootClientId)) === null || _getBlockListSettings === void 0 ? void 0 : _getBlockListSettings.orientation); 31270 setTargetBlockIndex(targetIndex === undefined ? 0 : targetIndex); 31271 31272 if (targetIndex !== null) { 31273 showInsertionPoint(targetRootClientId, targetIndex); 31274 } 31275 }, []), 200); 31276 return (0,external_wp_compose_namespaceObject.__experimentalUseDropZone)({ 31277 isDisabled: isLockedAll, 31278 onDrop: onBlockDrop, 31279 31280 onDragOver(event) { 31281 // `currentTarget` is only available while the event is being 31282 // handled, so get it now and pass it to the thottled function. 31283 // https://developer.mozilla.org/en-US/docs/Web/API/Event/currentTarget 31284 throttled(event, event.currentTarget); 31285 }, 31286 31287 onDragLeave() { 31288 throttled.cancel(); 31289 hideInsertionPoint(); 31290 setTargetBlockIndex(null); 31291 }, 31292 31293 onDragEnd() { 31294 throttled.cancel(); 31295 hideInsertionPoint(); 31296 setTargetBlockIndex(null); 31297 } 31298 31299 }); 31300 } 31301 31302 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inner-blocks/index.js 31303 31304 31305 31306 /** 31307 * External dependencies 31308 */ 31309 31310 /** 31311 * WordPress dependencies 31312 */ 31313 31314 31315 31316 31317 31318 /** 31319 * Internal dependencies 31320 */ 31321 31322 31323 31324 31325 31326 31327 31328 31329 31330 31331 31332 31333 /** 31334 * InnerBlocks is a component which allows a single block to have multiple blocks 31335 * as children. The UncontrolledInnerBlocks component is used whenever the inner 31336 * blocks are not controlled by another entity. In other words, it is normally 31337 * used for inner blocks in the post editor 31338 * 31339 * @param {Object} props The component props. 31340 */ 31341 31342 function UncontrolledInnerBlocks(props) { 31343 const { 31344 clientId, 31345 allowedBlocks, 31346 __experimentalDefaultBlock, 31347 __experimentalDirectInsert, 31348 template, 31349 templateLock, 31350 wrapperRef, 31351 templateInsertUpdatesSelection, 31352 __experimentalCaptureToolbars: captureToolbars, 31353 __experimentalAppenderTagName, 31354 renderAppender, 31355 orientation, 31356 placeholder, 31357 __experimentalLayout 31358 } = props; 31359 useNestedSettingsUpdate(clientId, allowedBlocks, __experimentalDefaultBlock, __experimentalDirectInsert, templateLock, captureToolbars, orientation, __experimentalLayout); 31360 useInnerBlockTemplateSync(clientId, template, templateLock, templateInsertUpdatesSelection); 31361 const context = (0,external_wp_data_namespaceObject.useSelect)(select => { 31362 const block = select(store).getBlock(clientId); 31363 const blockType = (0,external_wp_blocks_namespaceObject.getBlockType)(block.name); 31364 31365 if (!blockType || !blockType.providesContext) { 31366 return; 31367 } 31368 31369 return getBlockContext(block.attributes, blockType); 31370 }, [clientId]); // This component needs to always be synchronous as it's the one changing 31371 // the async mode depending on the block selection. 31372 31373 return (0,external_wp_element_namespaceObject.createElement)(BlockContextProvider, { 31374 value: context 31375 }, (0,external_wp_element_namespaceObject.createElement)(BlockListItems, { 31376 rootClientId: clientId, 31377 renderAppender: renderAppender, 31378 __experimentalAppenderTagName: __experimentalAppenderTagName, 31379 __experimentalLayout: __experimentalLayout, 31380 wrapperRef: wrapperRef, 31381 placeholder: placeholder 31382 })); 31383 } 31384 /** 31385 * The controlled inner blocks component wraps the uncontrolled inner blocks 31386 * component with the blockSync hook. This keeps the innerBlocks of the block in 31387 * the block-editor store in sync with the blocks of the controlling entity. An 31388 * example of an inner block controller is a template part block, which provides 31389 * its own blocks from the template part entity data source. 31390 * 31391 * @param {Object} props The component props. 31392 */ 31393 31394 31395 function ControlledInnerBlocks(props) { 31396 useBlockSync(props); 31397 return (0,external_wp_element_namespaceObject.createElement)(UncontrolledInnerBlocks, props); 31398 } 31399 31400 const ForwardedInnerBlocks = (0,external_wp_element_namespaceObject.forwardRef)((props, ref) => { 31401 const innerBlocksProps = useInnerBlocksProps({ 31402 ref 31403 }, props); 31404 return (0,external_wp_element_namespaceObject.createElement)("div", { 31405 className: "block-editor-inner-blocks" 31406 }, (0,external_wp_element_namespaceObject.createElement)("div", innerBlocksProps)); 31407 }); 31408 /** 31409 * This hook is used to lightly mark an element as an inner blocks wrapper 31410 * element. Call this hook and pass the returned props to the element to mark as 31411 * an inner blocks wrapper, automatically rendering inner blocks as children. If 31412 * you define a ref for the element, it is important to pass the ref to this 31413 * hook, which the hook in turn will pass to the component through the props it 31414 * returns. Optionally, you can also pass any other props through this hook, and 31415 * they will be merged and returned. 31416 * 31417 * @param {Object} props Optional. Props to pass to the element. Must contain 31418 * the ref if one is defined. 31419 * @param {Object} options Optional. Inner blocks options. 31420 * 31421 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/inner-blocks/README.md 31422 */ 31423 31424 function useInnerBlocksProps() { 31425 let props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; 31426 let options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; 31427 const { 31428 clientId 31429 } = useBlockEditContext(); 31430 const isSmallScreen = (0,external_wp_compose_namespaceObject.useViewportMatch)('medium', '<'); 31431 const { 31432 __experimentalCaptureToolbars, 31433 hasOverlay 31434 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 31435 if (!clientId) { 31436 return {}; 31437 } 31438 31439 const { 31440 getBlockName, 31441 isBlockSelected, 31442 hasSelectedInnerBlock, 31443 isNavigationMode 31444 } = select(store); 31445 const blockName = getBlockName(clientId); 31446 const enableClickThrough = isNavigationMode() || isSmallScreen; 31447 return { 31448 __experimentalCaptureToolbars: select(external_wp_blocks_namespaceObject.store).hasBlockSupport(blockName, '__experimentalExposeControlsToChildren', false), 31449 hasOverlay: blockName !== 'core/template' && !isBlockSelected(clientId) && !hasSelectedInnerBlock(clientId, true) && enableClickThrough 31450 }; 31451 }, [clientId, isSmallScreen]); 31452 const ref = (0,external_wp_compose_namespaceObject.useMergeRefs)([props.ref, useBlockDropZone({ 31453 rootClientId: clientId 31454 })]); 31455 const innerBlocksProps = { 31456 __experimentalCaptureToolbars, 31457 ...options 31458 }; 31459 const InnerBlocks = innerBlocksProps.value && innerBlocksProps.onChange ? ControlledInnerBlocks : UncontrolledInnerBlocks; 31460 return { ...props, 31461 ref, 31462 className: classnames_default()(props.className, 'block-editor-block-list__layout', { 31463 'has-overlay': hasOverlay 31464 }), 31465 children: clientId ? (0,external_wp_element_namespaceObject.createElement)(InnerBlocks, _extends({}, innerBlocksProps, { 31466 clientId: clientId 31467 })) : (0,external_wp_element_namespaceObject.createElement)(BlockListItems, options) 31468 }; 31469 } 31470 useInnerBlocksProps.save = external_wp_blocks_namespaceObject.__unstableGetInnerBlocksProps; // Expose default appender placeholders as components. 31471 31472 ForwardedInnerBlocks.DefaultBlockAppender = inner_blocks_default_block_appender; 31473 ForwardedInnerBlocks.ButtonBlockAppender = inner_blocks_button_block_appender; 31474 31475 ForwardedInnerBlocks.Content = () => useInnerBlocksProps.save().children; 31476 /** 31477 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/inner-blocks/README.md 31478 */ 31479 31480 31481 /* harmony default export */ var inner_blocks = (ForwardedInnerBlocks); 31482 31483 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-list/index.js 31484 31485 31486 /** 31487 * External dependencies 31488 */ 31489 31490 /** 31491 * WordPress dependencies 31492 */ 31493 31494 31495 31496 31497 /** 31498 * Internal dependencies 31499 */ 31500 31501 31502 31503 31504 31505 31506 31507 31508 31509 31510 31511 const elementContext = (0,external_wp_element_namespaceObject.createContext)(); 31512 const IntersectionObserver = (0,external_wp_element_namespaceObject.createContext)(); 31513 31514 function Root(_ref) { 31515 let { 31516 className, 31517 ...settings 31518 } = _ref; 31519 const [element, setElement] = (0,external_wp_element_namespaceObject.useState)(); 31520 const isLargeViewport = (0,external_wp_compose_namespaceObject.useViewportMatch)('medium'); 31521 const { 31522 isOutlineMode, 31523 isFocusMode, 31524 isNavigationMode 31525 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 31526 const { 31527 getSettings, 31528 isNavigationMode: _isNavigationMode 31529 } = select(store); 31530 const { 31531 outlineMode, 31532 focusMode 31533 } = getSettings(); 31534 return { 31535 isOutlineMode: outlineMode, 31536 isFocusMode: focusMode, 31537 isNavigationMode: _isNavigationMode() 31538 }; 31539 }, []); 31540 const innerBlocksProps = useInnerBlocksProps({ 31541 ref: (0,external_wp_compose_namespaceObject.useMergeRefs)([useBlockSelectionClearer(), useInBetweenInserter(), setElement]), 31542 className: classnames_default()('is-root-container', className, { 31543 'is-outline-mode': isOutlineMode, 31544 'is-focus-mode': isFocusMode && isLargeViewport, 31545 'is-navigate-mode': isNavigationMode 31546 }) 31547 }, settings); 31548 return (0,external_wp_element_namespaceObject.createElement)(elementContext.Provider, { 31549 value: element 31550 }, (0,external_wp_element_namespaceObject.createElement)("div", innerBlocksProps)); 31551 } 31552 31553 function BlockList(settings) { 31554 usePreParsePatterns(); 31555 return (0,external_wp_element_namespaceObject.createElement)(BlockToolsBackCompat, null, (0,external_wp_element_namespaceObject.createElement)(Provider, { 31556 value: DEFAULT_BLOCK_EDIT_CONTEXT 31557 }, (0,external_wp_element_namespaceObject.createElement)(Root, settings))); 31558 } 31559 BlockList.__unstableElementContext = elementContext; 31560 31561 function Items(_ref2) { 31562 let { 31563 placeholder, 31564 rootClientId, 31565 renderAppender, 31566 __experimentalAppenderTagName, 31567 __experimentalLayout: layout = defaultLayout 31568 } = _ref2; 31569 const [intersectingBlocks, setIntersectingBlocks] = (0,external_wp_element_namespaceObject.useState)(new Set()); 31570 const intersectionObserver = (0,external_wp_element_namespaceObject.useMemo)(() => { 31571 const { 31572 IntersectionObserver: Observer 31573 } = window; 31574 31575 if (!Observer) { 31576 return; 31577 } 31578 31579 return new Observer(entries => { 31580 setIntersectingBlocks(oldIntersectingBlocks => { 31581 const newIntersectingBlocks = new Set(oldIntersectingBlocks); 31582 31583 for (const entry of entries) { 31584 const clientId = entry.target.getAttribute('data-block'); 31585 const action = entry.isIntersecting ? 'add' : 'delete'; 31586 newIntersectingBlocks[action](clientId); 31587 } 31588 31589 return newIntersectingBlocks; 31590 }); 31591 }); 31592 }, [setIntersectingBlocks]); 31593 const { 31594 order, 31595 selectedBlocks 31596 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 31597 const { 31598 getBlockOrder, 31599 getSelectedBlockClientIds 31600 } = select(store); 31601 return { 31602 order: getBlockOrder(rootClientId), 31603 selectedBlocks: getSelectedBlockClientIds() 31604 }; 31605 }, [rootClientId]); 31606 return (0,external_wp_element_namespaceObject.createElement)(LayoutProvider, { 31607 value: layout 31608 }, (0,external_wp_element_namespaceObject.createElement)(IntersectionObserver.Provider, { 31609 value: intersectionObserver 31610 }, order.map(clientId => (0,external_wp_element_namespaceObject.createElement)(external_wp_data_namespaceObject.AsyncModeProvider, { 31611 key: clientId, 31612 value: // Only provide data asynchronously if the block is 31613 // not visible and not selected. 31614 !intersectingBlocks.has(clientId) && !selectedBlocks.includes(clientId) 31615 }, (0,external_wp_element_namespaceObject.createElement)(block, { 31616 rootClientId: rootClientId, 31617 clientId: clientId 31618 })))), order.length < 1 && placeholder, (0,external_wp_element_namespaceObject.createElement)(block_list_appender, { 31619 tagName: __experimentalAppenderTagName, 31620 rootClientId: rootClientId, 31621 renderAppender: renderAppender 31622 })); 31623 } 31624 31625 function BlockListItems(props) { 31626 // This component needs to always be synchronous as it's the one changing 31627 // the async mode depending on the block selection. 31628 return (0,external_wp_element_namespaceObject.createElement)(external_wp_data_namespaceObject.AsyncModeProvider, { 31629 value: false 31630 }, (0,external_wp_element_namespaceObject.createElement)(Items, props)); 31631 } 31632 31633 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/colors-gradients/control.js 31634 31635 31636 31637 /** 31638 * External dependencies 31639 */ 31640 31641 31642 /** 31643 * WordPress dependencies 31644 */ 31645 31646 31647 31648 31649 /** 31650 * Internal dependencies 31651 */ 31652 31653 31654 const colorsAndGradientKeys = ['colors', 'disableCustomColors', 'gradients', 'disableCustomGradients']; 31655 31656 function ColorGradientControlInner(_ref) { 31657 let { 31658 colors, 31659 gradients, 31660 disableCustomColors, 31661 disableCustomGradients, 31662 __experimentalHasMultipleOrigins, 31663 __experimentalIsRenderedInSidebar, 31664 className, 31665 label, 31666 onColorChange, 31667 onGradientChange, 31668 colorValue, 31669 gradientValue, 31670 clearable, 31671 showTitle = true, 31672 enableAlpha 31673 } = _ref; 31674 const canChooseAColor = onColorChange && (!(0,external_lodash_namespaceObject.isEmpty)(colors) || !disableCustomColors); 31675 const canChooseAGradient = onGradientChange && (!(0,external_lodash_namespaceObject.isEmpty)(gradients) || !disableCustomGradients); 31676 const [currentTab, setCurrentTab] = (0,external_wp_element_namespaceObject.useState)(gradientValue ? 'gradient' : !!canChooseAColor && 'color'); 31677 31678 if (!canChooseAColor && !canChooseAGradient) { 31679 return null; 31680 } 31681 31682 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.BaseControl, { 31683 className: classnames_default()('block-editor-color-gradient-control', className) 31684 }, (0,external_wp_element_namespaceObject.createElement)("fieldset", { 31685 className: "block-editor-color-gradient-control__fieldset" 31686 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalVStack, { 31687 spacing: 1 31688 }, showTitle && (0,external_wp_element_namespaceObject.createElement)("legend", null, (0,external_wp_element_namespaceObject.createElement)("div", { 31689 className: "block-editor-color-gradient-control__color-indicator" 31690 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.BaseControl.VisualLabel, null, label))), canChooseAColor && canChooseAGradient && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToggleGroupControl, { 31691 value: currentTab, 31692 onChange: setCurrentTab, 31693 label: (0,external_wp_i18n_namespaceObject.__)('Select color type'), 31694 hideLabelFromVision: true, 31695 isBlock: true 31696 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToggleGroupControlOption, { 31697 value: "color", 31698 label: (0,external_wp_i18n_namespaceObject.__)('Solid') 31699 }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToggleGroupControlOption, { 31700 value: "gradient", 31701 label: (0,external_wp_i18n_namespaceObject.__)('Gradient') 31702 })), (currentTab === 'color' || !canChooseAGradient) && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ColorPalette, { 31703 value: colorValue, 31704 onChange: canChooseAGradient ? newColor => { 31705 onColorChange(newColor); 31706 onGradientChange(); 31707 } : onColorChange, 31708 colors, 31709 disableCustomColors, 31710 __experimentalHasMultipleOrigins: __experimentalHasMultipleOrigins, 31711 __experimentalIsRenderedInSidebar: __experimentalIsRenderedInSidebar, 31712 clearable: clearable, 31713 enableAlpha: enableAlpha 31714 }), (currentTab === 'gradient' || !canChooseAColor) && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.GradientPicker, { 31715 value: gradientValue, 31716 onChange: canChooseAColor ? newGradient => { 31717 onGradientChange(newGradient); 31718 onColorChange(); 31719 } : onGradientChange, 31720 gradients, 31721 disableCustomGradients, 31722 __experimentalHasMultipleOrigins: __experimentalHasMultipleOrigins, 31723 __experimentalIsRenderedInSidebar: __experimentalIsRenderedInSidebar, 31724 clearable: clearable 31725 })))); 31726 } 31727 31728 function ColorGradientControlSelect(props) { 31729 const colorGradientSettings = {}; 31730 colorGradientSettings.colors = useSetting('color.palette'); 31731 colorGradientSettings.gradients = useSetting('color.gradients'); 31732 colorGradientSettings.disableCustomColors = !useSetting('color.custom'); 31733 colorGradientSettings.disableCustomGradients = !useSetting('color.customGradient'); 31734 return (0,external_wp_element_namespaceObject.createElement)(ColorGradientControlInner, _extends({}, colorGradientSettings, props)); 31735 } 31736 31737 function ColorGradientControl(props) { 31738 if ((0,external_lodash_namespaceObject.every)(colorsAndGradientKeys, key => props.hasOwnProperty(key))) { 31739 return (0,external_wp_element_namespaceObject.createElement)(ColorGradientControlInner, props); 31740 } 31741 31742 return (0,external_wp_element_namespaceObject.createElement)(ColorGradientControlSelect, props); 31743 } 31744 31745 /* harmony default export */ var control = (ColorGradientControl); 31746 31747 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/colors-gradients/dropdown.js 31748 31749 31750 31751 /** 31752 * External dependencies 31753 */ 31754 31755 /** 31756 * WordPress dependencies 31757 */ 31758 31759 31760 /** 31761 * Internal dependencies 31762 */ 31763 31764 31765 function ColorGradientSettingsDropdown(_ref) { 31766 let { 31767 colors, 31768 gradients, 31769 disableCustomColors, 31770 disableCustomGradients, 31771 __experimentalHasMultipleOrigins, 31772 __experimentalIsRenderedInSidebar, 31773 enableAlpha, 31774 settings 31775 } = _ref; 31776 let dropdownPosition; 31777 31778 if (__experimentalIsRenderedInSidebar) { 31779 dropdownPosition = 'bottom left'; 31780 } 31781 31782 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalItemGroup, { 31783 isBordered: true, 31784 isSeparated: true, 31785 className: "block-editor-panel-color-gradient-settings__item-group" 31786 }, settings.map((setting, index) => setting && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Dropdown, { 31787 key: index, 31788 position: dropdownPosition, 31789 className: "block-editor-panel-color-gradient-settings__dropdown", 31790 contentClassName: "block-editor-panel-color-gradient-settings__dropdown-content", 31791 renderToggle: _ref2 => { 31792 var _setting$gradientValu; 31793 31794 let { 31795 isOpen, 31796 onToggle 31797 } = _ref2; 31798 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalItem, { 31799 onClick: onToggle, 31800 className: classnames_default()('block-editor-panel-color-gradient-settings__item', { 31801 'is-open': isOpen 31802 }) 31803 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalHStack, { 31804 justify: "flex-start" 31805 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ColorIndicator, { 31806 className: "block-editor-panel-color-gradient-settings__color-indicator", 31807 colorValue: (_setting$gradientValu = setting.gradientValue) !== null && _setting$gradientValu !== void 0 ? _setting$gradientValu : setting.colorValue 31808 }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FlexItem, null, setting.label))); 31809 }, 31810 renderContent: () => (0,external_wp_element_namespaceObject.createElement)(control, _extends({ 31811 showTitle: false, 31812 colors, 31813 gradients, 31814 disableCustomColors, 31815 disableCustomGradients, 31816 __experimentalHasMultipleOrigins, 31817 __experimentalIsRenderedInSidebar, 31818 enableAlpha 31819 }, setting)) 31820 }))); 31821 } 31822 31823 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/colors-gradients/use-common-single-multiple-selects.js 31824 /** 31825 * Internal dependencies 31826 */ 31827 31828 function useCommonSingleMultipleSelects() { 31829 return { 31830 disableCustomColors: !useSetting('color.custom'), 31831 disableCustomGradients: !useSetting('color.customGradient') 31832 }; 31833 } 31834 31835 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/colors-gradients/use-multiple-origin-colors-and-gradients.js 31836 /** 31837 * WordPress dependencies 31838 */ 31839 31840 31841 /** 31842 * Internal dependencies 31843 */ 31844 31845 31846 31847 /** 31848 * Retrieves color and gradient related settings. 31849 * 31850 * The arrays for colors and gradients are made up of color palettes from each 31851 * origin i.e. "Core", "Theme", and "User". 31852 * 31853 * @return {Object} Color and gradient related settings. 31854 */ 31855 31856 function useMultipleOriginColorsAndGradients() { 31857 const colorGradientSettings = useCommonSingleMultipleSelects(); 31858 const customColors = useSetting('color.palette.custom'); 31859 const themeColors = useSetting('color.palette.theme'); 31860 const defaultColors = useSetting('color.palette.default'); 31861 const shouldDisplayDefaultColors = useSetting('color.defaultPalette'); 31862 colorGradientSettings.colors = (0,external_wp_element_namespaceObject.useMemo)(() => { 31863 const result = []; 31864 31865 if (themeColors && themeColors.length) { 31866 result.push({ 31867 name: (0,external_wp_i18n_namespaceObject._x)('Theme', 'Indicates this palette comes from the theme.'), 31868 colors: themeColors 31869 }); 31870 } 31871 31872 if (shouldDisplayDefaultColors && defaultColors && defaultColors.length) { 31873 result.push({ 31874 name: (0,external_wp_i18n_namespaceObject._x)('Default', 'Indicates this palette comes from WordPress.'), 31875 colors: defaultColors 31876 }); 31877 } 31878 31879 if (customColors && customColors.length) { 31880 result.push({ 31881 name: (0,external_wp_i18n_namespaceObject._x)('Custom', 'Indicates this palette comes from the theme.'), 31882 colors: customColors 31883 }); 31884 } 31885 31886 return result; 31887 }, [defaultColors, themeColors, customColors]); 31888 const customGradients = useSetting('color.gradients.custom'); 31889 const themeGradients = useSetting('color.gradients.theme'); 31890 const defaultGradients = useSetting('color.gradients.default'); 31891 const shouldDisplayDefaultGradients = useSetting('color.defaultGradients'); 31892 colorGradientSettings.gradients = (0,external_wp_element_namespaceObject.useMemo)(() => { 31893 const result = []; 31894 31895 if (themeGradients && themeGradients.length) { 31896 result.push({ 31897 name: (0,external_wp_i18n_namespaceObject._x)('Theme', 'Indicates this palette comes from the theme.'), 31898 gradients: themeGradients 31899 }); 31900 } 31901 31902 if (shouldDisplayDefaultGradients && defaultGradients && defaultGradients.length) { 31903 result.push({ 31904 name: (0,external_wp_i18n_namespaceObject._x)('Default', 'Indicates this palette comes from WordPress.'), 31905 gradients: defaultGradients 31906 }); 31907 } 31908 31909 if (customGradients && customGradients.length) { 31910 result.push({ 31911 name: (0,external_wp_i18n_namespaceObject._x)('Custom', 'Indicates this palette is created by the user.'), 31912 gradients: customGradients 31913 }); 31914 } 31915 31916 return result; 31917 }, [customGradients, themeGradients, defaultGradients]); 31918 return colorGradientSettings; 31919 } 31920 31921 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/colors/utils.js 31922 /** 31923 * External dependencies 31924 */ 31925 31926 31927 31928 31929 k([names, a11y]); 31930 /** 31931 * Provided an array of color objects as set by the theme or by the editor defaults, 31932 * and the values of the defined color or custom color returns a color object describing the color. 31933 * 31934 * @param {Array} colors Array of color objects as set by the theme or by the editor defaults. 31935 * @param {?string} definedColor A string containing the color slug. 31936 * @param {?string} customColor A string containing the customColor value. 31937 * 31938 * @return {?Object} If definedColor is passed and the name is found in colors, 31939 * the color object exactly as set by the theme or editor defaults is returned. 31940 * Otherwise, an object that just sets the color is defined. 31941 */ 31942 31943 const getColorObjectByAttributeValues = (colors, definedColor, customColor) => { 31944 if (definedColor) { 31945 const colorObj = (0,external_lodash_namespaceObject.find)(colors, { 31946 slug: definedColor 31947 }); 31948 31949 if (colorObj) { 31950 return colorObj; 31951 } 31952 } 31953 31954 return { 31955 color: customColor 31956 }; 31957 }; 31958 /** 31959 * Provided an array of color objects as set by the theme or by the editor defaults, and a color value returns the color object matching that value or undefined. 31960 * 31961 * @param {Array} colors Array of color objects as set by the theme or by the editor defaults. 31962 * @param {?string} colorValue A string containing the color value. 31963 * 31964 * @return {?Object} Color object included in the colors array whose color property equals colorValue. 31965 * Returns undefined if no color object matches this requirement. 31966 */ 31967 31968 const getColorObjectByColorValue = (colors, colorValue) => { 31969 return (0,external_lodash_namespaceObject.find)(colors, { 31970 color: colorValue 31971 }); 31972 }; 31973 /** 31974 * Returns a class based on the context a color is being used and its slug. 31975 * 31976 * @param {string} colorContextName Context/place where color is being used e.g: background, text etc... 31977 * @param {string} colorSlug Slug of the color. 31978 * 31979 * @return {?string} String with the class corresponding to the color in the provided context. 31980 * Returns undefined if either colorContextName or colorSlug are not provided. 31981 */ 31982 31983 function getColorClassName(colorContextName, colorSlug) { 31984 if (!colorContextName || !colorSlug) { 31985 return undefined; 31986 } 31987 31988 return `has-${(0,external_lodash_namespaceObject.kebabCase)(colorSlug)}-$colorContextName}`; 31989 } 31990 /** 31991 * Given an array of color objects and a color value returns the color value of the most readable color in the array. 31992 * 31993 * @param {Array} colors Array of color objects as set by the theme or by the editor defaults. 31994 * @param {?string} colorValue A string containing the color value. 31995 * 31996 * @return {string} String with the color value of the most readable color. 31997 */ 31998 31999 function getMostReadableColor(colors, colorValue) { 32000 const colordColor = w(colorValue); 32001 return (0,external_lodash_namespaceObject.maxBy)(colors, _ref => { 32002 let { 32003 color 32004 } = _ref; 32005 return colordColor.contrast(color); 32006 }).color; 32007 } 32008 32009 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/hooks/border-color.js 32010 32011 32012 32013 /** 32014 * External dependencies 32015 */ 32016 32017 /** 32018 * WordPress dependencies 32019 */ 32020 32021 32022 32023 32024 32025 /** 32026 * Internal dependencies 32027 */ 32028 32029 32030 32031 32032 32033 32034 // Defining empty array here instead of inline avoids unnecessary re-renders of 32035 // color control. 32036 32037 const border_color_EMPTY_ARRAY = []; 32038 /** 32039 * Inspector control panel containing the border color related configuration. 32040 * 32041 * There is deliberate overlap between the colors and borders block supports 32042 * relating to border color. It can be argued the border color controls could 32043 * be included within either, or both, the colors and borders panels in the 32044 * inspector controls. If they share the same block attributes it should not 32045 * matter. 32046 * 32047 * @param {Object} props Block properties. 32048 * 32049 * @return {WPElement} Border color edit element. 32050 */ 32051 32052 function BorderColorEdit(props) { 32053 const { 32054 attributes: { 32055 borderColor, 32056 style 32057 }, 32058 setAttributes 32059 } = props; 32060 const colorGradientSettings = useMultipleOriginColorsAndGradients(); 32061 const availableColors = colorGradientSettings.colors.reduce((colors, origin) => colors.concat(origin.colors), []); 32062 const { 32063 color: customBorderColor 32064 } = (style === null || style === void 0 ? void 0 : style.border) || {}; 32065 const [colorValue, setColorValue] = (0,external_wp_element_namespaceObject.useState)(() => { 32066 var _getColorObjectByAttr; 32067 32068 return (_getColorObjectByAttr = getColorObjectByAttributeValues(availableColors, borderColor, customBorderColor)) === null || _getColorObjectByAttr === void 0 ? void 0 : _getColorObjectByAttr.color; 32069 }); // Detect changes in the color attributes and update the colorValue to keep the 32070 // UI in sync. This is necessary for situations when border controls interact with 32071 // each other: eg, setting the border width to zero causes the color and style 32072 // selections to be cleared. 32073 32074 (0,external_wp_element_namespaceObject.useEffect)(() => { 32075 var _getColorObjectByAttr2; 32076 32077 setColorValue((_getColorObjectByAttr2 = getColorObjectByAttributeValues(availableColors, borderColor, customBorderColor)) === null || _getColorObjectByAttr2 === void 0 ? void 0 : _getColorObjectByAttr2.color); 32078 }, [borderColor, customBorderColor, availableColors]); 32079 32080 const onChangeColor = value => { 32081 setColorValue(value); 32082 const colorObject = getColorObjectByColorValue(availableColors, value); 32083 const newStyle = { ...style, 32084 border: { ...(style === null || style === void 0 ? void 0 : style.border), 32085 color: colorObject !== null && colorObject !== void 0 && colorObject.slug ? undefined : value 32086 } 32087 }; // If empty slug, ensure undefined to remove attribute. 32088 32089 const newNamedColor = colorObject !== null && colorObject !== void 0 && colorObject.slug ? colorObject.slug : undefined; 32090 setAttributes({ 32091 style: cleanEmptyObject(newStyle), 32092 borderColor: newNamedColor 32093 }); 32094 }; 32095 32096 const settings = [{ 32097 label: (0,external_wp_i18n_namespaceObject.__)('Color'), 32098 onColorChange: onChangeColor, 32099 colorValue, 32100 clearable: false 32101 }]; 32102 return (0,external_wp_element_namespaceObject.createElement)(ColorGradientSettingsDropdown, _extends({ 32103 settings: settings, 32104 disableCustomColors: true, 32105 disableCustomGradients: true, 32106 __experimentalHasMultipleOrigins: true, 32107 __experimentalIsRenderedInSidebar: true, 32108 enableAlpha: true 32109 }, colorGradientSettings)); 32110 } 32111 /** 32112 * Checks if there is a current value in the border color block support 32113 * attributes. 32114 * 32115 * @param {Object} props Block props. 32116 * @return {boolean} Whether or not the block has a border color value set. 32117 */ 32118 32119 function hasBorderColorValue(props) { 32120 var _style$border; 32121 32122 const { 32123 attributes: { 32124 borderColor, 32125 style 32126 } 32127 } = props; 32128 return !!borderColor || !!(style !== null && style !== void 0 && (_style$border = style.border) !== null && _style$border !== void 0 && _style$border.color); 32129 } 32130 /** 32131 * Resets the border color block support attributes. This can be used when 32132 * disabling the border color support controls for a block via a progressive 32133 * discovery panel. 32134 * 32135 * @param {Object} props Block props. 32136 * @param {Object} props.attributes Block's attributes. 32137 * @param {Object} props.setAttributes Function to set block's attributes. 32138 */ 32139 32140 function resetBorderColor(_ref) { 32141 let { 32142 attributes = {}, 32143 setAttributes 32144 } = _ref; 32145 const { 32146 style 32147 } = attributes; 32148 setAttributes({ 32149 borderColor: undefined, 32150 style: removeBorderAttribute(style, 'color') 32151 }); 32152 } 32153 /** 32154 * Filters registered block settings, extending attributes to include 32155 * `borderColor` if needed. 32156 * 32157 * @param {Object} settings Original block settings. 32158 * 32159 * @return {Object} Updated block settings. 32160 */ 32161 32162 function addAttributes(settings) { 32163 if (!hasBorderSupport(settings, 'color')) { 32164 return settings; 32165 } // Allow blocks to specify default value if needed. 32166 32167 32168 if (settings.attributes.borderColor) { 32169 return settings; 32170 } // Add new borderColor attribute to block settings. 32171 32172 32173 return { ...settings, 32174 attributes: { ...settings.attributes, 32175 borderColor: { 32176 type: 'string' 32177 } 32178 } 32179 }; 32180 } 32181 /** 32182 * Override props assigned to save component to inject border color. 32183 * 32184 * @param {Object} props Additional props applied to save element. 32185 * @param {Object} blockType Block type definition. 32186 * @param {Object} attributes Block's attributes. 32187 * 32188 * @return {Object} Filtered props to apply to save element. 32189 */ 32190 32191 32192 function border_color_addSaveProps(props, blockType, attributes) { 32193 var _style$border2; 32194 32195 if (!hasBorderSupport(blockType, 'color') || shouldSkipSerialization(blockType, BORDER_SUPPORT_KEY, 'color')) { 32196 return props; 32197 } 32198 32199 const { 32200 borderColor, 32201 style 32202 } = attributes; 32203 const borderColorClass = getColorClassName('border-color', borderColor); 32204 const newClassName = classnames_default()(props.className, { 32205 'has-border-color': borderColor || (style === null || style === void 0 ? void 0 : (_style$border2 = style.border) === null || _style$border2 === void 0 ? void 0 : _style$border2.color), 32206 [borderColorClass]: !!borderColorClass 32207 }); // If we are clearing the last of the previous classes in `className` 32208 // set it to `undefined` to avoid rendering empty DOM attributes. 32209 32210 props.className = newClassName ? newClassName : undefined; 32211 return props; 32212 } 32213 /** 32214 * Filters the registered block settings to apply border color styles and 32215 * classnames to the block edit wrapper. 32216 * 32217 * @param {Object} settings Original block settings. 32218 * 32219 * @return {Object} Filtered block settings. 32220 */ 32221 32222 32223 function addEditProps(settings) { 32224 if (!hasBorderSupport(settings, 'color') || shouldSkipSerialization(settings, BORDER_SUPPORT_KEY, 'color')) { 32225 return settings; 32226 } 32227 32228 const existingGetEditWrapperProps = settings.getEditWrapperProps; 32229 32230 settings.getEditWrapperProps = attributes => { 32231 let props = {}; 32232 32233 if (existingGetEditWrapperProps) { 32234 props = existingGetEditWrapperProps(attributes); 32235 } 32236 32237 return border_color_addSaveProps(props, settings, attributes); 32238 }; 32239 32240 return settings; 32241 } 32242 /** 32243 * This adds inline styles for color palette colors. 32244 * Ideally, this is not needed and themes should load their palettes on the editor. 32245 * 32246 * @param {Function} BlockListBlock Original component. 32247 * 32248 * @return {Function} Wrapped component. 32249 */ 32250 32251 32252 const withBorderColorPaletteStyles = (0,external_wp_compose_namespaceObject.createHigherOrderComponent)(BlockListBlock => props => { 32253 var _getColorObjectByAttr3, _props$wrapperProps; 32254 32255 const { 32256 name, 32257 attributes 32258 } = props; 32259 const { 32260 borderColor 32261 } = attributes; 32262 const colors = useSetting('color.palette') || border_color_EMPTY_ARRAY; 32263 32264 if (!hasBorderSupport(name, 'color') || shouldSkipSerialization(name, BORDER_SUPPORT_KEY, 'color')) { 32265 return (0,external_wp_element_namespaceObject.createElement)(BlockListBlock, props); 32266 } 32267 32268 const extraStyles = { 32269 borderColor: borderColor ? (_getColorObjectByAttr3 = getColorObjectByAttributeValues(colors, borderColor)) === null || _getColorObjectByAttr3 === void 0 ? void 0 : _getColorObjectByAttr3.color : undefined 32270 }; 32271 let wrapperProps = props.wrapperProps; 32272 wrapperProps = { ...props.wrapperProps, 32273 style: { ...extraStyles, 32274 ...((_props$wrapperProps = props.wrapperProps) === null || _props$wrapperProps === void 0 ? void 0 : _props$wrapperProps.style) 32275 } 32276 }; 32277 return (0,external_wp_element_namespaceObject.createElement)(BlockListBlock, _extends({}, props, { 32278 wrapperProps: wrapperProps 32279 })); 32280 }); 32281 (0,external_wp_hooks_namespaceObject.addFilter)('blocks.registerBlockType', 'core/border/addAttributes', addAttributes); 32282 (0,external_wp_hooks_namespaceObject.addFilter)('blocks.getSaveContent.extraProps', 'core/border/addSaveProps', border_color_addSaveProps); 32283 (0,external_wp_hooks_namespaceObject.addFilter)('blocks.registerBlockType', 'core/border/addEditProps', addEditProps); 32284 (0,external_wp_hooks_namespaceObject.addFilter)('editor.BlockListBlock', 'core/border/with-border-color-palette-styles', withBorderColorPaletteStyles); 32285 32286 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/border-radius-control/utils.js 32287 /** 32288 * WordPress dependencies 32289 */ 32290 32291 /** 32292 * Gets the (non-undefined) item with the highest occurrence within an array 32293 * Based in part on: https://stackoverflow.com/a/20762713 32294 * 32295 * Undefined values are always sorted to the end by `sort`, so this function 32296 * returns the first element, to always prioritize real values over undefined 32297 * values. 32298 * 32299 * See: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/sort#description 32300 * 32301 * @param {Array<any>} inputArray Array of items to check. 32302 * @return {any} The item with the most occurrences. 32303 */ 32304 32305 function mode(inputArray) { 32306 const arr = [...inputArray]; 32307 return arr.sort((a, b) => inputArray.filter(v => v === b).length - inputArray.filter(v => v === a).length).shift(); 32308 } 32309 /** 32310 * Returns the most common CSS unit in the radius values. 32311 * Falls back to `px` as a default unit. 32312 * 32313 * @param {Object|string} values Radius values. 32314 * @return {string} Most common CSS unit in values. Default: `px`. 32315 */ 32316 32317 function getAllUnit() { 32318 let values = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; 32319 32320 if (typeof values === 'string') { 32321 const [, unit] = (0,external_wp_components_namespaceObject.__experimentalParseQuantityAndUnitFromRawValue)(values); 32322 return unit || 'px'; 32323 } 32324 32325 const allUnits = Object.values(values).map(value => { 32326 const [, unit] = (0,external_wp_components_namespaceObject.__experimentalParseQuantityAndUnitFromRawValue)(value); 32327 return unit; 32328 }); 32329 return mode(allUnits) || 'px'; 32330 } 32331 /** 32332 * Gets the 'all' input value and unit from values data. 32333 * 32334 * @param {Object|string} values Radius values. 32335 * @return {string} A value + unit for the 'all' input. 32336 */ 32337 32338 function getAllValue() { 32339 let values = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; 32340 32341 /** 32342 * Border radius support was originally a single pixel value. 32343 * 32344 * To maintain backwards compatibility treat this case as the all value. 32345 */ 32346 if (typeof values === 'string') { 32347 return values; 32348 } 32349 32350 const parsedQuantitiesAndUnits = Object.values(values).map(value => (0,external_wp_components_namespaceObject.__experimentalParseQuantityAndUnitFromRawValue)(value)); 32351 const allValues = parsedQuantitiesAndUnits.map(value => { 32352 var _value$; 32353 32354 return (_value$ = value[0]) !== null && _value$ !== void 0 ? _value$ : ''; 32355 }); 32356 const allUnits = parsedQuantitiesAndUnits.map(value => value[1]); 32357 const value = allValues.every(v => v === allValues[0]) ? allValues[0] : ''; 32358 const unit = mode(allUnits); 32359 const allValue = value === 0 || value ? `$value}$unit}` : undefined; 32360 return allValue; 32361 } 32362 /** 32363 * Checks to determine if values are mixed. 32364 * 32365 * @param {Object} values Radius values. 32366 * @return {boolean} Whether values are mixed. 32367 */ 32368 32369 function hasMixedValues() { 32370 let values = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; 32371 const allValue = getAllValue(values); 32372 const isMixed = typeof values === 'string' ? false : isNaN(parseFloat(allValue)); 32373 return isMixed; 32374 } 32375 /** 32376 * Checks to determine if values are defined. 32377 * 32378 * @param {Object} values Radius values. 32379 * @return {boolean} Whether values are mixed. 32380 */ 32381 32382 function hasDefinedValues(values) { 32383 if (!values) { 32384 return false; 32385 } // A string value represents a shorthand value. 32386 32387 32388 if (typeof values === 'string') { 32389 return true; 32390 } // An object represents longhand border radius values, if any are set 32391 // flag values as being defined. 32392 32393 32394 const filteredValues = Object.values(values).filter(value => { 32395 return !!value || value === 0; 32396 }); 32397 return !!filteredValues.length; 32398 } 32399 32400 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/border-radius-control/all-input-control.js 32401 32402 32403 32404 /** 32405 * WordPress dependencies 32406 */ 32407 32408 32409 /** 32410 * Internal dependencies 32411 */ 32412 32413 32414 function AllInputControl(_ref) { 32415 let { 32416 onChange, 32417 values, 32418 ...props 32419 } = _ref; 32420 const allValue = getAllValue(values); 32421 const hasValues = hasDefinedValues(values); 32422 const isMixed = hasValues && hasMixedValues(values); 32423 const allPlaceholder = isMixed ? (0,external_wp_i18n_namespaceObject.__)('Mixed') : null; 32424 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalUnitControl, _extends({}, props, { 32425 "aria-label": (0,external_wp_i18n_namespaceObject.__)('Border radius'), 32426 disableUnits: isMixed, 32427 isOnly: true, 32428 value: allValue, 32429 onChange: onChange, 32430 placeholder: allPlaceholder 32431 })); 32432 } 32433 32434 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/border-radius-control/input-controls.js 32435 32436 32437 32438 /** 32439 * WordPress dependencies 32440 */ 32441 32442 32443 const CORNERS = { 32444 topLeft: (0,external_wp_i18n_namespaceObject.__)('Top left'), 32445 topRight: (0,external_wp_i18n_namespaceObject.__)('Top right'), 32446 bottomLeft: (0,external_wp_i18n_namespaceObject.__)('Bottom left'), 32447 bottomRight: (0,external_wp_i18n_namespaceObject.__)('Bottom right') 32448 }; 32449 function BoxInputControls(_ref) { 32450 let { 32451 onChange, 32452 values: valuesProp, 32453 ...props 32454 } = _ref; 32455 32456 const createHandleOnChange = corner => next => { 32457 if (!onChange) { 32458 return; 32459 } 32460 32461 onChange({ ...values, 32462 [corner]: next ? next : undefined 32463 }); 32464 }; // For shorthand style & backwards compatibility, handle flat string value. 32465 32466 32467 const values = typeof valuesProp !== 'string' ? valuesProp : { 32468 topLeft: valuesProp, 32469 topRight: valuesProp, 32470 bottomLeft: valuesProp, 32471 bottomRight: valuesProp 32472 }; // Controls are wrapped in tooltips as visible labels aren't desired here. 32473 32474 return (0,external_wp_element_namespaceObject.createElement)("div", { 32475 className: "components-border-radius-control__input-controls-wrapper" 32476 }, Object.entries(CORNERS).map(_ref2 => { 32477 let [key, label] = _ref2; 32478 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalUnitControl, _extends({}, props, { 32479 key: key, 32480 "aria-label": label, 32481 value: values[key], 32482 onChange: createHandleOnChange(key) 32483 })); 32484 })); 32485 } 32486 32487 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/link.js 32488 32489 32490 /** 32491 * WordPress dependencies 32492 */ 32493 32494 const link_link = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 32495 xmlns: "http://www.w3.org/2000/svg", 32496 viewBox: "0 0 24 24" 32497 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 32498 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" 32499 })); 32500 /* harmony default export */ var library_link = (link_link); 32501 32502 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/link-off.js 32503 32504 32505 /** 32506 * WordPress dependencies 32507 */ 32508 32509 const linkOff = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 32510 xmlns: "http://www.w3.org/2000/svg", 32511 viewBox: "0 0 24 24" 32512 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 32513 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" 32514 })); 32515 /* harmony default export */ var link_off = (linkOff); 32516 32517 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/border-radius-control/linked-button.js 32518 32519 32520 32521 /** 32522 * WordPress dependencies 32523 */ 32524 32525 32526 32527 function LinkedButton(_ref) { 32528 let { 32529 isLinked, 32530 ...props 32531 } = _ref; 32532 const label = isLinked ? (0,external_wp_i18n_namespaceObject.__)('Unlink Radii') : (0,external_wp_i18n_namespaceObject.__)('Link Radii'); 32533 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Tooltip, { 32534 text: label 32535 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, _extends({}, props, { 32536 className: "component-border-radius-control__linked-button", 32537 isPrimary: isLinked, 32538 isSecondary: !isLinked, 32539 isSmall: true, 32540 icon: isLinked ? library_link : link_off, 32541 iconSize: 16, 32542 "aria-label": label 32543 }))); 32544 } 32545 32546 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/border-radius-control/index.js 32547 32548 32549 /** 32550 * WordPress dependencies 32551 */ 32552 32553 32554 32555 /** 32556 * Internal dependencies 32557 */ 32558 32559 32560 32561 32562 32563 32564 const DEFAULT_VALUES = { 32565 topLeft: null, 32566 topRight: null, 32567 bottomLeft: null, 32568 bottomRight: null 32569 }; 32570 const MIN_BORDER_RADIUS_VALUE = 0; 32571 const MAX_BORDER_RADIUS_VALUES = { 32572 px: 100, 32573 em: 20, 32574 rem: 20 32575 }; 32576 /** 32577 * Control to display border radius options. 32578 * 32579 * @param {Object} props Component props. 32580 * @param {Function} props.onChange Callback to handle onChange. 32581 * @param {Object} props.values Border radius values. 32582 * 32583 * @return {WPElement} Custom border radius control. 32584 */ 32585 32586 function BorderRadiusControl(_ref) { 32587 let { 32588 onChange, 32589 values 32590 } = _ref; 32591 const [isLinked, setIsLinked] = (0,external_wp_element_namespaceObject.useState)(!hasDefinedValues(values) || !hasMixedValues(values)); 32592 const units = (0,external_wp_components_namespaceObject.__experimentalUseCustomUnits)({ 32593 availableUnits: useSetting('spacing.units') || ['px', 'em', 'rem'] 32594 }); 32595 const unit = getAllUnit(values); 32596 const unitConfig = units && units.find(item => item.value === unit); 32597 const step = (unitConfig === null || unitConfig === void 0 ? void 0 : unitConfig.step) || 1; 32598 const [allValue] = (0,external_wp_components_namespaceObject.__experimentalParseQuantityAndUnitFromRawValue)(getAllValue(values)); 32599 32600 const toggleLinked = () => setIsLinked(!isLinked); 32601 32602 const handleSliderChange = next => { 32603 onChange(next !== undefined ? `$next}$unit}` : undefined); 32604 }; 32605 32606 return (0,external_wp_element_namespaceObject.createElement)("fieldset", { 32607 className: "components-border-radius-control" 32608 }, (0,external_wp_element_namespaceObject.createElement)("legend", null, (0,external_wp_i18n_namespaceObject.__)('Radius')), (0,external_wp_element_namespaceObject.createElement)("div", { 32609 className: "components-border-radius-control__wrapper" 32610 }, isLinked ? (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(AllInputControl, { 32611 className: "components-border-radius-control__unit-control", 32612 values: values, 32613 min: MIN_BORDER_RADIUS_VALUE, 32614 onChange: onChange, 32615 units: units 32616 }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.RangeControl, { 32617 className: "components-border-radius-control__range-control", 32618 value: allValue !== null && allValue !== void 0 ? allValue : '', 32619 min: MIN_BORDER_RADIUS_VALUE, 32620 max: MAX_BORDER_RADIUS_VALUES[unit], 32621 initialPosition: 0, 32622 withInputField: false, 32623 onChange: handleSliderChange, 32624 step: step 32625 })) : (0,external_wp_element_namespaceObject.createElement)(BoxInputControls, { 32626 min: MIN_BORDER_RADIUS_VALUE, 32627 onChange: onChange, 32628 values: values || DEFAULT_VALUES, 32629 units: units 32630 }), (0,external_wp_element_namespaceObject.createElement)(LinkedButton, { 32631 onClick: toggleLinked, 32632 isLinked: isLinked 32633 }))); 32634 } 32635 32636 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/hooks/border-radius.js 32637 32638 32639 /** 32640 * Internal dependencies 32641 */ 32642 32643 32644 32645 /** 32646 * Inspector control panel containing the border radius related configuration. 32647 * 32648 * @param {Object} props Block properties. 32649 * 32650 * @return {WPElement} Border radius edit element. 32651 */ 32652 32653 function BorderRadiusEdit(props) { 32654 var _style$border; 32655 32656 const { 32657 attributes: { 32658 style 32659 }, 32660 setAttributes 32661 } = props; 32662 32663 const onChange = newRadius => { 32664 let newStyle = { ...style, 32665 border: { ...(style === null || style === void 0 ? void 0 : style.border), 32666 radius: newRadius 32667 } 32668 }; 32669 32670 if (newRadius === undefined || newRadius === '') { 32671 newStyle = cleanEmptyObject(newStyle); 32672 } 32673 32674 setAttributes({ 32675 style: newStyle 32676 }); 32677 }; 32678 32679 return (0,external_wp_element_namespaceObject.createElement)(BorderRadiusControl, { 32680 values: style === null || style === void 0 ? void 0 : (_style$border = style.border) === null || _style$border === void 0 ? void 0 : _style$border.radius, 32681 onChange: onChange 32682 }); 32683 } 32684 /** 32685 * Checks if there is a current value in the border radius block support 32686 * attributes. 32687 * 32688 * @param {Object} props Block props. 32689 * @return {boolean} Whether or not the block has a border radius value set. 32690 */ 32691 32692 function hasBorderRadiusValue(props) { 32693 var _props$attributes$sty, _props$attributes$sty2; 32694 32695 const borderRadius = (_props$attributes$sty = props.attributes.style) === null || _props$attributes$sty === void 0 ? void 0 : (_props$attributes$sty2 = _props$attributes$sty.border) === null || _props$attributes$sty2 === void 0 ? void 0 : _props$attributes$sty2.radius; 32696 32697 if (typeof borderRadius === 'object') { 32698 return Object.entries(borderRadius).some(Boolean); 32699 } 32700 32701 return !!borderRadius; 32702 } 32703 /** 32704 * Resets the border radius block support attributes. This can be used when 32705 * disabling the border radius support controls for a block via a progressive 32706 * discovery panel. 32707 * 32708 * @param {Object} props Block props. 32709 * @param {Object} props.attributes Block's attributes. 32710 * @param {Object} props.setAttributes Function to set block's attributes. 32711 */ 32712 32713 function resetBorderRadius(_ref) { 32714 let { 32715 attributes = {}, 32716 setAttributes 32717 } = _ref; 32718 const { 32719 style 32720 } = attributes; 32721 setAttributes({ 32722 style: removeBorderAttribute(style, 'radius') 32723 }); 32724 } 32725 32726 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/line-solid.js 32727 32728 32729 /** 32730 * WordPress dependencies 32731 */ 32732 32733 const lineSolid = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 32734 xmlns: "http://www.w3.org/2000/svg", 32735 width: "24", 32736 height: "24", 32737 fill: "none" 32738 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 32739 d: "M5 11.25h14v1.5H5z" 32740 })); 32741 /* harmony default export */ var line_solid = (lineSolid); 32742 32743 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/line-dashed.js 32744 32745 32746 /** 32747 * WordPress dependencies 32748 */ 32749 32750 const lineDashed = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 32751 xmlns: "http://www.w3.org/2000/svg", 32752 width: "24", 32753 height: "24", 32754 fill: "none" 32755 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 32756 fillRule: "evenodd", 32757 d: "M5 11.25h3v1.5H5v-1.5zm5.5 0h3v1.5h-3v-1.5zm8.5 0h-3v1.5h3v-1.5z", 32758 clipRule: "evenodd" 32759 })); 32760 /* harmony default export */ var line_dashed = (lineDashed); 32761 32762 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/line-dotted.js 32763 32764 32765 /** 32766 * WordPress dependencies 32767 */ 32768 32769 const lineDotted = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 32770 xmlns: "http://www.w3.org/2000/svg", 32771 width: "24", 32772 height: "24", 32773 fill: "none" 32774 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 32775 fillRule: "evenodd", 32776 d: "M5.25 11.25h1.5v1.5h-1.5v-1.5zm3 0h1.5v1.5h-1.5v-1.5zm4.5 0h-1.5v1.5h1.5v-1.5zm1.5 0h1.5v1.5h-1.5v-1.5zm4.5 0h-1.5v1.5h1.5v-1.5z", 32777 clipRule: "evenodd" 32778 })); 32779 /* harmony default export */ var line_dotted = (lineDotted); 32780 32781 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/border-style-control/index.js 32782 32783 32784 /** 32785 * WordPress dependencies 32786 */ 32787 32788 32789 32790 const BORDER_STYLES = [{ 32791 label: (0,external_wp_i18n_namespaceObject.__)('Solid'), 32792 icon: line_solid, 32793 value: 'solid' 32794 }, { 32795 label: (0,external_wp_i18n_namespaceObject.__)('Dashed'), 32796 icon: line_dashed, 32797 value: 'dashed' 32798 }, { 32799 label: (0,external_wp_i18n_namespaceObject.__)('Dotted'), 32800 icon: line_dotted, 32801 value: 'dotted' 32802 }]; 32803 /** 32804 * Control to display border style options. 32805 * 32806 * @param {Object} props Component props. 32807 * @param {Function} props.onChange Handler for changing border style selection. 32808 * @param {string} props.value Currently selected border style value. 32809 * 32810 * @return {WPElement} Custom border style segmented control. 32811 */ 32812 32813 function BorderStyleControl(_ref) { 32814 let { 32815 onChange, 32816 value 32817 } = _ref; 32818 return (0,external_wp_element_namespaceObject.createElement)("fieldset", { 32819 className: "components-border-style-control" 32820 }, (0,external_wp_element_namespaceObject.createElement)("legend", null, (0,external_wp_i18n_namespaceObject.__)('Style')), (0,external_wp_element_namespaceObject.createElement)("div", { 32821 className: "components-border-style-control__buttons" 32822 }, BORDER_STYLES.map(borderStyle => (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 32823 key: borderStyle.value, 32824 icon: borderStyle.icon, 32825 isSmall: true, 32826 isPressed: borderStyle.value === value, 32827 onClick: () => onChange(borderStyle.value === value ? undefined : borderStyle.value), 32828 "aria-label": borderStyle.label 32829 })))); 32830 } 32831 32832 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/hooks/border-style.js 32833 32834 32835 /** 32836 * Internal dependencies 32837 */ 32838 32839 32840 32841 /** 32842 * Inspector control for configuring border style property. 32843 * 32844 * @param {Object} props Block properties. 32845 * 32846 * @return {WPElement} Border style edit element. 32847 */ 32848 32849 const BorderStyleEdit = props => { 32850 var _style$border; 32851 32852 const { 32853 attributes: { 32854 style 32855 }, 32856 setAttributes 32857 } = props; 32858 32859 const onChange = newBorderStyle => { 32860 const newStyleAttributes = { ...style, 32861 border: { ...(style === null || style === void 0 ? void 0 : style.border), 32862 style: newBorderStyle 32863 } 32864 }; 32865 setAttributes({ 32866 style: cleanEmptyObject(newStyleAttributes) 32867 }); 32868 }; 32869 32870 return (0,external_wp_element_namespaceObject.createElement)(BorderStyleControl, { 32871 value: style === null || style === void 0 ? void 0 : (_style$border = style.border) === null || _style$border === void 0 ? void 0 : _style$border.style, 32872 onChange: onChange 32873 }); 32874 }; 32875 /** 32876 * Checks if there is a current value in the border style block support 32877 * attributes. 32878 * 32879 * @param {Object} props Block props. 32880 * @return {boolean} Whether or not the block has a border style value set. 32881 */ 32882 32883 function hasBorderStyleValue(props) { 32884 var _props$attributes$sty, _props$attributes$sty2; 32885 32886 return !!((_props$attributes$sty = props.attributes.style) !== null && _props$attributes$sty !== void 0 && (_props$attributes$sty2 = _props$attributes$sty.border) !== null && _props$attributes$sty2 !== void 0 && _props$attributes$sty2.style); 32887 } 32888 /** 32889 * Resets the border style block support attribute. This can be used when 32890 * disabling the border style support control for a block via a progressive 32891 * discovery panel. 32892 * 32893 * @param {Object} props Block props. 32894 * @param {Object} props.attributes Block's attributes. 32895 * @param {Object} props.setAttributes Function to set block's attributes. 32896 */ 32897 32898 function resetBorderStyle(_ref) { 32899 let { 32900 attributes = {}, 32901 setAttributes 32902 } = _ref; 32903 const { 32904 style 32905 } = attributes; 32906 setAttributes({ 32907 style: removeBorderAttribute(style, 'style') 32908 }); 32909 } 32910 32911 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/hooks/border-width.js 32912 32913 32914 /** 32915 * WordPress dependencies 32916 */ 32917 32918 32919 32920 /** 32921 * Internal dependencies 32922 */ 32923 32924 32925 32926 32927 const MIN_BORDER_WIDTH = 0; 32928 /** 32929 * Inspector control for configuring border width property. 32930 * 32931 * @param {Object} props Block properties. 32932 * 32933 * @return {WPElement} Border width edit element. 32934 */ 32935 32936 const BorderWidthEdit = props => { 32937 const { 32938 attributes: { 32939 borderColor, 32940 style 32941 }, 32942 setAttributes 32943 } = props; 32944 const { 32945 width, 32946 color: customBorderColor, 32947 style: borderStyle 32948 } = (style === null || style === void 0 ? void 0 : style.border) || {}; // Used to temporarily track previous border color & style selections to be 32949 // able to restore them when border width changes from zero value. 32950 32951 const [styleSelection, setStyleSelection] = (0,external_wp_element_namespaceObject.useState)(); 32952 const [colorSelection, setColorSelection] = (0,external_wp_element_namespaceObject.useState)(); 32953 const [customColorSelection, setCustomColorSelection] = (0,external_wp_element_namespaceObject.useState)(); 32954 32955 const onChange = newWidth => { 32956 let newStyle = { ...style, 32957 border: { ...(style === null || style === void 0 ? void 0 : style.border), 32958 width: newWidth 32959 } 32960 }; // Used to clear named border color attribute. 32961 32962 let borderPaletteColor = borderColor; 32963 const hasZeroWidth = parseFloat(newWidth) === 0; 32964 const hadPreviousZeroWidth = parseFloat(width) === 0; // Setting the border width explicitly to zero will also set the 32965 // border style to `none` and clear border color attributes. 32966 32967 if (hasZeroWidth && !hadPreviousZeroWidth) { 32968 // Before clearing color and style selections, keep track of 32969 // the current selections so they can be restored when the width 32970 // changes to a non-zero value. 32971 setColorSelection(borderColor); 32972 setCustomColorSelection(customBorderColor); 32973 setStyleSelection(borderStyle); // Clear style and color attributes. 32974 32975 borderPaletteColor = undefined; 32976 newStyle.border.color = undefined; 32977 newStyle.border.style = 'none'; 32978 } 32979 32980 if (!hasZeroWidth && hadPreviousZeroWidth) { 32981 // Restore previous border style selection if width is now not zero and 32982 // border style was 'none'. This is to support changes to the UI which 32983 // change the border style UI to a segmented control without a "none" 32984 // option. 32985 if (borderStyle === 'none') { 32986 newStyle.border.style = styleSelection; 32987 } // Restore previous border color selection if width is no longer zero 32988 // and current border color is undefined. 32989 32990 32991 if (borderColor === undefined) { 32992 borderPaletteColor = colorSelection; 32993 newStyle.border.color = customColorSelection; 32994 } 32995 } // If width was reset, clean out undefined styles. 32996 32997 32998 if (newWidth === undefined || newWidth === '') { 32999 newStyle = cleanEmptyObject(newStyle); 33000 } 33001 33002 setAttributes({ 33003 borderColor: borderPaletteColor, 33004 style: newStyle 33005 }); 33006 }; 33007 33008 const units = (0,external_wp_components_namespaceObject.__experimentalUseCustomUnits)({ 33009 availableUnits: useSetting('spacing.units') || ['px', 'em', 'rem'] 33010 }); 33011 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalUnitControl, { 33012 value: width, 33013 label: (0,external_wp_i18n_namespaceObject.__)('Width'), 33014 min: MIN_BORDER_WIDTH, 33015 onChange: onChange, 33016 units: units 33017 }); 33018 }; 33019 /** 33020 * Checks if there is a current value in the border width block support 33021 * attributes. 33022 * 33023 * @param {Object} props Block props. 33024 * @return {boolean} Whether or not the block has a border width value set. 33025 */ 33026 33027 function hasBorderWidthValue(props) { 33028 var _props$attributes$sty, _props$attributes$sty2; 33029 33030 return !!((_props$attributes$sty = props.attributes.style) !== null && _props$attributes$sty !== void 0 && (_props$attributes$sty2 = _props$attributes$sty.border) !== null && _props$attributes$sty2 !== void 0 && _props$attributes$sty2.width); 33031 } 33032 /** 33033 * Resets the border width block support attribute. This can be used when 33034 * disabling the border width support control for a block via a progressive 33035 * discovery panel. 33036 * 33037 * @param {Object} props Block props. 33038 * @param {Object} props.attributes Block's attributes. 33039 * @param {Object} props.setAttributes Function to set block's attributes. 33040 */ 33041 33042 function resetBorderWidth(_ref) { 33043 let { 33044 attributes = {}, 33045 setAttributes 33046 } = _ref; 33047 const { 33048 style 33049 } = attributes; 33050 setAttributes({ 33051 style: removeBorderAttribute(style, 'width') 33052 }); 33053 } 33054 33055 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/hooks/border.js 33056 33057 33058 /** 33059 * WordPress dependencies 33060 */ 33061 33062 33063 33064 33065 /** 33066 * Internal dependencies 33067 */ 33068 33069 33070 33071 33072 33073 33074 33075 33076 const BORDER_SUPPORT_KEY = '__experimentalBorder'; 33077 function BorderPanel(props) { 33078 const { 33079 clientId 33080 } = props; 33081 const isColorSupported = useSetting('border.color') && hasBorderSupport(props.name, 'color'); 33082 const isRadiusSupported = useSetting('border.radius') && hasBorderSupport(props.name, 'radius'); 33083 const isStyleSupported = useSetting('border.style') && hasBorderSupport(props.name, 'style'); 33084 const isWidthSupported = useSetting('border.width') && hasBorderSupport(props.name, 'width'); 33085 const isDisabled = [!isColorSupported, !isRadiusSupported, !isStyleSupported, !isWidthSupported].every(Boolean); 33086 33087 if (isDisabled) { 33088 return null; 33089 } 33090 33091 const defaultBorderControls = (0,external_wp_blocks_namespaceObject.getBlockSupport)(props.name, [BORDER_SUPPORT_KEY, '__experimentalDefaultControls']); 33092 33093 const createResetAllFilter = function (borderAttribute) { 33094 let topLevelAttributes = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; 33095 return newAttributes => { 33096 var _newAttributes$style; 33097 33098 return { ...newAttributes, 33099 ...topLevelAttributes, 33100 style: { ...newAttributes.style, 33101 border: { ...((_newAttributes$style = newAttributes.style) === null || _newAttributes$style === void 0 ? void 0 : _newAttributes$style.border), 33102 [borderAttribute]: undefined 33103 } 33104 } 33105 }; 33106 }; 33107 }; 33108 33109 return (0,external_wp_element_namespaceObject.createElement)(inspector_controls, { 33110 __experimentalGroup: "border" 33111 }, isWidthSupported && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToolsPanelItem, { 33112 className: "single-column", 33113 hasValue: () => hasBorderWidthValue(props), 33114 label: (0,external_wp_i18n_namespaceObject.__)('Width'), 33115 onDeselect: () => resetBorderWidth(props), 33116 isShownByDefault: defaultBorderControls === null || defaultBorderControls === void 0 ? void 0 : defaultBorderControls.width, 33117 resetAllFilter: createResetAllFilter('width'), 33118 panelId: clientId 33119 }, (0,external_wp_element_namespaceObject.createElement)(BorderWidthEdit, props)), isStyleSupported && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToolsPanelItem, { 33120 className: "single-column", 33121 hasValue: () => hasBorderStyleValue(props), 33122 label: (0,external_wp_i18n_namespaceObject.__)('Style'), 33123 onDeselect: () => resetBorderStyle(props), 33124 isShownByDefault: defaultBorderControls === null || defaultBorderControls === void 0 ? void 0 : defaultBorderControls.style, 33125 resetAllFilter: createResetAllFilter('style'), 33126 panelId: clientId 33127 }, (0,external_wp_element_namespaceObject.createElement)(BorderStyleEdit, props)), isColorSupported && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToolsPanelItem, { 33128 hasValue: () => hasBorderColorValue(props), 33129 label: (0,external_wp_i18n_namespaceObject.__)('Color'), 33130 onDeselect: () => resetBorderColor(props), 33131 isShownByDefault: defaultBorderControls === null || defaultBorderControls === void 0 ? void 0 : defaultBorderControls.color, 33132 resetAllFilter: createResetAllFilter('color', { 33133 borderColor: undefined 33134 }), 33135 panelId: clientId 33136 }, (0,external_wp_element_namespaceObject.createElement)(BorderColorEdit, props)), isRadiusSupported && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToolsPanelItem, { 33137 hasValue: () => hasBorderRadiusValue(props), 33138 label: (0,external_wp_i18n_namespaceObject.__)('Radius'), 33139 onDeselect: () => resetBorderRadius(props), 33140 isShownByDefault: defaultBorderControls === null || defaultBorderControls === void 0 ? void 0 : defaultBorderControls.radius, 33141 resetAllFilter: createResetAllFilter('radius'), 33142 panelId: clientId 33143 }, (0,external_wp_element_namespaceObject.createElement)(BorderRadiusEdit, props))); 33144 } 33145 /** 33146 * Determine whether there is block support for border properties. 33147 * 33148 * @param {string} blockName Block name. 33149 * @param {string} feature Border feature to check support for. 33150 * 33151 * @return {boolean} Whether there is support. 33152 */ 33153 33154 function hasBorderSupport(blockName) { 33155 let feature = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'any'; 33156 33157 if (external_wp_element_namespaceObject.Platform.OS !== 'web') { 33158 return false; 33159 } 33160 33161 const support = (0,external_wp_blocks_namespaceObject.getBlockSupport)(blockName, BORDER_SUPPORT_KEY); 33162 33163 if (support === true) { 33164 return true; 33165 } 33166 33167 if (feature === 'any') { 33168 return !!(support !== null && support !== void 0 && support.color || support !== null && support !== void 0 && support.radius || support !== null && support !== void 0 && support.width || support !== null && support !== void 0 && support.style); 33169 } 33170 33171 return !!(support !== null && support !== void 0 && support[feature]); 33172 } 33173 /** 33174 * Returns a new style object where the specified border attribute has been 33175 * removed. 33176 * 33177 * @param {Object} style Styles from block attributes. 33178 * @param {string} attribute The border style attribute to clear. 33179 * 33180 * @return {Object} Style object with the specified attribute removed. 33181 */ 33182 33183 function removeBorderAttribute(style, attribute) { 33184 return cleanEmptyObject({ ...style, 33185 border: { ...(style === null || style === void 0 ? void 0 : style.border), 33186 [attribute]: undefined 33187 } 33188 }); 33189 } 33190 33191 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/gradients/use-gradient.js 33192 /** 33193 * External dependencies 33194 */ 33195 33196 /** 33197 * WordPress dependencies 33198 */ 33199 33200 33201 33202 /** 33203 * Internal dependencies 33204 */ 33205 33206 33207 33208 33209 function __experimentalGetGradientClass(gradientSlug) { 33210 if (!gradientSlug) { 33211 return undefined; 33212 } 33213 33214 return `has-$gradientSlug}-gradient-background`; 33215 } 33216 /** 33217 * Retrieves the gradient value per slug. 33218 * 33219 * @param {Array} gradients Gradient Palette 33220 * @param {string} slug Gradient slug 33221 * 33222 * @return {string} Gradient value. 33223 */ 33224 33225 function getGradientValueBySlug(gradients, slug) { 33226 const gradient = (0,external_lodash_namespaceObject.find)(gradients, ['slug', slug]); 33227 return gradient && gradient.gradient; 33228 } 33229 function __experimentalGetGradientObjectByGradientValue(gradients, value) { 33230 const gradient = (0,external_lodash_namespaceObject.find)(gradients, ['gradient', value]); 33231 return gradient; 33232 } 33233 /** 33234 * Retrieves the gradient slug per slug. 33235 * 33236 * @param {Array} gradients Gradient Palette 33237 * @param {string} value Gradient value 33238 * @return {string} Gradient slug. 33239 */ 33240 33241 function getGradientSlugByValue(gradients, value) { 33242 const gradient = __experimentalGetGradientObjectByGradientValue(gradients, value); 33243 33244 return gradient && gradient.slug; 33245 } 33246 function __experimentalUseGradient() { 33247 let { 33248 gradientAttribute = 'gradient', 33249 customGradientAttribute = 'customGradient' 33250 } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; 33251 const { 33252 clientId 33253 } = useBlockEditContext(); 33254 const userGradientPalette = useSetting('color.gradients.custom'); 33255 const themeGradientPalette = useSetting('color.gradients.theme'); 33256 const defaultGradientPalette = useSetting('color.gradients.default'); 33257 const allGradients = (0,external_wp_element_namespaceObject.useMemo)(() => [...(userGradientPalette || []), ...(themeGradientPalette || []), ...(defaultGradientPalette || [])], [userGradientPalette, themeGradientPalette, defaultGradientPalette]); 33258 const { 33259 gradient, 33260 customGradient 33261 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 33262 const { 33263 getBlockAttributes 33264 } = select(store); 33265 const attributes = getBlockAttributes(clientId) || {}; 33266 return { 33267 customGradient: attributes[customGradientAttribute], 33268 gradient: attributes[gradientAttribute] 33269 }; 33270 }, [clientId, gradientAttribute, customGradientAttribute]); 33271 const { 33272 updateBlockAttributes 33273 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 33274 const setGradient = (0,external_wp_element_namespaceObject.useCallback)(newGradientValue => { 33275 const slug = getGradientSlugByValue(allGradients, newGradientValue); 33276 33277 if (slug) { 33278 updateBlockAttributes(clientId, { 33279 [gradientAttribute]: slug, 33280 [customGradientAttribute]: undefined 33281 }); 33282 return; 33283 } 33284 33285 updateBlockAttributes(clientId, { 33286 [gradientAttribute]: undefined, 33287 [customGradientAttribute]: newGradientValue 33288 }); 33289 }, [allGradients, clientId, updateBlockAttributes]); 33290 33291 const gradientClass = __experimentalGetGradientClass(gradient); 33292 33293 let gradientValue; 33294 33295 if (gradient) { 33296 gradientValue = getGradientValueBySlug(allGradients, gradient); 33297 } else { 33298 gradientValue = customGradient; 33299 } 33300 33301 return { 33302 gradientClass, 33303 gradientValue, 33304 setGradient 33305 }; 33306 } 33307 33308 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/contrast-checker/index.js 33309 33310 33311 /** 33312 * External dependencies 33313 */ 33314 33315 33316 33317 /** 33318 * WordPress dependencies 33319 */ 33320 33321 33322 33323 33324 k([names, a11y]); 33325 33326 function ContrastChecker(_ref) { 33327 let { 33328 backgroundColor, 33329 fallbackBackgroundColor, 33330 fallbackTextColor, 33331 fallbackLinkColor, 33332 fontSize, 33333 // Font size value in pixels. 33334 isLargeText, 33335 textColor, 33336 linkColor, 33337 enableAlphaChecker = false 33338 } = _ref; 33339 const currentBackgroundColor = backgroundColor || fallbackBackgroundColor; // Must have a background color. 33340 33341 if (!currentBackgroundColor) { 33342 return null; 33343 } 33344 33345 const currentTextColor = textColor || fallbackTextColor; 33346 const currentLinkColor = linkColor || fallbackLinkColor; // Must have at least one text color. 33347 33348 if (!currentTextColor && !currentLinkColor) { 33349 return null; 33350 } 33351 33352 const textColors = [{ 33353 color: currentTextColor, 33354 description: (0,external_wp_i18n_namespaceObject.__)('text color') 33355 }, { 33356 color: currentLinkColor, 33357 description: (0,external_wp_i18n_namespaceObject.__)('link color') 33358 }]; 33359 const colordBackgroundColor = w(currentBackgroundColor); 33360 const backgroundColorHasTransparency = colordBackgroundColor.alpha() < 1; 33361 const backgroundColorBrightness = colordBackgroundColor.brightness(); 33362 const isReadableOptions = { 33363 level: 'AA', 33364 size: isLargeText || isLargeText !== false && fontSize >= 24 ? 'large' : 'small' 33365 }; 33366 let message = ''; 33367 let speakMessage = ''; 33368 33369 for (const item of textColors) { 33370 // If there is no color, go no further. 33371 if (!item.color) { 33372 continue; 33373 } 33374 33375 const colordTextColor = w(item.color); 33376 const isColordTextReadable = colordTextColor.isReadable(colordBackgroundColor, isReadableOptions); 33377 const textHasTransparency = colordTextColor.alpha() < 1; // If the contrast is not readable. 33378 33379 if (!isColordTextReadable) { 33380 // Don't show the message if the background or text is transparent. 33381 if (backgroundColorHasTransparency || textHasTransparency) { 33382 continue; 33383 } 33384 33385 message = backgroundColorBrightness < colordTextColor.brightness() ? (0,external_wp_i18n_namespaceObject.sprintf)( // translators: %s is a type of text color, e.g., "text color" or "link color". 33386 (0,external_wp_i18n_namespaceObject.__)('This color combination may be hard for people to read. Try using a darker background color and/or a brighter %s.'), item.description) : (0,external_wp_i18n_namespaceObject.sprintf)( // translators: %s is a type of text color, e.g., "text color" or "link color". 33387 (0,external_wp_i18n_namespaceObject.__)('This color combination may be hard for people to read. Try using a brighter background color and/or a darker %s.'), item.description); 33388 speakMessage = (0,external_wp_i18n_namespaceObject.__)('This color combination may be hard for people to read.'); // Break from the loop when we have a contrast warning. 33389 // These messages take priority over the transparency warning. 33390 33391 break; 33392 } // If there is no contrast warning and the text is transparent, 33393 // show the transparent warning if alpha check is enabled. 33394 33395 33396 if (textHasTransparency && enableAlphaChecker) { 33397 message = (0,external_wp_i18n_namespaceObject.__)('Transparent text may be hard for people to read.'); 33398 speakMessage = (0,external_wp_i18n_namespaceObject.__)('Transparent text may be hard for people to read.'); 33399 } 33400 } 33401 33402 if (!message) { 33403 return null; 33404 } // Note: The `Notice` component can speak messages via its `spokenMessage` 33405 // prop, but the contrast checker requires granular control over when the 33406 // announcements are made. Notably, the message will be re-announced if a 33407 // new color combination is selected and the contrast is still insufficient. 33408 33409 33410 (0,external_wp_a11y_namespaceObject.speak)(speakMessage); 33411 return (0,external_wp_element_namespaceObject.createElement)("div", { 33412 className: "block-editor-contrast-checker" 33413 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Notice, { 33414 spokenMessage: null, 33415 status: "warning", 33416 isDismissible: false 33417 }, message)); 33418 } 33419 /** 33420 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/contrast-checker/README.md 33421 */ 33422 33423 33424 /* harmony default export */ var contrast_checker = (ContrastChecker); 33425 33426 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/colors-gradients/tools-panel-color-dropdown.js 33427 33428 33429 33430 /** 33431 * External dependencies 33432 */ 33433 33434 /** 33435 * WordPress dependencies 33436 */ 33437 33438 33439 /** 33440 * Internal dependencies 33441 */ 33442 33443 33444 33445 function ToolsPanelColorDropdown(_ref) { 33446 var _settings$gradientVal; 33447 33448 let { 33449 settings, 33450 enableAlpha, 33451 ...otherProps 33452 } = _ref; 33453 const colorGradientSettings = useMultipleOriginColorsAndGradients(); 33454 const controlSettings = { ...colorGradientSettings, 33455 clearable: false, 33456 enableAlpha, 33457 label: settings.label, 33458 onColorChange: settings.onColorChange, 33459 onGradientChange: settings.onGradientChange, 33460 colorValue: settings.colorValue, 33461 gradientValue: settings.gradientValue 33462 }; 33463 const selectedColor = (_settings$gradientVal = settings.gradientValue) !== null && _settings$gradientVal !== void 0 ? _settings$gradientVal : settings.colorValue; 33464 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToolsPanelItem, _extends({ 33465 hasValue: settings.hasValue, 33466 label: settings.label, 33467 onDeselect: settings.onDeselect, 33468 isShownByDefault: settings.isShownByDefault, 33469 resetAllFilter: settings.resetAllFilter 33470 }, otherProps, { 33471 className: "block-editor-tools-panel-color-gradient-settings__item" 33472 }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Dropdown, { 33473 className: "block-editor-tools-panel-color-dropdown", 33474 contentClassName: "block-editor-panel-color-gradient-settings__dropdown-content", 33475 renderToggle: _ref2 => { 33476 let { 33477 isOpen, 33478 onToggle 33479 } = _ref2; 33480 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 33481 onClick: onToggle, 33482 "aria-expanded": isOpen, 33483 className: classnames_default()('block-editor-panel-color-gradient-settings__dropdown', { 33484 'is-open': isOpen 33485 }) 33486 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalHStack, { 33487 justify: "flex-start" 33488 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ColorIndicator, { 33489 className: "block-editor-panel-color-gradient-settings__color-indicator", 33490 colorValue: selectedColor 33491 }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FlexItem, null, settings.label))); 33492 }, 33493 renderContent: () => (0,external_wp_element_namespaceObject.createElement)(control, _extends({ 33494 showTitle: false, 33495 __experimentalHasMultipleOrigins: true, 33496 __experimentalIsRenderedInSidebar: true, 33497 enableAlpha: true 33498 }, controlSettings)) 33499 })); 33500 } 33501 33502 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/hooks/color-panel.js 33503 33504 33505 /** 33506 * WordPress dependencies 33507 */ 33508 33509 /** 33510 * Internal dependencies 33511 */ 33512 33513 33514 33515 33516 33517 33518 function getComputedStyle(node) { 33519 return node.ownerDocument.defaultView.getComputedStyle(node); 33520 } 33521 33522 function ColorPanel(_ref) { 33523 let { 33524 enableAlpha = false, 33525 settings, 33526 clientId, 33527 enableContrastChecking = true 33528 } = _ref; 33529 const [detectedBackgroundColor, setDetectedBackgroundColor] = (0,external_wp_element_namespaceObject.useState)(); 33530 const [detectedColor, setDetectedColor] = (0,external_wp_element_namespaceObject.useState)(); 33531 const [detectedLinkColor, setDetectedLinkColor] = (0,external_wp_element_namespaceObject.useState)(); 33532 const ref = useBlockRef(clientId); 33533 (0,external_wp_element_namespaceObject.useEffect)(() => { 33534 var _ref$current; 33535 33536 if (!enableContrastChecking) { 33537 return; 33538 } 33539 33540 if (!ref.current) { 33541 return; 33542 } 33543 33544 setDetectedColor(getComputedStyle(ref.current).color); 33545 const firstLinkElement = (_ref$current = ref.current) === null || _ref$current === void 0 ? void 0 : _ref$current.querySelector('a'); 33546 33547 if (firstLinkElement && !!firstLinkElement.innerText) { 33548 setDetectedLinkColor(getComputedStyle(firstLinkElement).color); 33549 } 33550 33551 let backgroundColorNode = ref.current; 33552 let backgroundColor = getComputedStyle(backgroundColorNode).backgroundColor; 33553 33554 while (backgroundColor === 'rgba(0, 0, 0, 0)' && backgroundColorNode.parentNode && backgroundColorNode.parentNode.nodeType === backgroundColorNode.parentNode.ELEMENT_NODE) { 33555 backgroundColorNode = backgroundColorNode.parentNode; 33556 backgroundColor = getComputedStyle(backgroundColorNode).backgroundColor; 33557 } 33558 33559 setDetectedBackgroundColor(backgroundColor); 33560 }); 33561 return (0,external_wp_element_namespaceObject.createElement)(inspector_controls, { 33562 __experimentalGroup: "color" 33563 }, settings.map((setting, index) => (0,external_wp_element_namespaceObject.createElement)(ToolsPanelColorDropdown, { 33564 key: index, 33565 settings: setting, 33566 panelId: clientId, 33567 enableAlpha: enableAlpha 33568 })), enableContrastChecking && (0,external_wp_element_namespaceObject.createElement)(contrast_checker, { 33569 backgroundColor: detectedBackgroundColor, 33570 textColor: detectedColor, 33571 enableAlphaChecker: enableAlpha, 33572 linkColor: detectedLinkColor 33573 })); 33574 } 33575 33576 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/hooks/color.js 33577 33578 33579 33580 /** 33581 * External dependencies 33582 */ 33583 33584 33585 /** 33586 * WordPress dependencies 33587 */ 33588 33589 33590 33591 33592 33593 33594 /** 33595 * Internal dependencies 33596 */ 33597 33598 33599 33600 33601 33602 33603 const COLOR_SUPPORT_KEY = 'color'; 33604 33605 const hasColorSupport = blockType => { 33606 const colorSupport = (0,external_wp_blocks_namespaceObject.getBlockSupport)(blockType, COLOR_SUPPORT_KEY); 33607 return colorSupport && (colorSupport.link === true || colorSupport.gradient === true || colorSupport.background !== false || colorSupport.text !== false); 33608 }; 33609 33610 const hasLinkColorSupport = blockType => { 33611 if (external_wp_element_namespaceObject.Platform.OS !== 'web') { 33612 return false; 33613 } 33614 33615 const colorSupport = (0,external_wp_blocks_namespaceObject.getBlockSupport)(blockType, COLOR_SUPPORT_KEY); 33616 return (0,external_lodash_namespaceObject.isObject)(colorSupport) && !!colorSupport.link; 33617 }; 33618 33619 const hasGradientSupport = blockType => { 33620 const colorSupport = (0,external_wp_blocks_namespaceObject.getBlockSupport)(blockType, COLOR_SUPPORT_KEY); 33621 return (0,external_lodash_namespaceObject.isObject)(colorSupport) && !!colorSupport.gradients; 33622 }; 33623 33624 const hasBackgroundColorSupport = blockType => { 33625 const colorSupport = (0,external_wp_blocks_namespaceObject.getBlockSupport)(blockType, COLOR_SUPPORT_KEY); 33626 return colorSupport && colorSupport.background !== false; 33627 }; 33628 33629 const hasTextColorSupport = blockType => { 33630 const colorSupport = (0,external_wp_blocks_namespaceObject.getBlockSupport)(blockType, COLOR_SUPPORT_KEY); 33631 return colorSupport && colorSupport.text !== false; 33632 }; 33633 /** 33634 * Checks whether a color has been set either with a named preset color in 33635 * a top level block attribute or as a custom value within the style attribute 33636 * object. 33637 * 33638 * @param {string} name Name of the color to check. 33639 * @return {boolean} Whether or not a color has a value. 33640 */ 33641 33642 33643 const hasColor = name => props => { 33644 var _props$attributes$sty9, _props$attributes$sty10; 33645 33646 if (name === 'background') { 33647 var _props$attributes$sty, _props$attributes$sty2, _props$attributes$sty3, _props$attributes$sty4; 33648 33649 return !!props.attributes.backgroundColor || !!((_props$attributes$sty = props.attributes.style) !== null && _props$attributes$sty !== void 0 && (_props$attributes$sty2 = _props$attributes$sty.color) !== null && _props$attributes$sty2 !== void 0 && _props$attributes$sty2.background) || !!props.attributes.gradient || !!((_props$attributes$sty3 = props.attributes.style) !== null && _props$attributes$sty3 !== void 0 && (_props$attributes$sty4 = _props$attributes$sty3.color) !== null && _props$attributes$sty4 !== void 0 && _props$attributes$sty4.gradient); 33650 } 33651 33652 if (name === 'link') { 33653 var _props$attributes$sty5, _props$attributes$sty6, _props$attributes$sty7, _props$attributes$sty8; 33654 33655 return !!((_props$attributes$sty5 = props.attributes.style) !== null && _props$attributes$sty5 !== void 0 && (_props$attributes$sty6 = _props$attributes$sty5.elements) !== null && _props$attributes$sty6 !== void 0 && (_props$attributes$sty7 = _props$attributes$sty6.link) !== null && _props$attributes$sty7 !== void 0 && (_props$attributes$sty8 = _props$attributes$sty7.color) !== null && _props$attributes$sty8 !== void 0 && _props$attributes$sty8.text); 33656 } 33657 33658 return !!props.attributes[`$name}Color`] || !!((_props$attributes$sty9 = props.attributes.style) !== null && _props$attributes$sty9 !== void 0 && (_props$attributes$sty10 = _props$attributes$sty9.color) !== null && _props$attributes$sty10 !== void 0 && _props$attributes$sty10[name]); 33659 }; 33660 /** 33661 * Clears a single color property from a style object. 33662 * 33663 * @param {Array} path Path to color property to clear within styles object. 33664 * @param {Object} style Block attributes style object. 33665 * @return {Object} Styles with the color property omitted. 33666 */ 33667 33668 33669 const clearColorFromStyles = (path, style) => cleanEmptyObject(immutableSet(style, path, undefined)); 33670 /** 33671 * Resets the block attributes for text color. 33672 * 33673 * @param {Object} props Current block props. 33674 * @param {Object} props.attributes Block attributes. 33675 * @param {Function} props.setAttributes Block's setAttributes prop used to apply reset. 33676 */ 33677 33678 33679 const resetTextColor = _ref => { 33680 let { 33681 attributes, 33682 setAttributes 33683 } = _ref; 33684 setAttributes({ 33685 textColor: undefined, 33686 style: clearColorFromStyles(['color', 'text'], attributes.style) 33687 }); 33688 }; 33689 /** 33690 * Clears text color related properties from supplied attributes. 33691 * 33692 * @param {Object} attributes Block attributes. 33693 * @return {Object} Update block attributes with text color properties omitted. 33694 */ 33695 33696 33697 const resetAllTextFilter = attributes => ({ 33698 textColor: undefined, 33699 style: clearColorFromStyles(['color', 'text'], attributes.style) 33700 }); 33701 /** 33702 * Resets the block attributes for link color. 33703 * 33704 * @param {Object} props Current block props. 33705 * @param {Object} props.attributes Block attributes. 33706 * @param {Function} props.setAttributes Block's setAttributes prop used to apply reset. 33707 */ 33708 33709 33710 const resetLinkColor = _ref2 => { 33711 let { 33712 attributes, 33713 setAttributes 33714 } = _ref2; 33715 const path = ['elements', 'link', 'color', 'text']; 33716 setAttributes({ 33717 style: clearColorFromStyles(path, attributes.style) 33718 }); 33719 }; 33720 /** 33721 * Clears link color related properties from supplied attributes. 33722 * 33723 * @param {Object} attributes Block attributes. 33724 * @return {Object} Update block attributes with link color properties omitted. 33725 */ 33726 33727 33728 const resetAllLinkFilter = attributes => ({ 33729 style: clearColorFromStyles(['elements', 'link', 'color', 'text'], attributes.style) 33730 }); 33731 /** 33732 * Clears all background color related properties including gradients from 33733 * supplied block attributes. 33734 * 33735 * @param {Object} attributes Block attributes. 33736 * @return {Object} Block attributes with background and gradient omitted. 33737 */ 33738 33739 33740 const clearBackgroundAndGradient = attributes => { 33741 var _attributes$style; 33742 33743 return { 33744 backgroundColor: undefined, 33745 gradient: undefined, 33746 style: { ...attributes.style, 33747 color: { ...((_attributes$style = attributes.style) === null || _attributes$style === void 0 ? void 0 : _attributes$style.color), 33748 background: undefined, 33749 gradient: undefined 33750 } 33751 } 33752 }; 33753 }; 33754 /** 33755 * Resets the block attributes for both background color and gradient. 33756 * 33757 * @param {Object} props Current block props. 33758 * @param {Object} props.attributes Block attributes. 33759 * @param {Function} props.setAttributes Block's setAttributes prop used to apply reset. 33760 */ 33761 33762 33763 const resetBackgroundAndGradient = _ref3 => { 33764 let { 33765 attributes, 33766 setAttributes 33767 } = _ref3; 33768 setAttributes(clearBackgroundAndGradient(attributes)); 33769 }; 33770 /** 33771 * Filters registered block settings, extending attributes to include 33772 * `backgroundColor` and `textColor` attribute. 33773 * 33774 * @param {Object} settings Original block settings. 33775 * 33776 * @return {Object} Filtered block settings. 33777 */ 33778 33779 33780 function color_addAttributes(settings) { 33781 if (!hasColorSupport(settings)) { 33782 return settings; 33783 } // Allow blocks to specify their own attribute definition with default values if needed. 33784 33785 33786 if (!settings.attributes.backgroundColor) { 33787 Object.assign(settings.attributes, { 33788 backgroundColor: { 33789 type: 'string' 33790 } 33791 }); 33792 } 33793 33794 if (!settings.attributes.textColor) { 33795 Object.assign(settings.attributes, { 33796 textColor: { 33797 type: 'string' 33798 } 33799 }); 33800 } 33801 33802 if (hasGradientSupport(settings) && !settings.attributes.gradient) { 33803 Object.assign(settings.attributes, { 33804 gradient: { 33805 type: 'string' 33806 } 33807 }); 33808 } 33809 33810 return settings; 33811 } 33812 /** 33813 * Override props assigned to save component to inject colors classnames. 33814 * 33815 * @param {Object} props Additional props applied to save element. 33816 * @param {Object} blockType Block type. 33817 * @param {Object} attributes Block attributes. 33818 * 33819 * @return {Object} Filtered props applied to save element. 33820 */ 33821 33822 33823 function color_addSaveProps(props, blockType, attributes) { 33824 var _style$color, _style$color2, _style$color3, _style$color4, _style$elements, _style$elements$link; 33825 33826 if (!hasColorSupport(blockType) || shouldSkipSerialization(blockType, COLOR_SUPPORT_KEY)) { 33827 return props; 33828 } 33829 33830 const hasGradient = hasGradientSupport(blockType); // I'd have preferred to avoid the "style" attribute usage here 33831 33832 const { 33833 backgroundColor, 33834 textColor, 33835 gradient, 33836 style 33837 } = attributes; 33838 33839 const shouldSerialize = feature => !shouldSkipSerialization(blockType, COLOR_SUPPORT_KEY, feature); // Primary color classes must come before the `has-text-color`, 33840 // `has-background` and `has-link-color` classes to maintain backwards 33841 // compatibility and avoid block invalidations. 33842 33843 33844 const textClass = shouldSerialize('text') ? getColorClassName('color', textColor) : undefined; 33845 const gradientClass = shouldSerialize('gradients') ? __experimentalGetGradientClass(gradient) : undefined; 33846 const backgroundClass = shouldSerialize('background') ? getColorClassName('background-color', backgroundColor) : undefined; 33847 const serializeHasBackground = shouldSerialize('background') || shouldSerialize('gradients'); 33848 const hasBackground = backgroundColor || (style === null || style === void 0 ? void 0 : (_style$color = style.color) === null || _style$color === void 0 ? void 0 : _style$color.background) || hasGradient && (gradient || (style === null || style === void 0 ? void 0 : (_style$color2 = style.color) === null || _style$color2 === void 0 ? void 0 : _style$color2.gradient)); 33849 const newClassName = classnames_default()(props.className, textClass, gradientClass, { 33850 // Don't apply the background class if there's a custom gradient. 33851 [backgroundClass]: (!hasGradient || !(style !== null && style !== void 0 && (_style$color3 = style.color) !== null && _style$color3 !== void 0 && _style$color3.gradient)) && !!backgroundClass, 33852 'has-text-color': shouldSerialize('text') && (textColor || (style === null || style === void 0 ? void 0 : (_style$color4 = style.color) === null || _style$color4 === void 0 ? void 0 : _style$color4.text)), 33853 'has-background': serializeHasBackground && hasBackground, 33854 'has-link-color': shouldSerialize('link') && (style === null || style === void 0 ? void 0 : (_style$elements = style.elements) === null || _style$elements === void 0 ? void 0 : (_style$elements$link = _style$elements.link) === null || _style$elements$link === void 0 ? void 0 : _style$elements$link.color) 33855 }); 33856 props.className = newClassName ? newClassName : undefined; 33857 return props; 33858 } 33859 /** 33860 * Filters registered block settings to extend the block edit wrapper 33861 * to apply the desired styles and classnames properly. 33862 * 33863 * @param {Object} settings Original block settings. 33864 * 33865 * @return {Object} Filtered block settings. 33866 */ 33867 33868 function color_addEditProps(settings) { 33869 if (!hasColorSupport(settings) || shouldSkipSerialization(settings, COLOR_SUPPORT_KEY)) { 33870 return settings; 33871 } 33872 33873 const existingGetEditWrapperProps = settings.getEditWrapperProps; 33874 33875 settings.getEditWrapperProps = attributes => { 33876 let props = {}; 33877 33878 if (existingGetEditWrapperProps) { 33879 props = existingGetEditWrapperProps(attributes); 33880 } 33881 33882 return color_addSaveProps(props, settings, attributes); 33883 }; 33884 33885 return settings; 33886 } 33887 33888 const getLinkColorFromAttributeValue = (colors, value) => { 33889 const attributeParsed = /var:preset\|color\|(.+)/.exec(value); 33890 33891 if (attributeParsed && attributeParsed[1]) { 33892 return getColorObjectByAttributeValues(colors, attributeParsed[1]).color; 33893 } 33894 33895 return value; 33896 }; 33897 /** 33898 * Inspector control panel containing the color related configuration 33899 * 33900 * @param {Object} props 33901 * 33902 * @return {WPElement} Color edit element. 33903 */ 33904 33905 33906 function ColorEdit(props) { 33907 var _style$color6, _style$color7, _style$color8, _style$elements2, _style$elements2$link, _style$elements2$link2, _style$elements3, _style$elements3$link, _style$elements3$link2; 33908 33909 const { 33910 name: blockName, 33911 attributes 33912 } = props; // Some color settings have a special handling for deprecated flags in `useSetting`, 33913 // so we can't unwrap them by doing const { ... } = useSetting('color') 33914 // until https://github.com/WordPress/gutenberg/issues/37094 is fixed. 33915 33916 const userPalette = useSetting('color.palette.custom'); 33917 const themePalette = useSetting('color.palette.theme'); 33918 const defaultPalette = useSetting('color.palette.default'); 33919 const allSolids = (0,external_wp_element_namespaceObject.useMemo)(() => [...(userPalette || []), ...(themePalette || []), ...(defaultPalette || [])], [userPalette, themePalette, defaultPalette]); 33920 const userGradientPalette = useSetting('color.gradients.custom'); 33921 const themeGradientPalette = useSetting('color.gradients.theme'); 33922 const defaultGradientPalette = useSetting('color.gradients.default'); 33923 const allGradients = (0,external_wp_element_namespaceObject.useMemo)(() => [...(userGradientPalette || []), ...(themeGradientPalette || []), ...(defaultGradientPalette || [])], [userGradientPalette, themeGradientPalette, defaultGradientPalette]); 33924 const areCustomSolidsEnabled = useSetting('color.custom'); 33925 const areCustomGradientsEnabled = useSetting('color.customGradient'); 33926 const isBackgroundEnabled = useSetting('color.background'); 33927 const isLinkEnabled = useSetting('color.link'); 33928 const isTextEnabled = useSetting('color.text'); 33929 const solidsEnabled = areCustomSolidsEnabled || !themePalette || (themePalette === null || themePalette === void 0 ? void 0 : themePalette.length) > 0; 33930 const gradientsEnabled = areCustomGradientsEnabled || !themeGradientPalette || (themeGradientPalette === null || themeGradientPalette === void 0 ? void 0 : themeGradientPalette.length) > 0; // Shouldn't be needed but right now the ColorGradientsPanel 33931 // can trigger both onChangeColor and onChangeBackground 33932 // synchronously causing our two callbacks to override changes 33933 // from each other. 33934 33935 const localAttributes = (0,external_wp_element_namespaceObject.useRef)(attributes); 33936 (0,external_wp_element_namespaceObject.useEffect)(() => { 33937 localAttributes.current = attributes; 33938 }, [attributes]); 33939 33940 if (!hasColorSupport(blockName)) { 33941 return null; 33942 } 33943 33944 const hasLinkColor = hasLinkColorSupport(blockName) && isLinkEnabled && solidsEnabled; 33945 const hasTextColor = hasTextColorSupport(blockName) && isTextEnabled && solidsEnabled; 33946 const hasBackgroundColor = hasBackgroundColorSupport(blockName) && isBackgroundEnabled && solidsEnabled; 33947 const hasGradientColor = hasGradientSupport(blockName) && gradientsEnabled; 33948 33949 if (!hasLinkColor && !hasTextColor && !hasBackgroundColor && !hasGradientColor) { 33950 return null; 33951 } 33952 33953 const { 33954 style, 33955 textColor, 33956 backgroundColor, 33957 gradient 33958 } = attributes; 33959 let gradientValue; 33960 33961 if (hasGradientColor && gradient) { 33962 gradientValue = getGradientValueBySlug(allGradients, gradient); 33963 } else if (hasGradientColor) { 33964 var _style$color5; 33965 33966 gradientValue = style === null || style === void 0 ? void 0 : (_style$color5 = style.color) === null || _style$color5 === void 0 ? void 0 : _style$color5.gradient; 33967 } 33968 33969 const onChangeColor = name => value => { 33970 var _localAttributes$curr, _localAttributes$curr2; 33971 33972 const colorObject = getColorObjectByColorValue(allSolids, value); 33973 const attributeName = name + 'Color'; 33974 const newStyle = { ...localAttributes.current.style, 33975 color: { ...((_localAttributes$curr = localAttributes.current) === null || _localAttributes$curr === void 0 ? void 0 : (_localAttributes$curr2 = _localAttributes$curr.style) === null || _localAttributes$curr2 === void 0 ? void 0 : _localAttributes$curr2.color), 33976 [name]: colorObject !== null && colorObject !== void 0 && colorObject.slug ? undefined : value 33977 } 33978 }; 33979 const newNamedColor = colorObject !== null && colorObject !== void 0 && colorObject.slug ? colorObject.slug : undefined; 33980 const newAttributes = { 33981 style: cleanEmptyObject(newStyle), 33982 [attributeName]: newNamedColor 33983 }; 33984 props.setAttributes(newAttributes); 33985 localAttributes.current = { ...localAttributes.current, 33986 ...newAttributes 33987 }; 33988 }; 33989 33990 const onChangeGradient = value => { 33991 const slug = getGradientSlugByValue(allGradients, value); 33992 let newAttributes; 33993 33994 if (slug) { 33995 var _localAttributes$curr3, _localAttributes$curr4, _localAttributes$curr5; 33996 33997 const newStyle = { ...((_localAttributes$curr3 = localAttributes.current) === null || _localAttributes$curr3 === void 0 ? void 0 : _localAttributes$curr3.style), 33998 color: { ...((_localAttributes$curr4 = localAttributes.current) === null || _localAttributes$curr4 === void 0 ? void 0 : (_localAttributes$curr5 = _localAttributes$curr4.style) === null || _localAttributes$curr5 === void 0 ? void 0 : _localAttributes$curr5.color), 33999 gradient: undefined 34000 } 34001 }; 34002 newAttributes = { 34003 style: cleanEmptyObject(newStyle), 34004 gradient: slug 34005 }; 34006 } else { 34007 var _localAttributes$curr6, _localAttributes$curr7, _localAttributes$curr8; 34008 34009 const newStyle = { ...((_localAttributes$curr6 = localAttributes.current) === null || _localAttributes$curr6 === void 0 ? void 0 : _localAttributes$curr6.style), 34010 color: { ...((_localAttributes$curr7 = localAttributes.current) === null || _localAttributes$curr7 === void 0 ? void 0 : (_localAttributes$curr8 = _localAttributes$curr7.style) === null || _localAttributes$curr8 === void 0 ? void 0 : _localAttributes$curr8.color), 34011 gradient: value 34012 } 34013 }; 34014 newAttributes = { 34015 style: cleanEmptyObject(newStyle), 34016 gradient: undefined 34017 }; 34018 } 34019 34020 props.setAttributes(newAttributes); 34021 localAttributes.current = { ...localAttributes.current, 34022 ...newAttributes 34023 }; 34024 }; 34025 34026 const onChangeLinkColor = value => { 34027 const colorObject = getColorObjectByColorValue(allSolids, value); 34028 const newLinkColorValue = colorObject !== null && colorObject !== void 0 && colorObject.slug ? `var:preset|color|$colorObject.slug}` : value; 34029 const newStyle = cleanEmptyObject(immutableSet(style, ['elements', 'link', 'color', 'text'], newLinkColorValue)); 34030 props.setAttributes({ 34031 style: newStyle 34032 }); 34033 }; 34034 34035 const enableContrastChecking = external_wp_element_namespaceObject.Platform.OS === 'web' && !gradient && !(style !== null && style !== void 0 && (_style$color6 = style.color) !== null && _style$color6 !== void 0 && _style$color6.gradient); 34036 const defaultColorControls = (0,external_wp_blocks_namespaceObject.getBlockSupport)(props.name, [COLOR_SUPPORT_KEY, '__experimentalDefaultControls']); 34037 return (0,external_wp_element_namespaceObject.createElement)(ColorPanel, { 34038 enableContrastChecking: enableContrastChecking, 34039 clientId: props.clientId, 34040 enableAlpha: true, 34041 settings: [...(hasTextColor ? [{ 34042 label: (0,external_wp_i18n_namespaceObject.__)('Text'), 34043 onColorChange: onChangeColor('text'), 34044 colorValue: getColorObjectByAttributeValues(allSolids, textColor, style === null || style === void 0 ? void 0 : (_style$color7 = style.color) === null || _style$color7 === void 0 ? void 0 : _style$color7.text).color, 34045 isShownByDefault: defaultColorControls === null || defaultColorControls === void 0 ? void 0 : defaultColorControls.text, 34046 hasValue: () => hasColor('text')(props), 34047 onDeselect: () => resetTextColor(props), 34048 resetAllFilter: resetAllTextFilter 34049 }] : []), ...(hasBackgroundColor || hasGradientColor ? [{ 34050 label: (0,external_wp_i18n_namespaceObject.__)('Background'), 34051 onColorChange: hasBackgroundColor ? onChangeColor('background') : undefined, 34052 colorValue: getColorObjectByAttributeValues(allSolids, backgroundColor, style === null || style === void 0 ? void 0 : (_style$color8 = style.color) === null || _style$color8 === void 0 ? void 0 : _style$color8.background).color, 34053 gradientValue, 34054 onGradientChange: hasGradientColor ? onChangeGradient : undefined, 34055 isShownByDefault: defaultColorControls === null || defaultColorControls === void 0 ? void 0 : defaultColorControls.background, 34056 hasValue: () => hasColor('background')(props), 34057 onDeselect: () => resetBackgroundAndGradient(props), 34058 resetAllFilter: clearBackgroundAndGradient 34059 }] : []), ...(hasLinkColor ? [{ 34060 label: (0,external_wp_i18n_namespaceObject.__)('Link'), 34061 onColorChange: onChangeLinkColor, 34062 colorValue: getLinkColorFromAttributeValue(allSolids, style === null || style === void 0 ? void 0 : (_style$elements2 = style.elements) === null || _style$elements2 === void 0 ? void 0 : (_style$elements2$link = _style$elements2.link) === null || _style$elements2$link === void 0 ? void 0 : (_style$elements2$link2 = _style$elements2$link.color) === null || _style$elements2$link2 === void 0 ? void 0 : _style$elements2$link2.text), 34063 clearable: !!(style !== null && style !== void 0 && (_style$elements3 = style.elements) !== null && _style$elements3 !== void 0 && (_style$elements3$link = _style$elements3.link) !== null && _style$elements3$link !== void 0 && (_style$elements3$link2 = _style$elements3$link.color) !== null && _style$elements3$link2 !== void 0 && _style$elements3$link2.text), 34064 isShownByDefault: defaultColorControls === null || defaultColorControls === void 0 ? void 0 : defaultColorControls.link, 34065 hasValue: () => hasColor('link')(props), 34066 onDeselect: () => resetLinkColor(props), 34067 resetAllFilter: resetAllLinkFilter 34068 }] : [])] 34069 }); 34070 } 34071 /** 34072 * This adds inline styles for color palette colors. 34073 * Ideally, this is not needed and themes should load their palettes on the editor. 34074 * 34075 * @param {Function} BlockListBlock Original component. 34076 * 34077 * @return {Function} Wrapped component. 34078 */ 34079 34080 const withColorPaletteStyles = (0,external_wp_compose_namespaceObject.createHigherOrderComponent)(BlockListBlock => props => { 34081 var _props$wrapperProps; 34082 34083 const { 34084 name, 34085 attributes 34086 } = props; 34087 const { 34088 backgroundColor, 34089 textColor 34090 } = attributes; 34091 const userPalette = useSetting('color.palette.custom') || []; 34092 const themePalette = useSetting('color.palette.theme') || []; 34093 const defaultPalette = useSetting('color.palette.default') || []; 34094 const colors = (0,external_wp_element_namespaceObject.useMemo)(() => [...(userPalette || []), ...(themePalette || []), ...(defaultPalette || [])], [userPalette, themePalette, defaultPalette]); 34095 34096 if (!hasColorSupport(name) || shouldSkipSerialization(name, COLOR_SUPPORT_KEY)) { 34097 return (0,external_wp_element_namespaceObject.createElement)(BlockListBlock, props); 34098 } 34099 34100 const extraStyles = {}; 34101 34102 if (textColor && !shouldSkipSerialization(name, COLOR_SUPPORT_KEY, 'text')) { 34103 var _getColorObjectByAttr; 34104 34105 extraStyles.color = (_getColorObjectByAttr = getColorObjectByAttributeValues(colors, textColor)) === null || _getColorObjectByAttr === void 0 ? void 0 : _getColorObjectByAttr.color; 34106 } 34107 34108 if (backgroundColor && !shouldSkipSerialization(name, COLOR_SUPPORT_KEY, 'background')) { 34109 var _getColorObjectByAttr2; 34110 34111 extraStyles.backgroundColor = (_getColorObjectByAttr2 = getColorObjectByAttributeValues(colors, backgroundColor)) === null || _getColorObjectByAttr2 === void 0 ? void 0 : _getColorObjectByAttr2.color; 34112 } 34113 34114 let wrapperProps = props.wrapperProps; 34115 wrapperProps = { ...props.wrapperProps, 34116 style: { ...extraStyles, 34117 ...((_props$wrapperProps = props.wrapperProps) === null || _props$wrapperProps === void 0 ? void 0 : _props$wrapperProps.style) 34118 } 34119 }; 34120 return (0,external_wp_element_namespaceObject.createElement)(BlockListBlock, _extends({}, props, { 34121 wrapperProps: wrapperProps 34122 })); 34123 }); 34124 const MIGRATION_PATHS = { 34125 linkColor: [['style', 'elements', 'link', 'color', 'text']], 34126 textColor: [['textColor'], ['style', 'color', 'text']], 34127 backgroundColor: [['backgroundColor'], ['style', 'color', 'background']], 34128 gradient: [['gradient'], ['style', 'color', 'gradient']] 34129 }; 34130 function color_addTransforms(result, source, index, results) { 34131 const destinationBlockType = result.name; 34132 const activeSupports = { 34133 linkColor: hasLinkColorSupport(destinationBlockType), 34134 textColor: hasTextColorSupport(destinationBlockType), 34135 backgroundColor: hasBackgroundColorSupport(destinationBlockType), 34136 gradient: hasGradientSupport(destinationBlockType) 34137 }; 34138 return transformStyles(activeSupports, MIGRATION_PATHS, result, source, index, results); 34139 } 34140 (0,external_wp_hooks_namespaceObject.addFilter)('blocks.registerBlockType', 'core/color/addAttribute', color_addAttributes); 34141 (0,external_wp_hooks_namespaceObject.addFilter)('blocks.getSaveContent.extraProps', 'core/color/addSaveProps', color_addSaveProps); 34142 (0,external_wp_hooks_namespaceObject.addFilter)('blocks.registerBlockType', 'core/color/addEditProps', color_addEditProps); 34143 (0,external_wp_hooks_namespaceObject.addFilter)('editor.BlockListBlock', 'core/color/with-color-palette-styles', withColorPaletteStyles); 34144 (0,external_wp_hooks_namespaceObject.addFilter)('blocks.switchToBlockType.transformedBlock', 'core/color/addTransforms', color_addTransforms); 34145 34146 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/font-appearance-control/index.js 34147 34148 34149 /** 34150 * WordPress dependencies 34151 */ 34152 34153 34154 34155 const FONT_STYLES = [{ 34156 name: (0,external_wp_i18n_namespaceObject._x)('Regular', 'font style'), 34157 value: 'normal' 34158 }, { 34159 name: (0,external_wp_i18n_namespaceObject._x)('Italic', 'font style'), 34160 value: 'italic' 34161 }]; 34162 const FONT_WEIGHTS = [{ 34163 name: (0,external_wp_i18n_namespaceObject._x)('Thin', 'font weight'), 34164 value: '100' 34165 }, { 34166 name: (0,external_wp_i18n_namespaceObject._x)('Extra Light', 'font weight'), 34167 value: '200' 34168 }, { 34169 name: (0,external_wp_i18n_namespaceObject._x)('Light', 'font weight'), 34170 value: '300' 34171 }, { 34172 name: (0,external_wp_i18n_namespaceObject._x)('Regular', 'font weight'), 34173 value: '400' 34174 }, { 34175 name: (0,external_wp_i18n_namespaceObject._x)('Medium', 'font weight'), 34176 value: '500' 34177 }, { 34178 name: (0,external_wp_i18n_namespaceObject._x)('Semi Bold', 'font weight'), 34179 value: '600' 34180 }, { 34181 name: (0,external_wp_i18n_namespaceObject._x)('Bold', 'font weight'), 34182 value: '700' 34183 }, { 34184 name: (0,external_wp_i18n_namespaceObject._x)('Extra Bold', 'font weight'), 34185 value: '800' 34186 }, { 34187 name: (0,external_wp_i18n_namespaceObject._x)('Black', 'font weight'), 34188 value: '900' 34189 }]; 34190 /** 34191 * Adjusts font appearance field label in case either font styles or weights 34192 * are disabled. 34193 * 34194 * @param {boolean} hasFontStyles Whether font styles are enabled and present. 34195 * @param {boolean} hasFontWeights Whether font weights are enabled and present. 34196 * @return {string} A label representing what font appearance is being edited. 34197 */ 34198 34199 const getFontAppearanceLabel = (hasFontStyles, hasFontWeights) => { 34200 if (!hasFontStyles) { 34201 return (0,external_wp_i18n_namespaceObject.__)('Font weight'); 34202 } 34203 34204 if (!hasFontWeights) { 34205 return (0,external_wp_i18n_namespaceObject.__)('Font style'); 34206 } 34207 34208 return (0,external_wp_i18n_namespaceObject.__)('Appearance'); 34209 }; 34210 /** 34211 * Control to display unified font style and weight options. 34212 * 34213 * @param {Object} props Component props. 34214 * 34215 * @return {WPElement} Font appearance control. 34216 */ 34217 34218 function FontAppearanceControl(props) { 34219 const { 34220 onChange, 34221 hasFontStyles = true, 34222 hasFontWeights = true, 34223 value: { 34224 fontStyle, 34225 fontWeight 34226 } 34227 } = props; 34228 const hasStylesOrWeights = hasFontStyles || hasFontWeights; 34229 const label = getFontAppearanceLabel(hasFontStyles, hasFontWeights); 34230 const defaultOption = { 34231 key: 'default', 34232 name: (0,external_wp_i18n_namespaceObject.__)('Default'), 34233 style: { 34234 fontStyle: undefined, 34235 fontWeight: undefined 34236 } 34237 }; // Combines both font style and weight options into a single dropdown. 34238 34239 const combineOptions = () => { 34240 const combinedOptions = [defaultOption]; 34241 FONT_STYLES.forEach(_ref => { 34242 let { 34243 name: styleName, 34244 value: styleValue 34245 } = _ref; 34246 FONT_WEIGHTS.forEach(_ref2 => { 34247 let { 34248 name: weightName, 34249 value: weightValue 34250 } = _ref2; 34251 const optionName = styleValue === 'normal' ? weightName : (0,external_wp_i18n_namespaceObject.sprintf)( 34252 /* translators: 1: Font weight name. 2: Font style name. */ 34253 (0,external_wp_i18n_namespaceObject.__)('%1$s %2$s'), weightName, styleName); 34254 combinedOptions.push({ 34255 key: `$styleValue}-$weightValue}`, 34256 name: optionName, 34257 style: { 34258 fontStyle: styleValue, 34259 fontWeight: weightValue 34260 } 34261 }); 34262 }); 34263 }); 34264 return combinedOptions; 34265 }; // Generates select options for font styles only. 34266 34267 34268 const styleOptions = () => { 34269 const combinedOptions = [defaultOption]; 34270 FONT_STYLES.forEach(_ref3 => { 34271 let { 34272 name, 34273 value 34274 } = _ref3; 34275 combinedOptions.push({ 34276 key: value, 34277 name, 34278 style: { 34279 fontStyle: value, 34280 fontWeight: undefined 34281 } 34282 }); 34283 }); 34284 return combinedOptions; 34285 }; // Generates select options for font weights only. 34286 34287 34288 const weightOptions = () => { 34289 const combinedOptions = [defaultOption]; 34290 FONT_WEIGHTS.forEach(_ref4 => { 34291 let { 34292 name, 34293 value 34294 } = _ref4; 34295 combinedOptions.push({ 34296 key: value, 34297 name, 34298 style: { 34299 fontStyle: undefined, 34300 fontWeight: value 34301 } 34302 }); 34303 }); 34304 return combinedOptions; 34305 }; // Map font styles and weights to select options. 34306 34307 34308 const selectOptions = (0,external_wp_element_namespaceObject.useMemo)(() => { 34309 if (hasFontStyles && hasFontWeights) { 34310 return combineOptions(); 34311 } 34312 34313 return hasFontStyles ? styleOptions() : weightOptions(); 34314 }, [props.options]); // Find current selection by comparing font style & weight against options, 34315 // and fall back to the Default option if there is no matching option. 34316 34317 const currentSelection = selectOptions.find(option => option.style.fontStyle === fontStyle && option.style.fontWeight === fontWeight) || selectOptions[0]; // Adjusts screen reader description based on styles or weights. 34318 34319 const getDescribedBy = () => { 34320 if (!currentSelection) { 34321 return (0,external_wp_i18n_namespaceObject.__)('No selected font appearance'); 34322 } 34323 34324 if (!hasFontStyles) { 34325 return (0,external_wp_i18n_namespaceObject.sprintf)( // translators: %s: Currently selected font weight. 34326 (0,external_wp_i18n_namespaceObject.__)('Currently selected font weight: %s'), currentSelection.name); 34327 } 34328 34329 if (!hasFontWeights) { 34330 return (0,external_wp_i18n_namespaceObject.sprintf)( // translators: %s: Currently selected font style. 34331 (0,external_wp_i18n_namespaceObject.__)('Currently selected font style: %s'), currentSelection.name); 34332 } 34333 34334 return (0,external_wp_i18n_namespaceObject.sprintf)( // translators: %s: Currently selected font appearance. 34335 (0,external_wp_i18n_namespaceObject.__)('Currently selected font appearance: %s'), currentSelection.name); 34336 }; 34337 34338 return hasStylesOrWeights && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.CustomSelectControl, { 34339 className: "components-font-appearance-control", 34340 label: label, 34341 describedBy: getDescribedBy(), 34342 options: selectOptions, 34343 value: currentSelection, 34344 onChange: _ref5 => { 34345 let { 34346 selectedItem 34347 } = _ref5; 34348 return onChange(selectedItem.style); 34349 } 34350 }); 34351 } 34352 34353 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/line-height-control/utils.js 34354 const BASE_DEFAULT_VALUE = 1.5; 34355 const STEP = 0.1; 34356 /** 34357 * There are varying value types within LineHeightControl: 34358 * 34359 * {undefined} Initial value. No changes from the user. 34360 * {string} Input value. Value consumed/outputted by the input. Empty would be ''. 34361 * {number} Block attribute type. Input value needs to be converted for attribute setting. 34362 * 34363 * Note: If the value is undefined, the input requires it to be an empty string ('') 34364 * in order to be considered "controlled" by props (rather than internal state). 34365 */ 34366 34367 const RESET_VALUE = ''; 34368 /** 34369 * Determines if the lineHeight attribute has been properly defined. 34370 * 34371 * @param {any} lineHeight The value to check. 34372 * 34373 * @return {boolean} Whether the lineHeight attribute is valid. 34374 */ 34375 34376 function isLineHeightDefined(lineHeight) { 34377 return lineHeight !== undefined && lineHeight !== RESET_VALUE; 34378 } 34379 34380 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/line-height-control/index.js 34381 34382 34383 /** 34384 * WordPress dependencies 34385 */ 34386 34387 34388 34389 /** 34390 * Internal dependencies 34391 */ 34392 34393 34394 34395 const LineHeightControl = _ref => { 34396 let { 34397 value: lineHeight, 34398 onChange, 34399 34400 /** Start opting into the new margin-free styles that will become the default in a future version. */ 34401 __nextHasNoMarginBottom = false, 34402 __unstableInputWidth = '60px' 34403 } = _ref; 34404 const isDefined = isLineHeightDefined(lineHeight); 34405 34406 const adjustNextValue = (nextValue, wasTypedOrPasted) => { 34407 // Set the next value without modification if lineHeight has been defined. 34408 if (isDefined) return nextValue; 34409 /** 34410 * The following logic handles the initial step up/down action 34411 * (from an undefined value state) so that the next values are better suited for 34412 * line-height rendering. For example, the first step up should immediately 34413 * go to 1.6, rather than the normally expected 0.1. 34414 * 34415 * Step up/down actions can be triggered by keydowns of the up/down arrow keys, 34416 * or by clicking the spin buttons. 34417 */ 34418 34419 switch (`$nextValue}`) { 34420 case `$STEP}`: 34421 // Increment by step value. 34422 return BASE_DEFAULT_VALUE + STEP; 34423 34424 case '0': 34425 { 34426 // This means the user explicitly input '0', rather than stepped down 34427 // from an undefined value state. 34428 if (wasTypedOrPasted) return nextValue; // Decrement by step value. 34429 34430 return BASE_DEFAULT_VALUE - STEP; 34431 } 34432 34433 case '': 34434 return BASE_DEFAULT_VALUE; 34435 34436 default: 34437 return nextValue; 34438 } 34439 }; 34440 34441 const stateReducer = (state, action) => { 34442 var _action$payload$event; 34443 34444 // Be careful when changing this — cross-browser behavior of the 34445 // `inputType` field in `input` events are inconsistent. 34446 // For example, Firefox emits an input event with inputType="insertReplacementText" 34447 // on spin button clicks, while other browsers do not even emit an input event. 34448 const wasTypedOrPasted = ['insertText', 'insertFromPaste'].includes((_action$payload$event = action.payload.event.nativeEvent) === null || _action$payload$event === void 0 ? void 0 : _action$payload$event.inputType); 34449 const value = adjustNextValue(state.value, wasTypedOrPasted); 34450 return { ...state, 34451 value 34452 }; 34453 }; 34454 34455 const value = isDefined ? lineHeight : RESET_VALUE; 34456 34457 if (!__nextHasNoMarginBottom) { 34458 external_wp_deprecated_default()('Bottom margin styles for wp.blockEditor.LineHeightControl', { 34459 since: '6.0', 34460 version: '6.4', 34461 hint: 'Set the `__nextHasNoMarginBottom` prop to true to start opting into the new styles, which will become the default in a future version' 34462 }); 34463 } 34464 34465 const deprecatedStyles = __nextHasNoMarginBottom ? undefined : { 34466 marginBottom: 24 34467 }; 34468 return (0,external_wp_element_namespaceObject.createElement)("div", { 34469 className: "block-editor-line-height-control", 34470 style: deprecatedStyles 34471 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalNumberControl, { 34472 __unstableInputWidth: __unstableInputWidth, 34473 __unstableStateReducer: stateReducer, 34474 onChange: onChange, 34475 label: (0,external_wp_i18n_namespaceObject.__)('Line height'), 34476 placeholder: BASE_DEFAULT_VALUE, 34477 step: STEP, 34478 value: value, 34479 min: 0 34480 })); 34481 }; 34482 /** 34483 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/line-height-control/README.md 34484 */ 34485 34486 34487 /* harmony default export */ var line_height_control = (LineHeightControl); 34488 34489 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/hooks/line-height.js 34490 34491 34492 /** 34493 * WordPress dependencies 34494 */ 34495 34496 /** 34497 * Internal dependencies 34498 */ 34499 34500 34501 34502 34503 const LINE_HEIGHT_SUPPORT_KEY = 'typography.lineHeight'; 34504 /** 34505 * Inspector control panel containing the line height related configuration 34506 * 34507 * @param {Object} props 34508 * 34509 * @return {WPElement} Line height edit element. 34510 */ 34511 34512 function LineHeightEdit(props) { 34513 var _style$typography; 34514 34515 const { 34516 attributes: { 34517 style 34518 }, 34519 setAttributes 34520 } = props; 34521 34522 const onChange = newLineHeightValue => { 34523 const newStyle = { ...style, 34524 typography: { ...(style === null || style === void 0 ? void 0 : style.typography), 34525 lineHeight: newLineHeightValue 34526 } 34527 }; 34528 setAttributes({ 34529 style: cleanEmptyObject(newStyle) 34530 }); 34531 }; 34532 34533 return (0,external_wp_element_namespaceObject.createElement)(line_height_control, { 34534 __unstableInputWidth: "100%", 34535 __nextHasNoMarginBottom: true, 34536 value: style === null || style === void 0 ? void 0 : (_style$typography = style.typography) === null || _style$typography === void 0 ? void 0 : _style$typography.lineHeight, 34537 onChange: onChange 34538 }); 34539 } 34540 /** 34541 * Custom hook that checks if line-height settings have been disabled. 34542 * 34543 * @param {string} name The name of the block. 34544 * @return {boolean} Whether setting is disabled. 34545 */ 34546 34547 function useIsLineHeightDisabled() { 34548 let { 34549 name: blockName 34550 } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; 34551 const isDisabled = !useSetting('typography.lineHeight'); 34552 return !(0,external_wp_blocks_namespaceObject.hasBlockSupport)(blockName, LINE_HEIGHT_SUPPORT_KEY) || isDisabled; 34553 } 34554 /** 34555 * Checks if there is a current value set for the line height block support. 34556 * 34557 * @param {Object} props Block props. 34558 * @return {boolean} Whether or not the block has a line height value set. 34559 */ 34560 34561 function hasLineHeightValue(props) { 34562 var _props$attributes$sty, _props$attributes$sty2; 34563 34564 return !!((_props$attributes$sty = props.attributes.style) !== null && _props$attributes$sty !== void 0 && (_props$attributes$sty2 = _props$attributes$sty.typography) !== null && _props$attributes$sty2 !== void 0 && _props$attributes$sty2.lineHeight); 34565 } 34566 /** 34567 * Resets the line height block support attribute. This can be used when 34568 * disabling the line height support controls for a block via a progressive 34569 * discovery panel. 34570 * 34571 * @param {Object} props Block props. 34572 * @param {Object} props.attributes Block's attributes. 34573 * @param {Object} props.setAttributes Function to set block's attributes. 34574 */ 34575 34576 function resetLineHeight(_ref) { 34577 let { 34578 attributes = {}, 34579 setAttributes 34580 } = _ref; 34581 const { 34582 style 34583 } = attributes; 34584 setAttributes({ 34585 style: cleanEmptyObject({ ...style, 34586 typography: { ...(style === null || style === void 0 ? void 0 : style.typography), 34587 lineHeight: undefined 34588 } 34589 }) 34590 }); 34591 } 34592 34593 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/hooks/font-appearance.js 34594 34595 34596 /** 34597 * WordPress dependencies 34598 */ 34599 34600 /** 34601 * Internal dependencies 34602 */ 34603 34604 34605 34606 34607 /** 34608 * Key within block settings' support array indicating support for font style. 34609 */ 34610 34611 const FONT_STYLE_SUPPORT_KEY = 'typography.__experimentalFontStyle'; 34612 /** 34613 * Key within block settings' support array indicating support for font weight. 34614 */ 34615 34616 const FONT_WEIGHT_SUPPORT_KEY = 'typography.__experimentalFontWeight'; 34617 /** 34618 * Inspector control panel containing the font appearance options. 34619 * 34620 * @param {Object} props Block properties. 34621 * 34622 * @return {WPElement} Font appearance edit element. 34623 */ 34624 34625 function FontAppearanceEdit(props) { 34626 var _style$typography, _style$typography2; 34627 34628 const { 34629 attributes: { 34630 style 34631 }, 34632 setAttributes 34633 } = props; 34634 const hasFontStyles = !useIsFontStyleDisabled(props); 34635 const hasFontWeights = !useIsFontWeightDisabled(props); 34636 34637 const onChange = newStyles => { 34638 setAttributes({ 34639 style: cleanEmptyObject({ ...style, 34640 typography: { ...(style === null || style === void 0 ? void 0 : style.typography), 34641 fontStyle: newStyles.fontStyle, 34642 fontWeight: newStyles.fontWeight 34643 } 34644 }) 34645 }); 34646 }; 34647 34648 const fontStyle = style === null || style === void 0 ? void 0 : (_style$typography = style.typography) === null || _style$typography === void 0 ? void 0 : _style$typography.fontStyle; 34649 const fontWeight = style === null || style === void 0 ? void 0 : (_style$typography2 = style.typography) === null || _style$typography2 === void 0 ? void 0 : _style$typography2.fontWeight; 34650 return (0,external_wp_element_namespaceObject.createElement)(FontAppearanceControl, { 34651 onChange: onChange, 34652 hasFontStyles: hasFontStyles, 34653 hasFontWeights: hasFontWeights, 34654 value: { 34655 fontStyle, 34656 fontWeight 34657 } 34658 }); 34659 } 34660 /** 34661 * Checks if font style support has been disabled either by not opting in for 34662 * support or by failing to provide preset styles. 34663 * 34664 * @param {Object} props Block properties. 34665 * @param {string} props.name Name for the block type. 34666 * 34667 * @return {boolean} Whether font style support has been disabled. 34668 */ 34669 34670 function useIsFontStyleDisabled() { 34671 let { 34672 name: blockName 34673 } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; 34674 const styleSupport = (0,external_wp_blocks_namespaceObject.hasBlockSupport)(blockName, FONT_STYLE_SUPPORT_KEY); 34675 const hasFontStyles = useSetting('typography.fontStyle'); 34676 return !styleSupport || !hasFontStyles; 34677 } 34678 /** 34679 * Checks if font weight support has been disabled either by not opting in for 34680 * support or by failing to provide preset weights. 34681 * 34682 * @param {Object} props Block properties. 34683 * @param {string} props.name Name for the block type. 34684 * 34685 * @return {boolean} Whether font weight support has been disabled. 34686 */ 34687 34688 function useIsFontWeightDisabled() { 34689 let { 34690 name: blockName 34691 } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; 34692 const weightSupport = (0,external_wp_blocks_namespaceObject.hasBlockSupport)(blockName, FONT_WEIGHT_SUPPORT_KEY); 34693 const hasFontWeights = useSetting('typography.fontWeight'); 34694 return !weightSupport || !hasFontWeights; 34695 } 34696 /** 34697 * Checks if font appearance support has been disabled. 34698 * 34699 * @param {Object} props Block properties. 34700 * 34701 * @return {boolean} Whether font appearance support has been disabled. 34702 */ 34703 34704 function useIsFontAppearanceDisabled(props) { 34705 const stylesDisabled = useIsFontStyleDisabled(props); 34706 const weightsDisabled = useIsFontWeightDisabled(props); 34707 return stylesDisabled && weightsDisabled; 34708 } 34709 /** 34710 * Checks if there is either a font style or weight value set within the 34711 * typography styles. 34712 * 34713 * @param {Object} props Block props. 34714 * @return {boolean} Whether or not the block has a font style or weight. 34715 */ 34716 34717 function hasFontAppearanceValue(props) { 34718 var _props$attributes$sty; 34719 34720 const { 34721 fontStyle, 34722 fontWeight 34723 } = ((_props$attributes$sty = props.attributes.style) === null || _props$attributes$sty === void 0 ? void 0 : _props$attributes$sty.typography) || {}; 34724 return !!fontStyle || !!fontWeight; 34725 } 34726 /** 34727 * Resets the font style and weight block support attributes. This can be used 34728 * when disabling the font appearance support controls for a block via a 34729 * progressive discovery panel. 34730 * 34731 * @param {Object} props Block props. 34732 * @param {Object} props.attributes Block's attributes. 34733 * @param {Object} props.setAttributes Function to set block's attributes. 34734 */ 34735 34736 function resetFontAppearance(_ref) { 34737 let { 34738 attributes = {}, 34739 setAttributes 34740 } = _ref; 34741 const { 34742 style 34743 } = attributes; 34744 setAttributes({ 34745 style: cleanEmptyObject({ ...style, 34746 typography: { ...(style === null || style === void 0 ? void 0 : style.typography), 34747 fontStyle: undefined, 34748 fontWeight: undefined 34749 } 34750 }) 34751 }); 34752 } 34753 34754 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/font-family/index.js 34755 34756 34757 34758 /** 34759 * External dependencies 34760 */ 34761 34762 /** 34763 * WordPress dependencies 34764 */ 34765 34766 34767 34768 /** 34769 * Internal dependencies 34770 */ 34771 34772 34773 function FontFamilyControl(_ref) { 34774 let { 34775 value = '', 34776 onChange, 34777 fontFamilies, 34778 ...props 34779 } = _ref; 34780 const blockLevelFontFamilies = useSetting('typography.fontFamilies'); 34781 34782 if (!fontFamilies) { 34783 fontFamilies = blockLevelFontFamilies; 34784 } 34785 34786 if ((0,external_lodash_namespaceObject.isEmpty)(fontFamilies)) { 34787 return null; 34788 } 34789 34790 const options = [{ 34791 value: '', 34792 label: (0,external_wp_i18n_namespaceObject.__)('Default') 34793 }, ...fontFamilies.map(_ref2 => { 34794 let { 34795 fontFamily, 34796 name 34797 } = _ref2; 34798 return { 34799 value: fontFamily, 34800 label: name || fontFamily 34801 }; 34802 })]; 34803 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SelectControl, _extends({ 34804 label: (0,external_wp_i18n_namespaceObject.__)('Font family'), 34805 options: options, 34806 value: value, 34807 onChange: onChange, 34808 labelPosition: "top" 34809 }, props)); 34810 } 34811 34812 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/hooks/font-family.js 34813 34814 34815 /** 34816 * External dependencies 34817 */ 34818 34819 /** 34820 * WordPress dependencies 34821 */ 34822 34823 34824 34825 34826 /** 34827 * Internal dependencies 34828 */ 34829 34830 34831 34832 34833 34834 const FONT_FAMILY_SUPPORT_KEY = 'typography.__experimentalFontFamily'; 34835 /** 34836 * Filters registered block settings, extending attributes to include 34837 * the `fontFamily` attribute. 34838 * 34839 * @param {Object} settings Original block settings 34840 * @return {Object} Filtered block settings 34841 */ 34842 34843 function font_family_addAttributes(settings) { 34844 if (!(0,external_wp_blocks_namespaceObject.hasBlockSupport)(settings, FONT_FAMILY_SUPPORT_KEY)) { 34845 return settings; 34846 } // Allow blocks to specify a default value if needed. 34847 34848 34849 if (!settings.attributes.fontFamily) { 34850 Object.assign(settings.attributes, { 34851 fontFamily: { 34852 type: 'string' 34853 } 34854 }); 34855 } 34856 34857 return settings; 34858 } 34859 /** 34860 * Override props assigned to save component to inject font family. 34861 * 34862 * @param {Object} props Additional props applied to save element 34863 * @param {Object} blockType Block type 34864 * @param {Object} attributes Block attributes 34865 * @return {Object} Filtered props applied to save element 34866 */ 34867 34868 34869 function font_family_addSaveProps(props, blockType, attributes) { 34870 if (!(0,external_wp_blocks_namespaceObject.hasBlockSupport)(blockType, FONT_FAMILY_SUPPORT_KEY)) { 34871 return props; 34872 } 34873 34874 if (shouldSkipSerialization(blockType, TYPOGRAPHY_SUPPORT_KEY, 'fontFamily')) { 34875 return props; 34876 } 34877 34878 if (!(attributes !== null && attributes !== void 0 && attributes.fontFamily)) { 34879 return props; 34880 } // Use TokenList to dedupe classes. 34881 34882 34883 const classes = new (external_wp_tokenList_default())(props.className); 34884 classes.add(`has-${(0,external_lodash_namespaceObject.kebabCase)(attributes === null || attributes === void 0 ? void 0 : attributes.fontFamily)}-font-family`); 34885 const newClassName = classes.value; 34886 props.className = newClassName ? newClassName : undefined; 34887 return props; 34888 } 34889 /** 34890 * Filters registered block settings to expand the block edit wrapper 34891 * by applying the desired styles and classnames. 34892 * 34893 * @param {Object} settings Original block settings. 34894 * 34895 * @return {Object} Filtered block settings. 34896 */ 34897 34898 34899 function font_family_addEditProps(settings) { 34900 if (!(0,external_wp_blocks_namespaceObject.hasBlockSupport)(settings, FONT_FAMILY_SUPPORT_KEY)) { 34901 return settings; 34902 } 34903 34904 const existingGetEditWrapperProps = settings.getEditWrapperProps; 34905 34906 settings.getEditWrapperProps = attributes => { 34907 let props = {}; 34908 34909 if (existingGetEditWrapperProps) { 34910 props = existingGetEditWrapperProps(attributes); 34911 } 34912 34913 return font_family_addSaveProps(props, settings, attributes); 34914 }; 34915 34916 return settings; 34917 } 34918 34919 function FontFamilyEdit(_ref) { 34920 var _find; 34921 34922 let { 34923 setAttributes, 34924 attributes: { 34925 fontFamily 34926 } 34927 } = _ref; 34928 const fontFamilies = useSetting('typography.fontFamilies'); 34929 const value = (_find = (0,external_lodash_namespaceObject.find)(fontFamilies, _ref2 => { 34930 let { 34931 slug 34932 } = _ref2; 34933 return fontFamily === slug; 34934 })) === null || _find === void 0 ? void 0 : _find.fontFamily; 34935 34936 function onChange(newValue) { 34937 const predefinedFontFamily = (0,external_lodash_namespaceObject.find)(fontFamilies, _ref3 => { 34938 let { 34939 fontFamily: f 34940 } = _ref3; 34941 return f === newValue; 34942 }); 34943 setAttributes({ 34944 fontFamily: predefinedFontFamily === null || predefinedFontFamily === void 0 ? void 0 : predefinedFontFamily.slug 34945 }); 34946 } 34947 34948 return (0,external_wp_element_namespaceObject.createElement)(FontFamilyControl, { 34949 className: "block-editor-hooks-font-family-control", 34950 fontFamilies: fontFamilies, 34951 value: value, 34952 onChange: onChange 34953 }); 34954 } 34955 /** 34956 * Custom hook that checks if font-family functionality is disabled. 34957 * 34958 * @param {string} name The name of the block. 34959 * @return {boolean} Whether setting is disabled. 34960 */ 34961 34962 function useIsFontFamilyDisabled(_ref4) { 34963 let { 34964 name 34965 } = _ref4; 34966 const fontFamilies = useSetting('typography.fontFamilies'); 34967 return !fontFamilies || fontFamilies.length === 0 || !(0,external_wp_blocks_namespaceObject.hasBlockSupport)(name, FONT_FAMILY_SUPPORT_KEY); 34968 } 34969 /** 34970 * Checks if there is a current value set for the font family block support. 34971 * 34972 * @param {Object} props Block props. 34973 * @return {boolean} Whether or not the block has a font family value set. 34974 */ 34975 34976 function hasFontFamilyValue(props) { 34977 return !!props.attributes.fontFamily; 34978 } 34979 /** 34980 * Resets the font family block support attribute. This can be used when 34981 * disabling the font family support controls for a block via a progressive 34982 * discovery panel. 34983 * 34984 * @param {Object} props Block props. 34985 * @param {Object} props.setAttributes Function to set block's attributes. 34986 */ 34987 34988 function resetFontFamily(_ref5) { 34989 let { 34990 setAttributes 34991 } = _ref5; 34992 setAttributes({ 34993 fontFamily: undefined 34994 }); 34995 } 34996 (0,external_wp_hooks_namespaceObject.addFilter)('blocks.registerBlockType', 'core/fontFamily/addAttribute', font_family_addAttributes); 34997 (0,external_wp_hooks_namespaceObject.addFilter)('blocks.getSaveContent.extraProps', 'core/fontFamily/addSaveProps', font_family_addSaveProps); 34998 (0,external_wp_hooks_namespaceObject.addFilter)('blocks.registerBlockType', 'core/fontFamily/addEditProps', font_family_addEditProps); 34999 35000 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/font-sizes/utils.js 35001 /** 35002 * External dependencies 35003 */ 35004 35005 /** 35006 * Returns the font size object based on an array of named font sizes and the namedFontSize and customFontSize values. 35007 * If namedFontSize is undefined or not found in fontSizes an object with just the size value based on customFontSize is returned. 35008 * 35009 * @param {Array} fontSizes Array of font size objects containing at least the "name" and "size" values as properties. 35010 * @param {?string} fontSizeAttribute Content of the font size attribute (slug). 35011 * @param {?number} customFontSizeAttribute Contents of the custom font size attribute (value). 35012 * 35013 * @return {?Object} If fontSizeAttribute is set and an equal slug is found in fontSizes it returns the font size object for that slug. 35014 * Otherwise, an object with just the size value based on customFontSize is returned. 35015 */ 35016 35017 const getFontSize = (fontSizes, fontSizeAttribute, customFontSizeAttribute) => { 35018 if (fontSizeAttribute) { 35019 const fontSizeObject = (0,external_lodash_namespaceObject.find)(fontSizes, { 35020 slug: fontSizeAttribute 35021 }); 35022 35023 if (fontSizeObject) { 35024 return fontSizeObject; 35025 } 35026 } 35027 35028 return { 35029 size: customFontSizeAttribute 35030 }; 35031 }; 35032 /** 35033 * Returns the corresponding font size object for a given value. 35034 * 35035 * @param {Array} fontSizes Array of font size objects. 35036 * @param {number} value Font size value. 35037 * 35038 * @return {Object} Font size object. 35039 */ 35040 35041 function getFontSizeObjectByValue(fontSizes, value) { 35042 const fontSizeObject = (0,external_lodash_namespaceObject.find)(fontSizes, { 35043 size: value 35044 }); 35045 35046 if (fontSizeObject) { 35047 return fontSizeObject; 35048 } 35049 35050 return { 35051 size: value 35052 }; 35053 } 35054 /** 35055 * Returns a class based on fontSizeName. 35056 * 35057 * @param {string} fontSizeSlug Slug of the fontSize. 35058 * 35059 * @return {string} String with the class corresponding to the fontSize passed. 35060 * The class is generated by appending 'has-' followed by fontSizeSlug in kebabCase and ending with '-font-size'. 35061 */ 35062 35063 function getFontSizeClass(fontSizeSlug) { 35064 if (!fontSizeSlug) { 35065 return; 35066 } 35067 35068 return `has-${(0,external_lodash_namespaceObject.kebabCase)(fontSizeSlug)}-font-size`; 35069 } 35070 35071 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/font-sizes/font-size-picker.js 35072 35073 35074 35075 /** 35076 * WordPress dependencies 35077 */ 35078 35079 /** 35080 * Internal dependencies 35081 */ 35082 35083 35084 35085 function FontSizePicker(props) { 35086 const fontSizes = useSetting('typography.fontSizes'); 35087 const disableCustomFontSizes = !useSetting('typography.customFontSize'); 35088 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FontSizePicker, _extends({}, props, { 35089 fontSizes: fontSizes, 35090 disableCustomFontSizes: disableCustomFontSizes 35091 })); 35092 } 35093 /** 35094 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/font-sizes/README.md 35095 */ 35096 35097 35098 /* harmony default export */ var font_size_picker = (FontSizePicker); 35099 35100 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/hooks/font-size.js 35101 35102 35103 /** 35104 * WordPress dependencies 35105 */ 35106 35107 35108 35109 35110 /** 35111 * Internal dependencies 35112 */ 35113 35114 35115 35116 35117 35118 const FONT_SIZE_SUPPORT_KEY = 'typography.fontSize'; 35119 /** 35120 * Filters registered block settings, extending attributes to include 35121 * `fontSize` and `fontWeight` attributes. 35122 * 35123 * @param {Object} settings Original block settings. 35124 * 35125 * @return {Object} Filtered block settings. 35126 */ 35127 35128 function font_size_addAttributes(settings) { 35129 if (!(0,external_wp_blocks_namespaceObject.hasBlockSupport)(settings, FONT_SIZE_SUPPORT_KEY)) { 35130 return settings; 35131 } // Allow blocks to specify a default value if needed. 35132 35133 35134 if (!settings.attributes.fontSize) { 35135 Object.assign(settings.attributes, { 35136 fontSize: { 35137 type: 'string' 35138 } 35139 }); 35140 } 35141 35142 return settings; 35143 } 35144 /** 35145 * Override props assigned to save component to inject font size. 35146 * 35147 * @param {Object} props Additional props applied to save element. 35148 * @param {Object} blockType Block type. 35149 * @param {Object} attributes Block attributes. 35150 * 35151 * @return {Object} Filtered props applied to save element. 35152 */ 35153 35154 35155 function font_size_addSaveProps(props, blockType, attributes) { 35156 if (!(0,external_wp_blocks_namespaceObject.hasBlockSupport)(blockType, FONT_SIZE_SUPPORT_KEY)) { 35157 return props; 35158 } 35159 35160 if (shouldSkipSerialization(blockType, TYPOGRAPHY_SUPPORT_KEY, 'fontSize')) { 35161 return props; 35162 } // Use TokenList to dedupe classes. 35163 35164 35165 const classes = new (external_wp_tokenList_default())(props.className); 35166 classes.add(getFontSizeClass(attributes.fontSize)); 35167 const newClassName = classes.value; 35168 props.className = newClassName ? newClassName : undefined; 35169 return props; 35170 } 35171 /** 35172 * Filters registered block settings to expand the block edit wrapper 35173 * by applying the desired styles and classnames. 35174 * 35175 * @param {Object} settings Original block settings. 35176 * 35177 * @return {Object} Filtered block settings. 35178 */ 35179 35180 35181 function font_size_addEditProps(settings) { 35182 if (!(0,external_wp_blocks_namespaceObject.hasBlockSupport)(settings, FONT_SIZE_SUPPORT_KEY)) { 35183 return settings; 35184 } 35185 35186 const existingGetEditWrapperProps = settings.getEditWrapperProps; 35187 35188 settings.getEditWrapperProps = attributes => { 35189 let props = {}; 35190 35191 if (existingGetEditWrapperProps) { 35192 props = existingGetEditWrapperProps(attributes); 35193 } 35194 35195 return font_size_addSaveProps(props, settings, attributes); 35196 }; 35197 35198 return settings; 35199 } 35200 /** 35201 * Inspector control panel containing the font size related configuration 35202 * 35203 * @param {Object} props 35204 * 35205 * @return {WPElement} Font size edit element. 35206 */ 35207 35208 35209 function FontSizeEdit(props) { 35210 var _style$typography, _style$typography2; 35211 35212 const { 35213 attributes: { 35214 fontSize, 35215 style 35216 }, 35217 setAttributes 35218 } = props; 35219 const fontSizes = useSetting('typography.fontSizes'); 35220 35221 const onChange = value => { 35222 const fontSizeSlug = getFontSizeObjectByValue(fontSizes, value).slug; 35223 setAttributes({ 35224 style: cleanEmptyObject({ ...style, 35225 typography: { ...(style === null || style === void 0 ? void 0 : style.typography), 35226 fontSize: fontSizeSlug ? undefined : value 35227 } 35228 }), 35229 fontSize: fontSizeSlug 35230 }); 35231 }; 35232 35233 const fontSizeObject = getFontSize(fontSizes, fontSize, style === null || style === void 0 ? void 0 : (_style$typography = style.typography) === null || _style$typography === void 0 ? void 0 : _style$typography.fontSize); 35234 const fontSizeValue = (fontSizeObject === null || fontSizeObject === void 0 ? void 0 : fontSizeObject.size) || (style === null || style === void 0 ? void 0 : (_style$typography2 = style.typography) === null || _style$typography2 === void 0 ? void 0 : _style$typography2.fontSize) || fontSize; 35235 return (0,external_wp_element_namespaceObject.createElement)(font_size_picker, { 35236 onChange: onChange, 35237 value: fontSizeValue, 35238 withReset: false 35239 }); 35240 } 35241 /** 35242 * Checks if there is a current value set for the font size block support. 35243 * 35244 * @param {Object} props Block props. 35245 * @return {boolean} Whether or not the block has a font size value set. 35246 */ 35247 35248 function hasFontSizeValue(props) { 35249 var _style$typography3; 35250 35251 const { 35252 fontSize, 35253 style 35254 } = props.attributes; 35255 return !!fontSize || !!(style !== null && style !== void 0 && (_style$typography3 = style.typography) !== null && _style$typography3 !== void 0 && _style$typography3.fontSize); 35256 } 35257 /** 35258 * Resets the font size block support attribute. This can be used when 35259 * disabling the font size support controls for a block via a progressive 35260 * discovery panel. 35261 * 35262 * @param {Object} props Block props. 35263 * @param {Object} props.attributes Block's attributes. 35264 * @param {Object} props.setAttributes Function to set block's attributes. 35265 */ 35266 35267 function resetFontSize(_ref) { 35268 let { 35269 attributes = {}, 35270 setAttributes 35271 } = _ref; 35272 const { 35273 style 35274 } = attributes; 35275 setAttributes({ 35276 fontSize: undefined, 35277 style: cleanEmptyObject({ ...style, 35278 typography: { ...(style === null || style === void 0 ? void 0 : style.typography), 35279 fontSize: undefined 35280 } 35281 }) 35282 }); 35283 } 35284 /** 35285 * Custom hook that checks if font-size settings have been disabled. 35286 * 35287 * @param {string} name The name of the block. 35288 * @return {boolean} Whether setting is disabled. 35289 */ 35290 35291 function useIsFontSizeDisabled() { 35292 let { 35293 name: blockName 35294 } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; 35295 const fontSizes = useSetting('typography.fontSizes'); 35296 const hasFontSizes = !!(fontSizes !== null && fontSizes !== void 0 && fontSizes.length); 35297 return !(0,external_wp_blocks_namespaceObject.hasBlockSupport)(blockName, FONT_SIZE_SUPPORT_KEY) || !hasFontSizes; 35298 } 35299 /** 35300 * Add inline styles for font sizes. 35301 * Ideally, this is not needed and themes load the font-size classes on the 35302 * editor. 35303 * 35304 * @param {Function} BlockListBlock Original component. 35305 * 35306 * @return {Function} Wrapped component. 35307 */ 35308 35309 const withFontSizeInlineStyles = (0,external_wp_compose_namespaceObject.createHigherOrderComponent)(BlockListBlock => props => { 35310 var _style$typography4, _style$typography5; 35311 35312 const fontSizes = useSetting('typography.fontSizes'); 35313 const { 35314 name: blockName, 35315 attributes: { 35316 fontSize, 35317 style 35318 }, 35319 wrapperProps 35320 } = props; // Only add inline styles if the block supports font sizes, 35321 // doesn't skip serialization of font sizes, 35322 // doesn't already have an inline font size, 35323 // and does have a class to extract the font size from. 35324 35325 if (!(0,external_wp_blocks_namespaceObject.hasBlockSupport)(blockName, FONT_SIZE_SUPPORT_KEY) || shouldSkipSerialization(blockName, TYPOGRAPHY_SUPPORT_KEY, 'fontSize') || !fontSize || style !== null && style !== void 0 && (_style$typography4 = style.typography) !== null && _style$typography4 !== void 0 && _style$typography4.fontSize) { 35326 return (0,external_wp_element_namespaceObject.createElement)(BlockListBlock, props); 35327 } 35328 35329 const fontSizeValue = getFontSize(fontSizes, fontSize, style === null || style === void 0 ? void 0 : (_style$typography5 = style.typography) === null || _style$typography5 === void 0 ? void 0 : _style$typography5.fontSize).size; 35330 const newProps = { ...props, 35331 wrapperProps: { ...wrapperProps, 35332 style: { 35333 fontSize: fontSizeValue, 35334 ...(wrapperProps === null || wrapperProps === void 0 ? void 0 : wrapperProps.style) 35335 } 35336 } 35337 }; 35338 return (0,external_wp_element_namespaceObject.createElement)(BlockListBlock, newProps); 35339 }, 'withFontSizeInlineStyles'); 35340 const font_size_MIGRATION_PATHS = { 35341 fontSize: [['fontSize'], ['style', 'typography', 'fontSize']] 35342 }; 35343 function font_size_addTransforms(result, source, index, results) { 35344 const destinationBlockType = result.name; 35345 const activeSupports = { 35346 fontSize: (0,external_wp_blocks_namespaceObject.hasBlockSupport)(destinationBlockType, FONT_SIZE_SUPPORT_KEY) 35347 }; 35348 return transformStyles(activeSupports, font_size_MIGRATION_PATHS, result, source, index, results); 35349 } 35350 (0,external_wp_hooks_namespaceObject.addFilter)('blocks.registerBlockType', 'core/font/addAttribute', font_size_addAttributes); 35351 (0,external_wp_hooks_namespaceObject.addFilter)('blocks.getSaveContent.extraProps', 'core/font/addSaveProps', font_size_addSaveProps); 35352 (0,external_wp_hooks_namespaceObject.addFilter)('blocks.registerBlockType', 'core/font/addEditProps', font_size_addEditProps); 35353 (0,external_wp_hooks_namespaceObject.addFilter)('editor.BlockListBlock', 'core/font-size/with-font-size-inline-styles', withFontSizeInlineStyles); 35354 (0,external_wp_hooks_namespaceObject.addFilter)('blocks.switchToBlockType.transformedBlock', 'core/font-size/addTransforms', font_size_addTransforms); 35355 35356 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/format-underline.js 35357 35358 35359 /** 35360 * WordPress dependencies 35361 */ 35362 35363 const formatUnderline = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 35364 xmlns: "http://www.w3.org/2000/svg", 35365 viewBox: "0 0 24 24" 35366 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 35367 d: "M7 18v1h10v-1H7zm5-2c1.5 0 2.6-.4 3.4-1.2.8-.8 1.1-2 1.1-3.5V5H15v5.8c0 1.2-.2 2.1-.6 2.8-.4.7-1.2 1-2.4 1s-2-.3-2.4-1c-.4-.7-.6-1.6-.6-2.8V5H7.5v6.2c0 1.5.4 2.7 1.1 3.5.8.9 1.9 1.3 3.4 1.3z" 35368 })); 35369 /* harmony default export */ var format_underline = (formatUnderline); 35370 35371 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/format-strikethrough.js 35372 35373 35374 /** 35375 * WordPress dependencies 35376 */ 35377 35378 const formatStrikethrough = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 35379 xmlns: "http://www.w3.org/2000/svg", 35380 viewBox: "0 0 24 24" 35381 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 35382 d: "M9.1 9v-.5c0-.6.2-1.1.7-1.4.5-.3 1.2-.5 2-.5.7 0 1.4.1 2.1.3.7.2 1.4.5 2.1.9l.2-1.9c-.6-.3-1.2-.5-1.9-.7-.8-.1-1.6-.2-2.4-.2-1.5 0-2.7.3-3.6 1-.8.7-1.2 1.5-1.2 2.6V9h2zM20 12H4v1h8.3c.3.1.6.2.8.3.5.2.9.5 1.1.8.3.3.4.7.4 1.2 0 .7-.2 1.1-.8 1.5-.5.3-1.2.5-2.1.5-.8 0-1.6-.1-2.4-.3-.8-.2-1.5-.5-2.2-.8L7 18.1c.5.2 1.2.4 2 .6.8.2 1.6.3 2.4.3 1.7 0 3-.3 3.9-1 .9-.7 1.3-1.6 1.3-2.8 0-.9-.2-1.7-.7-2.2H20v-1z" 35383 })); 35384 /* harmony default export */ var format_strikethrough = (formatStrikethrough); 35385 35386 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/text-decoration-control/index.js 35387 35388 35389 /** 35390 * WordPress dependencies 35391 */ 35392 35393 35394 35395 const TEXT_DECORATIONS = [{ 35396 name: (0,external_wp_i18n_namespaceObject.__)('Underline'), 35397 value: 'underline', 35398 icon: format_underline 35399 }, { 35400 name: (0,external_wp_i18n_namespaceObject.__)('Strikethrough'), 35401 value: 'line-through', 35402 icon: format_strikethrough 35403 }]; 35404 /** 35405 * Control to facilitate text decoration selections. 35406 * 35407 * @param {Object} props Component props. 35408 * @param {string} props.value Currently selected text decoration. 35409 * @param {Function} props.onChange Handles change in text decoration selection. 35410 * 35411 * @return {WPElement} Text decoration control. 35412 */ 35413 35414 function TextDecorationControl(_ref) { 35415 let { 35416 value, 35417 onChange 35418 } = _ref; 35419 return (0,external_wp_element_namespaceObject.createElement)("fieldset", { 35420 className: "block-editor-text-decoration-control" 35421 }, (0,external_wp_element_namespaceObject.createElement)("legend", null, (0,external_wp_i18n_namespaceObject.__)('Decoration')), (0,external_wp_element_namespaceObject.createElement)("div", { 35422 className: "block-editor-text-decoration-control__buttons" 35423 }, TEXT_DECORATIONS.map(textDecoration => { 35424 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 35425 key: textDecoration.value, 35426 icon: textDecoration.icon, 35427 isSmall: true, 35428 isPressed: textDecoration.value === value, 35429 onClick: () => onChange(textDecoration.value === value ? undefined : textDecoration.value), 35430 "aria-label": textDecoration.name 35431 }); 35432 }))); 35433 } 35434 35435 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/hooks/text-decoration.js 35436 35437 35438 /** 35439 * WordPress dependencies 35440 */ 35441 35442 /** 35443 * Internal dependencies 35444 */ 35445 35446 35447 35448 35449 /** 35450 * Key within block settings' supports array indicating support for text 35451 * decorations e.g. settings found in `block.json`. 35452 */ 35453 35454 const TEXT_DECORATION_SUPPORT_KEY = 'typography.__experimentalTextDecoration'; 35455 /** 35456 * Inspector control panel containing the text decoration options. 35457 * 35458 * @param {Object} props Block properties. 35459 * 35460 * @return {WPElement} Text decoration edit element. 35461 */ 35462 35463 function TextDecorationEdit(props) { 35464 var _style$typography; 35465 35466 const { 35467 attributes: { 35468 style 35469 }, 35470 setAttributes 35471 } = props; 35472 35473 function onChange(newDecoration) { 35474 setAttributes({ 35475 style: cleanEmptyObject({ ...style, 35476 typography: { ...(style === null || style === void 0 ? void 0 : style.typography), 35477 textDecoration: newDecoration 35478 } 35479 }) 35480 }); 35481 } 35482 35483 return (0,external_wp_element_namespaceObject.createElement)(TextDecorationControl, { 35484 value: style === null || style === void 0 ? void 0 : (_style$typography = style.typography) === null || _style$typography === void 0 ? void 0 : _style$typography.textDecoration, 35485 onChange: onChange 35486 }); 35487 } 35488 /** 35489 * Checks if text-decoration settings have been disabled. 35490 * 35491 * @param {string} name Name of the block. 35492 * 35493 * @return {boolean} Whether or not the setting is disabled. 35494 */ 35495 35496 function useIsTextDecorationDisabled() { 35497 let { 35498 name: blockName 35499 } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; 35500 const notSupported = !(0,external_wp_blocks_namespaceObject.hasBlockSupport)(blockName, TEXT_DECORATION_SUPPORT_KEY); 35501 const hasTextDecoration = useSetting('typography.textDecoration'); 35502 return notSupported || !hasTextDecoration; 35503 } 35504 /** 35505 * Checks if there is a current value set for the text decoration block support. 35506 * 35507 * @param {Object} props Block props. 35508 * @return {boolean} Whether or not the block has a text decoration set. 35509 */ 35510 35511 function hasTextDecorationValue(props) { 35512 var _props$attributes$sty, _props$attributes$sty2; 35513 35514 return !!((_props$attributes$sty = props.attributes.style) !== null && _props$attributes$sty !== void 0 && (_props$attributes$sty2 = _props$attributes$sty.typography) !== null && _props$attributes$sty2 !== void 0 && _props$attributes$sty2.textDecoration); 35515 } 35516 /** 35517 * Resets the text decoration block support attribute. This can be used when 35518 * disabling the text decoration support controls for a block via a progressive 35519 * discovery panel. 35520 * 35521 * @param {Object} props Block props. 35522 * @param {Object} props.attributes Block's attributes. 35523 * @param {Object} props.setAttributes Function to set block's attributes. 35524 */ 35525 35526 function resetTextDecoration(_ref) { 35527 let { 35528 attributes = {}, 35529 setAttributes 35530 } = _ref; 35531 const { 35532 style 35533 } = attributes; 35534 setAttributes({ 35535 style: cleanEmptyObject({ ...style, 35536 typography: { ...(style === null || style === void 0 ? void 0 : style.typography), 35537 textDecoration: undefined 35538 } 35539 }) 35540 }); 35541 } 35542 35543 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/format-uppercase.js 35544 35545 35546 /** 35547 * WordPress dependencies 35548 */ 35549 35550 const formatUppercase = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 35551 xmlns: "http://www.w3.org/2000/svg", 35552 viewBox: "0 0 24 24" 35553 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 35554 d: "M6.1 6.8L2.1 18h1.6l1.1-3h4.3l1.1 3h1.6l-4-11.2H6.1zm-.8 6.8L7 8.9l1.7 4.7H5.3zm15.1-.7c-.4-.5-.9-.8-1.6-1 .4-.2.7-.5.8-.9.2-.4.3-.9.3-1.4 0-.9-.3-1.6-.8-2-.6-.5-1.3-.7-2.4-.7h-3.5V18h4.2c1.1 0 2-.3 2.6-.8.6-.6 1-1.4 1-2.4-.1-.8-.3-1.4-.6-1.9zm-5.7-4.7h1.8c.6 0 1.1.1 1.4.4.3.2.5.7.5 1.3 0 .6-.2 1.1-.5 1.3-.3.2-.8.4-1.4.4h-1.8V8.2zm4 8c-.4.3-.9.5-1.5.5h-2.6v-3.8h2.6c1.4 0 2 .6 2 1.9.1.6-.1 1-.5 1.4z" 35555 })); 35556 /* harmony default export */ var format_uppercase = (formatUppercase); 35557 35558 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/format-lowercase.js 35559 35560 35561 /** 35562 * WordPress dependencies 35563 */ 35564 35565 const formatLowercase = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 35566 xmlns: "http://www.w3.org/2000/svg", 35567 viewBox: "0 0 24 24" 35568 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 35569 d: "M11 16.8c-.1-.1-.2-.3-.3-.5v-2.6c0-.9-.1-1.7-.3-2.2-.2-.5-.5-.9-.9-1.2-.4-.2-.9-.3-1.6-.3-.5 0-1 .1-1.5.2s-.9.3-1.2.6l.2 1.2c.4-.3.7-.4 1.1-.5.3-.1.7-.2 1-.2.6 0 1 .1 1.3.4.3.2.4.7.4 1.4-1.2 0-2.3.2-3.3.7s-1.4 1.1-1.4 2.1c0 .7.2 1.2.7 1.6.4.4 1 .6 1.8.6.9 0 1.7-.4 2.4-1.2.1.3.2.5.4.7.1.2.3.3.6.4.3.1.6.1 1.1.1h.1l.2-1.2h-.1c-.4.1-.6 0-.7-.1zM9.2 16c-.2.3-.5.6-.9.8-.3.1-.7.2-1.1.2-.4 0-.7-.1-.9-.3-.2-.2-.3-.5-.3-.9 0-.6.2-1 .7-1.3.5-.3 1.3-.4 2.5-.5v2zm10.6-3.9c-.3-.6-.7-1.1-1.2-1.5-.6-.4-1.2-.6-1.9-.6-.5 0-.9.1-1.4.3-.4.2-.8.5-1.1.8V6h-1.4v12h1.3l.2-1c.2.4.6.6 1 .8.4.2.9.3 1.4.3.7 0 1.2-.2 1.8-.5.5-.4 1-.9 1.3-1.5.3-.6.5-1.3.5-2.1-.1-.6-.2-1.3-.5-1.9zm-1.7 4c-.4.5-.9.8-1.6.8s-1.2-.2-1.7-.7c-.4-.5-.7-1.2-.7-2.1 0-.9.2-1.6.7-2.1.4-.5 1-.7 1.7-.7s1.2.3 1.6.8c.4.5.6 1.2.6 2s-.2 1.4-.6 2z" 35570 })); 35571 /* harmony default export */ var format_lowercase = (formatLowercase); 35572 35573 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/format-capitalize.js 35574 35575 35576 /** 35577 * WordPress dependencies 35578 */ 35579 35580 const formatCapitalize = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 35581 xmlns: "http://www.w3.org/2000/svg", 35582 viewBox: "0 0 24 24" 35583 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 35584 d: "M7.1 6.8L3.1 18h1.6l1.1-3h4.3l1.1 3h1.6l-4-11.2H7.1zm-.8 6.8L8 8.9l1.7 4.7H6.3zm14.5-1.5c-.3-.6-.7-1.1-1.2-1.5-.6-.4-1.2-.6-1.9-.6-.5 0-.9.1-1.4.3-.4.2-.8.5-1.1.8V6h-1.4v12h1.3l.2-1c.2.4.6.6 1 .8.4.2.9.3 1.4.3.7 0 1.2-.2 1.8-.5.5-.4 1-.9 1.3-1.5.3-.6.5-1.3.5-2.1-.1-.6-.2-1.3-.5-1.9zm-1.7 4c-.4.5-.9.8-1.6.8s-1.2-.2-1.7-.7c-.4-.5-.7-1.2-.7-2.1 0-.9.2-1.6.7-2.1.4-.5 1-.7 1.7-.7s1.2.3 1.6.8c.4.5.6 1.2.6 2 .1.8-.2 1.4-.6 2z" 35585 })); 35586 /* harmony default export */ var format_capitalize = (formatCapitalize); 35587 35588 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/text-transform-control/index.js 35589 35590 35591 /** 35592 * WordPress dependencies 35593 */ 35594 35595 35596 35597 const TEXT_TRANSFORMS = [{ 35598 name: (0,external_wp_i18n_namespaceObject.__)('Uppercase'), 35599 value: 'uppercase', 35600 icon: format_uppercase 35601 }, { 35602 name: (0,external_wp_i18n_namespaceObject.__)('Lowercase'), 35603 value: 'lowercase', 35604 icon: format_lowercase 35605 }, { 35606 name: (0,external_wp_i18n_namespaceObject.__)('Capitalize'), 35607 value: 'capitalize', 35608 icon: format_capitalize 35609 }]; 35610 /** 35611 * Control to facilitate text transform selections. 35612 * 35613 * @param {Object} props Component props. 35614 * @param {string} props.value Currently selected text transform. 35615 * @param {Function} props.onChange Handles change in text transform selection. 35616 * 35617 * @return {WPElement} Text transform control. 35618 */ 35619 35620 function TextTransformControl(_ref) { 35621 let { 35622 value, 35623 onChange 35624 } = _ref; 35625 return (0,external_wp_element_namespaceObject.createElement)("fieldset", { 35626 className: "block-editor-text-transform-control" 35627 }, (0,external_wp_element_namespaceObject.createElement)("legend", null, (0,external_wp_i18n_namespaceObject.__)('Letter case')), (0,external_wp_element_namespaceObject.createElement)("div", { 35628 className: "block-editor-text-transform-control__buttons" 35629 }, TEXT_TRANSFORMS.map(textTransform => { 35630 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 35631 key: textTransform.value, 35632 icon: textTransform.icon, 35633 isSmall: true, 35634 isPressed: value === textTransform.value, 35635 "aria-label": textTransform.name, 35636 onClick: () => onChange(value === textTransform.value ? undefined : textTransform.value) 35637 }); 35638 }))); 35639 } 35640 35641 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/hooks/text-transform.js 35642 35643 35644 /** 35645 * WordPress dependencies 35646 */ 35647 35648 /** 35649 * Internal dependencies 35650 */ 35651 35652 35653 35654 35655 /** 35656 * Key within block settings' supports array indicating support for text 35657 * transforms e.g. settings found in `block.json`. 35658 */ 35659 35660 const TEXT_TRANSFORM_SUPPORT_KEY = 'typography.__experimentalTextTransform'; 35661 /** 35662 * Inspector control panel containing the text transform options. 35663 * 35664 * @param {Object} props Block properties. 35665 * 35666 * @return {WPElement} Text transform edit element. 35667 */ 35668 35669 function TextTransformEdit(props) { 35670 var _style$typography; 35671 35672 const { 35673 attributes: { 35674 style 35675 }, 35676 setAttributes 35677 } = props; 35678 35679 function onChange(newTransform) { 35680 setAttributes({ 35681 style: cleanEmptyObject({ ...style, 35682 typography: { ...(style === null || style === void 0 ? void 0 : style.typography), 35683 textTransform: newTransform 35684 } 35685 }) 35686 }); 35687 } 35688 35689 return (0,external_wp_element_namespaceObject.createElement)(TextTransformControl, { 35690 value: style === null || style === void 0 ? void 0 : (_style$typography = style.typography) === null || _style$typography === void 0 ? void 0 : _style$typography.textTransform, 35691 onChange: onChange 35692 }); 35693 } 35694 /** 35695 * Checks if text-transform settings have been disabled. 35696 * 35697 * @param {string} name Name of the block. 35698 * 35699 * @return {boolean} Whether or not the setting is disabled. 35700 */ 35701 35702 function useIsTextTransformDisabled() { 35703 let { 35704 name: blockName 35705 } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; 35706 const notSupported = !(0,external_wp_blocks_namespaceObject.hasBlockSupport)(blockName, TEXT_TRANSFORM_SUPPORT_KEY); 35707 const hasTextTransforms = useSetting('typography.textTransform'); 35708 return notSupported || !hasTextTransforms; 35709 } 35710 /** 35711 * Checks if there is a current value set for the text transform block support. 35712 * 35713 * @param {Object} props Block props. 35714 * @return {boolean} Whether or not the block has a text transform set. 35715 */ 35716 35717 function hasTextTransformValue(props) { 35718 var _props$attributes$sty, _props$attributes$sty2; 35719 35720 return !!((_props$attributes$sty = props.attributes.style) !== null && _props$attributes$sty !== void 0 && (_props$attributes$sty2 = _props$attributes$sty.typography) !== null && _props$attributes$sty2 !== void 0 && _props$attributes$sty2.textTransform); 35721 } 35722 /** 35723 * Resets the text transform block support attribute. This can be used when 35724 * disabling the text transform support controls for a block via a progressive 35725 * discovery panel. 35726 * 35727 * @param {Object} props Block props. 35728 * @param {Object} props.attributes Block's attributes. 35729 * @param {Object} props.setAttributes Function to set block's attributes. 35730 */ 35731 35732 function resetTextTransform(_ref) { 35733 let { 35734 attributes = {}, 35735 setAttributes 35736 } = _ref; 35737 const { 35738 style 35739 } = attributes; 35740 setAttributes({ 35741 style: cleanEmptyObject({ ...style, 35742 typography: { ...(style === null || style === void 0 ? void 0 : style.typography), 35743 textTransform: undefined 35744 } 35745 }) 35746 }); 35747 } 35748 35749 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/letter-spacing-control/index.js 35750 35751 35752 /** 35753 * WordPress dependencies 35754 */ 35755 35756 35757 /** 35758 * Internal dependencies 35759 */ 35760 35761 35762 /** 35763 * Control for letter-spacing. 35764 * 35765 * @param {Object} props Component props. 35766 * @param {string} props.value Currently selected letter-spacing. 35767 * @param {Function} props.onChange Handles change in letter-spacing selection. 35768 * @param {string|number|undefined} props.__unstableInputWidth Input width to pass through to inner UnitControl. Should be a valid CSS value. 35769 * 35770 * @return {WPElement} Letter-spacing control. 35771 */ 35772 35773 function LetterSpacingControl(_ref) { 35774 let { 35775 value, 35776 onChange, 35777 __unstableInputWidth = '60px' 35778 } = _ref; 35779 const units = (0,external_wp_components_namespaceObject.__experimentalUseCustomUnits)({ 35780 availableUnits: useSetting('spacing.units') || ['px', 'em', 'rem'], 35781 defaultValues: { 35782 px: 2, 35783 em: 0.2, 35784 rem: 0.2 35785 } 35786 }); 35787 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalUnitControl, { 35788 label: (0,external_wp_i18n_namespaceObject.__)('Letter spacing'), 35789 value: value, 35790 __unstableInputWidth: __unstableInputWidth, 35791 units: units, 35792 onChange: onChange 35793 }); 35794 } 35795 35796 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/hooks/letter-spacing.js 35797 35798 35799 /** 35800 * WordPress dependencies 35801 */ 35802 35803 /** 35804 * Internal dependencies 35805 */ 35806 35807 35808 35809 35810 /** 35811 * Key within block settings' supports array indicating support for letter-spacing 35812 * e.g. settings found in `block.json`. 35813 */ 35814 35815 const LETTER_SPACING_SUPPORT_KEY = 'typography.__experimentalLetterSpacing'; 35816 /** 35817 * Inspector control panel containing the letter-spacing options. 35818 * 35819 * @param {Object} props Block properties. 35820 * @return {WPElement} Letter-spacing edit element. 35821 */ 35822 35823 function LetterSpacingEdit(props) { 35824 var _style$typography; 35825 35826 const { 35827 attributes: { 35828 style 35829 }, 35830 setAttributes 35831 } = props; 35832 35833 function onChange(newSpacing) { 35834 setAttributes({ 35835 style: cleanEmptyObject({ ...style, 35836 typography: { ...(style === null || style === void 0 ? void 0 : style.typography), 35837 letterSpacing: newSpacing 35838 } 35839 }) 35840 }); 35841 } 35842 35843 return (0,external_wp_element_namespaceObject.createElement)(LetterSpacingControl, { 35844 value: style === null || style === void 0 ? void 0 : (_style$typography = style.typography) === null || _style$typography === void 0 ? void 0 : _style$typography.letterSpacing, 35845 onChange: onChange, 35846 __unstableInputWidth: '100%' 35847 }); 35848 } 35849 /** 35850 * Checks if letter-spacing settings have been disabled. 35851 * 35852 * @param {string} name Name of the block. 35853 * @return {boolean} Whether or not the setting is disabled. 35854 */ 35855 35856 function useIsLetterSpacingDisabled() { 35857 let { 35858 name: blockName 35859 } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; 35860 const notSupported = !(0,external_wp_blocks_namespaceObject.hasBlockSupport)(blockName, LETTER_SPACING_SUPPORT_KEY); 35861 const hasLetterSpacing = useSetting('typography.letterSpacing'); 35862 return notSupported || !hasLetterSpacing; 35863 } 35864 /** 35865 * Checks if there is a current value set for the letter spacing block support. 35866 * 35867 * @param {Object} props Block props. 35868 * @return {boolean} Whether or not the block has a letter spacing set. 35869 */ 35870 35871 function hasLetterSpacingValue(props) { 35872 var _props$attributes$sty, _props$attributes$sty2; 35873 35874 return !!((_props$attributes$sty = props.attributes.style) !== null && _props$attributes$sty !== void 0 && (_props$attributes$sty2 = _props$attributes$sty.typography) !== null && _props$attributes$sty2 !== void 0 && _props$attributes$sty2.letterSpacing); 35875 } 35876 /** 35877 * Resets the letter spacing block support attribute. This can be used when 35878 * disabling the letter spacing support controls for a block via a progressive 35879 * discovery panel. 35880 * 35881 * @param {Object} props Block props. 35882 * @param {Object} props.attributes Block's attributes. 35883 * @param {Object} props.setAttributes Function to set block's attributes. 35884 */ 35885 35886 function resetLetterSpacing(_ref) { 35887 let { 35888 attributes = {}, 35889 setAttributes 35890 } = _ref; 35891 const { 35892 style 35893 } = attributes; 35894 setAttributes({ 35895 style: cleanEmptyObject({ ...style, 35896 typography: { ...(style === null || style === void 0 ? void 0 : style.typography), 35897 letterSpacing: undefined 35898 } 35899 }) 35900 }); 35901 } 35902 35903 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/hooks/typography.js 35904 35905 35906 /** 35907 * WordPress dependencies 35908 */ 35909 35910 35911 35912 /** 35913 * Internal dependencies 35914 */ 35915 35916 35917 35918 35919 35920 35921 35922 35923 35924 35925 const TYPOGRAPHY_SUPPORT_KEY = 'typography'; 35926 const TYPOGRAPHY_SUPPORT_KEYS = [LINE_HEIGHT_SUPPORT_KEY, FONT_SIZE_SUPPORT_KEY, FONT_STYLE_SUPPORT_KEY, FONT_WEIGHT_SUPPORT_KEY, FONT_FAMILY_SUPPORT_KEY, TEXT_DECORATION_SUPPORT_KEY, TEXT_TRANSFORM_SUPPORT_KEY, LETTER_SPACING_SUPPORT_KEY]; 35927 function TypographyPanel(props) { 35928 const { 35929 clientId 35930 } = props; 35931 const isFontFamilyDisabled = useIsFontFamilyDisabled(props); 35932 const isFontSizeDisabled = useIsFontSizeDisabled(props); 35933 const isFontAppearanceDisabled = useIsFontAppearanceDisabled(props); 35934 const isLineHeightDisabled = useIsLineHeightDisabled(props); 35935 const isTextDecorationDisabled = useIsTextDecorationDisabled(props); 35936 const isTextTransformDisabled = useIsTextTransformDisabled(props); 35937 const isLetterSpacingDisabled = useIsLetterSpacingDisabled(props); 35938 const hasFontStyles = !useIsFontStyleDisabled(props); 35939 const hasFontWeights = !useIsFontWeightDisabled(props); 35940 const isDisabled = useIsTypographyDisabled(props); 35941 const isSupported = hasTypographySupport(props.name); 35942 if (isDisabled || !isSupported) return null; 35943 const defaultControls = (0,external_wp_blocks_namespaceObject.getBlockSupport)(props.name, [TYPOGRAPHY_SUPPORT_KEY, '__experimentalDefaultControls']); 35944 35945 const createResetAllFilter = attribute => newAttributes => { 35946 var _newAttributes$style; 35947 35948 return { ...newAttributes, 35949 style: { ...newAttributes.style, 35950 typography: { ...((_newAttributes$style = newAttributes.style) === null || _newAttributes$style === void 0 ? void 0 : _newAttributes$style.typography), 35951 [attribute]: undefined 35952 } 35953 } 35954 }; 35955 }; 35956 35957 return (0,external_wp_element_namespaceObject.createElement)(inspector_controls, { 35958 __experimentalGroup: "typography" 35959 }, !isFontFamilyDisabled && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToolsPanelItem, { 35960 hasValue: () => hasFontFamilyValue(props), 35961 label: (0,external_wp_i18n_namespaceObject.__)('Font family'), 35962 onDeselect: () => resetFontFamily(props), 35963 isShownByDefault: defaultControls === null || defaultControls === void 0 ? void 0 : defaultControls.fontFamily, 35964 resetAllFilter: newAttributes => ({ ...newAttributes, 35965 fontFamily: undefined 35966 }), 35967 panelId: clientId 35968 }, (0,external_wp_element_namespaceObject.createElement)(FontFamilyEdit, props)), !isFontSizeDisabled && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToolsPanelItem, { 35969 hasValue: () => hasFontSizeValue(props), 35970 label: (0,external_wp_i18n_namespaceObject.__)('Font size'), 35971 onDeselect: () => resetFontSize(props), 35972 isShownByDefault: defaultControls === null || defaultControls === void 0 ? void 0 : defaultControls.fontSize, 35973 resetAllFilter: newAttributes => { 35974 var _newAttributes$style2; 35975 35976 return { ...newAttributes, 35977 fontSize: undefined, 35978 style: { ...newAttributes.style, 35979 typography: { ...((_newAttributes$style2 = newAttributes.style) === null || _newAttributes$style2 === void 0 ? void 0 : _newAttributes$style2.typography), 35980 fontSize: undefined 35981 } 35982 } 35983 }; 35984 }, 35985 panelId: clientId 35986 }, (0,external_wp_element_namespaceObject.createElement)(FontSizeEdit, props)), !isFontAppearanceDisabled && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToolsPanelItem, { 35987 className: "single-column", 35988 hasValue: () => hasFontAppearanceValue(props), 35989 label: getFontAppearanceLabel(hasFontStyles, hasFontWeights), 35990 onDeselect: () => resetFontAppearance(props), 35991 isShownByDefault: defaultControls === null || defaultControls === void 0 ? void 0 : defaultControls.fontAppearance, 35992 resetAllFilter: newAttributes => { 35993 var _newAttributes$style3; 35994 35995 return { ...newAttributes, 35996 style: { ...newAttributes.style, 35997 typography: { ...((_newAttributes$style3 = newAttributes.style) === null || _newAttributes$style3 === void 0 ? void 0 : _newAttributes$style3.typography), 35998 fontStyle: undefined, 35999 fontWeight: undefined 36000 } 36001 } 36002 }; 36003 }, 36004 panelId: clientId 36005 }, (0,external_wp_element_namespaceObject.createElement)(FontAppearanceEdit, props)), !isLineHeightDisabled && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToolsPanelItem, { 36006 className: "single-column", 36007 hasValue: () => hasLineHeightValue(props), 36008 label: (0,external_wp_i18n_namespaceObject.__)('Line height'), 36009 onDeselect: () => resetLineHeight(props), 36010 isShownByDefault: defaultControls === null || defaultControls === void 0 ? void 0 : defaultControls.lineHeight, 36011 resetAllFilter: createResetAllFilter('lineHeight'), 36012 panelId: clientId 36013 }, (0,external_wp_element_namespaceObject.createElement)(LineHeightEdit, props)), !isTextDecorationDisabled && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToolsPanelItem, { 36014 className: "single-column", 36015 hasValue: () => hasTextDecorationValue(props), 36016 label: (0,external_wp_i18n_namespaceObject.__)('Decoration'), 36017 onDeselect: () => resetTextDecoration(props), 36018 isShownByDefault: defaultControls === null || defaultControls === void 0 ? void 0 : defaultControls.textDecoration, 36019 resetAllFilter: createResetAllFilter('textDecoration'), 36020 panelId: clientId 36021 }, (0,external_wp_element_namespaceObject.createElement)(TextDecorationEdit, props)), !isTextTransformDisabled && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToolsPanelItem, { 36022 className: "single-column", 36023 hasValue: () => hasTextTransformValue(props), 36024 label: (0,external_wp_i18n_namespaceObject.__)('Letter case'), 36025 onDeselect: () => resetTextTransform(props), 36026 isShownByDefault: defaultControls === null || defaultControls === void 0 ? void 0 : defaultControls.textTransform, 36027 resetAllFilter: createResetAllFilter('textTransform'), 36028 panelId: clientId 36029 }, (0,external_wp_element_namespaceObject.createElement)(TextTransformEdit, props)), !isLetterSpacingDisabled && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToolsPanelItem, { 36030 className: "single-column", 36031 hasValue: () => hasLetterSpacingValue(props), 36032 label: (0,external_wp_i18n_namespaceObject.__)('Letter spacing'), 36033 onDeselect: () => resetLetterSpacing(props), 36034 isShownByDefault: defaultControls === null || defaultControls === void 0 ? void 0 : defaultControls.letterSpacing, 36035 resetAllFilter: createResetAllFilter('letterSpacing'), 36036 panelId: clientId 36037 }, (0,external_wp_element_namespaceObject.createElement)(LetterSpacingEdit, props))); 36038 } 36039 const hasTypographySupport = blockName => { 36040 return TYPOGRAPHY_SUPPORT_KEYS.some(key => (0,external_wp_blocks_namespaceObject.hasBlockSupport)(blockName, key)); 36041 }; 36042 36043 function useIsTypographyDisabled() { 36044 let props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; 36045 const configs = [useIsFontAppearanceDisabled(props), useIsFontSizeDisabled(props), useIsLineHeightDisabled(props), useIsFontFamilyDisabled(props), useIsTextDecorationDisabled(props), useIsTextTransformDisabled(props), useIsLetterSpacingDisabled(props)]; 36046 return configs.filter(Boolean).length === configs.length; 36047 } 36048 36049 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/hooks/style.js 36050 36051 36052 36053 /** 36054 * External dependencies 36055 */ 36056 36057 36058 /** 36059 * WordPress dependencies 36060 */ 36061 36062 36063 36064 36065 36066 36067 /** 36068 * Internal dependencies 36069 */ 36070 36071 36072 36073 36074 36075 36076 36077 36078 const styleSupportKeys = [...TYPOGRAPHY_SUPPORT_KEYS, BORDER_SUPPORT_KEY, COLOR_SUPPORT_KEY, SPACING_SUPPORT_KEY]; 36079 36080 const hasStyleSupport = blockType => styleSupportKeys.some(key => (0,external_wp_blocks_namespaceObject.hasBlockSupport)(blockType, key)); 36081 36082 const VARIABLE_REFERENCE_PREFIX = 'var:'; 36083 const VARIABLE_PATH_SEPARATOR_TOKEN_ATTRIBUTE = '|'; 36084 const VARIABLE_PATH_SEPARATOR_TOKEN_STYLE = '--'; 36085 36086 function compileStyleValue(uncompiledValue) { 36087 if ((0,external_lodash_namespaceObject.startsWith)(uncompiledValue, VARIABLE_REFERENCE_PREFIX)) { 36088 const variable = uncompiledValue.slice(VARIABLE_REFERENCE_PREFIX.length).split(VARIABLE_PATH_SEPARATOR_TOKEN_ATTRIBUTE).join(VARIABLE_PATH_SEPARATOR_TOKEN_STYLE); 36089 return `var(--wp--$variable})`; 36090 } 36091 36092 return uncompiledValue; 36093 } 36094 /** 36095 * Returns the inline styles to add depending on the style object 36096 * 36097 * @param {Object} styles Styles configuration. 36098 * 36099 * @return {Object} Flattened CSS variables declaration. 36100 */ 36101 36102 36103 function getInlineStyles() { 36104 let styles = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; 36105 const ignoredStyles = ['spacing.blockGap']; 36106 const output = {}; 36107 Object.keys(external_wp_blocks_namespaceObject.__EXPERIMENTAL_STYLE_PROPERTY).forEach(propKey => { 36108 const path = external_wp_blocks_namespaceObject.__EXPERIMENTAL_STYLE_PROPERTY[propKey].value; 36109 const subPaths = external_wp_blocks_namespaceObject.__EXPERIMENTAL_STYLE_PROPERTY[propKey].properties; // Ignore styles on elements because they are handled on the server. 36110 36111 if ((0,external_lodash_namespaceObject.has)(styles, path) && 'elements' !== (0,external_lodash_namespaceObject.first)(path)) { 36112 // Checking if style value is a string allows for shorthand css 36113 // option and backwards compatibility for border radius support. 36114 const styleValue = (0,external_lodash_namespaceObject.get)(styles, path); 36115 36116 if (!external_wp_blocks_namespaceObject.__EXPERIMENTAL_STYLE_PROPERTY[propKey].useEngine) { 36117 if (!!subPaths && !(0,external_lodash_namespaceObject.isString)(styleValue)) { 36118 Object.entries(subPaths).forEach(entry => { 36119 const [name, subPath] = entry; 36120 const value = (0,external_lodash_namespaceObject.get)(styleValue, [subPath]); 36121 36122 if (value) { 36123 output[name] = compileStyleValue(value); 36124 } 36125 }); 36126 } else if (!ignoredStyles.includes(path.join('.'))) { 36127 output[propKey] = compileStyleValue((0,external_lodash_namespaceObject.get)(styles, path)); 36128 } 36129 } 36130 } 36131 }); // The goal is to move everything to server side generated engine styles 36132 // This is temporary as we absorb more and more styles into the engine. 36133 36134 const extraRules = getCSSRules(styles, { 36135 selector: 'self' 36136 }); 36137 extraRules.forEach(rule => { 36138 if (rule.selector !== 'self') { 36139 throw "This style can't be added as inline style"; 36140 } 36141 36142 output[rule.key] = rule.value; 36143 }); 36144 return output; 36145 } 36146 36147 function compileElementsStyles(selector) { 36148 let elements = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; 36149 return (0,external_lodash_namespaceObject.map)(elements, (styles, element) => { 36150 const elementStyles = getInlineStyles(styles); 36151 36152 if (!(0,external_lodash_namespaceObject.isEmpty)(elementStyles)) { 36153 // The .editor-styles-wrapper selector is required on elements styles. As it is 36154 // added to all other editor styles, not providing it causes reset and global 36155 // styles to override element styles because of higher specificity. 36156 return [`.editor-styles-wrapper .$selector} $external_wp_blocks_namespaceObject.__EXPERIMENTAL_ELEMENTS[element]}{`, ...(0,external_lodash_namespaceObject.map)(elementStyles, (value, property) => `\t${(0,external_lodash_namespaceObject.kebabCase)(property)}: $value};`), '}'].join('\n'); 36157 } 36158 36159 return ''; 36160 }).join('\n'); 36161 } 36162 /** 36163 * Filters registered block settings, extending attributes to include `style` attribute. 36164 * 36165 * @param {Object} settings Original block settings. 36166 * 36167 * @return {Object} Filtered block settings. 36168 */ 36169 36170 36171 function style_addAttribute(settings) { 36172 if (!hasStyleSupport(settings)) { 36173 return settings; 36174 } // Allow blocks to specify their own attribute definition with default values if needed. 36175 36176 36177 if (!settings.attributes.style) { 36178 Object.assign(settings.attributes, { 36179 style: { 36180 type: 'object' 36181 } 36182 }); 36183 } 36184 36185 return settings; 36186 } 36187 /** 36188 * A dictionary of paths to flag skipping block support serialization as the key, 36189 * with values providing the style paths to be omitted from serialization. 36190 * 36191 * @constant 36192 * @type {Record<string, string[]>} 36193 */ 36194 36195 36196 const skipSerializationPathsEdit = { 36197 [`$BORDER_SUPPORT_KEY}.__experimentalSkipSerialization`]: ['border'], 36198 [`$COLOR_SUPPORT_KEY}.__experimentalSkipSerialization`]: [COLOR_SUPPORT_KEY], 36199 [`$TYPOGRAPHY_SUPPORT_KEY}.__experimentalSkipSerialization`]: [TYPOGRAPHY_SUPPORT_KEY], 36200 [`$SPACING_SUPPORT_KEY}.__experimentalSkipSerialization`]: ['spacing'] 36201 }; 36202 /** 36203 * A dictionary of paths to flag skipping block support serialization as the key, 36204 * with values providing the style paths to be omitted from serialization. 36205 * 36206 * Extends the Edit skip paths to enable skipping additional paths in just 36207 * the Save component. This allows a block support to be serialized within the 36208 * editor, while using an alternate approach, such as server-side rendering, when 36209 * the support is saved. 36210 * 36211 * @constant 36212 * @type {Record<string, string[]>} 36213 */ 36214 36215 const skipSerializationPathsSave = { ...skipSerializationPathsEdit, 36216 [`$SPACING_SUPPORT_KEY}`]: ['spacing.blockGap'] 36217 }; 36218 /** 36219 * A dictionary used to normalize feature names between support flags, style 36220 * object properties and __experimentSkipSerialization configuration arrays. 36221 * 36222 * This allows not having to provide a migration for a support flag and possible 36223 * backwards compatibility bridges, while still achieving consistency between 36224 * the support flag and the skip serialization array. 36225 * 36226 * @constant 36227 * @type {Record<string, string>} 36228 */ 36229 36230 const renamedFeatures = { 36231 gradients: 'gradient' 36232 }; 36233 /** 36234 * Override props assigned to save component to inject the CSS variables definition. 36235 * 36236 * @param {Object} props Additional props applied to save element. 36237 * @param {Object} blockType Block type. 36238 * @param {Object} attributes Block attributes. 36239 * @param {?Record<string, string[]>} skipPaths An object of keys and paths to skip serialization. 36240 * 36241 * @return {Object} Filtered props applied to save element. 36242 */ 36243 36244 function style_addSaveProps(props, blockType, attributes) { 36245 let skipPaths = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : skipSerializationPathsSave; 36246 36247 if (!hasStyleSupport(blockType)) { 36248 return props; 36249 } 36250 36251 let { 36252 style 36253 } = attributes; 36254 (0,external_lodash_namespaceObject.forEach)(skipPaths, (path, indicator) => { 36255 const skipSerialization = (0,external_wp_blocks_namespaceObject.getBlockSupport)(blockType, indicator); 36256 36257 if (skipSerialization === true) { 36258 style = (0,external_lodash_namespaceObject.omit)(style, path); 36259 } 36260 36261 if (Array.isArray(skipSerialization)) { 36262 skipSerialization.forEach(featureName => { 36263 const feature = renamedFeatures[featureName] || featureName; 36264 style = (0,external_lodash_namespaceObject.omit)(style, [[...path, feature]]); 36265 }); 36266 } 36267 }); 36268 props.style = { ...getInlineStyles(style), 36269 ...props.style 36270 }; 36271 return props; 36272 } 36273 /** 36274 * Filters registered block settings to extend the block edit wrapper 36275 * to apply the desired styles and classnames properly. 36276 * 36277 * @param {Object} settings Original block settings. 36278 * 36279 * @return {Object}.Filtered block settings. 36280 */ 36281 36282 function style_addEditProps(settings) { 36283 if (!hasStyleSupport(settings)) { 36284 return settings; 36285 } 36286 36287 const existingGetEditWrapperProps = settings.getEditWrapperProps; 36288 36289 settings.getEditWrapperProps = attributes => { 36290 let props = {}; 36291 36292 if (existingGetEditWrapperProps) { 36293 props = existingGetEditWrapperProps(attributes); 36294 } 36295 36296 return style_addSaveProps(props, settings, attributes, skipSerializationPathsEdit); 36297 }; 36298 36299 return settings; 36300 } 36301 /** 36302 * Override the default edit UI to include new inspector controls for 36303 * all the custom styles configs. 36304 * 36305 * @param {Function} BlockEdit Original component. 36306 * 36307 * @return {Function} Wrapped component. 36308 */ 36309 36310 const withBlockControls = (0,external_wp_compose_namespaceObject.createHigherOrderComponent)(BlockEdit => props => { 36311 const shouldDisplayControls = useDisplayBlockControls(); 36312 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, shouldDisplayControls && (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(ColorEdit, props), (0,external_wp_element_namespaceObject.createElement)(TypographyPanel, props), (0,external_wp_element_namespaceObject.createElement)(BorderPanel, props), (0,external_wp_element_namespaceObject.createElement)(DimensionsPanel, props)), (0,external_wp_element_namespaceObject.createElement)(BlockEdit, props)); 36313 }, 'withToolbarControls'); 36314 /** 36315 * Override the default block element to include duotone styles. 36316 * 36317 * @param {Function} BlockListBlock Original component 36318 * @return {Function} Wrapped component 36319 */ 36320 36321 const withElementsStyles = (0,external_wp_compose_namespaceObject.createHigherOrderComponent)(BlockListBlock => props => { 36322 var _props$attributes$sty, _props$attributes$sty2; 36323 36324 const blockElementsContainerIdentifier = `wp-elements-${(0,external_wp_compose_namespaceObject.useInstanceId)(BlockListBlock)}`; 36325 const skipLinkColorSerialization = shouldSkipSerialization(props.name, COLOR_SUPPORT_KEY, 'link'); // The Elements API only supports link colors for now, 36326 // hence the specific omission of `link` in the elements styles. 36327 // This might need to be refactored or removed if the Elements API 36328 // changes or `link` supports styles beyond `color`. 36329 36330 const elements = skipLinkColorSerialization ? (0,external_lodash_namespaceObject.omit)((_props$attributes$sty = props.attributes.style) === null || _props$attributes$sty === void 0 ? void 0 : _props$attributes$sty.elements, ['link']) : (_props$attributes$sty2 = props.attributes.style) === null || _props$attributes$sty2 === void 0 ? void 0 : _props$attributes$sty2.elements; 36331 const styles = compileElementsStyles(blockElementsContainerIdentifier, elements); 36332 const element = (0,external_wp_element_namespaceObject.useContext)(BlockList.__unstableElementContext); 36333 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, elements && element && (0,external_wp_element_namespaceObject.createPortal)((0,external_wp_element_namespaceObject.createElement)("style", { 36334 dangerouslySetInnerHTML: { 36335 __html: styles 36336 } 36337 }), element), (0,external_wp_element_namespaceObject.createElement)(BlockListBlock, _extends({}, props, { 36338 className: elements ? classnames_default()(props.className, blockElementsContainerIdentifier) : props.className 36339 }))); 36340 }); 36341 (0,external_wp_hooks_namespaceObject.addFilter)('blocks.registerBlockType', 'core/style/addAttribute', style_addAttribute); 36342 (0,external_wp_hooks_namespaceObject.addFilter)('blocks.getSaveContent.extraProps', 'core/style/addSaveProps', style_addSaveProps); 36343 (0,external_wp_hooks_namespaceObject.addFilter)('blocks.registerBlockType', 'core/style/addEditProps', style_addEditProps); 36344 (0,external_wp_hooks_namespaceObject.addFilter)('editor.BlockEdit', 'core/style/with-block-controls', withBlockControls); 36345 (0,external_wp_hooks_namespaceObject.addFilter)('editor.BlockListBlock', 'core/editor/with-elements-styles', withElementsStyles); 36346 36347 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/duotone-control/index.js 36348 36349 36350 /** 36351 * WordPress dependencies 36352 */ 36353 36354 36355 36356 36357 function DuotoneControl(_ref) { 36358 let { 36359 colorPalette, 36360 duotonePalette, 36361 disableCustomColors, 36362 disableCustomDuotone, 36363 value, 36364 onChange 36365 } = _ref; 36366 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Dropdown, { 36367 popoverProps: { 36368 className: 'block-editor-duotone-control__popover', 36369 headerTitle: (0,external_wp_i18n_namespaceObject.__)('Duotone'), 36370 isAlternate: true 36371 }, 36372 renderToggle: _ref2 => { 36373 let { 36374 isOpen, 36375 onToggle 36376 } = _ref2; 36377 36378 const openOnArrowDown = event => { 36379 if (!isOpen && event.keyCode === external_wp_keycodes_namespaceObject.DOWN) { 36380 event.preventDefault(); 36381 onToggle(); 36382 } 36383 }; 36384 36385 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, { 36386 showTooltip: true, 36387 onClick: onToggle, 36388 "aria-haspopup": "true", 36389 "aria-expanded": isOpen, 36390 onKeyDown: openOnArrowDown, 36391 label: (0,external_wp_i18n_namespaceObject.__)('Apply duotone filter'), 36392 icon: (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.DuotoneSwatch, { 36393 values: value 36394 }) 36395 }); 36396 }, 36397 renderContent: () => (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuGroup, { 36398 label: (0,external_wp_i18n_namespaceObject.__)('Duotone') 36399 }, (0,external_wp_element_namespaceObject.createElement)("div", { 36400 className: "block-editor-duotone-control__description" 36401 }, (0,external_wp_i18n_namespaceObject.__)('Create a two-tone color effect without losing your original image.')), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.DuotonePicker, { 36402 colorPalette: colorPalette, 36403 duotonePalette: duotonePalette, 36404 disableCustomColors: disableCustomColors, 36405 disableCustomDuotone: disableCustomDuotone, 36406 value: value, 36407 onChange: onChange 36408 })) 36409 }); 36410 } 36411 36412 /* harmony default export */ var duotone_control = (DuotoneControl); 36413 36414 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/hooks/duotone.js 36415 36416 36417 36418 /** 36419 * External dependencies 36420 */ 36421 36422 36423 36424 /** 36425 * WordPress dependencies 36426 */ 36427 36428 36429 36430 36431 36432 36433 /** 36434 * Internal dependencies 36435 */ 36436 36437 36438 36439 const duotone_EMPTY_ARRAY = []; 36440 k([names]); 36441 /** 36442 * Convert a list of colors to an object of R, G, and B values. 36443 * 36444 * @param {string[]} colors Array of RBG color strings. 36445 * 36446 * @return {Object} R, G, and B values. 36447 */ 36448 36449 function getValuesFromColors() { 36450 let colors = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : []; 36451 const values = { 36452 r: [], 36453 g: [], 36454 b: [], 36455 a: [] 36456 }; 36457 colors.forEach(color => { 36458 const rgbColor = w(color).toRgb(); 36459 values.r.push(rgbColor.r / 255); 36460 values.g.push(rgbColor.g / 255); 36461 values.b.push(rgbColor.b / 255); 36462 values.a.push(rgbColor.a); 36463 }); 36464 return values; 36465 } 36466 /** 36467 * Values for the SVG `feComponentTransfer`. 36468 * 36469 * @typedef Values {Object} 36470 * @property {number[]} r Red values. 36471 * @property {number[]} g Green values. 36472 * @property {number[]} b Blue values. 36473 * @property {number[]} a Alpha values. 36474 */ 36475 36476 /** 36477 * Stylesheet for rendering the duotone filter. 36478 * 36479 * @param {Object} props Duotone props. 36480 * @param {string} props.selector Selector to apply the filter to. 36481 * @param {string} props.id Unique id for this duotone filter. 36482 * 36483 * @return {WPElement} Duotone element. 36484 */ 36485 36486 function DuotoneStylesheet(_ref) { 36487 let { 36488 selector, 36489 id 36490 } = _ref; 36491 const css = ` 36492 $selector} { 36493 filter: url( #$id} ); 36494 } 36495 `; 36496 return (0,external_wp_element_namespaceObject.createElement)("style", null, css); 36497 } 36498 /** 36499 * SVG for rendering the duotone filter. 36500 * 36501 * @param {Object} props Duotone props. 36502 * @param {string} props.id Unique id for this duotone filter. 36503 * @param {Values} props.values R, G, B, and A values to filter with. 36504 * 36505 * @return {WPElement} Duotone element. 36506 */ 36507 36508 36509 function DuotoneFilter(_ref2) { 36510 let { 36511 id, 36512 values 36513 } = _ref2; 36514 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, { 36515 xmlnsXlink: "http://www.w3.org/1999/xlink", 36516 viewBox: "0 0 0 0", 36517 width: "0", 36518 height: "0", 36519 focusable: "false", 36520 role: "none", 36521 style: { 36522 visibility: 'hidden', 36523 position: 'absolute', 36524 left: '-9999px', 36525 overflow: 'hidden' 36526 } 36527 }, (0,external_wp_element_namespaceObject.createElement)("defs", null, (0,external_wp_element_namespaceObject.createElement)("filter", { 36528 id: id 36529 }, (0,external_wp_element_namespaceObject.createElement)("feColorMatrix", { 36530 // Use sRGB instead of linearRGB so transparency looks correct. 36531 colorInterpolationFilters: "sRGB", 36532 type: "matrix" // Use perceptual brightness to convert to grayscale. 36533 , 36534 values: " .299 .587 .114 0 0 .299 .587 .114 0 0 .299 .587 .114 0 0 .299 .587 .114 0 0 " 36535 }), (0,external_wp_element_namespaceObject.createElement)("feComponentTransfer", { 36536 // Use sRGB instead of linearRGB to be consistent with how CSS gradients work. 36537 colorInterpolationFilters: "sRGB" 36538 }, (0,external_wp_element_namespaceObject.createElement)("feFuncR", { 36539 type: "table", 36540 tableValues: values.r.join(' ') 36541 }), (0,external_wp_element_namespaceObject.createElement)("feFuncG", { 36542 type: "table", 36543 tableValues: values.g.join(' ') 36544 }), (0,external_wp_element_namespaceObject.createElement)("feFuncB", { 36545 type: "table", 36546 tableValues: values.b.join(' ') 36547 }), (0,external_wp_element_namespaceObject.createElement)("feFuncA", { 36548 type: "table", 36549 tableValues: values.a.join(' ') 36550 })), (0,external_wp_element_namespaceObject.createElement)("feComposite", { 36551 // Re-mask the image with the original transparency since the feColorMatrix above loses that information. 36552 in2: "SourceGraphic", 36553 operator: "in" 36554 })))); 36555 } 36556 /** 36557 * SVG and stylesheet needed for rendering the duotone filter. 36558 * 36559 * @param {Object} props Duotone props. 36560 * @param {string} props.selector Selector to apply the filter to. 36561 * @param {string} props.id Unique id for this duotone filter. 36562 * @param {Values} props.values R, G, B, and A values to filter with. 36563 * 36564 * @return {WPElement} Duotone element. 36565 */ 36566 36567 36568 function InlineDuotone(_ref3) { 36569 let { 36570 selector, 36571 id, 36572 values 36573 } = _ref3; 36574 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(DuotoneFilter, { 36575 id: id, 36576 values: values 36577 }), (0,external_wp_element_namespaceObject.createElement)(DuotoneStylesheet, { 36578 id: id, 36579 selector: selector 36580 })); 36581 } 36582 36583 function useMultiOriginPresets(_ref4) { 36584 let { 36585 presetSetting, 36586 defaultSetting 36587 } = _ref4; 36588 const disableDefault = !useSetting(defaultSetting); 36589 const userPresets = useSetting(`$presetSetting}.custom`) || duotone_EMPTY_ARRAY; 36590 const themePresets = useSetting(`$presetSetting}.theme`) || duotone_EMPTY_ARRAY; 36591 const defaultPresets = useSetting(`$presetSetting}.default`) || duotone_EMPTY_ARRAY; 36592 return (0,external_wp_element_namespaceObject.useMemo)(() => [...userPresets, ...themePresets, ...(disableDefault ? duotone_EMPTY_ARRAY : defaultPresets)], [disableDefault, userPresets, themePresets, defaultPresets]); 36593 } 36594 36595 function DuotonePanel(_ref5) { 36596 var _style$color; 36597 36598 let { 36599 attributes, 36600 setAttributes 36601 } = _ref5; 36602 const style = attributes === null || attributes === void 0 ? void 0 : attributes.style; 36603 const duotone = style === null || style === void 0 ? void 0 : (_style$color = style.color) === null || _style$color === void 0 ? void 0 : _style$color.duotone; 36604 const duotonePalette = useMultiOriginPresets({ 36605 presetSetting: 'color.duotone', 36606 defaultSetting: 'color.defaultDuotone' 36607 }); 36608 const colorPalette = useMultiOriginPresets({ 36609 presetSetting: 'color.palette', 36610 defaultSetting: 'color.defaultPalette' 36611 }); 36612 const disableCustomColors = !useSetting('color.custom'); 36613 const disableCustomDuotone = !useSetting('color.customDuotone') || (colorPalette === null || colorPalette === void 0 ? void 0 : colorPalette.length) === 0 && disableCustomColors; 36614 36615 if ((duotonePalette === null || duotonePalette === void 0 ? void 0 : duotonePalette.length) === 0 && disableCustomDuotone) { 36616 return null; 36617 } 36618 36619 return (0,external_wp_element_namespaceObject.createElement)(block_controls, { 36620 group: "block", 36621 __experimentalShareWithChildBlocks: true 36622 }, (0,external_wp_element_namespaceObject.createElement)(duotone_control, { 36623 duotonePalette: duotonePalette, 36624 colorPalette: colorPalette, 36625 disableCustomDuotone: disableCustomDuotone, 36626 disableCustomColors: disableCustomColors, 36627 value: duotone, 36628 onChange: newDuotone => { 36629 const newStyle = { ...style, 36630 color: { ...(style === null || style === void 0 ? void 0 : style.color), 36631 duotone: newDuotone 36632 } 36633 }; 36634 setAttributes({ 36635 style: newStyle 36636 }); 36637 } 36638 })); 36639 } 36640 /** 36641 * Filters registered block settings, extending attributes to include 36642 * the `duotone` attribute. 36643 * 36644 * @param {Object} settings Original block settings. 36645 * 36646 * @return {Object} Filtered block settings. 36647 */ 36648 36649 36650 function addDuotoneAttributes(settings) { 36651 if (!(0,external_wp_blocks_namespaceObject.hasBlockSupport)(settings, 'color.__experimentalDuotone')) { 36652 return settings; 36653 } // Allow blocks to specify their own attribute definition with default 36654 // values if needed. 36655 36656 36657 if (!settings.attributes.style) { 36658 Object.assign(settings.attributes, { 36659 style: { 36660 type: 'object' 36661 } 36662 }); 36663 } 36664 36665 return settings; 36666 } 36667 /** 36668 * Override the default edit UI to include toolbar controls for duotone if the 36669 * block supports duotone. 36670 * 36671 * @param {Function} BlockEdit Original component. 36672 * 36673 * @return {Function} Wrapped component. 36674 */ 36675 36676 36677 const withDuotoneControls = (0,external_wp_compose_namespaceObject.createHigherOrderComponent)(BlockEdit => props => { 36678 const hasDuotoneSupport = (0,external_wp_blocks_namespaceObject.hasBlockSupport)(props.name, 'color.__experimentalDuotone'); 36679 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(BlockEdit, props), hasDuotoneSupport && (0,external_wp_element_namespaceObject.createElement)(DuotonePanel, props)); 36680 }, 'withDuotoneControls'); 36681 /** 36682 * Function that scopes a selector with another one. This works a bit like 36683 * SCSS nesting except the `&` operator isn't supported. 36684 * 36685 * @example 36686 * ```js 36687 * const scope = '.a, .b .c'; 36688 * const selector = '> .x, .y'; 36689 * const merged = scopeSelector( scope, selector ); 36690 * // merged is '.a > .x, .a .y, .b .c > .x, .b .c .y' 36691 * ``` 36692 * 36693 * @param {string} scope Selector to scope to. 36694 * @param {string} selector Original selector. 36695 * 36696 * @return {string} Scoped selector. 36697 */ 36698 36699 function scopeSelector(scope, selector) { 36700 const scopes = scope.split(','); 36701 const selectors = selector.split(','); 36702 const selectorsScoped = []; 36703 scopes.forEach(outer => { 36704 selectors.forEach(inner => { 36705 selectorsScoped.push(`$outer.trim()} $inner.trim()}`); 36706 }); 36707 }); 36708 return selectorsScoped.join(', '); 36709 } 36710 /** 36711 * Override the default block element to include duotone styles. 36712 * 36713 * @param {Function} BlockListBlock Original component. 36714 * 36715 * @return {Function} Wrapped component. 36716 */ 36717 36718 36719 const withDuotoneStyles = (0,external_wp_compose_namespaceObject.createHigherOrderComponent)(BlockListBlock => props => { 36720 var _props$attributes, _props$attributes$sty, _props$attributes$sty2; 36721 36722 const duotoneSupport = (0,external_wp_blocks_namespaceObject.getBlockSupport)(props.name, 'color.__experimentalDuotone'); 36723 const values = props === null || props === void 0 ? void 0 : (_props$attributes = props.attributes) === null || _props$attributes === void 0 ? void 0 : (_props$attributes$sty = _props$attributes.style) === null || _props$attributes$sty === void 0 ? void 0 : (_props$attributes$sty2 = _props$attributes$sty.color) === null || _props$attributes$sty2 === void 0 ? void 0 : _props$attributes$sty2.duotone; 36724 36725 if (!duotoneSupport || !values) { 36726 return (0,external_wp_element_namespaceObject.createElement)(BlockListBlock, props); 36727 } 36728 36729 const id = `wp-duotone-${(0,external_wp_compose_namespaceObject.useInstanceId)(BlockListBlock)}`; // Extra .editor-styles-wrapper specificity is needed in the editor 36730 // since we're not using inline styles to apply the filter. We need to 36731 // override duotone applied by global styles and theme.json. 36732 36733 const selectorsGroup = scopeSelector(`.editor-styles-wrapper .$id}`, duotoneSupport); 36734 const className = classnames_default()(props === null || props === void 0 ? void 0 : props.className, id); 36735 const element = (0,external_wp_element_namespaceObject.useContext)(BlockList.__unstableElementContext); 36736 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, element && (0,external_wp_element_namespaceObject.createPortal)((0,external_wp_element_namespaceObject.createElement)(InlineDuotone, { 36737 selector: selectorsGroup, 36738 id: id, 36739 values: getValuesFromColors(values) 36740 }), element), (0,external_wp_element_namespaceObject.createElement)(BlockListBlock, _extends({}, props, { 36741 className: className 36742 }))); 36743 }, 'withDuotoneStyles'); 36744 function PresetDuotoneFilter(_ref6) { 36745 let { 36746 preset 36747 } = _ref6; 36748 return (0,external_wp_element_namespaceObject.createElement)(DuotoneFilter, { 36749 id: `wp-duotone-$preset.slug}`, 36750 values: getValuesFromColors(preset.colors) 36751 }); 36752 } 36753 (0,external_wp_hooks_namespaceObject.addFilter)('blocks.registerBlockType', 'core/editor/duotone/add-attributes', addDuotoneAttributes); 36754 (0,external_wp_hooks_namespaceObject.addFilter)('editor.BlockEdit', 'core/editor/duotone/with-editor-controls', withDuotoneControls); 36755 (0,external_wp_hooks_namespaceObject.addFilter)('editor.BlockListBlock', 'core/editor/duotone/with-styles', withDuotoneStyles); 36756 36757 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/hooks/layout.js 36758 36759 36760 36761 /** 36762 * External dependencies 36763 */ 36764 36765 36766 /** 36767 * WordPress dependencies 36768 */ 36769 36770 36771 36772 36773 36774 36775 36776 36777 /** 36778 * Internal dependencies 36779 */ 36780 36781 36782 36783 36784 36785 36786 36787 const layoutBlockSupportKey = '__experimentalLayout'; 36788 36789 function LayoutPanel(_ref) { 36790 let { 36791 setAttributes, 36792 attributes, 36793 name: blockName 36794 } = _ref; 36795 const { 36796 layout 36797 } = attributes; 36798 const defaultThemeLayout = useSetting('layout'); 36799 const themeSupportsLayout = (0,external_wp_data_namespaceObject.useSelect)(select => { 36800 const { 36801 getSettings 36802 } = select(store); 36803 return getSettings().supportsLayout; 36804 }, []); 36805 const layoutBlockSupport = (0,external_wp_blocks_namespaceObject.getBlockSupport)(blockName, layoutBlockSupportKey, {}); 36806 const { 36807 allowSwitching, 36808 allowEditing = true, 36809 allowInheriting = true, 36810 default: defaultBlockLayout 36811 } = layoutBlockSupport; 36812 36813 if (!allowEditing) { 36814 return null; 36815 } // Only show the inherit toggle if it's supported, 36816 // a default theme layout is set (e.g. one that provides `contentSize` and/or `wideSize` values), 36817 // and that the default / flow layout type is in use, as this is the only one that supports inheritance. 36818 36819 36820 const showInheritToggle = !!(allowInheriting && !!defaultThemeLayout && (!(layout !== null && layout !== void 0 && layout.type) || (layout === null || layout === void 0 ? void 0 : layout.type) === 'default' || layout !== null && layout !== void 0 && layout.inherit)); 36821 const usedLayout = layout || defaultBlockLayout || {}; 36822 const { 36823 inherit = false, 36824 type = 'default' 36825 } = usedLayout; 36826 /** 36827 * `themeSupportsLayout` is only relevant to the `default/flow` 36828 * layout and it should not be taken into account when other 36829 * `layout` types are used. 36830 */ 36831 36832 if (type === 'default' && !themeSupportsLayout) { 36833 return null; 36834 } 36835 36836 const layoutType = getLayoutType(type); 36837 36838 const onChangeType = newType => setAttributes({ 36839 layout: { 36840 type: newType 36841 } 36842 }); 36843 36844 const onChangeLayout = newLayout => setAttributes({ 36845 layout: newLayout 36846 }); 36847 36848 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(inspector_controls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, { 36849 title: (0,external_wp_i18n_namespaceObject.__)('Layout') 36850 }, showInheritToggle && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, { 36851 label: (0,external_wp_i18n_namespaceObject.__)('Inherit default layout'), 36852 checked: !!inherit, 36853 onChange: () => setAttributes({ 36854 layout: { 36855 inherit: !inherit 36856 } 36857 }) 36858 }), !inherit && allowSwitching && (0,external_wp_element_namespaceObject.createElement)(LayoutTypeSwitcher, { 36859 type: type, 36860 onChange: onChangeType 36861 }), !inherit && layoutType && (0,external_wp_element_namespaceObject.createElement)(layoutType.inspectorControls, { 36862 layout: usedLayout, 36863 onChange: onChangeLayout, 36864 layoutBlockSupport: layoutBlockSupport 36865 }))), !inherit && layoutType && (0,external_wp_element_namespaceObject.createElement)(layoutType.toolBarControls, { 36866 layout: usedLayout, 36867 onChange: onChangeLayout, 36868 layoutBlockSupport: layoutBlockSupport 36869 })); 36870 } 36871 36872 function LayoutTypeSwitcher(_ref2) { 36873 let { 36874 type, 36875 onChange 36876 } = _ref2; 36877 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ButtonGroup, null, getLayoutTypes().map(_ref3 => { 36878 let { 36879 name, 36880 label 36881 } = _ref3; 36882 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 36883 key: name, 36884 isPressed: type === name, 36885 onClick: () => onChange(name) 36886 }, label); 36887 })); 36888 } 36889 /** 36890 * Filters registered block settings, extending attributes to include `layout`. 36891 * 36892 * @param {Object} settings Original block settings. 36893 * 36894 * @return {Object} Filtered block settings. 36895 */ 36896 36897 36898 function layout_addAttribute(settings) { 36899 if ((0,external_lodash_namespaceObject.has)(settings.attributes, ['layout', 'type'])) { 36900 return settings; 36901 } 36902 36903 if ((0,external_wp_blocks_namespaceObject.hasBlockSupport)(settings, layoutBlockSupportKey)) { 36904 settings.attributes = { ...settings.attributes, 36905 layout: { 36906 type: 'object' 36907 } 36908 }; 36909 } 36910 36911 return settings; 36912 } 36913 /** 36914 * Override the default edit UI to include layout controls 36915 * 36916 * @param {Function} BlockEdit Original component. 36917 * 36918 * @return {Function} Wrapped component. 36919 */ 36920 36921 const withInspectorControls = (0,external_wp_compose_namespaceObject.createHigherOrderComponent)(BlockEdit => props => { 36922 const { 36923 name: blockName 36924 } = props; 36925 const supportLayout = (0,external_wp_blocks_namespaceObject.hasBlockSupport)(blockName, layoutBlockSupportKey); 36926 return [supportLayout && (0,external_wp_element_namespaceObject.createElement)(LayoutPanel, _extends({ 36927 key: "layout" 36928 }, props)), (0,external_wp_element_namespaceObject.createElement)(BlockEdit, _extends({ 36929 key: "edit" 36930 }, props))]; 36931 }, 'withInspectorControls'); 36932 /** 36933 * Override the default block element to add the layout styles. 36934 * 36935 * @param {Function} BlockListBlock Original component. 36936 * 36937 * @return {Function} Wrapped component. 36938 */ 36939 36940 const withLayoutStyles = (0,external_wp_compose_namespaceObject.createHigherOrderComponent)(BlockListBlock => props => { 36941 const { 36942 name, 36943 attributes 36944 } = props; 36945 const shouldRenderLayoutStyles = (0,external_wp_blocks_namespaceObject.hasBlockSupport)(name, layoutBlockSupportKey); 36946 const id = (0,external_wp_compose_namespaceObject.useInstanceId)(BlockListBlock); 36947 const defaultThemeLayout = useSetting('layout') || {}; 36948 const element = (0,external_wp_element_namespaceObject.useContext)(BlockList.__unstableElementContext); 36949 const { 36950 layout 36951 } = attributes; 36952 const { 36953 default: defaultBlockLayout 36954 } = (0,external_wp_blocks_namespaceObject.getBlockSupport)(name, layoutBlockSupportKey) || {}; 36955 const usedLayout = layout !== null && layout !== void 0 && layout.inherit ? defaultThemeLayout : layout || defaultBlockLayout || {}; 36956 const className = classnames_default()(props === null || props === void 0 ? void 0 : props.className, { 36957 [`wp-container-$id}`]: shouldRenderLayoutStyles 36958 }); 36959 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, shouldRenderLayoutStyles && element && (0,external_wp_element_namespaceObject.createPortal)((0,external_wp_element_namespaceObject.createElement)(LayoutStyle, { 36960 blockName: name, 36961 selector: `.wp-container-$id}`, 36962 layout: usedLayout, 36963 style: attributes === null || attributes === void 0 ? void 0 : attributes.style 36964 }), element), (0,external_wp_element_namespaceObject.createElement)(BlockListBlock, _extends({}, props, { 36965 className: className 36966 }))); 36967 }); 36968 (0,external_wp_hooks_namespaceObject.addFilter)('blocks.registerBlockType', 'core/layout/addAttribute', layout_addAttribute); 36969 (0,external_wp_hooks_namespaceObject.addFilter)('editor.BlockListBlock', 'core/editor/layout/with-layout-styles', withLayoutStyles); 36970 (0,external_wp_hooks_namespaceObject.addFilter)('editor.BlockEdit', 'core/editor/layout/with-inspector-controls', withInspectorControls); 36971 36972 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/hooks/use-border-props.js 36973 /** 36974 * External dependencies 36975 */ 36976 36977 /** 36978 * Internal dependencies 36979 */ 36980 36981 36982 36983 // This utility is intended to assist where the serialization of the border 36984 // block support is being skipped for a block but the border related CSS classes 36985 // & styles still need to be generated so they can be applied to inner elements. 36986 36987 const use_border_props_EMPTY_ARRAY = []; 36988 /** 36989 * Provides the CSS class names and inline styles for a block's border support 36990 * attributes. 36991 * 36992 * @param {Object} attributes Block attributes. 36993 * @param {string} attributes.borderColor Selected named border color. 36994 * @param {Object} attributes.style Block's styles attribute. 36995 * 36996 * @return {Object} Border block support derived CSS classes & styles. 36997 */ 36998 36999 function getBorderClassesAndStyles(_ref) { 37000 var _style$border; 37001 37002 let { 37003 borderColor, 37004 style 37005 } = _ref; 37006 const borderStyles = (style === null || style === void 0 ? void 0 : style.border) || {}; 37007 const borderClass = getColorClassName('border-color', borderColor); 37008 const className = classnames_default()({ 37009 [borderClass]: !!borderClass, 37010 'has-border-color': borderColor || (style === null || style === void 0 ? void 0 : (_style$border = style.border) === null || _style$border === void 0 ? void 0 : _style$border.color) 37011 }); 37012 return { 37013 className: className || undefined, 37014 style: getInlineStyles({ 37015 border: borderStyles 37016 }) 37017 }; 37018 } 37019 /** 37020 * Derives the border related props for a block from its border block support 37021 * attributes. 37022 * 37023 * Inline styles are forced for named colors to ensure these selections are 37024 * reflected when themes do not load their color stylesheets in the editor. 37025 * 37026 * @param {Object} attributes Block attributes. 37027 * 37028 * @return {Object} ClassName & style props from border block support. 37029 */ 37030 37031 function useBorderProps(attributes) { 37032 const colors = useSetting('color.palette') || use_border_props_EMPTY_ARRAY; 37033 const borderProps = getBorderClassesAndStyles(attributes); // Force inline style to apply border color when themes do not load their 37034 // color stylesheets in the editor. 37035 37036 if (attributes.borderColor) { 37037 const borderColorObject = getColorObjectByAttributeValues(colors, attributes.borderColor); 37038 borderProps.style.borderColor = borderColorObject.color; 37039 } 37040 37041 return borderProps; 37042 } 37043 37044 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/hooks/use-color-props.js 37045 /** 37046 * External dependencies 37047 */ 37048 37049 /** 37050 * WordPress dependencies 37051 */ 37052 37053 37054 /** 37055 * Internal dependencies 37056 */ 37057 37058 37059 37060 37061 // The code in this file has largely been lifted from the color block support 37062 // hook. 37063 // 37064 // This utility is intended to assist where the serialization of the colors 37065 // block support is being skipped for a block but the color related CSS classes 37066 // & styles still need to be generated so they can be applied to inner elements. 37067 37068 /** 37069 * Provides the CSS class names and inline styles for a block's color support 37070 * attributes. 37071 * 37072 * @param {Object} attributes Block attributes. 37073 * 37074 * @return {Object} Color block support derived CSS classes & styles. 37075 */ 37076 37077 function getColorClassesAndStyles(attributes) { 37078 var _style$color, _style$color2, _style$color3, _style$color4, _style$elements, _style$elements$link; 37079 37080 const { 37081 backgroundColor, 37082 textColor, 37083 gradient, 37084 style 37085 } = attributes; // Collect color CSS classes. 37086 37087 const backgroundClass = getColorClassName('background-color', backgroundColor); 37088 const textClass = getColorClassName('color', textColor); 37089 37090 const gradientClass = __experimentalGetGradientClass(gradient); 37091 37092 const hasGradient = gradientClass || (style === null || style === void 0 ? void 0 : (_style$color = style.color) === null || _style$color === void 0 ? void 0 : _style$color.gradient); // Determine color CSS class name list. 37093 37094 const className = classnames_default()(textClass, gradientClass, { 37095 // Don't apply the background class if there's a gradient. 37096 [backgroundClass]: !hasGradient && !!backgroundClass, 37097 'has-text-color': textColor || (style === null || style === void 0 ? void 0 : (_style$color2 = style.color) === null || _style$color2 === void 0 ? void 0 : _style$color2.text), 37098 'has-background': backgroundColor || (style === null || style === void 0 ? void 0 : (_style$color3 = style.color) === null || _style$color3 === void 0 ? void 0 : _style$color3.background) || gradient || (style === null || style === void 0 ? void 0 : (_style$color4 = style.color) === null || _style$color4 === void 0 ? void 0 : _style$color4.gradient), 37099 'has-link-color': style === null || style === void 0 ? void 0 : (_style$elements = style.elements) === null || _style$elements === void 0 ? void 0 : (_style$elements$link = _style$elements.link) === null || _style$elements$link === void 0 ? void 0 : _style$elements$link.color 37100 }); // Collect inline styles for colors. 37101 37102 const colorStyles = (style === null || style === void 0 ? void 0 : style.color) || {}; 37103 const styleProp = getInlineStyles({ 37104 color: colorStyles 37105 }); 37106 return { 37107 className: className || undefined, 37108 style: styleProp 37109 }; 37110 } 37111 const EMPTY_OBJECT = {}; 37112 /** 37113 * Determines the color related props for a block derived from its color block 37114 * support attributes. 37115 * 37116 * Inline styles are forced for named colors to ensure these selections are 37117 * reflected when themes do not load their color stylesheets in the editor. 37118 * 37119 * @param {Object} attributes Block attributes. 37120 * 37121 * @return {Object} ClassName & style props from colors block support. 37122 */ 37123 37124 function useColorProps(attributes) { 37125 const { 37126 backgroundColor, 37127 textColor, 37128 gradient 37129 } = attributes; // Some color settings have a special handling for deprecated flags in `useSetting`, 37130 // so we can't unwrap them by doing const { ... } = useSetting('color') 37131 // until https://github.com/WordPress/gutenberg/issues/37094 is fixed. 37132 37133 const userPalette = useSetting('color.palette.custom') || []; 37134 const themePalette = useSetting('color.palette.theme') || []; 37135 const defaultPalette = useSetting('color.palette.default') || []; 37136 const gradientsPerOrigin = useSetting('color.gradients') || EMPTY_OBJECT; 37137 const colors = (0,external_wp_element_namespaceObject.useMemo)(() => [...(userPalette || []), ...(themePalette || []), ...(defaultPalette || [])], [userPalette, themePalette, defaultPalette]); 37138 const gradients = (0,external_wp_element_namespaceObject.useMemo)(() => [...((gradientsPerOrigin === null || gradientsPerOrigin === void 0 ? void 0 : gradientsPerOrigin.custom) || []), ...((gradientsPerOrigin === null || gradientsPerOrigin === void 0 ? void 0 : gradientsPerOrigin.theme) || []), ...((gradientsPerOrigin === null || gradientsPerOrigin === void 0 ? void 0 : gradientsPerOrigin.default) || [])], [gradientsPerOrigin]); 37139 const colorProps = getColorClassesAndStyles(attributes); // Force inline styles to apply colors when themes do not load their color 37140 // stylesheets in the editor. 37141 37142 if (backgroundColor) { 37143 const backgroundColorObject = getColorObjectByAttributeValues(colors, backgroundColor); 37144 colorProps.style.backgroundColor = backgroundColorObject.color; 37145 } 37146 37147 if (gradient) { 37148 colorProps.style.background = getGradientValueBySlug(gradients, gradient); 37149 } 37150 37151 if (textColor) { 37152 const textColorObject = getColorObjectByAttributeValues(colors, textColor); 37153 colorProps.style.color = textColorObject.color; 37154 } 37155 37156 return colorProps; 37157 } 37158 37159 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/hooks/use-spacing-props.js 37160 /** 37161 * Internal dependencies 37162 */ 37163 // This utility is intended to assist where the serialization of the spacing 37164 // block support is being skipped for a block but the spacing related CSS 37165 // styles still need to be generated so they can be applied to inner elements. 37166 37167 /** 37168 * Provides the CSS class names and inline styles for a block's spacing support 37169 * attributes. 37170 * 37171 * @param {Object} attributes Block attributes. 37172 * 37173 * @return {Object} Spacing block support derived CSS classes & styles. 37174 */ 37175 37176 function getSpacingClassesAndStyles(attributes) { 37177 const { 37178 style 37179 } = attributes; // Collect inline styles for spacing. 37180 37181 const spacingStyles = (style === null || style === void 0 ? void 0 : style.spacing) || {}; 37182 const styleProp = getInlineStyles({ 37183 spacing: spacingStyles 37184 }); 37185 return { 37186 style: styleProp 37187 }; 37188 } 37189 37190 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/hooks/use-cached-truthy.js 37191 /** 37192 * WordPress dependencies 37193 */ 37194 37195 /** 37196 * Keeps an up-to-date copy of the passed value and returns it. If value becomes falsy, it will return the last truthy copy. 37197 * 37198 * @param {any} value 37199 * @return {any} value 37200 */ 37201 37202 function useCachedTruthy(value) { 37203 const [cachedValue, setCachedValue] = (0,external_wp_element_namespaceObject.useState)(value); 37204 (0,external_wp_element_namespaceObject.useEffect)(() => { 37205 if (value) { 37206 setCachedValue(value); 37207 } 37208 }, [value]); 37209 return cachedValue; 37210 } 37211 37212 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/hooks/index.js 37213 /** 37214 * Internal dependencies 37215 */ 37216 37217 37218 37219 37220 37221 37222 37223 37224 37225 37226 37227 37228 37229 37230 37231 37232 37233 37234 37235 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/colors/with-colors.js 37236 37237 37238 37239 /** 37240 * External dependencies 37241 */ 37242 37243 /** 37244 * WordPress dependencies 37245 */ 37246 37247 37248 37249 /** 37250 * Internal dependencies 37251 */ 37252 37253 37254 37255 /** 37256 * Higher order component factory for injecting the `colorsArray` argument as 37257 * the colors prop in the `withCustomColors` HOC. 37258 * 37259 * @param {Array} colorsArray An array of color objects. 37260 * 37261 * @return {Function} The higher order component. 37262 */ 37263 37264 const withCustomColorPalette = colorsArray => (0,external_wp_compose_namespaceObject.createHigherOrderComponent)(WrappedComponent => props => (0,external_wp_element_namespaceObject.createElement)(WrappedComponent, _extends({}, props, { 37265 colors: colorsArray 37266 })), 'withCustomColorPalette'); 37267 /** 37268 * Higher order component factory for injecting the editor colors as the 37269 * `colors` prop in the `withColors` HOC. 37270 * 37271 * @return {Function} The higher order component. 37272 */ 37273 37274 37275 const withEditorColorPalette = () => (0,external_wp_compose_namespaceObject.createHigherOrderComponent)(WrappedComponent => props => { 37276 // Some color settings have a special handling for deprecated flags in `useSetting`, 37277 // so we can't unwrap them by doing const { ... } = useSetting('color') 37278 // until https://github.com/WordPress/gutenberg/issues/37094 is fixed. 37279 const userPalette = useSetting('color.palette.custom'); 37280 const themePalette = useSetting('color.palette.theme'); 37281 const defaultPalette = useSetting('color.palette.default'); 37282 const allColors = (0,external_wp_element_namespaceObject.useMemo)(() => [...(userPalette || []), ...(themePalette || []), ...(defaultPalette || [])], [userPalette, themePalette, defaultPalette]); 37283 return (0,external_wp_element_namespaceObject.createElement)(WrappedComponent, _extends({}, props, { 37284 colors: allColors 37285 })); 37286 }, 'withEditorColorPalette'); 37287 /** 37288 * Helper function used with `createHigherOrderComponent` to create 37289 * higher order components for managing color logic. 37290 * 37291 * @param {Array} colorTypes An array of color types (e.g. 'backgroundColor, borderColor). 37292 * @param {Function} withColorPalette A HOC for injecting the 'colors' prop into the WrappedComponent. 37293 * 37294 * @return {WPComponent} The component that can be used as a HOC. 37295 */ 37296 37297 37298 function createColorHOC(colorTypes, withColorPalette) { 37299 const colorMap = (0,external_lodash_namespaceObject.reduce)(colorTypes, (colorObject, colorType) => { 37300 return { ...colorObject, 37301 ...((0,external_lodash_namespaceObject.isString)(colorType) ? { 37302 [colorType]: (0,external_lodash_namespaceObject.kebabCase)(colorType) 37303 } : colorType) 37304 }; 37305 }, {}); 37306 return (0,external_wp_compose_namespaceObject.compose)([withColorPalette, WrappedComponent => { 37307 return class extends external_wp_element_namespaceObject.Component { 37308 constructor(props) { 37309 super(props); 37310 this.setters = this.createSetters(); 37311 this.colorUtils = { 37312 getMostReadableColor: this.getMostReadableColor.bind(this) 37313 }; 37314 this.state = {}; 37315 } 37316 37317 getMostReadableColor(colorValue) { 37318 const { 37319 colors 37320 } = this.props; 37321 return getMostReadableColor(colors, colorValue); 37322 } 37323 37324 createSetters() { 37325 return (0,external_lodash_namespaceObject.reduce)(colorMap, (settersAccumulator, colorContext, colorAttributeName) => { 37326 const upperFirstColorAttributeName = (0,external_lodash_namespaceObject.upperFirst)(colorAttributeName); 37327 const customColorAttributeName = `custom$upperFirstColorAttributeName}`; 37328 settersAccumulator[`set$upperFirstColorAttributeName}`] = this.createSetColor(colorAttributeName, customColorAttributeName); 37329 return settersAccumulator; 37330 }, {}); 37331 } 37332 37333 createSetColor(colorAttributeName, customColorAttributeName) { 37334 return colorValue => { 37335 const colorObject = getColorObjectByColorValue(this.props.colors, colorValue); 37336 this.props.setAttributes({ 37337 [colorAttributeName]: colorObject && colorObject.slug ? colorObject.slug : undefined, 37338 [customColorAttributeName]: colorObject && colorObject.slug ? undefined : colorValue 37339 }); 37340 }; 37341 } 37342 37343 static getDerivedStateFromProps(_ref, previousState) { 37344 let { 37345 attributes, 37346 colors 37347 } = _ref; 37348 return (0,external_lodash_namespaceObject.reduce)(colorMap, (newState, colorContext, colorAttributeName) => { 37349 const colorObject = getColorObjectByAttributeValues(colors, attributes[colorAttributeName], attributes[`custom${(0,external_lodash_namespaceObject.upperFirst)(colorAttributeName)}`]); 37350 const previousColorObject = previousState[colorAttributeName]; 37351 const previousColor = previousColorObject === null || previousColorObject === void 0 ? void 0 : previousColorObject.color; 37352 /** 37353 * The "and previousColorObject" condition checks that a previous color object was already computed. 37354 * At the start previousColorObject and colorValue are both equal to undefined 37355 * bus as previousColorObject does not exist we should compute the object. 37356 */ 37357 37358 if (previousColor === colorObject.color && previousColorObject) { 37359 newState[colorAttributeName] = previousColorObject; 37360 } else { 37361 newState[colorAttributeName] = { ...colorObject, 37362 class: getColorClassName(colorContext, colorObject.slug) 37363 }; 37364 } 37365 37366 return newState; 37367 }, {}); 37368 } 37369 37370 render() { 37371 return (0,external_wp_element_namespaceObject.createElement)(WrappedComponent, _extends({}, this.props, { 37372 colors: undefined 37373 }, this.state, this.setters, { 37374 colorUtils: this.colorUtils 37375 })); 37376 } 37377 37378 }; 37379 }]); 37380 } 37381 /** 37382 * A higher-order component factory for creating a 'withCustomColors' HOC, which handles color logic 37383 * for class generation color value, retrieval and color attribute setting. 37384 * 37385 * Use this higher-order component to work with a custom set of colors. 37386 * 37387 * @example 37388 * 37389 * ```jsx 37390 * const CUSTOM_COLORS = [ { name: 'Red', slug: 'red', color: '#ff0000' }, { name: 'Blue', slug: 'blue', color: '#0000ff' } ]; 37391 * const withCustomColors = createCustomColorsHOC( CUSTOM_COLORS ); 37392 * // ... 37393 * export default compose( 37394 * withCustomColors( 'backgroundColor', 'borderColor' ), 37395 * MyColorfulComponent, 37396 * ); 37397 * ``` 37398 * 37399 * @param {Array} colorsArray The array of color objects (name, slug, color, etc... ). 37400 * 37401 * @return {Function} Higher-order component. 37402 */ 37403 37404 37405 function createCustomColorsHOC(colorsArray) { 37406 return function () { 37407 const withColorPalette = withCustomColorPalette(colorsArray); 37408 37409 for (var _len = arguments.length, colorTypes = new Array(_len), _key = 0; _key < _len; _key++) { 37410 colorTypes[_key] = arguments[_key]; 37411 } 37412 37413 return (0,external_wp_compose_namespaceObject.createHigherOrderComponent)(createColorHOC(colorTypes, withColorPalette), 'withCustomColors'); 37414 }; 37415 } 37416 /** 37417 * A higher-order component, which handles color logic for class generation color value, retrieval and color attribute setting. 37418 * 37419 * For use with the default editor/theme color palette. 37420 * 37421 * @example 37422 * 37423 * ```jsx 37424 * export default compose( 37425 * withColors( 'backgroundColor', { textColor: 'color' } ), 37426 * MyColorfulComponent, 37427 * ); 37428 * ``` 37429 * 37430 * @param {...(Object|string)} colorTypes The arguments can be strings or objects. If the argument is an object, 37431 * it should contain the color attribute name as key and the color context as value. 37432 * If the argument is a string the value should be the color attribute name, 37433 * the color context is computed by applying a kebab case transform to the value. 37434 * Color context represents the context/place where the color is going to be used. 37435 * The class name of the color is generated using 'has' followed by the color name 37436 * and ending with the color context all in kebab case e.g: has-green-background-color. 37437 * 37438 * @return {Function} Higher-order component. 37439 */ 37440 37441 function withColors() { 37442 const withColorPalette = withEditorColorPalette(); 37443 37444 for (var _len2 = arguments.length, colorTypes = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) { 37445 colorTypes[_key2] = arguments[_key2]; 37446 } 37447 37448 return (0,external_wp_compose_namespaceObject.createHigherOrderComponent)(createColorHOC(colorTypes, withColorPalette), 'withColors'); 37449 } 37450 37451 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/colors/index.js 37452 37453 37454 37455 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/gradients/index.js 37456 37457 37458 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/font-sizes/with-font-sizes.js 37459 37460 37461 37462 /** 37463 * External dependencies 37464 */ 37465 37466 /** 37467 * WordPress dependencies 37468 */ 37469 37470 37471 37472 /** 37473 * Internal dependencies 37474 */ 37475 37476 37477 37478 const DEFAULT_FONT_SIZES = []; 37479 /** 37480 * Higher-order component, which handles font size logic for class generation, 37481 * font size value retrieval, and font size change handling. 37482 * 37483 * @param {...(Object|string)} fontSizeNames The arguments should all be strings. 37484 * Each string contains the font size 37485 * attribute name e.g: 'fontSize'. 37486 * 37487 * @return {Function} Higher-order component. 37488 */ 37489 37490 /* harmony default export */ var with_font_sizes = (function () { 37491 for (var _len = arguments.length, fontSizeNames = new Array(_len), _key = 0; _key < _len; _key++) { 37492 fontSizeNames[_key] = arguments[_key]; 37493 } 37494 37495 /* 37496 * Computes an object whose key is the font size attribute name as passed in the array, 37497 * and the value is the custom font size attribute name. 37498 * Custom font size is automatically compted by appending custom followed by the font size attribute name in with the first letter capitalized. 37499 */ 37500 const fontSizeAttributeNames = (0,external_lodash_namespaceObject.reduce)(fontSizeNames, (fontSizeAttributeNamesAccumulator, fontSizeAttributeName) => { 37501 fontSizeAttributeNamesAccumulator[fontSizeAttributeName] = `custom${(0,external_lodash_namespaceObject.upperFirst)(fontSizeAttributeName)}`; 37502 return fontSizeAttributeNamesAccumulator; 37503 }, {}); 37504 return (0,external_wp_compose_namespaceObject.createHigherOrderComponent)((0,external_wp_compose_namespaceObject.compose)([(0,external_wp_compose_namespaceObject.createHigherOrderComponent)(WrappedComponent => props => { 37505 const fontSizes = useSetting('typography.fontSizes') || DEFAULT_FONT_SIZES; 37506 return (0,external_wp_element_namespaceObject.createElement)(WrappedComponent, _extends({}, props, { 37507 fontSizes: fontSizes 37508 })); 37509 }, 'withFontSizes'), WrappedComponent => { 37510 return class extends external_wp_element_namespaceObject.Component { 37511 constructor(props) { 37512 super(props); 37513 this.setters = this.createSetters(); 37514 this.state = {}; 37515 } 37516 37517 createSetters() { 37518 return (0,external_lodash_namespaceObject.reduce)(fontSizeAttributeNames, (settersAccumulator, customFontSizeAttributeName, fontSizeAttributeName) => { 37519 const upperFirstFontSizeAttributeName = (0,external_lodash_namespaceObject.upperFirst)(fontSizeAttributeName); 37520 settersAccumulator[`set$upperFirstFontSizeAttributeName}`] = this.createSetFontSize(fontSizeAttributeName, customFontSizeAttributeName); 37521 return settersAccumulator; 37522 }, {}); 37523 } 37524 37525 createSetFontSize(fontSizeAttributeName, customFontSizeAttributeName) { 37526 return fontSizeValue => { 37527 const fontSizeObject = (0,external_lodash_namespaceObject.find)(this.props.fontSizes, { 37528 size: Number(fontSizeValue) 37529 }); 37530 this.props.setAttributes({ 37531 [fontSizeAttributeName]: fontSizeObject && fontSizeObject.slug ? fontSizeObject.slug : undefined, 37532 [customFontSizeAttributeName]: fontSizeObject && fontSizeObject.slug ? undefined : fontSizeValue 37533 }); 37534 }; 37535 } 37536 37537 static getDerivedStateFromProps(_ref, previousState) { 37538 let { 37539 attributes, 37540 fontSizes 37541 } = _ref; 37542 37543 const didAttributesChange = (customFontSizeAttributeName, fontSizeAttributeName) => { 37544 if (previousState[fontSizeAttributeName]) { 37545 // If new font size is name compare with the previous slug. 37546 if (attributes[fontSizeAttributeName]) { 37547 return attributes[fontSizeAttributeName] !== previousState[fontSizeAttributeName].slug; 37548 } // If font size is not named, update when the font size value changes. 37549 37550 37551 return previousState[fontSizeAttributeName].size !== attributes[customFontSizeAttributeName]; 37552 } // In this case we need to build the font size object. 37553 37554 37555 return true; 37556 }; 37557 37558 if (!(0,external_lodash_namespaceObject.some)(fontSizeAttributeNames, didAttributesChange)) { 37559 return null; 37560 } 37561 37562 const newState = (0,external_lodash_namespaceObject.reduce)((0,external_lodash_namespaceObject.pickBy)(fontSizeAttributeNames, didAttributesChange), (newStateAccumulator, customFontSizeAttributeName, fontSizeAttributeName) => { 37563 const fontSizeAttributeValue = attributes[fontSizeAttributeName]; 37564 const fontSizeObject = getFontSize(fontSizes, fontSizeAttributeValue, attributes[customFontSizeAttributeName]); 37565 newStateAccumulator[fontSizeAttributeName] = { ...fontSizeObject, 37566 class: getFontSizeClass(fontSizeAttributeValue) 37567 }; 37568 return newStateAccumulator; 37569 }, {}); 37570 return { ...previousState, 37571 ...newState 37572 }; 37573 } 37574 37575 render() { 37576 return (0,external_wp_element_namespaceObject.createElement)(WrappedComponent, _extends({}, this.props, { 37577 fontSizes: undefined 37578 }, this.state, this.setters)); 37579 } 37580 37581 }; 37582 }]), 'withFontSizes'); 37583 }); 37584 37585 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/font-sizes/index.js 37586 37587 37588 37589 37590 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/align-left.js 37591 37592 37593 /** 37594 * WordPress dependencies 37595 */ 37596 37597 const alignLeft = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 37598 xmlns: "http://www.w3.org/2000/svg", 37599 viewBox: "0 0 24 24" 37600 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 37601 d: "M4 19.8h8.9v-1.5H4v1.5zm8.9-15.6H4v1.5h8.9V4.2zm-8.9 7v1.5h16v-1.5H4z" 37602 })); 37603 /* harmony default export */ var align_left = (alignLeft); 37604 37605 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/align-center.js 37606 37607 37608 /** 37609 * WordPress dependencies 37610 */ 37611 37612 const align_center_alignCenter = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 37613 xmlns: "http://www.w3.org/2000/svg", 37614 viewBox: "0 0 24 24" 37615 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 37616 d: "M16.4 4.2H7.6v1.5h8.9V4.2zM4 11.2v1.5h16v-1.5H4zm3.6 8.6h8.9v-1.5H7.6v1.5z" 37617 })); 37618 /* harmony default export */ var align_center = (align_center_alignCenter); 37619 37620 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/align-right.js 37621 37622 37623 /** 37624 * WordPress dependencies 37625 */ 37626 37627 const alignRight = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 37628 xmlns: "http://www.w3.org/2000/svg", 37629 viewBox: "0 0 24 24" 37630 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 37631 d: "M11.1 19.8H20v-1.5h-8.9v1.5zm0-15.6v1.5H20V4.2h-8.9zM4 12.8h16v-1.5H4v1.5z" 37632 })); 37633 /* harmony default export */ var align_right = (alignRight); 37634 37635 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/alignment-control/ui.js 37636 37637 37638 37639 /** 37640 * External dependencies 37641 */ 37642 37643 /** 37644 * WordPress dependencies 37645 */ 37646 37647 37648 37649 37650 const DEFAULT_ALIGNMENT_CONTROLS = [{ 37651 icon: align_left, 37652 title: (0,external_wp_i18n_namespaceObject.__)('Align text left'), 37653 align: 'left' 37654 }, { 37655 icon: align_center, 37656 title: (0,external_wp_i18n_namespaceObject.__)('Align text center'), 37657 align: 'center' 37658 }, { 37659 icon: align_right, 37660 title: (0,external_wp_i18n_namespaceObject.__)('Align text right'), 37661 align: 'right' 37662 }]; 37663 const alignment_control_ui_POPOVER_PROPS = { 37664 position: 'bottom right', 37665 isAlternate: true 37666 }; 37667 37668 function AlignmentUI(_ref) { 37669 let { 37670 value, 37671 onChange, 37672 alignmentControls = DEFAULT_ALIGNMENT_CONTROLS, 37673 label = (0,external_wp_i18n_namespaceObject.__)('Align'), 37674 describedBy = (0,external_wp_i18n_namespaceObject.__)('Change text alignment'), 37675 isCollapsed = true, 37676 isToolbar 37677 } = _ref; 37678 37679 function applyOrUnset(align) { 37680 return () => onChange(value === align ? undefined : align); 37681 } 37682 37683 const activeAlignment = (0,external_lodash_namespaceObject.find)(alignmentControls, control => control.align === value); 37684 37685 function setIcon() { 37686 if (activeAlignment) return activeAlignment.icon; 37687 return (0,external_wp_i18n_namespaceObject.isRTL)() ? align_right : align_left; 37688 } 37689 37690 const UIComponent = isToolbar ? external_wp_components_namespaceObject.ToolbarGroup : external_wp_components_namespaceObject.ToolbarDropdownMenu; 37691 const extraProps = isToolbar ? { 37692 isCollapsed 37693 } : {}; 37694 return (0,external_wp_element_namespaceObject.createElement)(UIComponent, _extends({ 37695 icon: setIcon(), 37696 label: label, 37697 toggleProps: { 37698 describedBy 37699 }, 37700 popoverProps: alignment_control_ui_POPOVER_PROPS, 37701 controls: alignmentControls.map(control => { 37702 const { 37703 align 37704 } = control; 37705 const isActive = value === align; 37706 return { ...control, 37707 isActive, 37708 role: isCollapsed ? 'menuitemradio' : undefined, 37709 onClick: applyOrUnset(align) 37710 }; 37711 }) 37712 }, extraProps)); 37713 } 37714 37715 /* harmony default export */ var alignment_control_ui = (AlignmentUI); 37716 37717 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/alignment-control/index.js 37718 37719 37720 37721 /** 37722 * Internal dependencies 37723 */ 37724 37725 37726 const AlignmentControl = props => { 37727 return (0,external_wp_element_namespaceObject.createElement)(alignment_control_ui, _extends({}, props, { 37728 isToolbar: false 37729 })); 37730 }; 37731 37732 const AlignmentToolbar = props => { 37733 return (0,external_wp_element_namespaceObject.createElement)(alignment_control_ui, _extends({}, props, { 37734 isToolbar: true 37735 })); 37736 }; 37737 /** 37738 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/alignment-control/README.md 37739 */ 37740 37741 37742 37743 37744 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/autocompleters/block.js 37745 37746 37747 /** 37748 * External dependencies 37749 */ 37750 37751 /** 37752 * WordPress dependencies 37753 */ 37754 37755 37756 37757 37758 /** 37759 * Internal dependencies 37760 */ 37761 37762 37763 37764 37765 37766 const block_SHOWN_BLOCK_TYPES = 9; 37767 /** @typedef {import('@wordpress/components').WPCompleter} WPCompleter */ 37768 37769 /** 37770 * Creates a blocks repeater for replacing the current block with a selected block type. 37771 * 37772 * @return {WPCompleter} A blocks completer. 37773 */ 37774 37775 function createBlockCompleter() { 37776 return { 37777 name: 'blocks', 37778 className: 'block-editor-autocompleters__block', 37779 triggerPrefix: '/', 37780 37781 useItems(filterValue) { 37782 const { 37783 rootClientId, 37784 selectedBlockName 37785 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 37786 const { 37787 getSelectedBlockClientId, 37788 getBlockName, 37789 getBlockInsertionPoint 37790 } = select(store); 37791 const selectedBlockClientId = getSelectedBlockClientId(); 37792 return { 37793 selectedBlockName: selectedBlockClientId ? getBlockName(selectedBlockClientId) : null, 37794 rootClientId: getBlockInsertionPoint().rootClientId 37795 }; 37796 }, []); 37797 const [items, categories, collections] = use_block_types_state(rootClientId, external_lodash_namespaceObject.noop); 37798 const filteredItems = (0,external_wp_element_namespaceObject.useMemo)(() => { 37799 const initialFilteredItems = !!filterValue.trim() ? searchBlockItems(items, categories, collections, filterValue) : (0,external_lodash_namespaceObject.orderBy)(items, ['frecency'], ['desc']); 37800 return initialFilteredItems.filter(item => item.name !== selectedBlockName).slice(0, block_SHOWN_BLOCK_TYPES); 37801 }, [filterValue, selectedBlockName, items, categories, collections]); 37802 const options = (0,external_wp_element_namespaceObject.useMemo)(() => filteredItems.map(blockItem => { 37803 const { 37804 title, 37805 icon, 37806 isDisabled 37807 } = blockItem; 37808 return { 37809 key: `block-$blockItem.id}`, 37810 value: blockItem, 37811 label: (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(block_icon, { 37812 key: "icon", 37813 icon: icon, 37814 showColors: true 37815 }), title), 37816 isDisabled 37817 }; 37818 }), [filteredItems]); 37819 return [options]; 37820 }, 37821 37822 allowContext(before, after) { 37823 return !(/\S/.test(before) || /\S/.test(after)); 37824 }, 37825 37826 getOptionCompletion(inserterItem) { 37827 const { 37828 name, 37829 initialAttributes, 37830 innerBlocks 37831 } = inserterItem; 37832 return { 37833 action: 'replace', 37834 value: (0,external_wp_blocks_namespaceObject.createBlock)(name, initialAttributes, (0,external_wp_blocks_namespaceObject.createBlocksFromInnerBlocksTemplate)(innerBlocks)) 37835 }; 37836 } 37837 37838 }; 37839 } 37840 /** 37841 * Creates a blocks repeater for replacing the current block with a selected block type. 37842 * 37843 * @return {WPCompleter} A blocks completer. 37844 */ 37845 37846 37847 /* harmony default export */ var autocompleters_block = (createBlockCompleter()); 37848 37849 ;// CONCATENATED MODULE: external ["wp","apiFetch"] 37850 var external_wp_apiFetch_namespaceObject = window["wp"]["apiFetch"]; 37851 var external_wp_apiFetch_default = /*#__PURE__*/__webpack_require__.n(external_wp_apiFetch_namespaceObject); 37852 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/page.js 37853 37854 37855 /** 37856 * WordPress dependencies 37857 */ 37858 37859 const page = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 37860 xmlns: "http://www.w3.org/2000/svg", 37861 viewBox: "0 0 24 24" 37862 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 37863 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" 37864 })); 37865 /* harmony default export */ var library_page = (page); 37866 37867 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/post.js 37868 37869 37870 /** 37871 * WordPress dependencies 37872 */ 37873 37874 const post = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 37875 xmlns: "http://www.w3.org/2000/svg", 37876 viewBox: "0 0 24 24" 37877 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 37878 d: "m7.3 9.7 1.4 1.4c.2-.2.3-.3.4-.5 0 0 0-.1.1-.1.3-.5.4-1.1.3-1.6L12 7 9 4 7.2 6.5c-.6-.1-1.1 0-1.6.3 0 0-.1 0-.1.1-.3.1-.4.2-.6.4l1.4 1.4L4 11v1h1l2.3-2.3zM4 20h9v-1.5H4V20zm0-5.5V16h16v-1.5H4z" 37879 })); 37880 /* harmony default export */ var library_post = (post); 37881 37882 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/autocompleters/link.js 37883 37884 37885 /** 37886 * WordPress dependencies 37887 */ 37888 37889 37890 37891 const SHOWN_SUGGESTIONS = 10; 37892 /** @typedef {import('@wordpress/components').WPCompleter} WPCompleter */ 37893 37894 /** 37895 * Creates a suggestion list for links to posts or pages. 37896 * 37897 * @return {WPCompleter} A links completer. 37898 */ 37899 37900 function createLinkCompleter() { 37901 return { 37902 name: 'links', 37903 className: 'block-editor-autocompleters__link', 37904 triggerPrefix: '[[', 37905 options: async letters => { 37906 let options = await external_wp_apiFetch_default()({ 37907 path: (0,external_wp_url_namespaceObject.addQueryArgs)('/wp/v2/search', { 37908 per_page: SHOWN_SUGGESTIONS, 37909 search: letters, 37910 type: 'post', 37911 order_by: 'menu_order' 37912 }) 37913 }); 37914 options = options.filter(option => option.title !== ''); 37915 return options; 37916 }, 37917 37918 getOptionKeywords(item) { 37919 const expansionWords = item.title.split(/\s+/); 37920 return [...expansionWords]; 37921 }, 37922 37923 getOptionLabel(item) { 37924 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(build_module_icon, { 37925 key: "icon", 37926 icon: item.subtype === 'page' ? library_page : library_post 37927 }), item.title); 37928 }, 37929 37930 getOptionCompletion(item) { 37931 return (0,external_wp_element_namespaceObject.createElement)("a", { 37932 href: item.url 37933 }, item.title); 37934 } 37935 37936 }; 37937 } 37938 /** 37939 * Creates a suggestion list for links to posts or pages.. 37940 * 37941 * @return {WPCompleter} A link completer. 37942 */ 37943 37944 37945 /* harmony default export */ var autocompleters_link = (createLinkCompleter()); 37946 37947 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/autocomplete/index.js 37948 37949 37950 37951 /** 37952 * External dependencies 37953 */ 37954 37955 /** 37956 * WordPress dependencies 37957 */ 37958 37959 37960 37961 37962 37963 /** 37964 * Internal dependencies 37965 */ 37966 37967 37968 37969 37970 /** 37971 * Shared reference to an empty array for cases where it is important to avoid 37972 * returning a new array reference on every invocation. 37973 * 37974 * @type {Array} 37975 */ 37976 37977 const autocomplete_EMPTY_ARRAY = []; 37978 37979 function useCompleters(_ref) { 37980 let { 37981 completers = autocomplete_EMPTY_ARRAY 37982 } = _ref; 37983 const { 37984 name 37985 } = useBlockEditContext(); 37986 return (0,external_wp_element_namespaceObject.useMemo)(() => { 37987 let filteredCompleters = completers; 37988 37989 if (name === (0,external_wp_blocks_namespaceObject.getDefaultBlockName)() || (0,external_wp_blocks_namespaceObject.getBlockSupport)(name, '__experimentalSlashInserter', false)) { 37990 filteredCompleters = filteredCompleters.concat([autocompleters_block, autocompleters_link]); 37991 } 37992 37993 if ((0,external_wp_hooks_namespaceObject.hasFilter)('editor.Autocomplete.completers')) { 37994 // Provide copies so filters may directly modify them. 37995 if (filteredCompleters === completers) { 37996 filteredCompleters = filteredCompleters.map(external_lodash_namespaceObject.clone); 37997 } 37998 37999 filteredCompleters = (0,external_wp_hooks_namespaceObject.applyFilters)('editor.Autocomplete.completers', filteredCompleters, name); 38000 } 38001 38002 return filteredCompleters; 38003 }, [completers, name]); 38004 } 38005 38006 function useBlockEditorAutocompleteProps(props) { 38007 return (0,external_wp_components_namespaceObject.__unstableUseAutocompleteProps)({ ...props, 38008 completers: useCompleters(props) 38009 }); 38010 } 38011 /** 38012 * Wrap the default Autocomplete component with one that supports a filter hook 38013 * for customizing its list of autocompleters. 38014 * 38015 * @type {import('react').FC} 38016 */ 38017 38018 function BlockEditorAutocomplete(props) { 38019 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Autocomplete, _extends({}, props, { 38020 completers: useCompleters(props) 38021 })); 38022 } 38023 /** 38024 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/autocomplete/README.md 38025 */ 38026 38027 38028 /* harmony default export */ var autocomplete = (BlockEditorAutocomplete); 38029 38030 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/fullscreen.js 38031 38032 38033 /** 38034 * WordPress dependencies 38035 */ 38036 38037 const fullscreen = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 38038 xmlns: "http://www.w3.org/2000/svg", 38039 viewBox: "0 0 24 24" 38040 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 38041 d: "M4.2 9h1.5V5.8H9V4.2H4.2V9zm14 9.2H15v1.5h4.8V15h-1.5v3.2zM15 4.2v1.5h3.2V9h1.5V4.2H15zM5.8 15H4.2v4.8H9v-1.5H5.8V15z" 38042 })); 38043 /* harmony default export */ var library_fullscreen = (fullscreen); 38044 38045 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-full-height-alignment-control/index.js 38046 38047 38048 /** 38049 * WordPress dependencies 38050 */ 38051 38052 38053 38054 38055 function BlockFullHeightAlignmentControl(_ref) { 38056 let { 38057 isActive, 38058 label = (0,external_wp_i18n_namespaceObject.__)('Toggle full height'), 38059 onToggle, 38060 isDisabled 38061 } = _ref; 38062 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, { 38063 isActive: isActive, 38064 icon: library_fullscreen, 38065 label: label, 38066 onClick: () => onToggle(!isActive), 38067 disabled: isDisabled 38068 }); 38069 } 38070 38071 /* harmony default export */ var block_full_height_alignment_control = (BlockFullHeightAlignmentControl); 38072 38073 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-alignment-matrix-control/index.js 38074 38075 38076 /** 38077 * External dependencies 38078 */ 38079 38080 /** 38081 * WordPress dependencies 38082 */ 38083 38084 38085 38086 38087 38088 function BlockAlignmentMatrixControl(props) { 38089 const { 38090 label = (0,external_wp_i18n_namespaceObject.__)('Change matrix alignment'), 38091 onChange = external_lodash_namespaceObject.noop, 38092 value = 'center', 38093 isDisabled 38094 } = props; 38095 const icon = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalAlignmentMatrixControl.Icon, { 38096 value: value 38097 }); 38098 const className = 'block-editor-block-alignment-matrix-control'; 38099 const popoverClassName = `$className}__popover`; 38100 const isAlternate = true; 38101 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Dropdown, { 38102 position: "bottom right", 38103 className: className, 38104 popoverProps: { 38105 className: popoverClassName, 38106 isAlternate 38107 }, 38108 renderToggle: _ref => { 38109 let { 38110 onToggle, 38111 isOpen 38112 } = _ref; 38113 38114 const openOnArrowDown = event => { 38115 if (!isOpen && event.keyCode === external_wp_keycodes_namespaceObject.DOWN) { 38116 event.preventDefault(); 38117 onToggle(); 38118 } 38119 }; 38120 38121 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, { 38122 onClick: onToggle, 38123 "aria-haspopup": "true", 38124 "aria-expanded": isOpen, 38125 onKeyDown: openOnArrowDown, 38126 label: label, 38127 icon: icon, 38128 showTooltip: true, 38129 disabled: isDisabled 38130 }); 38131 }, 38132 renderContent: () => (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalAlignmentMatrixControl, { 38133 hasFocusBorder: false, 38134 onChange: onChange, 38135 value: value 38136 }) 38137 }); 38138 } 38139 38140 /* harmony default export */ var block_alignment_matrix_control = (BlockAlignmentMatrixControl); 38141 38142 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/chevron-right-small.js 38143 38144 38145 /** 38146 * WordPress dependencies 38147 */ 38148 38149 const chevronRightSmall = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 38150 xmlns: "http://www.w3.org/2000/svg", 38151 viewBox: "0 0 24 24" 38152 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 38153 d: "M10.8622 8.04053L14.2805 12.0286L10.8622 16.0167L9.72327 15.0405L12.3049 12.0286L9.72327 9.01672L10.8622 8.04053Z" 38154 })); 38155 /* harmony default export */ var chevron_right_small = (chevronRightSmall); 38156 38157 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-breadcrumb/index.js 38158 38159 38160 /** 38161 * WordPress dependencies 38162 */ 38163 38164 38165 38166 38167 /** 38168 * Internal dependencies 38169 */ 38170 38171 38172 38173 /** 38174 * Block breadcrumb component, displaying the hierarchy of the current block selection as a breadcrumb. 38175 * 38176 * @param {Object} props Component props. 38177 * @param {string} props.rootLabelText Translated label for the root element of the breadcrumb trail. 38178 * @return {WPElement} Block Breadcrumb. 38179 */ 38180 38181 function BlockBreadcrumb(_ref) { 38182 let { 38183 rootLabelText 38184 } = _ref; 38185 const { 38186 selectBlock, 38187 clearSelectedBlock 38188 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 38189 const { 38190 clientId, 38191 parents, 38192 hasSelection 38193 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 38194 const { 38195 getSelectionStart, 38196 getSelectedBlockClientId, 38197 getBlockParents 38198 } = select(store); 38199 const selectedBlockClientId = getSelectedBlockClientId(); 38200 return { 38201 parents: getBlockParents(selectedBlockClientId), 38202 clientId: selectedBlockClientId, 38203 hasSelection: !!getSelectionStart().clientId 38204 }; 38205 }, []); 38206 38207 const rootLabel = rootLabelText || (0,external_wp_i18n_namespaceObject.__)('Document'); 38208 /* 38209 * Disable reason: The `list` ARIA role is redundant but 38210 * Safari+VoiceOver won't announce the list otherwise. 38211 */ 38212 38213 /* eslint-disable jsx-a11y/no-redundant-roles */ 38214 38215 38216 return (0,external_wp_element_namespaceObject.createElement)("ul", { 38217 className: "block-editor-block-breadcrumb", 38218 role: "list", 38219 "aria-label": (0,external_wp_i18n_namespaceObject.__)('Block breadcrumb') 38220 }, (0,external_wp_element_namespaceObject.createElement)("li", { 38221 className: !hasSelection ? 'block-editor-block-breadcrumb__current' : undefined, 38222 "aria-current": !hasSelection ? 'true' : undefined 38223 }, hasSelection && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 38224 className: "block-editor-block-breadcrumb__button", 38225 variant: "tertiary", 38226 onClick: clearSelectedBlock 38227 }, rootLabel), !hasSelection && rootLabel, !!clientId && (0,external_wp_element_namespaceObject.createElement)(build_module_icon, { 38228 icon: chevron_right_small, 38229 className: "block-editor-block-breadcrumb__separator" 38230 })), parents.map(parentClientId => (0,external_wp_element_namespaceObject.createElement)("li", { 38231 key: parentClientId 38232 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 38233 className: "block-editor-block-breadcrumb__button", 38234 variant: "tertiary", 38235 onClick: () => selectBlock(parentClientId) 38236 }, (0,external_wp_element_namespaceObject.createElement)(BlockTitle, { 38237 clientId: parentClientId, 38238 maximumLength: 35 38239 })), (0,external_wp_element_namespaceObject.createElement)(build_module_icon, { 38240 icon: chevron_right_small, 38241 className: "block-editor-block-breadcrumb__separator" 38242 }))), !!clientId && (0,external_wp_element_namespaceObject.createElement)("li", { 38243 className: "block-editor-block-breadcrumb__current", 38244 "aria-current": "true" 38245 }, (0,external_wp_element_namespaceObject.createElement)(BlockTitle, { 38246 clientId: clientId, 38247 maximumLength: 35 38248 }))) 38249 /* eslint-enable jsx-a11y/no-redundant-roles */ 38250 ; 38251 } 38252 38253 /* harmony default export */ var block_breadcrumb = (BlockBreadcrumb); 38254 38255 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-content-overlay/index.js 38256 38257 38258 38259 /** 38260 * WordPress dependencies 38261 */ 38262 38263 38264 /** 38265 * Internal dependencies 38266 */ 38267 38268 38269 /** 38270 * External dependencies 38271 */ 38272 38273 38274 function BlockContentOverlay(_ref) { 38275 let { 38276 clientId, 38277 tagName: TagName = 'div', 38278 wrapperProps, 38279 className 38280 } = _ref; 38281 const baseClassName = 'block-editor-block-content-overlay'; 38282 const [isOverlayActive, setIsOverlayActive] = (0,external_wp_element_namespaceObject.useState)(true); 38283 const [isHovered, setIsHovered] = (0,external_wp_element_namespaceObject.useState)(false); 38284 const { 38285 isParentSelected, 38286 hasChildSelected, 38287 isDraggingBlocks, 38288 isParentHighlighted 38289 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 38290 const { 38291 isBlockSelected, 38292 hasSelectedInnerBlock, 38293 isDraggingBlocks: _isDraggingBlocks, 38294 isBlockHighlighted 38295 } = select(store); 38296 return { 38297 isParentSelected: isBlockSelected(clientId), 38298 hasChildSelected: hasSelectedInnerBlock(clientId, true), 38299 isDraggingBlocks: _isDraggingBlocks(), 38300 isParentHighlighted: isBlockHighlighted(clientId) 38301 }; 38302 }, [clientId]); 38303 const classes = classnames_default()(baseClassName, wrapperProps === null || wrapperProps === void 0 ? void 0 : wrapperProps.className, className, { 38304 'overlay-active': isOverlayActive, 38305 'parent-highlighted': isParentHighlighted, 38306 'is-dragging-blocks': isDraggingBlocks 38307 }); 38308 (0,external_wp_element_namespaceObject.useEffect)(() => { 38309 // Reenable when blocks are not in use. 38310 if (!isParentSelected && !hasChildSelected && !isOverlayActive) { 38311 setIsOverlayActive(true); 38312 } // Disable if parent selected by another means (such as list view). 38313 // We check hover to ensure the overlay click interaction is not taking place. 38314 // Trying to click the overlay will select the parent block via its 'focusin' 38315 // listener on the wrapper, so if the block is selected while hovered we will 38316 // let the mouseup disable the overlay instead. 38317 38318 38319 if (isParentSelected && !isHovered && isOverlayActive) { 38320 setIsOverlayActive(false); 38321 } // Ensure overlay is disabled if a child block is selected. 38322 38323 38324 if (hasChildSelected && isOverlayActive) { 38325 setIsOverlayActive(false); 38326 } 38327 }, [isParentSelected, hasChildSelected, isOverlayActive, isHovered]); // Disabled because the overlay div doesn't actually have a role or functionality 38328 // as far as the a11y is concerned. We're just catching the first click so that 38329 // the block can be selected without interacting with its contents. 38330 38331 /* eslint-disable jsx-a11y/no-static-element-interactions */ 38332 38333 return (0,external_wp_element_namespaceObject.createElement)(TagName, _extends({}, wrapperProps, { 38334 className: classes, 38335 onMouseEnter: () => setIsHovered(true), 38336 onMouseLeave: () => setIsHovered(false), 38337 onMouseUp: isOverlayActive ? () => setIsOverlayActive(false) : undefined 38338 }), wrapperProps === null || wrapperProps === void 0 ? void 0 : wrapperProps.children); 38339 } 38340 /* eslint-enable jsx-a11y/no-static-element-interactions */ 38341 38342 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/color-style-selector/index.js 38343 38344 38345 /** 38346 * WordPress dependencies 38347 */ 38348 38349 38350 38351 38352 const ColorSelectorSVGIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, { 38353 xmlns: "https://www.w3.org/2000/svg", 38354 viewBox: "0 0 20 20" 38355 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, { 38356 d: "M7.434 5l3.18 9.16H8.538l-.692-2.184H4.628l-.705 2.184H2L5.18 5h2.254zm-1.13 1.904h-.115l-1.148 3.593H7.44L6.304 6.904zM14.348 7.006c1.853 0 2.9.876 2.9 2.374v4.78h-1.79v-.914h-.114c-.362.64-1.123 1.022-2.031 1.022-1.346 0-2.292-.826-2.292-2.108 0-1.27.972-2.006 2.71-2.107l1.696-.102V9.38c0-.584-.42-.914-1.18-.914-.667 0-1.112.228-1.264.647h-1.701c.12-1.295 1.307-2.107 3.066-2.107zm1.079 4.1l-1.416.09c-.793.056-1.18.342-1.18.844 0 .52.45.837 1.091.837.857 0 1.505-.545 1.505-1.256v-.515z" 38357 })); 38358 /** 38359 * Color Selector Icon component. 38360 * 38361 * @param {Object} props Component properties. 38362 * @param {Object} props.style Style object. 38363 * @param {string} props.className Class name for component. 38364 * 38365 * @return {*} React Icon component. 38366 */ 38367 38368 38369 const ColorSelectorIcon = _ref => { 38370 let { 38371 style, 38372 className 38373 } = _ref; 38374 return (0,external_wp_element_namespaceObject.createElement)("div", { 38375 className: "block-library-colors-selector__icon-container" 38376 }, (0,external_wp_element_namespaceObject.createElement)("div", { 38377 className: `$className} block-library-colors-selector__state-selection`, 38378 style: style 38379 }, (0,external_wp_element_namespaceObject.createElement)(ColorSelectorSVGIcon, null))); 38380 }; 38381 /** 38382 * Renders the Colors Selector Toolbar with the icon button. 38383 * 38384 * @param {Object} props Component properties. 38385 * @param {Object} props.TextColor Text color component that wraps icon. 38386 * @param {Object} props.BackgroundColor Background color component that wraps icon. 38387 * 38388 * @return {*} React toggle button component. 38389 */ 38390 38391 38392 const renderToggleComponent = _ref2 => { 38393 let { 38394 TextColor, 38395 BackgroundColor 38396 } = _ref2; 38397 return _ref3 => { 38398 let { 38399 onToggle, 38400 isOpen 38401 } = _ref3; 38402 38403 const openOnArrowDown = event => { 38404 if (!isOpen && event.keyCode === external_wp_keycodes_namespaceObject.DOWN) { 38405 event.preventDefault(); 38406 onToggle(); 38407 } 38408 }; 38409 38410 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarGroup, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, { 38411 className: "components-toolbar__control block-library-colors-selector__toggle", 38412 label: (0,external_wp_i18n_namespaceObject.__)('Open Colors Selector'), 38413 onClick: onToggle, 38414 onKeyDown: openOnArrowDown, 38415 icon: (0,external_wp_element_namespaceObject.createElement)(BackgroundColor, null, (0,external_wp_element_namespaceObject.createElement)(TextColor, null, (0,external_wp_element_namespaceObject.createElement)(ColorSelectorIcon, null))) 38416 })); 38417 }; 38418 }; 38419 38420 const BlockColorsStyleSelector = _ref4 => { 38421 let { 38422 children, 38423 ...other 38424 } = _ref4; 38425 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Dropdown, { 38426 position: "bottom right", 38427 className: "block-library-colors-selector", 38428 contentClassName: "block-library-colors-selector__popover", 38429 renderToggle: renderToggleComponent(other), 38430 renderContent: () => children 38431 }); 38432 }; 38433 38434 /* harmony default export */ var color_style_selector = (BlockColorsStyleSelector); 38435 38436 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/list-view.js 38437 38438 38439 /** 38440 * WordPress dependencies 38441 */ 38442 38443 const listView = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 38444 viewBox: "0 0 24 24", 38445 xmlns: "http://www.w3.org/2000/svg" 38446 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 38447 d: "M13.8 5.2H3v1.5h10.8V5.2zm-3.6 12v1.5H21v-1.5H10.2zm7.2-6H6.6v1.5h10.8v-1.5z" 38448 })); 38449 /* harmony default export */ var list_view = (listView); 38450 38451 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/list-view/leaf.js 38452 38453 38454 38455 /** 38456 * External dependencies 38457 */ 38458 38459 38460 /** 38461 * WordPress dependencies 38462 */ 38463 38464 38465 /** 38466 * Internal dependencies 38467 */ 38468 38469 38470 const AnimatedTreeGridRow = animated(external_wp_components_namespaceObject.__experimentalTreeGridRow); 38471 function ListViewLeaf(_ref) { 38472 let { 38473 isSelected, 38474 position, 38475 level, 38476 rowCount, 38477 children, 38478 className, 38479 path, 38480 ...props 38481 } = _ref; 38482 const ref = use_moving_animation({ 38483 isSelected, 38484 adjustScrolling: false, 38485 enableAnimation: true, 38486 triggerAnimationOnChange: path 38487 }); 38488 return (0,external_wp_element_namespaceObject.createElement)(AnimatedTreeGridRow, _extends({ 38489 ref: ref, 38490 className: classnames_default()('block-editor-list-view-leaf', className), 38491 level: level, 38492 positionInSet: position, 38493 setSize: rowCount 38494 }, props), children); 38495 } 38496 38497 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/list-view/expander.js 38498 38499 38500 /** 38501 * WordPress dependencies 38502 */ 38503 38504 function ListViewExpander(_ref) { 38505 let { 38506 onClick 38507 } = _ref; 38508 return (// Keyboard events are handled by TreeGrid see: components/src/tree-grid/index.js 38509 // 38510 // The expander component is implemented as a pseudo element in the w3 example 38511 // https://www.w3.org/TR/wai-aria-practices/examples/treegrid/treegrid-1.html 38512 // 38513 // We've mimicked this by adding an icon with aria-hidden set to true to hide this from the accessibility tree. 38514 // For the current tree grid implementation, please do not try to make this a button. 38515 // 38516 // eslint-disable-next-line jsx-a11y/click-events-have-key-events,jsx-a11y/no-static-element-interactions 38517 (0,external_wp_element_namespaceObject.createElement)("span", { 38518 className: "block-editor-list-view__expander", 38519 onClick: event => onClick(event, { 38520 forceToggle: true 38521 }), 38522 "aria-hidden": "true" 38523 }, (0,external_wp_element_namespaceObject.createElement)(build_module_icon, { 38524 icon: chevron_right_small 38525 })) 38526 ); 38527 } 38528 38529 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/list-view/block-select-button.js 38530 38531 38532 /** 38533 * External dependencies 38534 */ 38535 38536 /** 38537 * WordPress dependencies 38538 */ 38539 38540 38541 38542 38543 38544 /** 38545 * Internal dependencies 38546 */ 38547 38548 38549 38550 38551 38552 38553 38554 function ListViewBlockSelectButton(_ref, ref) { 38555 let { 38556 className, 38557 block: { 38558 clientId 38559 }, 38560 onClick, 38561 onToggleExpanded, 38562 tabIndex, 38563 onFocus, 38564 onDragStart, 38565 onDragEnd, 38566 draggable 38567 } = _ref; 38568 const blockInformation = useBlockDisplayInformation(clientId); 38569 const { 38570 isLocked 38571 } = useBlockLock(clientId); // The `href` attribute triggers the browser's native HTML drag operations. 38572 // When the link is dragged, the element's outerHTML is set in DataTransfer object as text/html. 38573 // We need to clear any HTML drag data to prevent `pasteHandler` from firing 38574 // inside the `useOnBlockDrop` hook. 38575 38576 const onDragStartHandler = event => { 38577 event.dataTransfer.clearData(); 38578 onDragStart === null || onDragStart === void 0 ? void 0 : onDragStart(event); 38579 }; 38580 38581 function onKeyDownHandler(event) { 38582 if (event.keyCode === external_wp_keycodes_namespaceObject.ENTER || event.keyCode === external_wp_keycodes_namespaceObject.SPACE) { 38583 onClick(event); 38584 } 38585 } 38586 38587 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 38588 className: classnames_default()('block-editor-list-view-block-select-button', className), 38589 onClick: onClick, 38590 onKeyDown: onKeyDownHandler, 38591 ref: ref, 38592 tabIndex: tabIndex, 38593 onFocus: onFocus, 38594 onDragStart: onDragStartHandler, 38595 onDragEnd: onDragEnd, 38596 draggable: draggable, 38597 href: `#block-$clientId}`, 38598 "aria-hidden": true 38599 }, (0,external_wp_element_namespaceObject.createElement)(ListViewExpander, { 38600 onClick: onToggleExpanded 38601 }), (0,external_wp_element_namespaceObject.createElement)(block_icon, { 38602 icon: blockInformation === null || blockInformation === void 0 ? void 0 : blockInformation.icon, 38603 showColors: true 38604 }), (0,external_wp_element_namespaceObject.createElement)("span", { 38605 className: "block-editor-list-view-block-select-button__title" 38606 }, (0,external_wp_element_namespaceObject.createElement)(BlockTitle, { 38607 clientId: clientId, 38608 maximumLength: 35 38609 })), (blockInformation === null || blockInformation === void 0 ? void 0 : blockInformation.anchor) && (0,external_wp_element_namespaceObject.createElement)("span", { 38610 className: "block-editor-list-view-block-select-button__anchor" 38611 }, blockInformation.anchor), isLocked && (0,external_wp_element_namespaceObject.createElement)("span", { 38612 className: "block-editor-list-view-block-select-button__lock" 38613 }, (0,external_wp_element_namespaceObject.createElement)(build_module_icon, { 38614 icon: library_lock 38615 })))); 38616 } 38617 38618 /* harmony default export */ var block_select_button = ((0,external_wp_element_namespaceObject.forwardRef)(ListViewBlockSelectButton)); 38619 38620 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/list-view/block-contents.js 38621 38622 38623 38624 /** 38625 * External dependencies 38626 */ 38627 38628 /** 38629 * WordPress dependencies 38630 */ 38631 38632 38633 38634 /** 38635 * Internal dependencies 38636 */ 38637 38638 38639 38640 38641 const ListViewBlockContents = (0,external_wp_element_namespaceObject.forwardRef)((_ref, ref) => { 38642 let { 38643 onClick, 38644 onToggleExpanded, 38645 block, 38646 isSelected, 38647 position, 38648 siblingBlockCount, 38649 level, 38650 isExpanded, 38651 selectedClientIds, 38652 ...props 38653 } = _ref; 38654 const { 38655 clientId 38656 } = block; 38657 const { 38658 blockMovingClientId, 38659 selectedBlockInBlockEditor 38660 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 38661 const { 38662 hasBlockMovingClientId, 38663 getSelectedBlockClientId 38664 } = select(store); 38665 return { 38666 blockMovingClientId: hasBlockMovingClientId(), 38667 selectedBlockInBlockEditor: getSelectedBlockClientId() 38668 }; 38669 }, [clientId]); 38670 const isBlockMoveTarget = blockMovingClientId && selectedBlockInBlockEditor === clientId; 38671 const className = classnames_default()('block-editor-list-view-block-contents', { 38672 'is-dropping-before': isBlockMoveTarget 38673 }); // Only include all selected blocks if the currently clicked on block 38674 // is one of the selected blocks. This ensures that if a user attempts 38675 // to drag a block that isn't part of the selection, they're still able 38676 // to drag it and rearrange its position. 38677 38678 const draggableClientIds = selectedClientIds.includes(clientId) ? selectedClientIds : [clientId]; 38679 return (0,external_wp_element_namespaceObject.createElement)(block_draggable, { 38680 clientIds: draggableClientIds 38681 }, _ref2 => { 38682 let { 38683 draggable, 38684 onDragStart, 38685 onDragEnd 38686 } = _ref2; 38687 return (0,external_wp_element_namespaceObject.createElement)(block_select_button, _extends({ 38688 ref: ref, 38689 className: className, 38690 block: block, 38691 onClick: onClick, 38692 onToggleExpanded: onToggleExpanded, 38693 isSelected: isSelected, 38694 position: position, 38695 siblingBlockCount: siblingBlockCount, 38696 level: level, 38697 draggable: draggable, 38698 onDragStart: onDragStart, 38699 onDragEnd: onDragEnd, 38700 isExpanded: isExpanded 38701 }, props)); 38702 }); 38703 }); 38704 /* harmony default export */ var block_contents = (ListViewBlockContents); 38705 38706 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/list-view/context.js 38707 /** 38708 * WordPress dependencies 38709 */ 38710 38711 const ListViewContext = (0,external_wp_element_namespaceObject.createContext)({ 38712 __experimentalFeatures: false, 38713 __experimentalPersistentListViewFeatures: false 38714 }); 38715 const useListViewContext = () => (0,external_wp_element_namespaceObject.useContext)(ListViewContext); 38716 38717 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/list-view/utils.js 38718 /** 38719 * External dependencies 38720 */ 38721 38722 /** 38723 * WordPress dependencies 38724 */ 38725 38726 38727 const getBlockPositionDescription = (position, siblingCount, level) => (0,external_wp_i18n_namespaceObject.sprintf)( 38728 /* translators: 1: The numerical position of the block. 2: The total number of blocks. 3. The level of nesting for the block. */ 38729 (0,external_wp_i18n_namespaceObject.__)('Block %1$d of %2$d, Level %3$d'), position, siblingCount, level); 38730 /** 38731 * Returns true if the client ID occurs within the block selection or multi-selection, 38732 * or false otherwise. 38733 * 38734 * @param {string} clientId Block client ID. 38735 * @param {string|string[]} selectedBlockClientIds Selected block client ID, or an array of multi-selected blocks client IDs. 38736 * 38737 * @return {boolean} Whether the block is in multi-selection set. 38738 */ 38739 38740 const isClientIdSelected = (clientId, selectedBlockClientIds) => (0,external_lodash_namespaceObject.isArray)(selectedBlockClientIds) && selectedBlockClientIds.length ? selectedBlockClientIds.indexOf(clientId) !== -1 : selectedBlockClientIds === clientId; 38741 /** 38742 * From a start and end clientId of potentially different nesting levels, 38743 * return the nearest-depth ids that have a common level of depth in the 38744 * nesting hierarchy. For multiple block selection, this ensure that the 38745 * selection is always at the same nesting level, and not split across 38746 * separate levels. 38747 * 38748 * @param {string} startId The first id of a selection. 38749 * @param {string} endId The end id of a selection, usually one that has been clicked on. 38750 * @param {string[]} startParents An array of ancestor ids for the start id, in descending order. 38751 * @param {string[]} endParents An array of ancestor ids for the end id, in descending order. 38752 * @return {Object} An object containing the start and end ids. 38753 */ 38754 38755 function getCommonDepthClientIds(startId, endId, startParents, endParents) { 38756 const startPath = [...startParents, startId]; 38757 const endPath = [...endParents, endId]; 38758 const depth = Math.min(startPath.length, endPath.length) - 1; 38759 const start = startPath[depth]; 38760 const end = endPath[depth]; 38761 return { 38762 start, 38763 end 38764 }; 38765 } 38766 38767 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/list-view/block.js 38768 38769 38770 /** 38771 * External dependencies 38772 */ 38773 38774 /** 38775 * WordPress dependencies 38776 */ 38777 38778 38779 38780 38781 38782 38783 38784 /** 38785 * Internal dependencies 38786 */ 38787 38788 38789 38790 38791 38792 38793 38794 38795 38796 38797 38798 function ListViewBlock(_ref) { 38799 let { 38800 block, 38801 isDragged, 38802 isSelected, 38803 isBranchSelected, 38804 selectBlock, 38805 position, 38806 level, 38807 rowCount, 38808 siblingBlockCount, 38809 showBlockMovers, 38810 path, 38811 isExpanded, 38812 selectedClientIds, 38813 preventAnnouncement 38814 } = _ref; 38815 const cellRef = (0,external_wp_element_namespaceObject.useRef)(null); 38816 const [isHovered, setIsHovered] = (0,external_wp_element_namespaceObject.useState)(false); 38817 const { 38818 clientId 38819 } = block; 38820 const isFirstSelectedBlock = isSelected && selectedClientIds[0] === clientId; 38821 const isLastSelectedBlock = isSelected && selectedClientIds[selectedClientIds.length - 1] === clientId; 38822 const { 38823 toggleBlockHighlight 38824 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 38825 const blockInformation = useBlockDisplayInformation(clientId); 38826 const { 38827 isLocked 38828 } = useBlockLock(clientId); 38829 const instanceId = (0,external_wp_compose_namespaceObject.useInstanceId)(ListViewBlock); 38830 const descriptionId = `list-view-block-select-button__$instanceId}`; 38831 const blockPositionDescription = getBlockPositionDescription(position, siblingBlockCount, level); 38832 38833 let blockAriaLabel = (0,external_wp_i18n_namespaceObject.__)('Link'); 38834 38835 if (blockInformation) { 38836 blockAriaLabel = isLocked ? (0,external_wp_i18n_namespaceObject.sprintf)( // translators: %s: The title of the block. This string indicates a link to select the locked block. 38837 (0,external_wp_i18n_namespaceObject.__)('%s link (locked)'), blockInformation.title) : (0,external_wp_i18n_namespaceObject.sprintf)( // translators: %s: The title of the block. This string indicates a link to select the block. 38838 (0,external_wp_i18n_namespaceObject.__)('%s link'), blockInformation.title); 38839 } 38840 38841 const settingsAriaLabel = blockInformation ? (0,external_wp_i18n_namespaceObject.sprintf)( // translators: %s: The title of the block. 38842 (0,external_wp_i18n_namespaceObject.__)('Options for %s block'), blockInformation.title) : (0,external_wp_i18n_namespaceObject.__)('Options'); 38843 const { 38844 __experimentalFeatures: withExperimentalFeatures, 38845 __experimentalPersistentListViewFeatures: withExperimentalPersistentListViewFeatures, 38846 __experimentalHideContainerBlockActions: hideContainerBlockActions, 38847 isTreeGridMounted, 38848 expand, 38849 collapse 38850 } = useListViewContext(); 38851 const hasSiblings = siblingBlockCount > 0; 38852 const hasRenderedMovers = showBlockMovers && hasSiblings; 38853 const moverCellClassName = classnames_default()('block-editor-list-view-block__mover-cell', { 38854 'is-visible': isHovered || isSelected 38855 }); 38856 const listViewBlockSettingsClassName = classnames_default()('block-editor-list-view-block__menu-cell', { 38857 'is-visible': isHovered || isFirstSelectedBlock 38858 }); // If ListView has experimental features related to the Persistent List View, 38859 // only focus the selected list item on mount; otherwise the list would always 38860 // try to steal the focus from the editor canvas. 38861 38862 (0,external_wp_element_namespaceObject.useEffect)(() => { 38863 if (withExperimentalPersistentListViewFeatures && !isTreeGridMounted && isSelected) { 38864 cellRef.current.focus(); 38865 } 38866 }, []); 38867 const highlightBlock = withExperimentalPersistentListViewFeatures ? toggleBlockHighlight : () => {}; 38868 const onMouseEnter = (0,external_wp_element_namespaceObject.useCallback)(() => { 38869 setIsHovered(true); 38870 highlightBlock(clientId, true); 38871 }, [clientId, setIsHovered, highlightBlock]); 38872 const onMouseLeave = (0,external_wp_element_namespaceObject.useCallback)(() => { 38873 setIsHovered(false); 38874 highlightBlock(clientId, false); 38875 }, [clientId, setIsHovered, highlightBlock]); 38876 const selectEditorBlock = (0,external_wp_element_namespaceObject.useCallback)(event => { 38877 selectBlock(event, clientId); 38878 event.preventDefault(); 38879 }, [clientId, selectBlock]); 38880 const updateSelection = (0,external_wp_element_namespaceObject.useCallback)(newClientId => { 38881 selectBlock(undefined, newClientId); 38882 }, [selectBlock]); 38883 const toggleExpanded = (0,external_wp_element_namespaceObject.useCallback)(event => { 38884 // Prevent shift+click from opening link in a new window when toggling. 38885 event.preventDefault(); 38886 event.stopPropagation(); 38887 38888 if (isExpanded === true) { 38889 collapse(clientId); 38890 } else if (isExpanded === false) { 38891 expand(clientId); 38892 } 38893 }, [clientId, expand, collapse, isExpanded]); 38894 const showBlockActions = withExperimentalFeatures && ( // hide actions for blocks like core/widget-areas 38895 !hideContainerBlockActions || hideContainerBlockActions && level > 1); 38896 const hideBlockActions = withExperimentalFeatures && !showBlockActions; 38897 let colSpan; 38898 38899 if (hasRenderedMovers) { 38900 colSpan = 2; 38901 } else if (hideBlockActions) { 38902 colSpan = 3; 38903 } 38904 38905 const classes = classnames_default()({ 38906 'is-selected': isSelected, 38907 'is-first-selected': isFirstSelectedBlock, 38908 'is-last-selected': isLastSelectedBlock, 38909 'is-branch-selected': withExperimentalPersistentListViewFeatures && isBranchSelected, 38910 'is-dragging': isDragged, 38911 'has-single-cell': hideBlockActions 38912 }); // Only include all selected blocks if the currently clicked on block 38913 // is one of the selected blocks. This ensures that if a user attempts 38914 // to alter a block that isn't part of the selection, they're still able 38915 // to do so. 38916 38917 const dropdownClientIds = selectedClientIds.includes(clientId) ? selectedClientIds : [clientId]; 38918 return (0,external_wp_element_namespaceObject.createElement)(ListViewLeaf, { 38919 className: classes, 38920 onMouseEnter: onMouseEnter, 38921 onMouseLeave: onMouseLeave, 38922 onFocus: onMouseEnter, 38923 onBlur: onMouseLeave, 38924 level: level, 38925 position: position, 38926 rowCount: rowCount, 38927 path: path, 38928 id: `list-view-block-$clientId}`, 38929 "data-block": clientId, 38930 isExpanded: isExpanded, 38931 "aria-selected": !!isSelected 38932 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalTreeGridCell, { 38933 className: "block-editor-list-view-block__contents-cell", 38934 colSpan: colSpan, 38935 ref: cellRef, 38936 "aria-label": blockAriaLabel, 38937 "aria-selected": !!isSelected, 38938 "aria-expanded": isExpanded, 38939 "aria-describedby": descriptionId 38940 }, _ref2 => { 38941 let { 38942 ref, 38943 tabIndex, 38944 onFocus 38945 } = _ref2; 38946 return (0,external_wp_element_namespaceObject.createElement)("div", { 38947 className: "block-editor-list-view-block__contents-container" 38948 }, (0,external_wp_element_namespaceObject.createElement)(block_contents, { 38949 block: block, 38950 onClick: selectEditorBlock, 38951 onToggleExpanded: toggleExpanded, 38952 isSelected: isSelected, 38953 position: position, 38954 siblingBlockCount: siblingBlockCount, 38955 level: level, 38956 ref: ref, 38957 tabIndex: tabIndex, 38958 onFocus: onFocus, 38959 isExpanded: isExpanded, 38960 selectedClientIds: selectedClientIds, 38961 preventAnnouncement: preventAnnouncement 38962 }), (0,external_wp_element_namespaceObject.createElement)("div", { 38963 className: "block-editor-list-view-block-select-button__description", 38964 id: descriptionId 38965 }, blockPositionDescription)); 38966 }), hasRenderedMovers && (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalTreeGridCell, { 38967 className: moverCellClassName, 38968 withoutGridItem: true 38969 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalTreeGridItem, null, _ref3 => { 38970 let { 38971 ref, 38972 tabIndex, 38973 onFocus 38974 } = _ref3; 38975 return (0,external_wp_element_namespaceObject.createElement)(BlockMoverUpButton, { 38976 orientation: "vertical", 38977 clientIds: [clientId], 38978 ref: ref, 38979 tabIndex: tabIndex, 38980 onFocus: onFocus 38981 }); 38982 }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalTreeGridItem, null, _ref4 => { 38983 let { 38984 ref, 38985 tabIndex, 38986 onFocus 38987 } = _ref4; 38988 return (0,external_wp_element_namespaceObject.createElement)(BlockMoverDownButton, { 38989 orientation: "vertical", 38990 clientIds: [clientId], 38991 ref: ref, 38992 tabIndex: tabIndex, 38993 onFocus: onFocus 38994 }); 38995 }))), showBlockActions && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalTreeGridCell, { 38996 className: listViewBlockSettingsClassName, 38997 "aria-selected": !!isSelected 38998 }, _ref5 => { 38999 let { 39000 ref, 39001 tabIndex, 39002 onFocus 39003 } = _ref5; 39004 return (0,external_wp_element_namespaceObject.createElement)(block_settings_dropdown, { 39005 clientIds: dropdownClientIds, 39006 icon: more_vertical, 39007 label: settingsAriaLabel, 39008 toggleProps: { 39009 ref, 39010 className: 'block-editor-list-view-block__menu', 39011 tabIndex, 39012 onFocus 39013 }, 39014 disableOpenOnArrowDown: true, 39015 __experimentalSelectBlock: updateSelection 39016 }); 39017 })); 39018 } 39019 39020 /* harmony default export */ var list_view_block = ((0,external_wp_element_namespaceObject.memo)(ListViewBlock)); 39021 39022 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/list-view/branch.js 39023 39024 39025 /** 39026 * External dependencies 39027 */ 39028 39029 /** 39030 * WordPress dependencies 39031 */ 39032 39033 39034 39035 /** 39036 * Internal dependencies 39037 */ 39038 39039 39040 39041 39042 /** 39043 * Given a block, returns the total number of blocks in that subtree. This is used to help determine 39044 * the list position of a block. 39045 * 39046 * When a block is collapsed, we do not count their children as part of that total. In the current drag 39047 * implementation dragged blocks and their children are not counted. 39048 * 39049 * @param {Object} block block tree 39050 * @param {Object} expandedState state that notes which branches are collapsed 39051 * @param {Array} draggedClientIds a list of dragged client ids 39052 * @param {boolean} isExpandedByDefault flag to determine the default fallback expanded state. 39053 * @return {number} block count 39054 */ 39055 39056 function countBlocks(block, expandedState, draggedClientIds, isExpandedByDefault) { 39057 var _expandedState$block$; 39058 39059 const isDragged = draggedClientIds === null || draggedClientIds === void 0 ? void 0 : draggedClientIds.includes(block.clientId); 39060 39061 if (isDragged) { 39062 return 0; 39063 } 39064 39065 const isExpanded = (_expandedState$block$ = expandedState[block.clientId]) !== null && _expandedState$block$ !== void 0 ? _expandedState$block$ : isExpandedByDefault; 39066 39067 if (isExpanded) { 39068 return 1 + block.innerBlocks.reduce(countReducer(expandedState, draggedClientIds, isExpandedByDefault), 0); 39069 } 39070 39071 return 1; 39072 } 39073 39074 const countReducer = (expandedState, draggedClientIds, isExpandedByDefault) => (count, block) => { 39075 var _expandedState$block$2; 39076 39077 const isDragged = draggedClientIds === null || draggedClientIds === void 0 ? void 0 : draggedClientIds.includes(block.clientId); 39078 39079 if (isDragged) { 39080 return count; 39081 } 39082 39083 const isExpanded = (_expandedState$block$2 = expandedState[block.clientId]) !== null && _expandedState$block$2 !== void 0 ? _expandedState$block$2 : isExpandedByDefault; 39084 39085 if (isExpanded && block.innerBlocks.length > 0) { 39086 return count + countBlocks(block, expandedState, draggedClientIds, isExpandedByDefault); 39087 } 39088 39089 return count + 1; 39090 }; 39091 39092 function ListViewBranch(props) { 39093 const { 39094 blocks, 39095 selectBlock, 39096 showBlockMovers, 39097 showNestedBlocks, 39098 selectedClientIds, 39099 level = 1, 39100 path = '', 39101 isBranchSelected = false, 39102 listPosition = 0, 39103 fixedListWindow, 39104 expandNested 39105 } = props; 39106 const { 39107 expandedState, 39108 draggedClientIds, 39109 __experimentalPersistentListViewFeatures 39110 } = useListViewContext(); 39111 const filteredBlocks = (0,external_lodash_namespaceObject.compact)(blocks); 39112 const blockCount = filteredBlocks.length; 39113 let nextPosition = listPosition; 39114 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, filteredBlocks.map((block, index) => { 39115 var _expandedState$client; 39116 39117 const { 39118 clientId, 39119 innerBlocks 39120 } = block; 39121 39122 if (index > 0) { 39123 nextPosition += countBlocks(filteredBlocks[index - 1], expandedState, draggedClientIds, expandNested); 39124 } 39125 39126 const usesWindowing = __experimentalPersistentListViewFeatures; 39127 const { 39128 itemInView 39129 } = fixedListWindow; 39130 const blockInView = !usesWindowing || itemInView(nextPosition); 39131 const position = index + 1; 39132 const updatedPath = path.length > 0 ? `$path}_$position}` : `$position}`; 39133 const hasNestedBlocks = showNestedBlocks && !!innerBlocks && !!innerBlocks.length; 39134 const isExpanded = hasNestedBlocks ? (_expandedState$client = expandedState[clientId]) !== null && _expandedState$client !== void 0 ? _expandedState$client : expandNested : undefined; 39135 const isDragged = !!(draggedClientIds !== null && draggedClientIds !== void 0 && draggedClientIds.includes(clientId)); 39136 const showBlock = isDragged || blockInView; // Make updates to the selected or dragged blocks synchronous, 39137 // but asynchronous for any other block. 39138 39139 const isSelected = isClientIdSelected(clientId, selectedClientIds); 39140 const isSelectedBranch = isBranchSelected || isSelected && hasNestedBlocks; 39141 return (0,external_wp_element_namespaceObject.createElement)(external_wp_data_namespaceObject.AsyncModeProvider, { 39142 key: clientId, 39143 value: !isSelected 39144 }, showBlock && (0,external_wp_element_namespaceObject.createElement)(list_view_block, { 39145 block: block, 39146 selectBlock: selectBlock, 39147 isSelected: isSelected, 39148 isBranchSelected: isSelectedBranch, 39149 isDragged: isDragged, 39150 level: level, 39151 position: position, 39152 rowCount: blockCount, 39153 siblingBlockCount: blockCount, 39154 showBlockMovers: showBlockMovers, 39155 path: updatedPath, 39156 isExpanded: isExpanded, 39157 listPosition: nextPosition, 39158 selectedClientIds: selectedClientIds 39159 }), !showBlock && (0,external_wp_element_namespaceObject.createElement)("tr", null, (0,external_wp_element_namespaceObject.createElement)("td", { 39160 className: "block-editor-list-view-placeholder" 39161 })), hasNestedBlocks && isExpanded && !isDragged && (0,external_wp_element_namespaceObject.createElement)(ListViewBranch, { 39162 blocks: innerBlocks, 39163 selectBlock: selectBlock, 39164 showBlockMovers: showBlockMovers, 39165 showNestedBlocks: showNestedBlocks, 39166 level: level + 1, 39167 path: updatedPath, 39168 listPosition: nextPosition + 1, 39169 fixedListWindow: fixedListWindow, 39170 isBranchSelected: isSelectedBranch, 39171 selectedClientIds: selectedClientIds, 39172 expandNested: expandNested 39173 })); 39174 })); 39175 } 39176 39177 ListViewBranch.defaultProps = { 39178 selectBlock: () => {} 39179 }; 39180 /* harmony default export */ var branch = ((0,external_wp_element_namespaceObject.memo)(ListViewBranch)); 39181 39182 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/list-view/drop-indicator.js 39183 39184 39185 /** 39186 * WordPress dependencies 39187 */ 39188 39189 39190 function ListViewDropIndicator(_ref) { 39191 let { 39192 listViewRef, 39193 blockDropTarget 39194 } = _ref; 39195 const { 39196 rootClientId, 39197 clientId, 39198 dropPosition 39199 } = blockDropTarget || {}; 39200 const [rootBlockElement, blockElement] = (0,external_wp_element_namespaceObject.useMemo)(() => { 39201 if (!listViewRef.current) { 39202 return []; 39203 } // The rootClientId will be defined whenever dropping into inner 39204 // block lists, but is undefined when dropping at the root level. 39205 39206 39207 const _rootBlockElement = rootClientId ? listViewRef.current.querySelector(`[data-block="$rootClientId}"]`) : undefined; // The clientId represents the sibling block, the dragged block will 39208 // usually be inserted adjacent to it. It will be undefined when 39209 // dropping a block into an empty block list. 39210 39211 39212 const _blockElement = clientId ? listViewRef.current.querySelector(`[data-block="$clientId}"]`) : undefined; 39213 39214 return [_rootBlockElement, _blockElement]; 39215 }, [rootClientId, clientId]); // The targetElement is the element that the drop indicator will appear 39216 // before or after. When dropping into an empty block list, blockElement 39217 // is undefined, so the indicator will appear after the rootBlockElement. 39218 39219 const targetElement = blockElement || rootBlockElement; 39220 const getDropIndicatorIndent = (0,external_wp_element_namespaceObject.useCallback)(() => { 39221 if (!rootBlockElement) { 39222 return 0; 39223 } // Calculate the indent using the block icon of the root block. 39224 // Using a classname selector here might be flaky and could be 39225 // improved. 39226 39227 39228 const targetElementRect = targetElement.getBoundingClientRect(); 39229 const rootBlockIconElement = rootBlockElement.querySelector('.block-editor-block-icon'); 39230 const rootBlockIconRect = rootBlockIconElement.getBoundingClientRect(); 39231 return rootBlockIconRect.right - targetElementRect.left; 39232 }, [rootBlockElement, targetElement]); 39233 const style = (0,external_wp_element_namespaceObject.useMemo)(() => { 39234 if (!targetElement) { 39235 return {}; 39236 } 39237 39238 const indent = getDropIndicatorIndent(); 39239 return { 39240 width: targetElement.offsetWidth - indent 39241 }; 39242 }, [getDropIndicatorIndent, targetElement]); 39243 const getAnchorRect = (0,external_wp_element_namespaceObject.useCallback)(() => { 39244 if (!targetElement) { 39245 return {}; 39246 } 39247 39248 const ownerDocument = targetElement.ownerDocument; 39249 const rect = targetElement.getBoundingClientRect(); 39250 const indent = getDropIndicatorIndent(); 39251 const anchorRect = { 39252 left: rect.left + indent, 39253 right: rect.right, 39254 width: 0, 39255 height: rect.height, 39256 ownerDocument 39257 }; 39258 39259 if (dropPosition === 'top') { 39260 return { ...anchorRect, 39261 top: rect.top, 39262 bottom: rect.top 39263 }; 39264 } 39265 39266 if (dropPosition === 'bottom' || dropPosition === 'inside') { 39267 return { ...anchorRect, 39268 top: rect.bottom, 39269 bottom: rect.bottom 39270 }; 39271 } 39272 39273 return {}; 39274 }, [targetElement, dropPosition, getDropIndicatorIndent]); 39275 39276 if (!targetElement) { 39277 return null; 39278 } 39279 39280 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Popover, { 39281 noArrow: true, 39282 animate: false, 39283 getAnchorRect: getAnchorRect, 39284 focusOnMount: false, 39285 className: "block-editor-list-view-drop-indicator" 39286 }, (0,external_wp_element_namespaceObject.createElement)("div", { 39287 style: style, 39288 className: "block-editor-list-view-drop-indicator__line" 39289 })); 39290 } 39291 39292 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/list-view/use-block-selection.js 39293 /** 39294 * External dependencies 39295 */ 39296 39297 /** 39298 * WordPress dependencies 39299 */ 39300 39301 39302 39303 39304 39305 39306 39307 /** 39308 * Internal dependencies 39309 */ 39310 39311 39312 39313 function useBlockSelection() { 39314 const { 39315 clearSelectedBlock, 39316 multiSelect, 39317 selectBlock 39318 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 39319 const { 39320 getBlockName, 39321 getBlockParents, 39322 getBlockSelectionStart, 39323 getBlockSelectionEnd, 39324 getSelectedBlockClientIds, 39325 hasMultiSelection, 39326 hasSelectedBlock 39327 } = (0,external_wp_data_namespaceObject.useSelect)(store); 39328 const { 39329 getBlockType 39330 } = (0,external_wp_data_namespaceObject.useSelect)(external_wp_blocks_namespaceObject.store); 39331 const updateBlockSelection = (0,external_wp_element_namespaceObject.useCallback)(async (event, clientId, destinationClientId) => { 39332 if (!(event !== null && event !== void 0 && event.shiftKey)) { 39333 await clearSelectedBlock(); 39334 selectBlock(clientId); 39335 return; 39336 } // To handle multiple block selection via the `SHIFT` key, prevent 39337 // the browser default behavior of opening the link in a new window. 39338 39339 39340 event.preventDefault(); 39341 const isKeyPress = event.type === 'keydown' && (event.keyCode === external_wp_keycodes_namespaceObject.UP || event.keyCode === external_wp_keycodes_namespaceObject.DOWN || event.keyCode === external_wp_keycodes_namespaceObject.HOME || event.keyCode === external_wp_keycodes_namespaceObject.END); // Handle clicking on a block when no blocks are selected, and return early. 39342 39343 if (!isKeyPress && !hasSelectedBlock() && !hasMultiSelection()) { 39344 selectBlock(clientId, null); 39345 return; 39346 } 39347 39348 const selectedBlocks = getSelectedBlockClientIds(); 39349 const clientIdWithParents = [...getBlockParents(clientId), clientId]; 39350 39351 if (isKeyPress && !selectedBlocks.some(blockId => clientIdWithParents.includes(blockId))) { 39352 // Ensure that shift-selecting blocks via the keyboard only 39353 // expands the current selection if focusing over already 39354 // selected blocks. Otherwise, clear the selection so that 39355 // a user can create a new selection entirely by keyboard. 39356 await clearSelectedBlock(); 39357 } 39358 39359 let startTarget = getBlockSelectionStart(); 39360 let endTarget = clientId; // Handle keyboard behavior for selecting multiple blocks. 39361 39362 if (isKeyPress) { 39363 if (!hasSelectedBlock() && !hasMultiSelection()) { 39364 // Set the starting point of the selection to the currently 39365 // focused block, if there are no blocks currently selected. 39366 // This ensures that as the selection is expanded or contracted, 39367 // the starting point of the selection is anchored to that block. 39368 startTarget = clientId; 39369 } 39370 39371 if (destinationClientId) { 39372 // If the user presses UP or DOWN, we want to ensure that the block they're 39373 // moving to is the target for selection, and not the currently focused one. 39374 endTarget = destinationClientId; 39375 } 39376 } 39377 39378 const startParents = getBlockParents(startTarget); 39379 const endParents = getBlockParents(endTarget); 39380 const { 39381 start, 39382 end 39383 } = getCommonDepthClientIds(startTarget, endTarget, startParents, endParents); 39384 await multiSelect(start, end, null); // Announce deselected block, or number of deselected blocks if 39385 // the total number of blocks deselected is greater than one. 39386 39387 const updatedSelectedBlocks = getSelectedBlockClientIds(); // If the selection is greater than 1 and the Home or End keys 39388 // were used to generate the selection, then skip announcing the 39389 // deselected blocks. 39390 39391 if ((event.keyCode === external_wp_keycodes_namespaceObject.HOME || event.keyCode === external_wp_keycodes_namespaceObject.END) && updatedSelectedBlocks.length > 1) { 39392 return; 39393 } 39394 39395 const selectionDiff = (0,external_lodash_namespaceObject.difference)(selectedBlocks, updatedSelectedBlocks); 39396 let label; 39397 39398 if (selectionDiff.length === 1) { 39399 var _getBlockType; 39400 39401 const title = (_getBlockType = getBlockType(getBlockName(selectionDiff[0]))) === null || _getBlockType === void 0 ? void 0 : _getBlockType.title; 39402 39403 if (title) { 39404 label = (0,external_wp_i18n_namespaceObject.sprintf)( 39405 /* translators: %s: block name */ 39406 (0,external_wp_i18n_namespaceObject.__)('%s deselected.'), title); 39407 } 39408 } else if (selectionDiff.length > 1) { 39409 label = (0,external_wp_i18n_namespaceObject.sprintf)( 39410 /* translators: %s: number of deselected blocks */ 39411 (0,external_wp_i18n_namespaceObject.__)('%s blocks deselected.'), selectionDiff.length); 39412 } 39413 39414 if (label) { 39415 (0,external_wp_a11y_namespaceObject.speak)(label); 39416 } 39417 }, [clearSelectedBlock, getBlockName, getBlockType, getBlockParents, getBlockSelectionStart, getBlockSelectionEnd, getSelectedBlockClientIds, hasMultiSelection, hasSelectedBlock, multiSelect, selectBlock]); 39418 return { 39419 updateBlockSelection 39420 }; 39421 } 39422 39423 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/list-view/use-list-view-client-ids.js 39424 /** 39425 * WordPress dependencies 39426 */ 39427 39428 /** 39429 * Internal dependencies 39430 */ 39431 39432 39433 function useListViewClientIds(blocks) { 39434 return (0,external_wp_data_namespaceObject.useSelect)(select => { 39435 const { 39436 getDraggedBlockClientIds, 39437 getSelectedBlockClientIds, 39438 __unstableGetClientIdsTree 39439 } = select(store); 39440 return { 39441 selectedClientIds: getSelectedBlockClientIds(), 39442 draggedClientIds: getDraggedBlockClientIds(), 39443 clientIdsTree: blocks ? blocks : __unstableGetClientIdsTree() 39444 }; 39445 }, [blocks]); 39446 } 39447 39448 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/list-view/use-list-view-drop-zone.js 39449 /** 39450 * WordPress dependencies 39451 */ 39452 39453 39454 39455 /** 39456 * Internal dependencies 39457 */ 39458 39459 39460 39461 39462 /** @typedef {import('../../utils/math').WPPoint} WPPoint */ 39463 39464 /** 39465 * The type of a drag event. 39466 * 39467 * @typedef {'default'|'file'|'html'} WPDragEventType 39468 */ 39469 39470 /** 39471 * An array representing data for blocks in the DOM used by drag and drop. 39472 * 39473 * @typedef {Object} WPListViewDropZoneBlocks 39474 * @property {string} clientId The client id for the block. 39475 * @property {string} rootClientId The root client id for the block. 39476 * @property {number} blockIndex The block's index. 39477 * @property {Element} element The DOM element representing the block. 39478 * @property {number} innerBlockCount The number of inner blocks the block has. 39479 * @property {boolean} isDraggedBlock Whether the block is currently being dragged. 39480 * @property {boolean} canInsertDraggedBlocksAsSibling Whether the dragged block can be a sibling of this block. 39481 * @property {boolean} canInsertDraggedBlocksAsChild Whether the dragged block can be a child of this block. 39482 */ 39483 39484 /** 39485 * An object containing details of a drop target. 39486 * 39487 * @typedef {Object} WPListViewDropZoneTarget 39488 * @property {string} blockIndex The insertion index. 39489 * @property {string} rootClientId The root client id for the block. 39490 * @property {string|undefined} clientId The client id for the block. 39491 * @property {'top'|'bottom'|'inside'} dropPosition The position relative to the block that the user is dropping to. 39492 * 'inside' refers to nesting as an inner block. 39493 */ 39494 39495 /** 39496 * Is the point contained by the rectangle. 39497 * 39498 * @param {WPPoint} point The point. 39499 * @param {DOMRect} rect The rectangle. 39500 * 39501 * @return {boolean} True if the point is contained by the rectangle, false otherwise. 39502 */ 39503 39504 function isPointContainedByRect(point, rect) { 39505 return rect.left <= point.x && rect.right >= point.x && rect.top <= point.y && rect.bottom >= point.y; 39506 } 39507 /** 39508 * Determines whether the user positioning the dragged block to nest as an 39509 * inner block. 39510 * 39511 * Presently this is determined by whether the cursor is on the right hand side 39512 * of the block. 39513 * 39514 * @param {WPPoint} point The point representing the cursor position when dragging. 39515 * @param {DOMRect} rect The rectangle. 39516 */ 39517 39518 39519 function isNestingGesture(point, rect) { 39520 const blockCenterX = rect.left + rect.width / 2; 39521 return point.x > blockCenterX; 39522 } // Block navigation is always a vertical list, so only allow dropping 39523 // to the above or below a block. 39524 39525 39526 const ALLOWED_DROP_EDGES = ['top', 'bottom']; 39527 /** 39528 * Given blocks data and the cursor position, compute the drop target. 39529 * 39530 * @param {WPListViewDropZoneBlocks} blocksData Data about the blocks in list view. 39531 * @param {WPPoint} position The point representing the cursor position when dragging. 39532 * 39533 * @return {WPListViewDropZoneTarget} An object containing data about the drop target. 39534 */ 39535 39536 function getListViewDropTarget(blocksData, position) { 39537 let candidateEdge; 39538 let candidateBlockData; 39539 let candidateDistance; 39540 let candidateRect; 39541 39542 for (const blockData of blocksData) { 39543 if (blockData.isDraggedBlock) { 39544 continue; 39545 } 39546 39547 const rect = blockData.element.getBoundingClientRect(); 39548 const [distance, edge] = getDistanceToNearestEdge(position, rect, ALLOWED_DROP_EDGES); 39549 const isCursorWithinBlock = isPointContainedByRect(position, rect); 39550 39551 if (candidateDistance === undefined || distance < candidateDistance || isCursorWithinBlock) { 39552 candidateDistance = distance; 39553 const index = blocksData.indexOf(blockData); 39554 const previousBlockData = blocksData[index - 1]; // If dragging near the top of a block and the preceding block 39555 // is at the same level, use the preceding block as the candidate 39556 // instead, as later it makes determining a nesting drop easier. 39557 39558 if (edge === 'top' && previousBlockData && previousBlockData.rootClientId === blockData.rootClientId && !previousBlockData.isDraggedBlock) { 39559 candidateBlockData = previousBlockData; 39560 candidateEdge = 'bottom'; 39561 candidateRect = previousBlockData.element.getBoundingClientRect(); 39562 } else { 39563 candidateBlockData = blockData; 39564 candidateEdge = edge; 39565 candidateRect = rect; 39566 } // If the mouse position is within the block, break early 39567 // as the user would intend to drop either before or after 39568 // this block. 39569 // 39570 // This solves an issue where some rows in the list view 39571 // tree overlap slightly due to sub-pixel rendering. 39572 39573 39574 if (isCursorWithinBlock) { 39575 break; 39576 } 39577 } 39578 } 39579 39580 if (!candidateBlockData) { 39581 return; 39582 } 39583 39584 const isDraggingBelow = candidateEdge === 'bottom'; // If the user is dragging towards the bottom of the block check whether 39585 // they might be trying to nest the block as a child. 39586 // If the block already has inner blocks, this should always be treated 39587 // as nesting since the next block in the tree will be the first child. 39588 39589 if (isDraggingBelow && candidateBlockData.canInsertDraggedBlocksAsChild && (candidateBlockData.innerBlockCount > 0 || isNestingGesture(position, candidateRect))) { 39590 return { 39591 rootClientId: candidateBlockData.clientId, 39592 blockIndex: 0, 39593 dropPosition: 'inside' 39594 }; 39595 } // If dropping as a sibling, but block cannot be inserted in 39596 // this context, return early. 39597 39598 39599 if (!candidateBlockData.canInsertDraggedBlocksAsSibling) { 39600 return; 39601 } 39602 39603 const offset = isDraggingBelow ? 1 : 0; 39604 return { 39605 rootClientId: candidateBlockData.rootClientId, 39606 clientId: candidateBlockData.clientId, 39607 blockIndex: candidateBlockData.blockIndex + offset, 39608 dropPosition: candidateEdge 39609 }; 39610 } 39611 /** 39612 * A react hook for implementing a drop zone in list view. 39613 * 39614 * @return {WPListViewDropZoneTarget} The drop target. 39615 */ 39616 39617 39618 function useListViewDropZone() { 39619 const { 39620 getBlockRootClientId, 39621 getBlockIndex, 39622 getBlockCount, 39623 getDraggedBlockClientIds, 39624 canInsertBlocks 39625 } = (0,external_wp_data_namespaceObject.useSelect)(store); 39626 const [target, setTarget] = (0,external_wp_element_namespaceObject.useState)(); 39627 const { 39628 rootClientId: targetRootClientId, 39629 blockIndex: targetBlockIndex 39630 } = target || {}; 39631 const onBlockDrop = useOnBlockDrop(targetRootClientId, targetBlockIndex); 39632 const draggedBlockClientIds = getDraggedBlockClientIds(); 39633 const throttled = (0,external_wp_compose_namespaceObject.useThrottle)((0,external_wp_element_namespaceObject.useCallback)((event, currentTarget) => { 39634 const position = { 39635 x: event.clientX, 39636 y: event.clientY 39637 }; 39638 const isBlockDrag = !!(draggedBlockClientIds !== null && draggedBlockClientIds !== void 0 && draggedBlockClientIds.length); 39639 const blockElements = Array.from(currentTarget.querySelectorAll('[data-block]')); 39640 const blocksData = blockElements.map(blockElement => { 39641 const clientId = blockElement.dataset.block; 39642 const rootClientId = getBlockRootClientId(clientId); 39643 return { 39644 clientId, 39645 rootClientId, 39646 blockIndex: getBlockIndex(clientId), 39647 element: blockElement, 39648 isDraggedBlock: isBlockDrag ? draggedBlockClientIds.includes(clientId) : false, 39649 innerBlockCount: getBlockCount(clientId), 39650 canInsertDraggedBlocksAsSibling: isBlockDrag ? canInsertBlocks(draggedBlockClientIds, rootClientId) : true, 39651 canInsertDraggedBlocksAsChild: isBlockDrag ? canInsertBlocks(draggedBlockClientIds, clientId) : true 39652 }; 39653 }); 39654 const newTarget = getListViewDropTarget(blocksData, position); 39655 39656 if (newTarget) { 39657 setTarget(newTarget); 39658 } 39659 }, [draggedBlockClientIds]), 200); 39660 const ref = (0,external_wp_compose_namespaceObject.__experimentalUseDropZone)({ 39661 onDrop: onBlockDrop, 39662 39663 onDragOver(event) { 39664 // `currentTarget` is only available while the event is being 39665 // handled, so get it now and pass it to the thottled function. 39666 // https://developer.mozilla.org/en-US/docs/Web/API/Event/currentTarget 39667 throttled(event, event.currentTarget); 39668 }, 39669 39670 onDragEnd() { 39671 throttled.cancel(); 39672 setTarget(null); 39673 } 39674 39675 }); 39676 return { 39677 ref, 39678 target 39679 }; 39680 } 39681 39682 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/list-view/use-list-view-expand-selected-item.js 39683 /** 39684 * WordPress dependencies 39685 */ 39686 39687 39688 /** 39689 * Internal dependencies 39690 */ 39691 39692 39693 function useListViewExpandSelectedItem(_ref) { 39694 let { 39695 firstSelectedBlockClientId, 39696 setExpandedState 39697 } = _ref; 39698 const [selectedTreeId, setSelectedTreeId] = (0,external_wp_element_namespaceObject.useState)(null); 39699 const { 39700 selectedBlockParentClientIds 39701 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 39702 const { 39703 getBlockParents 39704 } = select(store); 39705 return { 39706 selectedBlockParentClientIds: getBlockParents(firstSelectedBlockClientId, false) 39707 }; 39708 }, [firstSelectedBlockClientId]); 39709 const parentClientIds = Array.isArray(selectedBlockParentClientIds) && selectedBlockParentClientIds.length ? selectedBlockParentClientIds : null; // Expand tree when a block is selected. 39710 39711 (0,external_wp_element_namespaceObject.useEffect)(() => { 39712 // If the selectedTreeId is the same as the selected block, 39713 // it means that the block was selected using the block list tree. 39714 if (selectedTreeId === firstSelectedBlockClientId) { 39715 return; 39716 } // If the selected block has parents, get the top-level parent. 39717 39718 39719 if (parentClientIds) { 39720 // If the selected block has parents, 39721 // expand the tree branch. 39722 setExpandedState({ 39723 type: 'expand', 39724 clientIds: selectedBlockParentClientIds 39725 }); 39726 } 39727 }, [firstSelectedBlockClientId]); 39728 return { 39729 setSelectedTreeId 39730 }; 39731 } 39732 39733 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/list-view/index.js 39734 39735 39736 39737 /** 39738 * WordPress dependencies 39739 */ 39740 39741 39742 39743 39744 39745 /** 39746 * Internal dependencies 39747 */ 39748 39749 39750 39751 39752 39753 39754 39755 39756 39757 39758 const expanded = (state, action) => { 39759 if (Array.isArray(action.clientIds)) { 39760 return { ...state, 39761 ...action.clientIds.reduce((newState, id) => ({ ...newState, 39762 [id]: action.type === 'expand' 39763 }), {}) 39764 }; 39765 } 39766 39767 return state; 39768 }; 39769 39770 const BLOCK_LIST_ITEM_HEIGHT = 36; 39771 /** 39772 * Wrap `ListViewRows` with `TreeGrid`. ListViewRows is a 39773 * recursive component (it renders itself), so this ensures TreeGrid is only 39774 * present at the very top of the navigation grid. 39775 * 39776 * @param {Object} props Components props. 39777 * @param {Array} props.blocks Custom subset of block client IDs to be used instead of the default hierarchy. 39778 * @param {boolean} props.showNestedBlocks Flag to enable displaying nested blocks. 39779 * @param {boolean} props.showBlockMovers Flag to enable block movers 39780 * @param {boolean} props.__experimentalFeatures Flag to enable experimental features. 39781 * @param {boolean} props.__experimentalPersistentListViewFeatures Flag to enable features for the Persistent List View experiment. 39782 * @param {boolean} props.__experimentalHideContainerBlockActions Flag to hide actions of top level blocks (like core/widget-area) 39783 * @param {string} props.id Unique identifier for the root list element (primarily for a11y purposes). 39784 * @param {boolean} props.expandNested Flag to determine whether nested levels are expanded by default. 39785 * @param {Object} ref Forwarded ref 39786 */ 39787 39788 function ListView(_ref, ref) { 39789 let { 39790 blocks, 39791 __experimentalFeatures, 39792 __experimentalPersistentListViewFeatures, 39793 __experimentalHideContainerBlockActions, 39794 showNestedBlocks, 39795 showBlockMovers, 39796 id, 39797 expandNested = false, 39798 ...props 39799 } = _ref; 39800 const { 39801 clientIdsTree, 39802 draggedClientIds, 39803 selectedClientIds 39804 } = useListViewClientIds(blocks); 39805 const { 39806 visibleBlockCount 39807 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 39808 const { 39809 getGlobalBlockCount, 39810 getClientIdsOfDescendants 39811 } = select(store); 39812 const draggedBlockCount = (draggedClientIds === null || draggedClientIds === void 0 ? void 0 : draggedClientIds.length) > 0 ? getClientIdsOfDescendants(draggedClientIds).length + 1 : 0; 39813 return { 39814 visibleBlockCount: getGlobalBlockCount() - draggedBlockCount 39815 }; 39816 }, [draggedClientIds]); 39817 const { 39818 updateBlockSelection 39819 } = useBlockSelection(); 39820 const [expandedState, setExpandedState] = (0,external_wp_element_namespaceObject.useReducer)(expanded, {}); 39821 const { 39822 ref: dropZoneRef, 39823 target: blockDropTarget 39824 } = useListViewDropZone(); 39825 const elementRef = (0,external_wp_element_namespaceObject.useRef)(); 39826 const treeGridRef = (0,external_wp_compose_namespaceObject.useMergeRefs)([elementRef, dropZoneRef, ref]); 39827 const isMounted = (0,external_wp_element_namespaceObject.useRef)(false); 39828 const { 39829 setSelectedTreeId 39830 } = useListViewExpandSelectedItem({ 39831 firstSelectedBlockClientId: selectedClientIds[0], 39832 setExpandedState 39833 }); 39834 const selectEditorBlock = (0,external_wp_element_namespaceObject.useCallback)((event, clientId) => { 39835 updateBlockSelection(event, clientId); 39836 setSelectedTreeId(clientId); 39837 }, [setSelectedTreeId, updateBlockSelection]); 39838 (0,external_wp_element_namespaceObject.useEffect)(() => { 39839 isMounted.current = true; 39840 }, []); // List View renders a fixed number of items and relies on each having a fixed item height of 36px. 39841 // If this value changes, we should also change the itemHeight value set in useFixedWindowList. 39842 // See: https://github.com/WordPress/gutenberg/pull/35230 for additional context. 39843 39844 const [fixedListWindow] = (0,external_wp_compose_namespaceObject.__experimentalUseFixedWindowList)(elementRef, BLOCK_LIST_ITEM_HEIGHT, visibleBlockCount, { 39845 useWindowing: __experimentalPersistentListViewFeatures, 39846 windowOverscan: 40 39847 }); 39848 const expand = (0,external_wp_element_namespaceObject.useCallback)(clientId => { 39849 if (!clientId) { 39850 return; 39851 } 39852 39853 setExpandedState({ 39854 type: 'expand', 39855 clientIds: [clientId] 39856 }); 39857 }, [setExpandedState]); 39858 const collapse = (0,external_wp_element_namespaceObject.useCallback)(clientId => { 39859 if (!clientId) { 39860 return; 39861 } 39862 39863 setExpandedState({ 39864 type: 'collapse', 39865 clientIds: [clientId] 39866 }); 39867 }, [setExpandedState]); 39868 const expandRow = (0,external_wp_element_namespaceObject.useCallback)(row => { 39869 var _row$dataset; 39870 39871 expand(row === null || row === void 0 ? void 0 : (_row$dataset = row.dataset) === null || _row$dataset === void 0 ? void 0 : _row$dataset.block); 39872 }, [expand]); 39873 const collapseRow = (0,external_wp_element_namespaceObject.useCallback)(row => { 39874 var _row$dataset2; 39875 39876 collapse(row === null || row === void 0 ? void 0 : (_row$dataset2 = row.dataset) === null || _row$dataset2 === void 0 ? void 0 : _row$dataset2.block); 39877 }, [collapse]); 39878 const focusRow = (0,external_wp_element_namespaceObject.useCallback)((event, startRow, endRow) => { 39879 if (event.shiftKey) { 39880 var _startRow$dataset, _endRow$dataset; 39881 39882 updateBlockSelection(event, startRow === null || startRow === void 0 ? void 0 : (_startRow$dataset = startRow.dataset) === null || _startRow$dataset === void 0 ? void 0 : _startRow$dataset.block, endRow === null || endRow === void 0 ? void 0 : (_endRow$dataset = endRow.dataset) === null || _endRow$dataset === void 0 ? void 0 : _endRow$dataset.block); 39883 } 39884 }, [updateBlockSelection]); 39885 const contextValue = (0,external_wp_element_namespaceObject.useMemo)(() => ({ 39886 __experimentalFeatures, 39887 __experimentalPersistentListViewFeatures, 39888 __experimentalHideContainerBlockActions, 39889 isTreeGridMounted: isMounted.current, 39890 draggedClientIds, 39891 expandedState, 39892 expand, 39893 collapse 39894 }), [__experimentalFeatures, __experimentalPersistentListViewFeatures, __experimentalHideContainerBlockActions, isMounted.current, draggedClientIds, expandedState, expand, collapse]); 39895 return (0,external_wp_element_namespaceObject.createElement)(external_wp_data_namespaceObject.AsyncModeProvider, { 39896 value: true 39897 }, (0,external_wp_element_namespaceObject.createElement)(ListViewDropIndicator, { 39898 listViewRef: elementRef, 39899 blockDropTarget: blockDropTarget 39900 }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalTreeGrid, { 39901 id: id, 39902 className: "block-editor-list-view-tree", 39903 "aria-label": (0,external_wp_i18n_namespaceObject.__)('Block navigation structure'), 39904 ref: treeGridRef, 39905 onCollapseRow: collapseRow, 39906 onExpandRow: expandRow, 39907 onFocusRow: focusRow 39908 }, (0,external_wp_element_namespaceObject.createElement)(ListViewContext.Provider, { 39909 value: contextValue 39910 }, (0,external_wp_element_namespaceObject.createElement)(branch, _extends({ 39911 blocks: clientIdsTree, 39912 selectBlock: selectEditorBlock, 39913 showNestedBlocks: showNestedBlocks, 39914 showBlockMovers: showBlockMovers, 39915 fixedListWindow: fixedListWindow, 39916 selectedClientIds: selectedClientIds, 39917 expandNested: expandNested 39918 }, props))))); 39919 } 39920 39921 /* harmony default export */ var components_list_view = ((0,external_wp_element_namespaceObject.forwardRef)(ListView)); 39922 39923 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-navigation/dropdown.js 39924 39925 39926 39927 /** 39928 * WordPress dependencies 39929 */ 39930 39931 39932 39933 39934 39935 /** 39936 * Internal dependencies 39937 */ 39938 39939 39940 39941 39942 function BlockNavigationDropdownToggle(_ref) { 39943 let { 39944 isEnabled, 39945 onToggle, 39946 isOpen, 39947 innerRef, 39948 ...props 39949 } = _ref; 39950 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, _extends({}, props, { 39951 ref: innerRef, 39952 icon: list_view, 39953 "aria-expanded": isOpen, 39954 "aria-haspopup": "true", 39955 onClick: isEnabled ? onToggle : undefined 39956 /* translators: button label text should, if possible, be under 16 characters. */ 39957 , 39958 label: (0,external_wp_i18n_namespaceObject.__)('List view'), 39959 className: "block-editor-block-navigation", 39960 "aria-disabled": !isEnabled 39961 })); 39962 } 39963 39964 function BlockNavigationDropdown(_ref2, ref) { 39965 let { 39966 isDisabled, 39967 __experimentalFeatures, 39968 ...props 39969 } = _ref2; 39970 const hasBlocks = (0,external_wp_data_namespaceObject.useSelect)(select => !!select(store).getBlockCount(), []); 39971 const isEnabled = hasBlocks && !isDisabled; 39972 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Dropdown, { 39973 contentClassName: "block-editor-block-navigation__popover", 39974 position: "bottom right", 39975 renderToggle: _ref3 => { 39976 let { 39977 isOpen, 39978 onToggle 39979 } = _ref3; 39980 return (0,external_wp_element_namespaceObject.createElement)(BlockNavigationDropdownToggle, _extends({}, props, { 39981 innerRef: ref, 39982 isOpen: isOpen, 39983 onToggle: onToggle, 39984 isEnabled: isEnabled 39985 })); 39986 }, 39987 renderContent: () => (0,external_wp_element_namespaceObject.createElement)("div", { 39988 className: "block-editor-block-navigation__container" 39989 }, (0,external_wp_element_namespaceObject.createElement)("p", { 39990 className: "block-editor-block-navigation__label" 39991 }, (0,external_wp_i18n_namespaceObject.__)('List view')), (0,external_wp_element_namespaceObject.createElement)(components_list_view, { 39992 showNestedBlocks: true, 39993 __experimentalFeatures: __experimentalFeatures 39994 })) 39995 }); 39996 } 39997 39998 /* harmony default export */ var dropdown = ((0,external_wp_element_namespaceObject.forwardRef)(BlockNavigationDropdown)); 39999 40000 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-styles/preview-panel.js 40001 40002 40003 /** 40004 * WordPress dependencies 40005 */ 40006 40007 /** 40008 * Internal dependencies 40009 */ 40010 40011 40012 40013 function BlockStylesPreviewPanel(_ref) { 40014 let { 40015 genericPreviewBlock, 40016 style, 40017 className, 40018 activeStyle 40019 } = _ref; 40020 const styleClassName = replaceActiveStyle(className, activeStyle, style); 40021 const previewBlocks = (0,external_wp_element_namespaceObject.useMemo)(() => { 40022 return { ...genericPreviewBlock, 40023 title: style.label || style.name, 40024 description: style.description, 40025 initialAttributes: { ...genericPreviewBlock.attributes, 40026 className: styleClassName + ' block-editor-block-styles__block-preview-container' 40027 } 40028 }; 40029 }, [genericPreviewBlock, styleClassName]); 40030 return (0,external_wp_element_namespaceObject.createElement)(preview_panel, { 40031 item: previewBlocks, 40032 isStylePreview: true 40033 }); 40034 } 40035 40036 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-styles/index.js 40037 40038 40039 /** 40040 * External dependencies 40041 */ 40042 40043 40044 /** 40045 * WordPress dependencies 40046 */ 40047 40048 40049 40050 40051 40052 /** 40053 * Internal dependencies 40054 */ 40055 40056 40057 40058 40059 function BlockStylesPreviewPanelSlot(_ref) { 40060 let { 40061 scope 40062 } = _ref; 40063 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Slot, { 40064 name: `BlockStylesPreviewPanel/$scope}` 40065 }); 40066 } 40067 40068 function BlockStylesPreviewPanelFill(_ref2) { 40069 let { 40070 children, 40071 scope, 40072 ...props 40073 } = _ref2; 40074 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Fill, { 40075 name: `BlockStylesPreviewPanel/$scope}` 40076 }, (0,external_wp_element_namespaceObject.createElement)("div", props, children)); 40077 } // Top position (in px) of the Block Styles container 40078 // relative to the editor pane. 40079 // The value is the equivalent of the container's right position. 40080 40081 40082 const DEFAULT_POSITION_TOP = 16; // Block Styles component for the Settings Sidebar. 40083 40084 function BlockStyles(_ref3) { 40085 let { 40086 clientId, 40087 onSwitch = external_lodash_namespaceObject.noop, 40088 onHoverClassName = external_lodash_namespaceObject.noop, 40089 scope 40090 } = _ref3; 40091 const { 40092 onSelect, 40093 stylesToRender, 40094 activeStyle, 40095 genericPreviewBlock, 40096 className: previewClassName 40097 } = useStylesForBlocks({ 40098 clientId, 40099 onSwitch 40100 }); 40101 const [hoveredStyle, setHoveredStyle] = (0,external_wp_element_namespaceObject.useState)(null); 40102 const [containerScrollTop, setContainerScrollTop] = (0,external_wp_element_namespaceObject.useState)(0); 40103 const isMobileViewport = (0,external_wp_compose_namespaceObject.useViewportMatch)('medium', '<'); 40104 (0,external_wp_element_namespaceObject.useLayoutEffect)(() => { 40105 const scrollContainer = document.querySelector('.interface-interface-skeleton__content'); 40106 const scrollTop = (scrollContainer === null || scrollContainer === void 0 ? void 0 : scrollContainer.scrollTop) || 0; 40107 setContainerScrollTop(scrollTop + DEFAULT_POSITION_TOP); 40108 }, [hoveredStyle]); 40109 40110 if (!stylesToRender || stylesToRender.length === 0) { 40111 return null; 40112 } 40113 40114 const debouncedSetHoveredStyle = (0,external_lodash_namespaceObject.debounce)(setHoveredStyle, 250); 40115 40116 const onSelectStylePreview = style => { 40117 onSelect(style); 40118 onHoverClassName(null); 40119 setHoveredStyle(null); 40120 debouncedSetHoveredStyle.cancel(); 40121 }; 40122 40123 const styleItemHandler = item => { 40124 var _item$name; 40125 40126 if (hoveredStyle === item) { 40127 debouncedSetHoveredStyle.cancel(); 40128 return; 40129 } 40130 40131 debouncedSetHoveredStyle(item); 40132 onHoverClassName((_item$name = item === null || item === void 0 ? void 0 : item.name) !== null && _item$name !== void 0 ? _item$name : null); 40133 }; 40134 40135 return (0,external_wp_element_namespaceObject.createElement)("div", { 40136 className: "block-editor-block-styles" 40137 }, (0,external_wp_element_namespaceObject.createElement)("div", { 40138 className: "block-editor-block-styles__variants" 40139 }, stylesToRender.map(style => { 40140 const buttonText = style.label || style.name; 40141 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 40142 className: classnames_default()('block-editor-block-styles__item', { 40143 'is-active': activeStyle.name === style.name 40144 }), 40145 key: style.name, 40146 variant: "secondary", 40147 label: buttonText, 40148 onMouseEnter: () => styleItemHandler(style), 40149 onFocus: () => styleItemHandler(style), 40150 onMouseLeave: () => styleItemHandler(null), 40151 onBlur: () => styleItemHandler(null), 40152 onKeyDown: event => { 40153 if (external_wp_keycodes_namespaceObject.ENTER === event.keyCode || external_wp_keycodes_namespaceObject.SPACE === event.keyCode) { 40154 event.preventDefault(); 40155 onSelectStylePreview(style); 40156 } 40157 }, 40158 onClick: () => onSelectStylePreview(style), 40159 role: "button", 40160 tabIndex: "0" 40161 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalText, { 40162 as: "span", 40163 limit: 12, 40164 ellipsizeMode: "tail", 40165 className: "block-editor-block-styles__item-text", 40166 truncate: true 40167 }, buttonText)); 40168 })), hoveredStyle && !isMobileViewport && (0,external_wp_element_namespaceObject.createElement)(BlockStylesPreviewPanelFill, { 40169 scope: scope, 40170 className: "block-editor-block-styles__preview-panel", 40171 style: { 40172 top: containerScrollTop 40173 }, 40174 onMouseLeave: () => styleItemHandler(null) 40175 }, (0,external_wp_element_namespaceObject.createElement)(BlockStylesPreviewPanel, { 40176 activeStyle: activeStyle, 40177 className: previewClassName, 40178 genericPreviewBlock: genericPreviewBlock, 40179 style: hoveredStyle 40180 }))); 40181 } 40182 40183 BlockStyles.Slot = BlockStylesPreviewPanelSlot; 40184 /* harmony default export */ var block_styles = (BlockStyles); 40185 40186 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/layout.js 40187 40188 40189 /** 40190 * WordPress dependencies 40191 */ 40192 40193 const layout = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 40194 xmlns: "http://www.w3.org/2000/svg", 40195 viewBox: "0 0 24 24" 40196 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 40197 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" 40198 })); 40199 /* harmony default export */ var library_layout = (layout); 40200 40201 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-variation-picker/index.js 40202 40203 40204 /** 40205 * External dependencies 40206 */ 40207 40208 /** 40209 * WordPress dependencies 40210 */ 40211 40212 40213 40214 40215 40216 function BlockVariationPicker(_ref) { 40217 let { 40218 icon = library_layout, 40219 label = (0,external_wp_i18n_namespaceObject.__)('Choose variation'), 40220 instructions = (0,external_wp_i18n_namespaceObject.__)('Select a variation to start with.'), 40221 variations, 40222 onSelect, 40223 allowSkip 40224 } = _ref; 40225 const classes = classnames_default()('block-editor-block-variation-picker', { 40226 'has-many-variations': variations.length > 4 40227 }); 40228 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Placeholder, { 40229 icon: icon, 40230 label: label, 40231 instructions: instructions, 40232 className: classes 40233 }, (0,external_wp_element_namespaceObject.createElement)("ul", { 40234 className: "block-editor-block-variation-picker__variations", 40235 role: "list", 40236 "aria-label": (0,external_wp_i18n_namespaceObject.__)('Block variations') 40237 }, variations.map(variation => (0,external_wp_element_namespaceObject.createElement)("li", { 40238 key: variation.name 40239 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 40240 variant: "secondary", 40241 icon: variation.icon, 40242 iconSize: 48, 40243 onClick: () => onSelect(variation), 40244 className: "block-editor-block-variation-picker__variation", 40245 label: variation.description || variation.title 40246 }), (0,external_wp_element_namespaceObject.createElement)("span", { 40247 className: "block-editor-block-variation-picker__variation-label", 40248 role: "presentation" 40249 }, variation.title)))), allowSkip && (0,external_wp_element_namespaceObject.createElement)("div", { 40250 className: "block-editor-block-variation-picker__skip" 40251 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 40252 variant: "link", 40253 onClick: () => onSelect() 40254 }, (0,external_wp_i18n_namespaceObject.__)('Skip')))); 40255 } 40256 40257 /* harmony default export */ var block_variation_picker = (BlockVariationPicker); 40258 40259 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/grid.js 40260 40261 40262 /** 40263 * WordPress dependencies 40264 */ 40265 40266 const grid = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 40267 xmlns: "http://www.w3.org/2000/svg", 40268 viewBox: "0 0 24 24" 40269 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 40270 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", 40271 fillRule: "evenodd", 40272 clipRule: "evenodd" 40273 })); 40274 /* harmony default export */ var library_grid = (grid); 40275 40276 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-pattern-setup/constants.js 40277 const VIEWMODES = { 40278 carousel: 'carousel', 40279 grid: 'grid' 40280 }; 40281 40282 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-pattern-setup/setup-toolbar.js 40283 40284 40285 /** 40286 * WordPress dependencies 40287 */ 40288 40289 40290 40291 /** 40292 * Internal dependencies 40293 */ 40294 40295 40296 40297 const Actions = _ref => { 40298 let { 40299 onStartBlank, 40300 onBlockPatternSelect 40301 } = _ref; 40302 return (0,external_wp_element_namespaceObject.createElement)("div", { 40303 className: "block-editor-block-pattern-setup__actions" 40304 }, onStartBlank && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 40305 onClick: onStartBlank 40306 }, (0,external_wp_i18n_namespaceObject.__)('Start blank')), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 40307 variant: "primary", 40308 onClick: onBlockPatternSelect 40309 }, (0,external_wp_i18n_namespaceObject.__)('Choose'))); 40310 }; 40311 40312 const CarouselNavigation = _ref2 => { 40313 let { 40314 handlePrevious, 40315 handleNext, 40316 activeSlide, 40317 totalSlides 40318 } = _ref2; 40319 return (0,external_wp_element_namespaceObject.createElement)("div", { 40320 className: "block-editor-block-pattern-setup__navigation" 40321 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 40322 icon: chevron_left, 40323 label: (0,external_wp_i18n_namespaceObject.__)('Previous pattern'), 40324 onClick: handlePrevious, 40325 disabled: activeSlide === 0 40326 }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 40327 icon: chevron_right, 40328 label: (0,external_wp_i18n_namespaceObject.__)('Next pattern'), 40329 onClick: handleNext, 40330 disabled: activeSlide === totalSlides - 1 40331 })); 40332 }; 40333 40334 const SetupToolbar = _ref3 => { 40335 let { 40336 viewMode, 40337 setViewMode, 40338 handlePrevious, 40339 handleNext, 40340 activeSlide, 40341 totalSlides, 40342 onBlockPatternSelect, 40343 onStartBlank 40344 } = _ref3; 40345 const isCarouselView = viewMode === VIEWMODES.carousel; 40346 const displayControls = (0,external_wp_element_namespaceObject.createElement)("div", { 40347 className: "block-editor-block-pattern-setup__display-controls" 40348 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 40349 icon: stretch_full_width, 40350 label: (0,external_wp_i18n_namespaceObject.__)('Carousel view'), 40351 onClick: () => setViewMode(VIEWMODES.carousel), 40352 isPressed: isCarouselView 40353 }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 40354 icon: library_grid, 40355 label: (0,external_wp_i18n_namespaceObject.__)('Grid view'), 40356 onClick: () => setViewMode(VIEWMODES.grid), 40357 isPressed: viewMode === VIEWMODES.grid 40358 })); 40359 return (0,external_wp_element_namespaceObject.createElement)("div", { 40360 className: "block-editor-block-pattern-setup__toolbar" 40361 }, isCarouselView && (0,external_wp_element_namespaceObject.createElement)(CarouselNavigation, { 40362 handlePrevious: handlePrevious, 40363 handleNext: handleNext, 40364 activeSlide: activeSlide, 40365 totalSlides: totalSlides 40366 }), displayControls, isCarouselView && (0,external_wp_element_namespaceObject.createElement)(Actions, { 40367 onBlockPatternSelect: onBlockPatternSelect, 40368 onStartBlank: onStartBlank 40369 })); 40370 }; 40371 40372 /* harmony default export */ var setup_toolbar = (SetupToolbar); 40373 40374 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-pattern-setup/use-patterns-setup.js 40375 /** 40376 * WordPress dependencies 40377 */ 40378 40379 /** 40380 * Internal dependencies 40381 */ 40382 40383 40384 40385 function usePatternsSetup(clientId, blockName, filterPatternsFn) { 40386 return (0,external_wp_data_namespaceObject.useSelect)(select => { 40387 const { 40388 getBlockRootClientId, 40389 __experimentalGetPatternsByBlockTypes, 40390 __experimentalGetAllowedPatterns 40391 } = select(store); 40392 const rootClientId = getBlockRootClientId(clientId); 40393 40394 if (filterPatternsFn) { 40395 return __experimentalGetAllowedPatterns(rootClientId).filter(filterPatternsFn); 40396 } 40397 40398 return __experimentalGetPatternsByBlockTypes(blockName, rootClientId); 40399 }, [clientId, blockName, filterPatternsFn]); 40400 } 40401 40402 /* harmony default export */ var use_patterns_setup = (usePatternsSetup); 40403 40404 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-pattern-setup/index.js 40405 40406 40407 40408 /** 40409 * WordPress dependencies 40410 */ 40411 40412 40413 40414 40415 40416 40417 /** 40418 * Internal dependencies 40419 */ 40420 40421 40422 40423 40424 40425 40426 40427 const SetupContent = _ref => { 40428 let { 40429 viewMode, 40430 activeSlide, 40431 patterns, 40432 onBlockPatternSelect, 40433 height 40434 } = _ref; 40435 const composite = (0,external_wp_components_namespaceObject.__unstableUseCompositeState)(); 40436 const containerClass = 'block-editor-block-pattern-setup__container'; 40437 40438 if (viewMode === VIEWMODES.carousel) { 40439 const slideClass = new Map([[activeSlide, 'active-slide'], [activeSlide - 1, 'previous-slide'], [activeSlide + 1, 'next-slide']]); 40440 return (0,external_wp_element_namespaceObject.createElement)("div", { 40441 className: "block-editor-block-pattern-setup__carousel", 40442 style: { 40443 height 40444 } 40445 }, (0,external_wp_element_namespaceObject.createElement)("div", { 40446 className: containerClass 40447 }, (0,external_wp_element_namespaceObject.createElement)("ul", { 40448 className: "carousel-container" 40449 }, patterns.map((pattern, index) => (0,external_wp_element_namespaceObject.createElement)(BlockPatternSlide, { 40450 className: slideClass.get(index) || '', 40451 key: pattern.name, 40452 pattern: pattern, 40453 minHeight: height 40454 }))))); 40455 } 40456 40457 return (0,external_wp_element_namespaceObject.createElement)("div", { 40458 style: { 40459 height 40460 }, 40461 className: "block-editor-block-pattern-setup__grid" 40462 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__unstableComposite, _extends({}, composite, { 40463 role: "listbox", 40464 className: containerClass, 40465 "aria-label": (0,external_wp_i18n_namespaceObject.__)('Patterns list') 40466 }), patterns.map(pattern => (0,external_wp_element_namespaceObject.createElement)(block_pattern_setup_BlockPattern, { 40467 key: pattern.name, 40468 pattern: pattern, 40469 onSelect: onBlockPatternSelect, 40470 composite: composite 40471 })))); 40472 }; 40473 40474 function block_pattern_setup_BlockPattern(_ref2) { 40475 let { 40476 pattern, 40477 onSelect, 40478 composite 40479 } = _ref2; 40480 const baseClassName = 'block-editor-block-pattern-setup-list'; 40481 const { 40482 blocks, 40483 description, 40484 viewportWidth = 700 40485 } = pattern; 40486 const descriptionId = (0,external_wp_compose_namespaceObject.useInstanceId)(block_pattern_setup_BlockPattern, `$baseClassName}__item-description`); 40487 return (0,external_wp_element_namespaceObject.createElement)("div", { 40488 className: `$baseClassName}__list-item`, 40489 "aria-label": pattern.title, 40490 "aria-describedby": pattern.description ? descriptionId : undefined 40491 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__unstableCompositeItem, _extends({ 40492 role: "option", 40493 as: "div" 40494 }, composite, { 40495 className: `$baseClassName}__item`, 40496 onClick: () => onSelect(blocks) 40497 }), (0,external_wp_element_namespaceObject.createElement)(block_preview, { 40498 blocks: blocks, 40499 viewportWidth: viewportWidth 40500 })), !!description && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.VisuallyHidden, { 40501 id: descriptionId 40502 }, description)); 40503 } 40504 40505 function BlockPatternSlide(_ref3) { 40506 let { 40507 className, 40508 pattern, 40509 minHeight 40510 } = _ref3; 40511 const { 40512 blocks, 40513 title, 40514 description 40515 } = pattern; 40516 const descriptionId = (0,external_wp_compose_namespaceObject.useInstanceId)(BlockPatternSlide, 'block-editor-block-pattern-setup-list__item-description'); 40517 return (0,external_wp_element_namespaceObject.createElement)("li", { 40518 className: `pattern-slide $className}`, 40519 "aria-label": title, 40520 "aria-describedby": description ? descriptionId : undefined 40521 }, (0,external_wp_element_namespaceObject.createElement)(block_preview, { 40522 blocks: blocks, 40523 __experimentalMinHeight: minHeight 40524 }), !!description && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.VisuallyHidden, { 40525 id: descriptionId 40526 }, description)); 40527 } 40528 40529 const BlockPatternSetup = _ref4 => { 40530 let { 40531 clientId, 40532 blockName, 40533 filterPatternsFn, 40534 startBlankComponent, 40535 onBlockPatternSelect 40536 } = _ref4; 40537 const [viewMode, setViewMode] = (0,external_wp_element_namespaceObject.useState)(VIEWMODES.carousel); 40538 const [activeSlide, setActiveSlide] = (0,external_wp_element_namespaceObject.useState)(0); 40539 const [showBlank, setShowBlank] = (0,external_wp_element_namespaceObject.useState)(false); 40540 const { 40541 replaceBlock 40542 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 40543 const patterns = use_patterns_setup(clientId, blockName, filterPatternsFn); 40544 const [contentResizeListener, { 40545 height: contentHeight 40546 }] = (0,external_wp_compose_namespaceObject.useResizeObserver)(); 40547 40548 if (!(patterns !== null && patterns !== void 0 && patterns.length) || showBlank) { 40549 return startBlankComponent; 40550 } 40551 40552 const onBlockPatternSelectDefault = blocks => { 40553 const clonedBlocks = blocks.map(block => (0,external_wp_blocks_namespaceObject.cloneBlock)(block)); 40554 replaceBlock(clientId, clonedBlocks); 40555 }; 40556 40557 const onPatternSelectCallback = onBlockPatternSelect || onBlockPatternSelectDefault; 40558 const onStartBlank = startBlankComponent ? () => { 40559 setShowBlank(true); 40560 } : undefined; 40561 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, contentResizeListener, (0,external_wp_element_namespaceObject.createElement)("div", { 40562 className: `block-editor-block-pattern-setup view-mode-$viewMode}` 40563 }, (0,external_wp_element_namespaceObject.createElement)(SetupContent, { 40564 viewMode: viewMode, 40565 activeSlide: activeSlide, 40566 patterns: patterns, 40567 onBlockPatternSelect: onPatternSelectCallback, 40568 height: contentHeight - 2 * 60 40569 }), (0,external_wp_element_namespaceObject.createElement)(setup_toolbar, { 40570 viewMode: viewMode, 40571 setViewMode: setViewMode, 40572 activeSlide: activeSlide, 40573 totalSlides: patterns.length, 40574 handleNext: () => { 40575 setActiveSlide(active => active + 1); 40576 }, 40577 handlePrevious: () => { 40578 setActiveSlide(active => active - 1); 40579 }, 40580 onBlockPatternSelect: () => { 40581 onPatternSelectCallback(patterns[activeSlide].blocks); 40582 }, 40583 onStartBlank: onStartBlank 40584 }))); 40585 }; 40586 40587 /* harmony default export */ var block_pattern_setup = (BlockPatternSetup); 40588 40589 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-variation-transforms/index.js 40590 40591 40592 /** 40593 * WordPress dependencies 40594 */ 40595 40596 40597 40598 40599 40600 40601 /** 40602 * Internal dependencies 40603 */ 40604 40605 40606 40607 function VariationsButtons(_ref) { 40608 let { 40609 className, 40610 onSelectVariation, 40611 selectedValue, 40612 variations 40613 } = _ref; 40614 return (0,external_wp_element_namespaceObject.createElement)("fieldset", { 40615 className: className 40616 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.VisuallyHidden, { 40617 as: "legend" 40618 }, (0,external_wp_i18n_namespaceObject.__)('Transform to variation')), variations.map(variation => (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 40619 key: variation.name, 40620 icon: variation.icon, 40621 isPressed: selectedValue === variation.name, 40622 label: selectedValue === variation.name ? variation.title : (0,external_wp_i18n_namespaceObject.sprintf)( 40623 /* translators: %s: Name of the block variation */ 40624 (0,external_wp_i18n_namespaceObject.__)('Transform to %s'), variation.title), 40625 onClick: () => onSelectVariation(variation.name), 40626 "aria-label": variation.title, 40627 showTooltip: true 40628 }))); 40629 } 40630 40631 function VariationsDropdown(_ref2) { 40632 let { 40633 className, 40634 onSelectVariation, 40635 selectedValue, 40636 variations 40637 } = _ref2; 40638 const selectOptions = variations.map(_ref3 => { 40639 let { 40640 name, 40641 title, 40642 description 40643 } = _ref3; 40644 return { 40645 value: name, 40646 label: title, 40647 info: description 40648 }; 40649 }); 40650 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.DropdownMenu, { 40651 className: className, 40652 label: (0,external_wp_i18n_namespaceObject.__)('Transform to variation'), 40653 text: (0,external_wp_i18n_namespaceObject.__)('Transform to variation'), 40654 popoverProps: { 40655 position: 'bottom center', 40656 className: `$className}__popover` 40657 }, 40658 icon: chevron_down, 40659 toggleProps: { 40660 iconPosition: 'right' 40661 } 40662 }, () => (0,external_wp_element_namespaceObject.createElement)("div", { 40663 className: `$className}__container` 40664 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuGroup, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItemsChoice, { 40665 choices: selectOptions, 40666 value: selectedValue, 40667 onSelect: onSelectVariation 40668 })))); 40669 } 40670 40671 function __experimentalBlockVariationTransforms(_ref4) { 40672 let { 40673 blockClientId 40674 } = _ref4; 40675 const { 40676 updateBlockAttributes 40677 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 40678 const { 40679 activeBlockVariation, 40680 variations 40681 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 40682 const { 40683 getActiveBlockVariation, 40684 getBlockVariations 40685 } = select(external_wp_blocks_namespaceObject.store); 40686 const { 40687 getBlockName, 40688 getBlockAttributes 40689 } = select(store); 40690 const name = blockClientId && getBlockName(blockClientId); 40691 return { 40692 activeBlockVariation: getActiveBlockVariation(name, getBlockAttributes(blockClientId)), 40693 variations: name && getBlockVariations(name, 'transform') 40694 }; 40695 }, [blockClientId]); 40696 const selectedValue = activeBlockVariation === null || activeBlockVariation === void 0 ? void 0 : activeBlockVariation.name; // Check if each variation has a unique icon. 40697 40698 const hasUniqueIcons = (0,external_wp_element_namespaceObject.useMemo)(() => { 40699 const variationIcons = new Set(); 40700 variations.forEach(variation => { 40701 if (variation.icon) { 40702 variationIcons.add(variation.icon); 40703 } 40704 }); 40705 return variationIcons.size === variations.length; 40706 }, [variations]); 40707 40708 const onSelectVariation = variationName => { 40709 updateBlockAttributes(blockClientId, { ...variations.find(_ref5 => { 40710 let { 40711 name 40712 } = _ref5; 40713 return name === variationName; 40714 }).attributes 40715 }); 40716 }; 40717 40718 const baseClass = 'block-editor-block-variation-transforms'; // Skip rendering if there are no variations 40719 40720 if (!(variations !== null && variations !== void 0 && variations.length)) return null; 40721 const Component = hasUniqueIcons ? VariationsButtons : VariationsDropdown; 40722 return (0,external_wp_element_namespaceObject.createElement)(Component, { 40723 className: baseClass, 40724 onSelectVariation: onSelectVariation, 40725 selectedValue: selectedValue, 40726 variations: variations 40727 }); 40728 } 40729 40730 /* harmony default export */ var block_variation_transforms = (__experimentalBlockVariationTransforms); 40731 40732 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/color-palette/with-color-context.js 40733 40734 40735 40736 /** 40737 * External dependencies 40738 */ 40739 40740 /** 40741 * WordPress dependencies 40742 */ 40743 40744 40745 /** 40746 * Internal dependencies 40747 */ 40748 40749 40750 /* harmony default export */ var with_color_context = ((0,external_wp_compose_namespaceObject.createHigherOrderComponent)(WrappedComponent => { 40751 return props => { 40752 const colorsFeature = useSetting('color.palette'); 40753 const disableCustomColorsFeature = !useSetting('color.custom'); 40754 const colors = props.colors === undefined ? colorsFeature : props.colors; 40755 const disableCustomColors = props.disableCustomColors === undefined ? disableCustomColorsFeature : props.disableCustomColors; 40756 const hasColorsToChoose = !(0,external_lodash_namespaceObject.isEmpty)(colors) || !disableCustomColors; 40757 return (0,external_wp_element_namespaceObject.createElement)(WrappedComponent, _extends({}, props, { 40758 colors, 40759 disableCustomColors, 40760 hasColorsToChoose 40761 })); 40762 }; 40763 }, 'withColorContext')); 40764 40765 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/color-palette/index.js 40766 /** 40767 * WordPress dependencies 40768 */ 40769 40770 /** 40771 * Internal dependencies 40772 */ 40773 40774 40775 /* harmony default export */ var color_palette = (with_color_context(external_wp_components_namespaceObject.ColorPalette)); 40776 40777 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/color-palette/control.js 40778 40779 40780 40781 /** 40782 * Internal dependencies 40783 */ 40784 40785 function ColorPaletteControl(_ref) { 40786 let { 40787 onChange, 40788 value, 40789 ...otherProps 40790 } = _ref; 40791 return (0,external_wp_element_namespaceObject.createElement)(control, _extends({}, otherProps, { 40792 onColorChange: onChange, 40793 colorValue: value, 40794 gradients: [], 40795 disableCustomGradients: true 40796 })); 40797 } 40798 40799 ;// CONCATENATED MODULE: external ["wp","date"] 40800 var external_wp_date_namespaceObject = window["wp"]["date"]; 40801 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/date-format-picker/index.js 40802 40803 40804 /** 40805 * External dependencies 40806 */ 40807 40808 /** 40809 * WordPress dependencies 40810 */ 40811 40812 40813 40814 40815 // So that we can illustrate the different formats in the dropdown properly, 40816 // show a date that has a day greater than 12 and a month with more than three 40817 // letters. Here we're using 2022-01-25 which is when WordPress 5.9 was 40818 // released. 40819 40820 const EXAMPLE_DATE = new Date(2022, 0, 25); 40821 /** 40822 * The `DateFormatPicker` component renders controls that let the user choose a 40823 * _date format_. That is, how they want their dates to be formatted. 40824 * 40825 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/date-format-picker/README.md 40826 * 40827 * @param {Object} props 40828 * @param {string|null} props.format The selected date 40829 * format. If 40830 * `null`, 40831 * _Default_ is 40832 * selected. 40833 * @param {string} props.defaultFormat The date format that 40834 * will be used if the 40835 * user selects 40836 * 'Default'. 40837 * @param {( format: string|null ) => void} props.onChange Called when a 40838 * selection is 40839 * made. If `null`, 40840 * _Default_ is 40841 * selected. 40842 */ 40843 40844 function DateFormatPicker(_ref) { 40845 let { 40846 format, 40847 defaultFormat, 40848 onChange 40849 } = _ref; 40850 return (0,external_wp_element_namespaceObject.createElement)("fieldset", { 40851 className: "block-editor-date-format-picker" 40852 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.VisuallyHidden, { 40853 as: "legend" 40854 }, (0,external_wp_i18n_namespaceObject.__)('Date format')), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, { 40855 label: (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_i18n_namespaceObject.__)('Default format'), (0,external_wp_element_namespaceObject.createElement)("span", { 40856 className: "block-editor-date-format-picker__default-format-toggle-control__hint" 40857 }, (0,external_wp_date_namespaceObject.dateI18n)(defaultFormat, EXAMPLE_DATE))), 40858 checked: !format, 40859 onChange: checked => onChange(checked ? null : defaultFormat) 40860 }), format && (0,external_wp_element_namespaceObject.createElement)(NonDefaultControls, { 40861 format: format, 40862 onChange: onChange 40863 })); 40864 } 40865 40866 function NonDefaultControls(_ref2) { 40867 var _suggestedOptions$fin; 40868 40869 let { 40870 format, 40871 onChange 40872 } = _ref2; 40873 // Suggest a short format, medium format, long format, and a standardised 40874 // (YYYY-MM-DD) format. The short, medium, and long formats are localised as 40875 // different languages have different ways of writing these. For example, 'F 40876 // j, Y' (April 20, 2022) in American English (en_US) is 'j. F Y' (20. April 40877 // 2022) in German (de). The resultant array is de-duplicated as some 40878 // languages will use the same format string for short, medium, and long 40879 // formats. 40880 const suggestedFormats = (0,external_lodash_namespaceObject.uniq)(['Y-m-d', (0,external_wp_i18n_namespaceObject._x)('n/j/Y', 'short date format'), (0,external_wp_i18n_namespaceObject._x)('n/j/Y g:i A', 'short date format with time'), (0,external_wp_i18n_namespaceObject._x)('M j, Y', 'medium date format'), (0,external_wp_i18n_namespaceObject._x)('M j, Y g:i A', 'medium date format with time'), (0,external_wp_i18n_namespaceObject._x)('F j, Y', 'long date format')]); 40881 const suggestedOptions = suggestedFormats.map((suggestedFormat, index) => ({ 40882 key: `suggested-$index}`, 40883 name: (0,external_wp_date_namespaceObject.dateI18n)(suggestedFormat, EXAMPLE_DATE), 40884 format: suggestedFormat 40885 })); 40886 const customOption = { 40887 key: 'custom', 40888 name: (0,external_wp_i18n_namespaceObject.__)('Custom'), 40889 className: 'block-editor-date-format-picker__custom-format-select-control__custom-option', 40890 __experimentalHint: (0,external_wp_i18n_namespaceObject.__)('Enter your own date format') 40891 }; 40892 const [isCustom, setIsCustom] = (0,external_wp_element_namespaceObject.useState)(() => !!format && !suggestedFormats.includes(format)); 40893 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.BaseControl, { 40894 className: "block-editor-date-format-picker__custom-format-select-control" 40895 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.CustomSelectControl, { 40896 label: (0,external_wp_i18n_namespaceObject.__)('Choose a format'), 40897 options: [...suggestedOptions, customOption], 40898 value: isCustom ? customOption : (_suggestedOptions$fin = suggestedOptions.find(option => option.format === format)) !== null && _suggestedOptions$fin !== void 0 ? _suggestedOptions$fin : customOption, 40899 onChange: _ref3 => { 40900 let { 40901 selectedItem 40902 } = _ref3; 40903 40904 if (selectedItem === customOption) { 40905 setIsCustom(true); 40906 } else { 40907 setIsCustom(false); 40908 onChange(selectedItem.format); 40909 } 40910 } 40911 })), isCustom && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, { 40912 label: (0,external_wp_i18n_namespaceObject.__)('Custom format'), 40913 hideLabelFromVision: true, 40914 help: (0,external_wp_element_namespaceObject.createInterpolateElement)((0,external_wp_i18n_namespaceObject.__)('Enter a date or time <Link>format string</Link>.'), { 40915 Link: (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ExternalLink, { 40916 href: (0,external_wp_i18n_namespaceObject.__)('https://wordpress.org/support/article/formatting-date-and-time/') 40917 }) 40918 }), 40919 value: format, 40920 onChange: value => onChange(value) 40921 })); 40922 } 40923 40924 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/colors-gradients/panel-color-gradient-settings.js 40925 40926 40927 40928 /** 40929 * External dependencies 40930 */ 40931 40932 40933 /** 40934 * WordPress dependencies 40935 */ 40936 40937 40938 40939 /** 40940 * Internal dependencies 40941 */ 40942 40943 40944 40945 40946 40947 40948 // translators: first %s: The type of color or gradient (e.g. background, overlay...), second %s: the color name or value (e.g. red or #ff0000) 40949 40950 const colorIndicatorAriaLabel = (0,external_wp_i18n_namespaceObject.__)('(%s: color %s)'); // translators: first %s: The type of color or gradient (e.g. background, overlay...), second %s: the color name or value (e.g. red or #ff0000) 40951 40952 40953 const gradientIndicatorAriaLabel = (0,external_wp_i18n_namespaceObject.__)('(%s: gradient %s)'); 40954 40955 const panel_color_gradient_settings_colorsAndGradientKeys = ['colors', 'disableCustomColors', 'gradients', 'disableCustomGradients']; 40956 40957 const Indicators = _ref => { 40958 let { 40959 colors, 40960 gradients, 40961 settings 40962 } = _ref; 40963 return settings.map((_ref2, index) => { 40964 let { 40965 colorValue, 40966 gradientValue, 40967 label, 40968 colors: availableColors, 40969 gradients: availableGradients 40970 } = _ref2; 40971 40972 if (!colorValue && !gradientValue) { 40973 return null; 40974 } 40975 40976 let ariaLabel; 40977 40978 if (colorValue) { 40979 const colorObject = getColorObjectByColorValue(availableColors || colors, colorValue); 40980 ariaLabel = (0,external_wp_i18n_namespaceObject.sprintf)(colorIndicatorAriaLabel, label.toLowerCase(), colorObject && colorObject.name || colorValue); 40981 } else { 40982 const gradientObject = __experimentalGetGradientObjectByGradientValue(availableGradients || gradients, colorValue); 40983 40984 ariaLabel = (0,external_wp_i18n_namespaceObject.sprintf)(gradientIndicatorAriaLabel, label.toLowerCase(), gradientObject && gradientObject.name || gradientValue); 40985 } 40986 40987 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ColorIndicator, { 40988 key: index, 40989 colorValue: colorValue || gradientValue, 40990 "aria-label": ariaLabel 40991 }); 40992 }); 40993 }; 40994 40995 const PanelColorGradientSettingsInner = _ref3 => { 40996 let { 40997 className, 40998 colors, 40999 gradients, 41000 disableCustomColors, 41001 disableCustomGradients, 41002 children, 41003 settings, 41004 title, 41005 showTitle = true, 41006 __experimentalHasMultipleOrigins, 41007 __experimentalIsRenderedInSidebar, 41008 enableAlpha, 41009 ...props 41010 } = _ref3; 41011 41012 if ((0,external_lodash_namespaceObject.isEmpty)(colors) && (0,external_lodash_namespaceObject.isEmpty)(gradients) && disableCustomColors && disableCustomGradients && (0,external_lodash_namespaceObject.every)(settings, setting => (0,external_lodash_namespaceObject.isEmpty)(setting.colors) && (0,external_lodash_namespaceObject.isEmpty)(setting.gradients) && (setting.disableCustomColors === undefined || setting.disableCustomColors) && (setting.disableCustomGradients === undefined || setting.disableCustomGradients))) { 41013 return null; 41014 } 41015 41016 const titleElement = (0,external_wp_element_namespaceObject.createElement)("span", { 41017 className: "block-editor-panel-color-gradient-settings__panel-title" 41018 }, title, (0,external_wp_element_namespaceObject.createElement)(Indicators, { 41019 colors: colors, 41020 gradients: gradients, 41021 settings: settings 41022 })); 41023 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, _extends({ 41024 className: classnames_default()('block-editor-panel-color-gradient-settings', className), 41025 title: showTitle ? titleElement : undefined 41026 }, props), (0,external_wp_element_namespaceObject.createElement)(ColorGradientSettingsDropdown, { 41027 settings: settings, 41028 colors, 41029 gradients, 41030 disableCustomColors, 41031 disableCustomGradients, 41032 __experimentalHasMultipleOrigins, 41033 __experimentalIsRenderedInSidebar, 41034 enableAlpha 41035 }), !!children && (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalSpacer, { 41036 marginY: 4 41037 }), " ", children)); 41038 }; 41039 41040 const PanelColorGradientSettingsSingleSelect = props => { 41041 const colorGradientSettings = useCommonSingleMultipleSelects(); 41042 colorGradientSettings.colors = useSetting('color.palette'); 41043 colorGradientSettings.gradients = useSetting('color.gradients'); 41044 return (0,external_wp_element_namespaceObject.createElement)(PanelColorGradientSettingsInner, _extends({}, colorGradientSettings, props)); 41045 }; 41046 41047 const PanelColorGradientSettingsMultipleSelect = props => { 41048 const colorGradientSettings = useMultipleOriginColorsAndGradients(); 41049 return (0,external_wp_element_namespaceObject.createElement)(PanelColorGradientSettingsInner, _extends({}, colorGradientSettings, props)); 41050 }; 41051 41052 const PanelColorGradientSettings = props => { 41053 if ((0,external_lodash_namespaceObject.every)(panel_color_gradient_settings_colorsAndGradientKeys, key => props.hasOwnProperty(key))) { 41054 return (0,external_wp_element_namespaceObject.createElement)(PanelColorGradientSettingsInner, props); 41055 } 41056 41057 if (props.__experimentalHasMultipleOrigins) { 41058 return (0,external_wp_element_namespaceObject.createElement)(PanelColorGradientSettingsMultipleSelect, props); 41059 } 41060 41061 return (0,external_wp_element_namespaceObject.createElement)(PanelColorGradientSettingsSingleSelect, props); 41062 }; 41063 41064 /* harmony default export */ var panel_color_gradient_settings = (PanelColorGradientSettings); 41065 41066 ;// CONCATENATED MODULE: ./node_modules/react-easy-crop/node_modules/tslib/tslib.es6.js 41067 /*! ***************************************************************************** 41068 Copyright (c) Microsoft Corporation. 41069 41070 Permission to use, copy, modify, and/or distribute this software for any 41071 purpose with or without fee is hereby granted. 41072 41073 THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH 41074 REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY 41075 AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, 41076 INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM 41077 LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR 41078 OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR 41079 PERFORMANCE OF THIS SOFTWARE. 41080 ***************************************************************************** */ 41081 /* global Reflect, Promise */ 41082 41083 var extendStatics = function(d, b) { 41084 extendStatics = Object.setPrototypeOf || 41085 ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || 41086 function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; }; 41087 return extendStatics(d, b); 41088 }; 41089 41090 function __extends(d, b) { 41091 extendStatics(d, b); 41092 function __() { this.constructor = d; } 41093 d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); 41094 } 41095 41096 var __assign = function() { 41097 __assign = Object.assign || function __assign(t) { 41098 for (var s, i = 1, n = arguments.length; i < n; i++) { 41099 s = arguments[i]; 41100 for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; 41101 } 41102 return t; 41103 } 41104 return __assign.apply(this, arguments); 41105 } 41106 41107 function __rest(s, e) { 41108 var t = {}; 41109 for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) 41110 t[p] = s[p]; 41111 if (s != null && typeof Object.getOwnPropertySymbols === "function") 41112 for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) { 41113 if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) 41114 t[p[i]] = s[p[i]]; 41115 } 41116 return t; 41117 } 41118 41119 function __decorate(decorators, target, key, desc) { 41120 var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; 41121 if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); 41122 else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; 41123 return c > 3 && r && Object.defineProperty(target, key, r), r; 41124 } 41125 41126 function __param(paramIndex, decorator) { 41127 return function (target, key) { decorator(target, key, paramIndex); } 41128 } 41129 41130 function __metadata(metadataKey, metadataValue) { 41131 if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(metadataKey, metadataValue); 41132 } 41133 41134 function __awaiter(thisArg, _arguments, P, generator) { 41135 function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } 41136 return new (P || (P = Promise))(function (resolve, reject) { 41137 function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } 41138 function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } 41139 function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } 41140 step((generator = generator.apply(thisArg, _arguments || [])).next()); 41141 }); 41142 } 41143 41144 function __generator(thisArg, body) { 41145 var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; 41146 return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; 41147 function verb(n) { return function (v) { return step([n, v]); }; } 41148 function step(op) { 41149 if (f) throw new TypeError("Generator is already executing."); 41150 while (_) try { 41151 if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; 41152 if (y = 0, t) op = [op[0] & 2, t.value]; 41153 switch (op[0]) { 41154 case 0: case 1: t = op; break; 41155 case 4: _.label++; return { value: op[1], done: false }; 41156 case 5: _.label++; y = op[1]; op = [0]; continue; 41157 case 7: op = _.ops.pop(); _.trys.pop(); continue; 41158 default: 41159 if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } 41160 if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } 41161 if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } 41162 if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } 41163 if (t[2]) _.ops.pop(); 41164 _.trys.pop(); continue; 41165 } 41166 op = body.call(thisArg, _); 41167 } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } 41168 if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; 41169 } 41170 } 41171 41172 var __createBinding = Object.create ? (function(o, m, k, k2) { 41173 if (k2 === undefined) k2 = k; 41174 Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); 41175 }) : (function(o, m, k, k2) { 41176 if (k2 === undefined) k2 = k; 41177 o[k2] = m[k]; 41178 }); 41179 41180 function __exportStar(m, o) { 41181 for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p); 41182 } 41183 41184 function __values(o) { 41185 var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0; 41186 if (m) return m.call(o); 41187 if (o && typeof o.length === "number") return { 41188 next: function () { 41189 if (o && i >= o.length) o = void 0; 41190 return { value: o && o[i++], done: !o }; 41191 } 41192 }; 41193 throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined."); 41194 } 41195 41196 function __read(o, n) { 41197 var m = typeof Symbol === "function" && o[Symbol.iterator]; 41198 if (!m) return o; 41199 var i = m.call(o), r, ar = [], e; 41200 try { 41201 while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value); 41202 } 41203 catch (error) { e = { error: error }; } 41204 finally { 41205 try { 41206 if (r && !r.done && (m = i["return"])) m.call(i); 41207 } 41208 finally { if (e) throw e.error; } 41209 } 41210 return ar; 41211 } 41212 41213 function __spread() { 41214 for (var ar = [], i = 0; i < arguments.length; i++) 41215 ar = ar.concat(__read(arguments[i])); 41216 return ar; 41217 } 41218 41219 function __spreadArrays() { 41220 for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length; 41221 for (var r = Array(s), k = 0, i = 0; i < il; i++) 41222 for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) 41223 r[k] = a[j]; 41224 return r; 41225 }; 41226 41227 function __await(v) { 41228 return this instanceof __await ? (this.v = v, this) : new __await(v); 41229 } 41230 41231 function __asyncGenerator(thisArg, _arguments, generator) { 41232 if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); 41233 var g = generator.apply(thisArg, _arguments || []), i, q = []; 41234 return i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i; 41235 function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; } 41236 function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } } 41237 function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); } 41238 function fulfill(value) { resume("next", value); } 41239 function reject(value) { resume("throw", value); } 41240 function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); } 41241 } 41242 41243 function __asyncDelegator(o) { 41244 var i, p; 41245 return i = {}, verb("next"), verb("throw", function (e) { throw e; }), verb("return"), i[Symbol.iterator] = function () { return this; }, i; 41246 function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === "return" } : f ? f(v) : v; } : f; } 41247 } 41248 41249 function __asyncValues(o) { 41250 if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); 41251 var m = o[Symbol.asyncIterator], i; 41252 return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i); 41253 function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; } 41254 function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); } 41255 } 41256 41257 function __makeTemplateObject(cooked, raw) { 41258 if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; } 41259 return cooked; 41260 }; 41261 41262 var __setModuleDefault = Object.create ? (function(o, v) { 41263 Object.defineProperty(o, "default", { enumerable: true, value: v }); 41264 }) : function(o, v) { 41265 o["default"] = v; 41266 }; 41267 41268 function __importStar(mod) { 41269 if (mod && mod.__esModule) return mod; 41270 var result = {}; 41271 if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); 41272 __setModuleDefault(result, mod); 41273 return result; 41274 } 41275 41276 function __importDefault(mod) { 41277 return (mod && mod.__esModule) ? mod : { default: mod }; 41278 } 41279 41280 function __classPrivateFieldGet(receiver, privateMap) { 41281 if (!privateMap.has(receiver)) { 41282 throw new TypeError("attempted to get private field on non-instance"); 41283 } 41284 return privateMap.get(receiver); 41285 } 41286 41287 function __classPrivateFieldSet(receiver, privateMap, value) { 41288 if (!privateMap.has(receiver)) { 41289 throw new TypeError("attempted to set private field on non-instance"); 41290 } 41291 privateMap.set(receiver, value); 41292 return value; 41293 } 41294 41295 // EXTERNAL MODULE: ./node_modules/normalize-wheel/index.js 41296 var normalize_wheel = __webpack_require__(7970); 41297 var normalize_wheel_default = /*#__PURE__*/__webpack_require__.n(normalize_wheel); 41298 ;// CONCATENATED MODULE: ./node_modules/react-easy-crop/index.module.js 41299 41300 41301 41302 41303 /** 41304 * Compute the dimension of the crop area based on media size, 41305 * aspect ratio and optionally rotation 41306 */ 41307 41308 function getCropSize(mediaWidth, mediaHeight, containerWidth, containerHeight, aspect, rotation) { 41309 if (rotation === void 0) { 41310 rotation = 0; 41311 } 41312 41313 var _a = translateSize(mediaWidth, mediaHeight, rotation), 41314 width = _a.width, 41315 height = _a.height; 41316 41317 var fittingWidth = Math.min(width, containerWidth); 41318 var fittingHeight = Math.min(height, containerHeight); 41319 41320 if (fittingWidth > fittingHeight * aspect) { 41321 return { 41322 width: fittingHeight * aspect, 41323 height: fittingHeight 41324 }; 41325 } 41326 41327 return { 41328 width: fittingWidth, 41329 height: fittingWidth / aspect 41330 }; 41331 } 41332 /** 41333 * Ensure a new media position stays in the crop area. 41334 */ 41335 41336 function restrictPosition(position, mediaSize, cropSize, zoom, rotation) { 41337 if (rotation === void 0) { 41338 rotation = 0; 41339 } 41340 41341 var _a = translateSize(mediaSize.width, mediaSize.height, rotation), 41342 width = _a.width, 41343 height = _a.height; 41344 41345 return { 41346 x: restrictPositionCoord(position.x, width, cropSize.width, zoom), 41347 y: restrictPositionCoord(position.y, height, cropSize.height, zoom) 41348 }; 41349 } 41350 41351 function restrictPositionCoord(position, mediaSize, cropSize, zoom) { 41352 var maxPosition = mediaSize * zoom / 2 - cropSize / 2; 41353 return Math.min(maxPosition, Math.max(position, -maxPosition)); 41354 } 41355 41356 function getDistanceBetweenPoints(pointA, pointB) { 41357 return Math.sqrt(Math.pow(pointA.y - pointB.y, 2) + Math.pow(pointA.x - pointB.x, 2)); 41358 } 41359 function getRotationBetweenPoints(pointA, pointB) { 41360 return Math.atan2(pointB.y - pointA.y, pointB.x - pointA.x) * 180 / Math.PI; 41361 } 41362 /** 41363 * Compute the output cropped area of the media in percentages and pixels. 41364 * x/y are the top-left coordinates on the src media 41365 */ 41366 41367 function computeCroppedArea(crop, mediaSize, cropSize, aspect, zoom, rotation, restrictPosition) { 41368 if (rotation === void 0) { 41369 rotation = 0; 41370 } 41371 41372 if (restrictPosition === void 0) { 41373 restrictPosition = true; 41374 } // if the media is rotated by the user, we cannot limit the position anymore 41375 // as it might need to be negative. 41376 41377 41378 var limitAreaFn = restrictPosition && rotation === 0 ? limitArea : noOp; 41379 var croppedAreaPercentages = { 41380 x: limitAreaFn(100, ((mediaSize.width - cropSize.width / zoom) / 2 - crop.x / zoom) / mediaSize.width * 100), 41381 y: limitAreaFn(100, ((mediaSize.height - cropSize.height / zoom) / 2 - crop.y / zoom) / mediaSize.height * 100), 41382 width: limitAreaFn(100, cropSize.width / mediaSize.width * 100 / zoom), 41383 height: limitAreaFn(100, cropSize.height / mediaSize.height * 100 / zoom) 41384 }; // we compute the pixels size naively 41385 41386 var widthInPixels = Math.round(limitAreaFn(mediaSize.naturalWidth, croppedAreaPercentages.width * mediaSize.naturalWidth / 100)); 41387 var heightInPixels = Math.round(limitAreaFn(mediaSize.naturalHeight, croppedAreaPercentages.height * mediaSize.naturalHeight / 100)); 41388 var isImgWiderThanHigh = mediaSize.naturalWidth >= mediaSize.naturalHeight * aspect; // then we ensure the width and height exactly match the aspect (to avoid rounding approximations) 41389 // if the media is wider than high, when zoom is 0, the crop height will be equals to iamge height 41390 // thus we want to compute the width from the height and aspect for accuracy. 41391 // Otherwise, we compute the height from width and aspect. 41392 41393 var sizePixels = isImgWiderThanHigh ? { 41394 width: Math.round(heightInPixels * aspect), 41395 height: heightInPixels 41396 } : { 41397 width: widthInPixels, 41398 height: Math.round(widthInPixels / aspect) 41399 }; 41400 41401 var croppedAreaPixels = __assign(__assign({}, sizePixels), { 41402 x: Math.round(limitAreaFn(mediaSize.naturalWidth - sizePixels.width, croppedAreaPercentages.x * mediaSize.naturalWidth / 100)), 41403 y: Math.round(limitAreaFn(mediaSize.naturalHeight - sizePixels.height, croppedAreaPercentages.y * mediaSize.naturalHeight / 100)) 41404 }); 41405 41406 return { 41407 croppedAreaPercentages: croppedAreaPercentages, 41408 croppedAreaPixels: croppedAreaPixels 41409 }; 41410 } 41411 /** 41412 * Ensure the returned value is between 0 and max 41413 */ 41414 41415 function limitArea(max, value) { 41416 return Math.min(max, Math.max(0, value)); 41417 } 41418 41419 function noOp(_max, value) { 41420 return value; 41421 } 41422 /** 41423 * Compute the crop and zoom from the croppedAreaPixels 41424 */ 41425 41426 41427 function getZoomFromCroppedAreaPixels(croppedAreaPixels, mediaSize, cropSize) { 41428 var mediaZoom = mediaSize.width / mediaSize.naturalWidth; 41429 41430 if (cropSize) { 41431 var isHeightMaxSize_1 = cropSize.height > cropSize.width; 41432 return isHeightMaxSize_1 ? cropSize.height / mediaZoom / croppedAreaPixels.height : cropSize.width / mediaZoom / croppedAreaPixels.width; 41433 } 41434 41435 var aspect = croppedAreaPixels.width / croppedAreaPixels.height; 41436 var isHeightMaxSize = mediaSize.naturalWidth >= mediaSize.naturalHeight * aspect; 41437 return isHeightMaxSize ? mediaSize.naturalHeight / croppedAreaPixels.height : mediaSize.naturalWidth / croppedAreaPixels.width; 41438 } 41439 /** 41440 * Compute the crop and zoom from the croppedAreaPixels 41441 */ 41442 41443 41444 function getInitialCropFromCroppedAreaPixels(croppedAreaPixels, mediaSize, cropSize) { 41445 var mediaZoom = mediaSize.width / mediaSize.naturalWidth; 41446 var zoom = getZoomFromCroppedAreaPixels(croppedAreaPixels, mediaSize, cropSize); 41447 var cropZoom = mediaZoom * zoom; 41448 var crop = { 41449 x: ((mediaSize.naturalWidth - croppedAreaPixels.width) / 2 - croppedAreaPixels.x) * cropZoom, 41450 y: ((mediaSize.naturalHeight - croppedAreaPixels.height) / 2 - croppedAreaPixels.y) * cropZoom 41451 }; 41452 return { 41453 crop: crop, 41454 zoom: zoom 41455 }; 41456 } 41457 /** 41458 * Return the point that is the center of point a and b 41459 */ 41460 41461 function getCenter(a, b) { 41462 return { 41463 x: (b.x + a.x) / 2, 41464 y: (b.y + a.y) / 2 41465 }; 41466 } 41467 /** 41468 * 41469 * Returns an x,y point once rotated around xMid,yMid 41470 */ 41471 41472 function rotateAroundMidPoint(x, y, xMid, yMid, degrees) { 41473 var cos = Math.cos; 41474 var sin = Math.sin; 41475 var radian = degrees * Math.PI / 180; // Convert to radians 41476 // Subtract midpoints, so that midpoint is translated to origin 41477 // and add it in the end again 41478 41479 var xr = (x - xMid) * cos(radian) - (y - yMid) * sin(radian) + xMid; 41480 var yr = (x - xMid) * sin(radian) + (y - yMid) * cos(radian) + yMid; 41481 return [xr, yr]; 41482 } 41483 /** 41484 * Returns the new bounding area of a rotated rectangle. 41485 */ 41486 41487 function translateSize(width, height, rotation) { 41488 var centerX = width / 2; 41489 var centerY = height / 2; 41490 var outerBounds = [rotateAroundMidPoint(0, 0, centerX, centerY, rotation), rotateAroundMidPoint(width, 0, centerX, centerY, rotation), rotateAroundMidPoint(width, height, centerX, centerY, rotation), rotateAroundMidPoint(0, height, centerX, centerY, rotation)]; 41491 var minX = Math.min.apply(Math, outerBounds.map(function (p) { 41492 return p[0]; 41493 })); 41494 var maxX = Math.max.apply(Math, outerBounds.map(function (p) { 41495 return p[0]; 41496 })); 41497 var minY = Math.min.apply(Math, outerBounds.map(function (p) { 41498 return p[1]; 41499 })); 41500 var maxY = Math.max.apply(Math, outerBounds.map(function (p) { 41501 return p[1]; 41502 })); 41503 return { 41504 width: maxX - minX, 41505 height: maxY - minY 41506 }; 41507 } 41508 /** 41509 * Combine multiple class names into a single string. 41510 */ 41511 41512 function classNames() { 41513 var args = []; 41514 41515 for (var _i = 0; _i < arguments.length; _i++) { 41516 args[_i] = arguments[_i]; 41517 } 41518 41519 return args.filter(function (value) { 41520 if (typeof value === 'string' && value.length > 0) { 41521 return true; 41522 } 41523 41524 return false; 41525 }).join(' ').trim(); 41526 } 41527 41528 var css_248z = ".reactEasyCrop_Container {\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n overflow: hidden;\n user-select: none;\n touch-action: none;\n cursor: move;\n display: flex;\n justify-content: center;\n align-items: center;\n}\n\n.reactEasyCrop_Image,\n.reactEasyCrop_Video {\n will-change: transform; /* this improves performances and prevent painting issues on iOS Chrome */\n}\n\n.reactEasyCrop_Contain {\n max-width: 100%;\n max-height: 100%;\n margin: auto;\n position: absolute;\n top: 0;\n bottom: 0;\n left: 0;\n right: 0;\n}\n.reactEasyCrop_Cover_Horizontal {\n width: 100%;\n height: auto;\n}\n.reactEasyCrop_Cover_Vertical {\n width: auto;\n height: 100%;\n}\n\n.reactEasyCrop_CropArea {\n position: absolute;\n left: 50%;\n top: 50%;\n transform: translate(-50%, -50%);\n border: 1px solid rgba(255, 255, 255, 0.5);\n box-sizing: border-box;\n box-shadow: 0 0 0 9999em;\n color: rgba(0, 0, 0, 0.5);\n overflow: hidden;\n}\n\n.reactEasyCrop_CropAreaRound {\n border-radius: 50%;\n}\n\n.reactEasyCrop_CropAreaGrid::before {\n content: ' ';\n box-sizing: border-box;\n position: absolute;\n border: 1px solid rgba(255, 255, 255, 0.5);\n top: 0;\n bottom: 0;\n left: 33.33%;\n right: 33.33%;\n border-top: 0;\n border-bottom: 0;\n}\n\n.reactEasyCrop_CropAreaGrid::after {\n content: ' ';\n box-sizing: border-box;\n position: absolute;\n border: 1px solid rgba(255, 255, 255, 0.5);\n top: 33.33%;\n bottom: 33.33%;\n left: 0;\n right: 0;\n border-left: 0;\n border-right: 0;\n}\n"; 41529 41530 var MIN_ZOOM = 1; 41531 var MAX_ZOOM = 3; 41532 41533 var Cropper = 41534 /** @class */ 41535 function (_super) { 41536 __extends(Cropper, _super); 41537 41538 function Cropper() { 41539 var _this = _super !== null && _super.apply(this, arguments) || this; 41540 41541 _this.imageRef = null; 41542 _this.videoRef = null; 41543 _this.containerRef = null; 41544 _this.styleRef = null; 41545 _this.containerRect = null; 41546 _this.mediaSize = { 41547 width: 0, 41548 height: 0, 41549 naturalWidth: 0, 41550 naturalHeight: 0 41551 }; 41552 _this.dragStartPosition = { 41553 x: 0, 41554 y: 0 41555 }; 41556 _this.dragStartCrop = { 41557 x: 0, 41558 y: 0 41559 }; 41560 _this.lastPinchDistance = 0; 41561 _this.lastPinchRotation = 0; 41562 _this.rafDragTimeout = null; 41563 _this.rafPinchTimeout = null; 41564 _this.wheelTimer = null; 41565 _this.state = { 41566 cropSize: null, 41567 hasWheelJustStarted: false 41568 }; // this is to prevent Safari on iOS >= 10 to zoom the page 41569 41570 _this.preventZoomSafari = function (e) { 41571 return e.preventDefault(); 41572 }; 41573 41574 _this.cleanEvents = function () { 41575 document.removeEventListener('mousemove', _this.onMouseMove); 41576 document.removeEventListener('mouseup', _this.onDragStopped); 41577 document.removeEventListener('touchmove', _this.onTouchMove); 41578 document.removeEventListener('touchend', _this.onDragStopped); 41579 }; 41580 41581 _this.clearScrollEvent = function () { 41582 if (_this.containerRef) _this.containerRef.removeEventListener('wheel', _this.onWheel); 41583 41584 if (_this.wheelTimer) { 41585 clearTimeout(_this.wheelTimer); 41586 } 41587 }; 41588 41589 _this.onMediaLoad = function () { 41590 _this.computeSizes(); 41591 41592 _this.emitCropData(); 41593 41594 _this.setInitialCrop(); 41595 41596 if (_this.props.onMediaLoaded) { 41597 _this.props.onMediaLoaded(_this.mediaSize); 41598 } 41599 }; 41600 41601 _this.setInitialCrop = function () { 41602 var _a = _this.props, 41603 initialCroppedAreaPixels = _a.initialCroppedAreaPixels, 41604 cropSize = _a.cropSize; 41605 41606 if (!initialCroppedAreaPixels) { 41607 return; 41608 } 41609 41610 var _b = getInitialCropFromCroppedAreaPixels(initialCroppedAreaPixels, _this.mediaSize, cropSize), 41611 crop = _b.crop, 41612 zoom = _b.zoom; 41613 41614 _this.props.onCropChange(crop); 41615 41616 _this.props.onZoomChange && _this.props.onZoomChange(zoom); 41617 }; 41618 41619 _this.computeSizes = function () { 41620 var _a, _b, _c, _d, _e, _f; 41621 41622 var mediaRef = _this.imageRef || _this.videoRef; 41623 41624 if (mediaRef && _this.containerRef) { 41625 _this.containerRect = _this.containerRef.getBoundingClientRect(); 41626 _this.mediaSize = { 41627 width: mediaRef.offsetWidth, 41628 height: mediaRef.offsetHeight, 41629 naturalWidth: ((_a = _this.imageRef) === null || _a === void 0 ? void 0 : _a.naturalWidth) || ((_b = _this.videoRef) === null || _b === void 0 ? void 0 : _b.videoWidth) || 0, 41630 naturalHeight: ((_c = _this.imageRef) === null || _c === void 0 ? void 0 : _c.naturalHeight) || ((_d = _this.videoRef) === null || _d === void 0 ? void 0 : _d.videoHeight) || 0 41631 }; 41632 var cropSize = _this.props.cropSize ? _this.props.cropSize : getCropSize(mediaRef.offsetWidth, mediaRef.offsetHeight, _this.containerRect.width, _this.containerRect.height, _this.props.aspect, _this.props.rotation); 41633 41634 if (((_e = _this.state.cropSize) === null || _e === void 0 ? void 0 : _e.height) !== cropSize.height || ((_f = _this.state.cropSize) === null || _f === void 0 ? void 0 : _f.width) !== cropSize.width) { 41635 _this.props.onCropSizeChange && _this.props.onCropSizeChange(cropSize); 41636 } 41637 41638 _this.setState({ 41639 cropSize: cropSize 41640 }, _this.recomputeCropPosition); 41641 } 41642 }; 41643 41644 _this.onMouseDown = function (e) { 41645 e.preventDefault(); 41646 document.addEventListener('mousemove', _this.onMouseMove); 41647 document.addEventListener('mouseup', _this.onDragStopped); 41648 41649 _this.onDragStart(Cropper.getMousePoint(e)); 41650 }; 41651 41652 _this.onMouseMove = function (e) { 41653 return _this.onDrag(Cropper.getMousePoint(e)); 41654 }; 41655 41656 _this.onTouchStart = function (e) { 41657 document.addEventListener('touchmove', _this.onTouchMove, { 41658 passive: false 41659 }); // iOS 11 now defaults to passive: true 41660 41661 document.addEventListener('touchend', _this.onDragStopped); 41662 41663 if (e.touches.length === 2) { 41664 _this.onPinchStart(e); 41665 } else if (e.touches.length === 1) { 41666 _this.onDragStart(Cropper.getTouchPoint(e.touches[0])); 41667 } 41668 }; 41669 41670 _this.onTouchMove = function (e) { 41671 // Prevent whole page from scrolling on iOS. 41672 e.preventDefault(); 41673 41674 if (e.touches.length === 2) { 41675 _this.onPinchMove(e); 41676 } else if (e.touches.length === 1) { 41677 _this.onDrag(Cropper.getTouchPoint(e.touches[0])); 41678 } 41679 }; 41680 41681 _this.onDragStart = function (_a) { 41682 var _b, _c; 41683 41684 var x = _a.x, 41685 y = _a.y; 41686 _this.dragStartPosition = { 41687 x: x, 41688 y: y 41689 }; 41690 _this.dragStartCrop = __assign({}, _this.props.crop); 41691 (_c = (_b = _this.props).onInteractionStart) === null || _c === void 0 ? void 0 : _c.call(_b); 41692 }; 41693 41694 _this.onDrag = function (_a) { 41695 var x = _a.x, 41696 y = _a.y; 41697 if (_this.rafDragTimeout) window.cancelAnimationFrame(_this.rafDragTimeout); 41698 _this.rafDragTimeout = window.requestAnimationFrame(function () { 41699 if (!_this.state.cropSize) return; 41700 if (x === undefined || y === undefined) return; 41701 var offsetX = x - _this.dragStartPosition.x; 41702 var offsetY = y - _this.dragStartPosition.y; 41703 var requestedPosition = { 41704 x: _this.dragStartCrop.x + offsetX, 41705 y: _this.dragStartCrop.y + offsetY 41706 }; 41707 var newPosition = _this.props.restrictPosition ? restrictPosition(requestedPosition, _this.mediaSize, _this.state.cropSize, _this.props.zoom, _this.props.rotation) : requestedPosition; 41708 41709 _this.props.onCropChange(newPosition); 41710 }); 41711 }; 41712 41713 _this.onDragStopped = function () { 41714 var _a, _b; 41715 41716 _this.cleanEvents(); 41717 41718 _this.emitCropData(); 41719 41720 (_b = (_a = _this.props).onInteractionEnd) === null || _b === void 0 ? void 0 : _b.call(_a); 41721 }; 41722 41723 _this.onWheel = function (e) { 41724 e.preventDefault(); 41725 var point = Cropper.getMousePoint(e); 41726 var pixelY = normalize_wheel_default()(e).pixelY; 41727 var newZoom = _this.props.zoom - pixelY * _this.props.zoomSpeed / 200; 41728 41729 _this.setNewZoom(newZoom, point); 41730 41731 if (!_this.state.hasWheelJustStarted) { 41732 _this.setState({ 41733 hasWheelJustStarted: true 41734 }, function () { 41735 var _a, _b; 41736 41737 return (_b = (_a = _this.props).onInteractionStart) === null || _b === void 0 ? void 0 : _b.call(_a); 41738 }); 41739 } 41740 41741 if (_this.wheelTimer) { 41742 clearTimeout(_this.wheelTimer); 41743 } 41744 41745 _this.wheelTimer = window.setTimeout(function () { 41746 return _this.setState({ 41747 hasWheelJustStarted: false 41748 }, function () { 41749 var _a, _b; 41750 41751 return (_b = (_a = _this.props).onInteractionEnd) === null || _b === void 0 ? void 0 : _b.call(_a); 41752 }); 41753 }, 250); 41754 }; 41755 41756 _this.getPointOnContainer = function (_a) { 41757 var x = _a.x, 41758 y = _a.y; 41759 41760 if (!_this.containerRect) { 41761 throw new Error('The Cropper is not mounted'); 41762 } 41763 41764 return { 41765 x: _this.containerRect.width / 2 - (x - _this.containerRect.left), 41766 y: _this.containerRect.height / 2 - (y - _this.containerRect.top) 41767 }; 41768 }; 41769 41770 _this.getPointOnMedia = function (_a) { 41771 var x = _a.x, 41772 y = _a.y; 41773 var _b = _this.props, 41774 crop = _b.crop, 41775 zoom = _b.zoom; 41776 return { 41777 x: (x + crop.x) / zoom, 41778 y: (y + crop.y) / zoom 41779 }; 41780 }; 41781 41782 _this.setNewZoom = function (zoom, point) { 41783 if (!_this.state.cropSize || !_this.props.onZoomChange) return; 41784 41785 var zoomPoint = _this.getPointOnContainer(point); 41786 41787 var zoomTarget = _this.getPointOnMedia(zoomPoint); 41788 41789 var newZoom = Math.min(_this.props.maxZoom, Math.max(zoom, _this.props.minZoom)); 41790 var requestedPosition = { 41791 x: zoomTarget.x * newZoom - zoomPoint.x, 41792 y: zoomTarget.y * newZoom - zoomPoint.y 41793 }; 41794 var newPosition = _this.props.restrictPosition ? restrictPosition(requestedPosition, _this.mediaSize, _this.state.cropSize, newZoom, _this.props.rotation) : requestedPosition; 41795 41796 _this.props.onCropChange(newPosition); 41797 41798 _this.props.onZoomChange(newZoom); 41799 }; 41800 41801 _this.getCropData = function () { 41802 if (!_this.state.cropSize) { 41803 return null; 41804 } // this is to ensure the crop is correctly restricted after a zoom back (https://github.com/ricardo-ch/react-easy-crop/issues/6) 41805 41806 41807 var restrictedPosition = _this.props.restrictPosition ? restrictPosition(_this.props.crop, _this.mediaSize, _this.state.cropSize, _this.props.zoom, _this.props.rotation) : _this.props.crop; 41808 return computeCroppedArea(restrictedPosition, _this.mediaSize, _this.state.cropSize, _this.getAspect(), _this.props.zoom, _this.props.rotation, _this.props.restrictPosition); 41809 }; 41810 41811 _this.emitCropData = function () { 41812 var cropData = _this.getCropData(); 41813 41814 if (!cropData) return; 41815 var croppedAreaPercentages = cropData.croppedAreaPercentages, 41816 croppedAreaPixels = cropData.croppedAreaPixels; 41817 41818 if (_this.props.onCropComplete) { 41819 _this.props.onCropComplete(croppedAreaPercentages, croppedAreaPixels); 41820 } 41821 41822 if (_this.props.onCropAreaChange) { 41823 _this.props.onCropAreaChange(croppedAreaPercentages, croppedAreaPixels); 41824 } 41825 }; 41826 41827 _this.emitCropAreaChange = function () { 41828 var cropData = _this.getCropData(); 41829 41830 if (!cropData) return; 41831 var croppedAreaPercentages = cropData.croppedAreaPercentages, 41832 croppedAreaPixels = cropData.croppedAreaPixels; 41833 41834 if (_this.props.onCropAreaChange) { 41835 _this.props.onCropAreaChange(croppedAreaPercentages, croppedAreaPixels); 41836 } 41837 }; 41838 41839 _this.recomputeCropPosition = function () { 41840 if (!_this.state.cropSize) return; 41841 var newPosition = _this.props.restrictPosition ? restrictPosition(_this.props.crop, _this.mediaSize, _this.state.cropSize, _this.props.zoom, _this.props.rotation) : _this.props.crop; 41842 41843 _this.props.onCropChange(newPosition); 41844 41845 _this.emitCropData(); 41846 }; 41847 41848 return _this; 41849 } 41850 41851 Cropper.prototype.componentDidMount = function () { 41852 window.addEventListener('resize', this.computeSizes); 41853 41854 if (this.containerRef) { 41855 this.props.zoomWithScroll && this.containerRef.addEventListener('wheel', this.onWheel, { 41856 passive: false 41857 }); 41858 this.containerRef.addEventListener('gesturestart', this.preventZoomSafari); 41859 this.containerRef.addEventListener('gesturechange', this.preventZoomSafari); 41860 } 41861 41862 if (!this.props.disableAutomaticStylesInjection) { 41863 this.styleRef = document.createElement('style'); 41864 this.styleRef.setAttribute('type', 'text/css'); 41865 this.styleRef.innerHTML = css_248z; 41866 document.head.appendChild(this.styleRef); 41867 } // when rendered via SSR, the image can already be loaded and its onLoad callback will never be called 41868 41869 41870 if (this.imageRef && this.imageRef.complete) { 41871 this.onMediaLoad(); 41872 } 41873 }; 41874 41875 Cropper.prototype.componentWillUnmount = function () { 41876 var _a; 41877 41878 window.removeEventListener('resize', this.computeSizes); 41879 41880 if (this.containerRef) { 41881 this.containerRef.removeEventListener('gesturestart', this.preventZoomSafari); 41882 this.containerRef.removeEventListener('gesturechange', this.preventZoomSafari); 41883 } 41884 41885 if (this.styleRef) { 41886 (_a = this.styleRef.parentNode) === null || _a === void 0 ? void 0 : _a.removeChild(this.styleRef); 41887 } 41888 41889 this.cleanEvents(); 41890 this.props.zoomWithScroll && this.clearScrollEvent(); 41891 }; 41892 41893 Cropper.prototype.componentDidUpdate = function (prevProps) { 41894 var _a, _b, _c, _d, _e, _f, _g, _h, _j; 41895 41896 if (prevProps.rotation !== this.props.rotation) { 41897 this.computeSizes(); 41898 this.recomputeCropPosition(); 41899 } else if (prevProps.aspect !== this.props.aspect) { 41900 this.computeSizes(); 41901 } else if (prevProps.zoom !== this.props.zoom) { 41902 this.recomputeCropPosition(); 41903 } else if (((_a = prevProps.cropSize) === null || _a === void 0 ? void 0 : _a.height) !== ((_b = this.props.cropSize) === null || _b === void 0 ? void 0 : _b.height) || ((_c = prevProps.cropSize) === null || _c === void 0 ? void 0 : _c.width) !== ((_d = this.props.cropSize) === null || _d === void 0 ? void 0 : _d.width)) { 41904 this.computeSizes(); 41905 } else if (((_e = prevProps.crop) === null || _e === void 0 ? void 0 : _e.x) !== ((_f = this.props.crop) === null || _f === void 0 ? void 0 : _f.x) || ((_g = prevProps.crop) === null || _g === void 0 ? void 0 : _g.y) !== ((_h = this.props.crop) === null || _h === void 0 ? void 0 : _h.y)) { 41906 this.emitCropAreaChange(); 41907 } 41908 41909 if (prevProps.zoomWithScroll !== this.props.zoomWithScroll && this.containerRef) { 41910 this.props.zoomWithScroll ? this.containerRef.addEventListener('wheel', this.onWheel, { 41911 passive: false 41912 }) : this.clearScrollEvent(); 41913 } 41914 41915 if (prevProps.video !== this.props.video) { 41916 (_j = this.videoRef) === null || _j === void 0 ? void 0 : _j.load(); 41917 } 41918 }; 41919 41920 Cropper.prototype.getAspect = function () { 41921 var _a = this.props, 41922 cropSize = _a.cropSize, 41923 aspect = _a.aspect; 41924 41925 if (cropSize) { 41926 return cropSize.width / cropSize.height; 41927 } 41928 41929 return aspect; 41930 }; 41931 41932 Cropper.prototype.onPinchStart = function (e) { 41933 var pointA = Cropper.getTouchPoint(e.touches[0]); 41934 var pointB = Cropper.getTouchPoint(e.touches[1]); 41935 this.lastPinchDistance = getDistanceBetweenPoints(pointA, pointB); 41936 this.lastPinchRotation = getRotationBetweenPoints(pointA, pointB); 41937 this.onDragStart(getCenter(pointA, pointB)); 41938 }; 41939 41940 Cropper.prototype.onPinchMove = function (e) { 41941 var _this = this; 41942 41943 var pointA = Cropper.getTouchPoint(e.touches[0]); 41944 var pointB = Cropper.getTouchPoint(e.touches[1]); 41945 var center = getCenter(pointA, pointB); 41946 this.onDrag(center); 41947 if (this.rafPinchTimeout) window.cancelAnimationFrame(this.rafPinchTimeout); 41948 this.rafPinchTimeout = window.requestAnimationFrame(function () { 41949 var distance = getDistanceBetweenPoints(pointA, pointB); 41950 var newZoom = _this.props.zoom * (distance / _this.lastPinchDistance); 41951 41952 _this.setNewZoom(newZoom, center); 41953 41954 _this.lastPinchDistance = distance; 41955 var rotation = getRotationBetweenPoints(pointA, pointB); 41956 var newRotation = _this.props.rotation + (rotation - _this.lastPinchRotation); 41957 _this.props.onRotationChange && _this.props.onRotationChange(newRotation); 41958 _this.lastPinchRotation = rotation; 41959 }); 41960 }; 41961 41962 Cropper.prototype.render = function () { 41963 var _this = this; 41964 41965 var _a = this.props, 41966 image = _a.image, 41967 video = _a.video, 41968 mediaProps = _a.mediaProps, 41969 transform = _a.transform, 41970 _b = _a.crop, 41971 x = _b.x, 41972 y = _b.y, 41973 rotation = _a.rotation, 41974 zoom = _a.zoom, 41975 cropShape = _a.cropShape, 41976 showGrid = _a.showGrid, 41977 _c = _a.style, 41978 containerStyle = _c.containerStyle, 41979 cropAreaStyle = _c.cropAreaStyle, 41980 mediaStyle = _c.mediaStyle, 41981 _d = _a.classes, 41982 containerClassName = _d.containerClassName, 41983 cropAreaClassName = _d.cropAreaClassName, 41984 mediaClassName = _d.mediaClassName, 41985 objectFit = _a.objectFit; 41986 return /*#__PURE__*/external_React_default().createElement("div", { 41987 onMouseDown: this.onMouseDown, 41988 onTouchStart: this.onTouchStart, 41989 ref: function ref(el) { 41990 return _this.containerRef = el; 41991 }, 41992 "data-testid": "container", 41993 style: containerStyle, 41994 className: classNames('reactEasyCrop_Container', containerClassName) 41995 }, image ? /*#__PURE__*/external_React_default().createElement("img", __assign({ 41996 alt: "", 41997 className: classNames('reactEasyCrop_Image', objectFit === 'contain' && 'reactEasyCrop_Contain', objectFit === 'horizontal-cover' && 'reactEasyCrop_Cover_Horizontal', objectFit === 'vertical-cover' && 'reactEasyCrop_Cover_Vertical', mediaClassName) 41998 }, mediaProps, { 41999 src: image, 42000 ref: function ref(el) { 42001 return _this.imageRef = el; 42002 }, 42003 style: __assign(__assign({}, mediaStyle), { 42004 transform: transform || "translate(" + x + "px, " + y + "px) rotate(" + rotation + "deg) scale(" + zoom + ")" 42005 }), 42006 onLoad: this.onMediaLoad 42007 })) : video && /*#__PURE__*/external_React_default().createElement("video", __assign({ 42008 autoPlay: true, 42009 loop: true, 42010 muted: true, 42011 className: classNames('reactEasyCrop_Video', objectFit === 'contain' && 'reactEasyCrop_Contain', objectFit === 'horizontal-cover' && 'reactEasyCrop_Cover_Horizontal', objectFit === 'vertical-cover' && 'reactEasyCrop_Cover_Vertical', mediaClassName) 42012 }, mediaProps, { 42013 ref: function ref(el) { 42014 return _this.videoRef = el; 42015 }, 42016 onLoadedMetadata: this.onMediaLoad, 42017 style: __assign(__assign({}, mediaStyle), { 42018 transform: transform || "translate(" + x + "px, " + y + "px) rotate(" + rotation + "deg) scale(" + zoom + ")" 42019 }), 42020 controls: false 42021 }), (Array.isArray(video) ? video : [{ 42022 src: video 42023 }]).map(function (item) { 42024 return /*#__PURE__*/external_React_default().createElement("source", __assign({ 42025 key: item.src 42026 }, item)); 42027 })), this.state.cropSize && /*#__PURE__*/external_React_default().createElement("div", { 42028 style: __assign(__assign({}, cropAreaStyle), { 42029 width: this.state.cropSize.width, 42030 height: this.state.cropSize.height 42031 }), 42032 "data-testid": "cropper", 42033 className: classNames('reactEasyCrop_CropArea', cropShape === 'round' && 'reactEasyCrop_CropAreaRound', showGrid && 'reactEasyCrop_CropAreaGrid', cropAreaClassName) 42034 })); 42035 }; 42036 42037 Cropper.defaultProps = { 42038 zoom: 1, 42039 rotation: 0, 42040 aspect: 4 / 3, 42041 maxZoom: MAX_ZOOM, 42042 minZoom: MIN_ZOOM, 42043 cropShape: 'rect', 42044 objectFit: 'contain', 42045 showGrid: true, 42046 style: {}, 42047 classes: {}, 42048 mediaProps: {}, 42049 zoomSpeed: 1, 42050 restrictPosition: true, 42051 zoomWithScroll: true 42052 }; 42053 42054 Cropper.getMousePoint = function (e) { 42055 return { 42056 x: Number(e.clientX), 42057 y: Number(e.clientY) 42058 }; 42059 }; 42060 42061 Cropper.getTouchPoint = function (touch) { 42062 return { 42063 x: Number(touch.clientX), 42064 y: Number(touch.clientY) 42065 }; 42066 }; 42067 42068 return Cropper; 42069 }((external_React_default()).Component); 42070 42071 /* harmony default export */ var index_module = (Cropper); 42072 42073 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/image-editor/constants.js 42074 const constants_MIN_ZOOM = 100; 42075 const constants_MAX_ZOOM = 300; 42076 const constants_POPOVER_PROPS = { 42077 position: 'bottom right', 42078 isAlternate: true 42079 }; 42080 42081 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/image-editor/use-save-image.js 42082 /** 42083 * WordPress dependencies 42084 */ 42085 42086 42087 42088 42089 42090 function useSaveImage(_ref) { 42091 let { 42092 crop, 42093 rotation, 42094 height, 42095 width, 42096 aspect, 42097 url, 42098 id, 42099 onSaveImage, 42100 onFinishEditing 42101 } = _ref; 42102 const { 42103 createErrorNotice 42104 } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_notices_namespaceObject.store); 42105 const [isInProgress, setIsInProgress] = (0,external_wp_element_namespaceObject.useState)(false); 42106 const cancel = (0,external_wp_element_namespaceObject.useCallback)(() => { 42107 setIsInProgress(false); 42108 onFinishEditing(); 42109 }, [setIsInProgress, onFinishEditing]); 42110 const apply = (0,external_wp_element_namespaceObject.useCallback)(() => { 42111 setIsInProgress(true); 42112 let attrs = {}; // The crop script may return some very small, sub-pixel values when the image was not cropped. 42113 // Crop only when the new size has changed by more than 0.1%. 42114 42115 if (crop.width < 99.9 || crop.height < 99.9) { 42116 attrs = crop; 42117 } 42118 42119 if (rotation > 0) { 42120 attrs.rotation = rotation; 42121 } 42122 42123 attrs.src = url; 42124 external_wp_apiFetch_default()({ 42125 path: `/wp/v2/media/$id}/edit`, 42126 method: 'POST', 42127 data: attrs 42128 }).then(response => { 42129 onSaveImage({ 42130 id: response.id, 42131 url: response.source_url, 42132 height: height && width ? width / aspect : undefined 42133 }); 42134 }).catch(error => { 42135 createErrorNotice((0,external_wp_i18n_namespaceObject.sprintf)( 42136 /* translators: 1. Error message */ 42137 (0,external_wp_i18n_namespaceObject.__)('Could not edit image. %s'), error.message), { 42138 id: 'image-editing-error', 42139 type: 'snackbar' 42140 }); 42141 }).finally(() => { 42142 setIsInProgress(false); 42143 onFinishEditing(); 42144 }); 42145 }, [setIsInProgress, crop, rotation, height, width, aspect, url, onSaveImage, createErrorNotice, setIsInProgress, onFinishEditing]); 42146 return (0,external_wp_element_namespaceObject.useMemo)(() => ({ 42147 isInProgress, 42148 apply, 42149 cancel 42150 }), [isInProgress, apply, cancel]); 42151 } 42152 42153 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/image-editor/use-transform-image.js 42154 /** 42155 * WordPress dependencies 42156 */ 42157 42158 42159 42160 function useTransformState(_ref) { 42161 let { 42162 url, 42163 naturalWidth, 42164 naturalHeight 42165 } = _ref; 42166 const [editedUrl, setEditedUrl] = (0,external_wp_element_namespaceObject.useState)(); 42167 const [crop, setCrop] = (0,external_wp_element_namespaceObject.useState)(); 42168 const [position, setPosition] = (0,external_wp_element_namespaceObject.useState)({ 42169 x: 0, 42170 y: 0 42171 }); 42172 const [zoom, setZoom] = (0,external_wp_element_namespaceObject.useState)(); 42173 const [rotation, setRotation] = (0,external_wp_element_namespaceObject.useState)(); 42174 const [aspect, setAspect] = (0,external_wp_element_namespaceObject.useState)(); 42175 const [defaultAspect, setDefaultAspect] = (0,external_wp_element_namespaceObject.useState)(); 42176 const initializeTransformValues = (0,external_wp_element_namespaceObject.useCallback)(() => { 42177 setPosition({ 42178 x: 0, 42179 y: 0 42180 }); 42181 setZoom(100); 42182 setRotation(0); 42183 setAspect(naturalWidth / naturalHeight); 42184 setDefaultAspect(naturalWidth / naturalHeight); 42185 }, [naturalWidth, naturalHeight, setPosition, setZoom, setRotation, setAspect, setDefaultAspect]); 42186 const rotateClockwise = (0,external_wp_element_namespaceObject.useCallback)(() => { 42187 const angle = (rotation + 90) % 360; 42188 let naturalAspectRatio = naturalWidth / naturalHeight; 42189 42190 if (rotation % 180 === 90) { 42191 naturalAspectRatio = naturalHeight / naturalWidth; 42192 } 42193 42194 if (angle === 0) { 42195 setEditedUrl(); 42196 setRotation(angle); 42197 setAspect(1 / aspect); 42198 setPosition({ 42199 x: -(position.y * naturalAspectRatio), 42200 y: position.x * naturalAspectRatio 42201 }); 42202 return; 42203 } 42204 42205 function editImage(event) { 42206 const canvas = document.createElement('canvas'); 42207 let translateX = 0; 42208 let translateY = 0; 42209 42210 if (angle % 180) { 42211 canvas.width = event.target.height; 42212 canvas.height = event.target.width; 42213 } else { 42214 canvas.width = event.target.width; 42215 canvas.height = event.target.height; 42216 } 42217 42218 if (angle === 90 || angle === 180) { 42219 translateX = canvas.width; 42220 } 42221 42222 if (angle === 270 || angle === 180) { 42223 translateY = canvas.height; 42224 } 42225 42226 const context = canvas.getContext('2d'); 42227 context.translate(translateX, translateY); 42228 context.rotate(angle * Math.PI / 180); 42229 context.drawImage(event.target, 0, 0); 42230 canvas.toBlob(blob => { 42231 setEditedUrl(URL.createObjectURL(blob)); 42232 setRotation(angle); 42233 setAspect(1 / aspect); 42234 setPosition({ 42235 x: -(position.y * naturalAspectRatio), 42236 y: position.x * naturalAspectRatio 42237 }); 42238 }); 42239 } 42240 42241 const el = new window.Image(); 42242 el.src = url; 42243 el.onload = editImage; 42244 const imgCrossOrigin = (0,external_wp_hooks_namespaceObject.applyFilters)('media.crossOrigin', undefined, url); 42245 42246 if (typeof imgCrossOrigin === 'string') { 42247 el.crossOrigin = imgCrossOrigin; 42248 } 42249 }, [rotation, naturalWidth, naturalHeight, setEditedUrl, setRotation, setAspect, setPosition]); 42250 return (0,external_wp_element_namespaceObject.useMemo)(() => ({ 42251 editedUrl, 42252 setEditedUrl, 42253 crop, 42254 setCrop, 42255 position, 42256 setPosition, 42257 zoom, 42258 setZoom, 42259 rotation, 42260 setRotation, 42261 rotateClockwise, 42262 aspect, 42263 setAspect, 42264 defaultAspect, 42265 initializeTransformValues 42266 }), [editedUrl, setEditedUrl, crop, setCrop, position, setPosition, zoom, setZoom, rotation, setRotation, rotateClockwise, aspect, setAspect, defaultAspect, initializeTransformValues]); 42267 } 42268 42269 function useTransformImage(imageProperties, isEditing) { 42270 const transformState = useTransformState(imageProperties); 42271 const { 42272 initializeTransformValues 42273 } = transformState; 42274 (0,external_wp_element_namespaceObject.useEffect)(() => { 42275 if (isEditing) { 42276 initializeTransformValues(); 42277 } 42278 }, [isEditing, initializeTransformValues]); 42279 return transformState; 42280 } 42281 42282 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/image-editor/context.js 42283 42284 42285 /** 42286 * WordPress dependencies 42287 */ 42288 42289 /** 42290 * Internal dependencies 42291 */ 42292 42293 42294 42295 const ImageEditingContext = (0,external_wp_element_namespaceObject.createContext)({}); 42296 const useImageEditingContext = () => (0,external_wp_element_namespaceObject.useContext)(ImageEditingContext); 42297 function ImageEditingProvider(_ref) { 42298 let { 42299 id, 42300 url, 42301 naturalWidth, 42302 naturalHeight, 42303 isEditing, 42304 onFinishEditing, 42305 onSaveImage, 42306 children 42307 } = _ref; 42308 const transformImage = useTransformImage({ 42309 url, 42310 naturalWidth, 42311 naturalHeight 42312 }, isEditing); 42313 const saveImage = useSaveImage({ 42314 id, 42315 url, 42316 onSaveImage, 42317 onFinishEditing, 42318 ...transformImage 42319 }); 42320 const providerValue = (0,external_wp_element_namespaceObject.useMemo)(() => ({ ...transformImage, 42321 ...saveImage 42322 }), [transformImage, saveImage]); 42323 return (0,external_wp_element_namespaceObject.createElement)(ImageEditingContext.Provider, { 42324 value: providerValue 42325 }, children); 42326 } 42327 42328 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/image-editor/cropper.js 42329 42330 42331 /** 42332 * External dependencies 42333 */ 42334 42335 42336 /** 42337 * WordPress dependencies 42338 */ 42339 42340 42341 /** 42342 * Internal dependencies 42343 */ 42344 42345 42346 42347 function ImageCropper(_ref) { 42348 let { 42349 url, 42350 width, 42351 height, 42352 clientWidth, 42353 naturalHeight, 42354 naturalWidth 42355 } = _ref; 42356 const { 42357 isInProgress, 42358 editedUrl, 42359 position, 42360 zoom, 42361 aspect, 42362 setPosition, 42363 setCrop, 42364 setZoom, 42365 rotation 42366 } = useImageEditingContext(); 42367 let editedHeight = height || clientWidth * naturalHeight / naturalWidth; 42368 42369 if (rotation % 180 === 90) { 42370 editedHeight = clientWidth * naturalWidth / naturalHeight; 42371 } 42372 42373 return (0,external_wp_element_namespaceObject.createElement)("div", { 42374 className: classnames_default()('wp-block-image__crop-area', { 42375 'is-applying': isInProgress 42376 }), 42377 style: { 42378 width: width || clientWidth, 42379 height: editedHeight 42380 } 42381 }, (0,external_wp_element_namespaceObject.createElement)(index_module, { 42382 image: editedUrl || url, 42383 disabled: isInProgress, 42384 minZoom: constants_MIN_ZOOM / 100, 42385 maxZoom: constants_MAX_ZOOM / 100, 42386 crop: position, 42387 zoom: zoom / 100, 42388 aspect: aspect, 42389 onCropChange: setPosition, 42390 onCropComplete: newCropPercent => { 42391 setCrop(newCropPercent); 42392 }, 42393 onZoomChange: newZoom => { 42394 setZoom(newZoom * 100); 42395 } 42396 }), isInProgress && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Spinner, null)); 42397 } 42398 42399 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/search.js 42400 42401 42402 /** 42403 * WordPress dependencies 42404 */ 42405 42406 const search = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 42407 xmlns: "http://www.w3.org/2000/svg", 42408 viewBox: "0 0 24 24" 42409 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 42410 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" 42411 })); 42412 /* harmony default export */ var library_search = (search); 42413 42414 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/image-editor/zoom-dropdown.js 42415 42416 42417 /** 42418 * WordPress dependencies 42419 */ 42420 42421 42422 42423 /** 42424 * Internal dependencies 42425 */ 42426 42427 42428 42429 function ZoomDropdown() { 42430 const { 42431 isInProgress, 42432 zoom, 42433 setZoom 42434 } = useImageEditingContext(); 42435 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Dropdown, { 42436 contentClassName: "wp-block-image__zoom", 42437 popoverProps: constants_POPOVER_PROPS, 42438 renderToggle: _ref => { 42439 let { 42440 isOpen, 42441 onToggle 42442 } = _ref; 42443 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, { 42444 icon: library_search, 42445 label: (0,external_wp_i18n_namespaceObject.__)('Zoom'), 42446 onClick: onToggle, 42447 "aria-expanded": isOpen, 42448 disabled: isInProgress 42449 }); 42450 }, 42451 renderContent: () => (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.RangeControl, { 42452 label: (0,external_wp_i18n_namespaceObject.__)('Zoom'), 42453 min: constants_MIN_ZOOM, 42454 max: constants_MAX_ZOOM, 42455 value: Math.round(zoom), 42456 onChange: setZoom 42457 }) 42458 }); 42459 } 42460 42461 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/aspect-ratio.js 42462 42463 42464 /** 42465 * WordPress dependencies 42466 */ 42467 42468 const aspectRatio = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 42469 xmlns: "http://www.w3.org/2000/svg", 42470 viewBox: "0 0 24 24" 42471 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 42472 d: "M18.5 5.5h-13c-1.1 0-2 .9-2 2v9c0 1.1.9 2 2 2h13c1.1 0 2-.9 2-2v-9c0-1.1-.9-2-2-2zm.5 11c0 .3-.2.5-.5.5h-13c-.3 0-.5-.2-.5-.5v-9c0-.3.2-.5.5-.5h13c.3 0 .5.2.5.5v9zM6.5 12H8v-2h2V8.5H6.5V12zm9.5 2h-2v1.5h3.5V12H16v2z" 42473 })); 42474 /* harmony default export */ var aspect_ratio = (aspectRatio); 42475 42476 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/image-editor/aspect-ratio-dropdown.js 42477 42478 42479 /** 42480 * WordPress dependencies 42481 */ 42482 42483 42484 42485 /** 42486 * Internal dependencies 42487 */ 42488 42489 42490 42491 42492 function AspectGroup(_ref) { 42493 let { 42494 aspectRatios, 42495 isDisabled, 42496 label, 42497 onClick, 42498 value 42499 } = _ref; 42500 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuGroup, { 42501 label: label 42502 }, aspectRatios.map(_ref2 => { 42503 let { 42504 title, 42505 aspect 42506 } = _ref2; 42507 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, { 42508 key: aspect, 42509 disabled: isDisabled, 42510 onClick: () => { 42511 onClick(aspect); 42512 }, 42513 role: "menuitemradio", 42514 isSelected: aspect === value, 42515 icon: aspect === value ? library_check : undefined 42516 }, title); 42517 })); 42518 } 42519 42520 function AspectRatioDropdown(_ref3) { 42521 let { 42522 toggleProps 42523 } = _ref3; 42524 const { 42525 isInProgress, 42526 aspect, 42527 setAspect, 42528 defaultAspect 42529 } = useImageEditingContext(); 42530 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.DropdownMenu, { 42531 icon: aspect_ratio, 42532 label: (0,external_wp_i18n_namespaceObject.__)('Aspect Ratio'), 42533 popoverProps: constants_POPOVER_PROPS, 42534 toggleProps: toggleProps, 42535 className: "wp-block-image__aspect-ratio" 42536 }, _ref4 => { 42537 let { 42538 onClose 42539 } = _ref4; 42540 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(AspectGroup, { 42541 isDisabled: isInProgress, 42542 onClick: newAspect => { 42543 setAspect(newAspect); 42544 onClose(); 42545 }, 42546 value: aspect, 42547 aspectRatios: [{ 42548 title: (0,external_wp_i18n_namespaceObject.__)('Original'), 42549 aspect: defaultAspect 42550 }, { 42551 title: (0,external_wp_i18n_namespaceObject.__)('Square'), 42552 aspect: 1 42553 }] 42554 }), (0,external_wp_element_namespaceObject.createElement)(AspectGroup, { 42555 label: (0,external_wp_i18n_namespaceObject.__)('Landscape'), 42556 isDisabled: isInProgress, 42557 onClick: newAspect => { 42558 setAspect(newAspect); 42559 onClose(); 42560 }, 42561 value: aspect, 42562 aspectRatios: [{ 42563 title: (0,external_wp_i18n_namespaceObject.__)('16:10'), 42564 aspect: 16 / 10 42565 }, { 42566 title: (0,external_wp_i18n_namespaceObject.__)('16:9'), 42567 aspect: 16 / 9 42568 }, { 42569 title: (0,external_wp_i18n_namespaceObject.__)('4:3'), 42570 aspect: 4 / 3 42571 }, { 42572 title: (0,external_wp_i18n_namespaceObject.__)('3:2'), 42573 aspect: 3 / 2 42574 }] 42575 }), (0,external_wp_element_namespaceObject.createElement)(AspectGroup, { 42576 label: (0,external_wp_i18n_namespaceObject.__)('Portrait'), 42577 isDisabled: isInProgress, 42578 onClick: newAspect => { 42579 setAspect(newAspect); 42580 onClose(); 42581 }, 42582 value: aspect, 42583 aspectRatios: [{ 42584 title: (0,external_wp_i18n_namespaceObject.__)('10:16'), 42585 aspect: 10 / 16 42586 }, { 42587 title: (0,external_wp_i18n_namespaceObject.__)('9:16'), 42588 aspect: 9 / 16 42589 }, { 42590 title: (0,external_wp_i18n_namespaceObject.__)('3:4'), 42591 aspect: 3 / 4 42592 }, { 42593 title: (0,external_wp_i18n_namespaceObject.__)('2:3'), 42594 aspect: 2 / 3 42595 }] 42596 })); 42597 }); 42598 } 42599 42600 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/rotate-right.js 42601 42602 42603 /** 42604 * WordPress dependencies 42605 */ 42606 42607 const rotateRight = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 42608 xmlns: "http://www.w3.org/2000/svg", 42609 viewBox: "0 0 24 24" 42610 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 42611 d: "M15.1 4.8l-3-2.5V4c-4.4 0-8 3.6-8 8 0 3.7 2.5 6.9 6 7.7.3.1.6.1 1 .2l.2-1.5c-.4 0-.7-.1-1.1-.2l-.1.2v-.2c-2.6-.8-4.5-3.3-4.5-6.2 0-3.6 2.9-6.5 6.5-6.5v1.8l3-2.5zM20 11c-.2-1.4-.7-2.7-1.6-3.8l-1.2.8c.7.9 1.1 2 1.3 3.1L20 11zm-1.5 1.8c-.1.5-.2 1.1-.4 1.6s-.5 1-.8 1.5l1.2.9c.4-.5.8-1.1 1-1.8s.5-1.3.5-2l-1.5-.2zm-5.6 5.6l.2 1.5c1.4-.2 2.7-.7 3.8-1.6l-.9-1.1c-.9.7-2 1.1-3.1 1.2z" 42612 })); 42613 /* harmony default export */ var rotate_right = (rotateRight); 42614 42615 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/image-editor/rotation-button.js 42616 42617 42618 /** 42619 * WordPress dependencies 42620 */ 42621 42622 42623 42624 /** 42625 * Internal dependencies 42626 */ 42627 42628 42629 function RotationButton() { 42630 const { 42631 isInProgress, 42632 rotateClockwise 42633 } = useImageEditingContext(); 42634 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, { 42635 icon: rotate_right, 42636 label: (0,external_wp_i18n_namespaceObject.__)('Rotate'), 42637 onClick: rotateClockwise, 42638 disabled: isInProgress 42639 }); 42640 } 42641 42642 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/image-editor/form-controls.js 42643 42644 42645 /** 42646 * WordPress dependencies 42647 */ 42648 42649 42650 /** 42651 * Internal dependencies 42652 */ 42653 42654 42655 function FormControls() { 42656 const { 42657 isInProgress, 42658 apply, 42659 cancel 42660 } = useImageEditingContext(); 42661 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, { 42662 onClick: apply, 42663 disabled: isInProgress 42664 }, (0,external_wp_i18n_namespaceObject.__)('Apply')), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, { 42665 onClick: cancel 42666 }, (0,external_wp_i18n_namespaceObject.__)('Cancel'))); 42667 } 42668 42669 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/image-editor/index.js 42670 42671 42672 /** 42673 * WordPress dependencies 42674 */ 42675 42676 /** 42677 * Internal dependencies 42678 */ 42679 42680 42681 42682 42683 42684 42685 42686 function ImageEditor(_ref) { 42687 let { 42688 url, 42689 width, 42690 height, 42691 clientWidth, 42692 naturalHeight, 42693 naturalWidth 42694 } = _ref; 42695 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(ImageCropper, { 42696 url: url, 42697 width: width, 42698 height: height, 42699 clientWidth: clientWidth, 42700 naturalHeight: naturalHeight, 42701 naturalWidth: naturalWidth 42702 }), (0,external_wp_element_namespaceObject.createElement)(block_controls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarGroup, null, (0,external_wp_element_namespaceObject.createElement)(ZoomDropdown, null), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarItem, null, toggleProps => (0,external_wp_element_namespaceObject.createElement)(AspectRatioDropdown, { 42703 toggleProps: toggleProps 42704 })), (0,external_wp_element_namespaceObject.createElement)(RotationButton, null)), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarGroup, null, (0,external_wp_element_namespaceObject.createElement)(FormControls, null)))); 42705 } 42706 42707 42708 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/image-size-control/use-dimension-handler.js 42709 /** 42710 * WordPress dependencies 42711 */ 42712 42713 function useDimensionHandler(customHeight, customWidth, defaultHeight, defaultWidth, onChange) { 42714 var _ref, _ref2; 42715 42716 const [currentWidth, setCurrentWidth] = (0,external_wp_element_namespaceObject.useState)((_ref = customWidth !== null && customWidth !== void 0 ? customWidth : defaultWidth) !== null && _ref !== void 0 ? _ref : ''); 42717 const [currentHeight, setCurrentHeight] = (0,external_wp_element_namespaceObject.useState)((_ref2 = customHeight !== null && customHeight !== void 0 ? customHeight : defaultHeight) !== null && _ref2 !== void 0 ? _ref2 : ''); // When an image is first inserted, the default dimensions are initially 42718 // undefined. This effect updates the dimensions when the default values 42719 // come through. 42720 42721 (0,external_wp_element_namespaceObject.useEffect)(() => { 42722 if (customWidth === undefined && defaultWidth !== undefined) { 42723 setCurrentWidth(defaultWidth); 42724 } 42725 42726 if (customHeight === undefined && defaultHeight !== undefined) { 42727 setCurrentHeight(defaultHeight); 42728 } 42729 }, [defaultWidth, defaultHeight]); // If custom values change, it means an outsider has resized the image using some other method (eg resize box) 42730 // this keeps track of these values too. We need to parse before comparing; custom values can be strings. 42731 42732 (0,external_wp_element_namespaceObject.useEffect)(() => { 42733 if (customWidth !== undefined && Number.parseInt(customWidth) !== Number.parseInt(currentWidth)) { 42734 setCurrentWidth(customWidth); 42735 } 42736 42737 if (customHeight !== undefined && Number.parseInt(customHeight) !== Number.parseInt(currentHeight)) { 42738 setCurrentHeight(customHeight); 42739 } 42740 }, [customWidth, customHeight]); 42741 42742 const updateDimension = (dimension, value) => { 42743 if (dimension === 'width') { 42744 setCurrentWidth(value); 42745 } else { 42746 setCurrentHeight(value); 42747 } 42748 42749 onChange({ 42750 [dimension]: value === '' ? undefined : parseInt(value, 10) 42751 }); 42752 }; 42753 42754 const updateDimensions = (nextHeight, nextWidth) => { 42755 setCurrentHeight(nextHeight !== null && nextHeight !== void 0 ? nextHeight : defaultHeight); 42756 setCurrentWidth(nextWidth !== null && nextWidth !== void 0 ? nextWidth : defaultWidth); 42757 onChange({ 42758 height: nextHeight, 42759 width: nextWidth 42760 }); 42761 }; 42762 42763 return { 42764 currentHeight, 42765 currentWidth, 42766 updateDimension, 42767 updateDimensions 42768 }; 42769 } 42770 42771 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/image-size-control/index.js 42772 42773 42774 /** 42775 * External dependencies 42776 */ 42777 42778 /** 42779 * WordPress dependencies 42780 */ 42781 42782 42783 42784 /** 42785 * Internal dependencies 42786 */ 42787 42788 42789 const IMAGE_SIZE_PRESETS = [25, 50, 75, 100]; 42790 function ImageSizeControl(_ref) { 42791 let { 42792 imageWidth, 42793 imageHeight, 42794 imageSizeOptions = [], 42795 isResizable = true, 42796 slug, 42797 width, 42798 height, 42799 onChange, 42800 onChangeImage = external_lodash_namespaceObject.noop 42801 } = _ref; 42802 const { 42803 currentHeight, 42804 currentWidth, 42805 updateDimension, 42806 updateDimensions 42807 } = useDimensionHandler(height, width, imageHeight, imageWidth, onChange); 42808 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, !(0,external_lodash_namespaceObject.isEmpty)(imageSizeOptions) && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SelectControl, { 42809 label: (0,external_wp_i18n_namespaceObject.__)('Image size'), 42810 value: slug, 42811 options: imageSizeOptions, 42812 onChange: onChangeImage 42813 }), isResizable && (0,external_wp_element_namespaceObject.createElement)("div", { 42814 className: "block-editor-image-size-control" 42815 }, (0,external_wp_element_namespaceObject.createElement)("p", { 42816 className: "block-editor-image-size-control__row" 42817 }, (0,external_wp_i18n_namespaceObject.__)('Image dimensions')), (0,external_wp_element_namespaceObject.createElement)("div", { 42818 className: "block-editor-image-size-control__row" 42819 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, { 42820 type: "number", 42821 className: "block-editor-image-size-control__width", 42822 label: (0,external_wp_i18n_namespaceObject.__)('Width'), 42823 value: currentWidth, 42824 min: 1, 42825 onChange: value => updateDimension('width', value) 42826 }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, { 42827 type: "number", 42828 className: "block-editor-image-size-control__height", 42829 label: (0,external_wp_i18n_namespaceObject.__)('Height'), 42830 value: currentHeight, 42831 min: 1, 42832 onChange: value => updateDimension('height', value) 42833 })), (0,external_wp_element_namespaceObject.createElement)("div", { 42834 className: "block-editor-image-size-control__row" 42835 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ButtonGroup, { 42836 "aria-label": (0,external_wp_i18n_namespaceObject.__)('Image size presets') 42837 }, IMAGE_SIZE_PRESETS.map(scale => { 42838 const scaledWidth = Math.round(imageWidth * (scale / 100)); 42839 const scaledHeight = Math.round(imageHeight * (scale / 100)); 42840 const isCurrent = currentWidth === scaledWidth && currentHeight === scaledHeight; 42841 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 42842 key: scale, 42843 isSmall: true, 42844 variant: isCurrent ? 'primary' : undefined, 42845 isPressed: isCurrent, 42846 onClick: () => updateDimensions(scaledHeight, scaledWidth) 42847 }, scale, "%"); 42848 })), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 42849 isSmall: true, 42850 onClick: () => updateDimensions() 42851 }, (0,external_wp_i18n_namespaceObject.__)('Reset'))))); 42852 } 42853 42854 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/keyboard-return.js 42855 42856 42857 /** 42858 * WordPress dependencies 42859 */ 42860 42861 const keyboardReturn = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 42862 xmlns: "http://www.w3.org/2000/svg", 42863 viewBox: "-2 -2 24 24" 42864 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 42865 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" 42866 })); 42867 /* harmony default export */ var keyboard_return = (keyboardReturn); 42868 42869 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/link-control/settings-drawer.js 42870 42871 42872 /** 42873 * External dependencies 42874 */ 42875 42876 /** 42877 * WordPress dependencies 42878 */ 42879 42880 42881 42882 42883 const LinkControlSettingsDrawer = _ref => { 42884 let { 42885 value, 42886 onChange = external_lodash_namespaceObject.noop, 42887 settings 42888 } = _ref; 42889 42890 if (!settings || !settings.length) { 42891 return null; 42892 } 42893 42894 const handleSettingChange = setting => newValue => { 42895 onChange({ ...value, 42896 [setting.id]: newValue 42897 }); 42898 }; 42899 42900 const theSettings = settings.map(setting => (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, { 42901 className: "block-editor-link-control__setting", 42902 key: setting.id, 42903 label: setting.title, 42904 onChange: handleSettingChange(setting), 42905 checked: value ? !!value[setting.id] : false 42906 })); 42907 return (0,external_wp_element_namespaceObject.createElement)("fieldset", { 42908 className: "block-editor-link-control__settings" 42909 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.VisuallyHidden, { 42910 as: "legend" 42911 }, (0,external_wp_i18n_namespaceObject.__)('Currently selected link settings')), theSettings); 42912 }; 42913 42914 /* harmony default export */ var settings_drawer = (LinkControlSettingsDrawer); 42915 42916 // EXTERNAL MODULE: ./node_modules/dom-scroll-into-view/lib/index.js 42917 var dom_scroll_into_view_lib = __webpack_require__(5425); 42918 var lib_default = /*#__PURE__*/__webpack_require__.n(dom_scroll_into_view_lib); 42919 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/url-input/index.js 42920 42921 42922 42923 /** 42924 * External dependencies 42925 */ 42926 42927 42928 42929 /** 42930 * WordPress dependencies 42931 */ 42932 42933 42934 42935 42936 42937 42938 42939 42940 /** 42941 * Internal dependencies 42942 */ 42943 42944 42945 42946 class URLInput extends external_wp_element_namespaceObject.Component { 42947 constructor(props) { 42948 super(props); 42949 this.onChange = this.onChange.bind(this); 42950 this.onFocus = this.onFocus.bind(this); 42951 this.onKeyDown = this.onKeyDown.bind(this); 42952 this.selectLink = this.selectLink.bind(this); 42953 this.handleOnClick = this.handleOnClick.bind(this); 42954 this.bindSuggestionNode = this.bindSuggestionNode.bind(this); 42955 this.autocompleteRef = props.autocompleteRef || (0,external_wp_element_namespaceObject.createRef)(); 42956 this.inputRef = (0,external_wp_element_namespaceObject.createRef)(); 42957 this.updateSuggestions = (0,external_lodash_namespaceObject.debounce)(this.updateSuggestions.bind(this), 200); 42958 this.suggestionNodes = []; 42959 this.isUpdatingSuggestions = false; 42960 this.state = { 42961 suggestions: [], 42962 showSuggestions: false, 42963 selectedSuggestion: null, 42964 suggestionsListboxId: '', 42965 suggestionOptionIdPrefix: '' 42966 }; 42967 } 42968 42969 componentDidUpdate(prevProps) { 42970 const { 42971 showSuggestions, 42972 selectedSuggestion 42973 } = this.state; 42974 const { 42975 value, 42976 __experimentalShowInitialSuggestions = false 42977 } = this.props; // Only have to worry about scrolling selected suggestion into view 42978 // when already expanded. 42979 42980 if (showSuggestions && selectedSuggestion !== null && this.suggestionNodes[selectedSuggestion] && !this.scrollingIntoView) { 42981 this.scrollingIntoView = true; 42982 lib_default()(this.suggestionNodes[selectedSuggestion], this.autocompleteRef.current, { 42983 onlyScrollIfNeeded: true 42984 }); 42985 this.props.setTimeout(() => { 42986 this.scrollingIntoView = false; 42987 }, 100); 42988 } // Update suggestions when the value changes. 42989 42990 42991 if (prevProps.value !== value && !this.props.disableSuggestions && !this.isUpdatingSuggestions) { 42992 if (value !== null && value !== void 0 && value.length) { 42993 // If the new value is not empty we need to update with suggestions for it. 42994 this.updateSuggestions(value); 42995 } else if (__experimentalShowInitialSuggestions) { 42996 // If the new value is empty and we can show initial suggestions, then show initial suggestions. 42997 this.updateSuggestions(); 42998 } 42999 } 43000 } 43001 43002 componentDidMount() { 43003 if (this.shouldShowInitialSuggestions()) { 43004 this.updateSuggestions(); 43005 } 43006 } 43007 43008 componentWillUnmount() { 43009 var _this$suggestionsRequ, _this$suggestionsRequ2; 43010 43011 (_this$suggestionsRequ = this.suggestionsRequest) === null || _this$suggestionsRequ === void 0 ? void 0 : (_this$suggestionsRequ2 = _this$suggestionsRequ.cancel) === null || _this$suggestionsRequ2 === void 0 ? void 0 : _this$suggestionsRequ2.call(_this$suggestionsRequ); 43012 delete this.suggestionsRequest; 43013 } 43014 43015 bindSuggestionNode(index) { 43016 return ref => { 43017 this.suggestionNodes[index] = ref; 43018 }; 43019 } 43020 43021 shouldShowInitialSuggestions() { 43022 const { 43023 suggestions 43024 } = this.state; 43025 const { 43026 __experimentalShowInitialSuggestions = false, 43027 value 43028 } = this.props; 43029 return !this.isUpdatingSuggestions && __experimentalShowInitialSuggestions && !(value && value.length) && !(suggestions && suggestions.length); 43030 } 43031 43032 updateSuggestions() { 43033 var _value; 43034 43035 let value = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : ''; 43036 const { 43037 __experimentalFetchLinkSuggestions: fetchLinkSuggestions, 43038 __experimentalHandleURLSuggestions: handleURLSuggestions 43039 } = this.props; 43040 43041 if (!fetchLinkSuggestions) { 43042 return; 43043 } // Initial suggestions may only show if there is no value 43044 // (note: this includes whitespace). 43045 43046 43047 const isInitialSuggestions = !((_value = value) !== null && _value !== void 0 && _value.length); // Trim only now we've determined whether or not it originally had a "length" 43048 // (even if that value was all whitespace). 43049 43050 value = value.trim(); // Allow a suggestions request if: 43051 // - there are at least 2 characters in the search input (except manual searches where 43052 // search input length is not required to trigger a fetch) 43053 // - this is a direct entry (eg: a URL) 43054 43055 if (!isInitialSuggestions && (value.length < 2 || !handleURLSuggestions && (0,external_wp_url_namespaceObject.isURL)(value))) { 43056 this.setState({ 43057 showSuggestions: false, 43058 selectedSuggestion: null, 43059 loading: false 43060 }); 43061 return; 43062 } 43063 43064 this.isUpdatingSuggestions = true; 43065 this.setState({ 43066 selectedSuggestion: null, 43067 loading: true 43068 }); 43069 const request = fetchLinkSuggestions(value, { 43070 isInitialSuggestions 43071 }); 43072 request.then(suggestions => { 43073 // A fetch Promise doesn't have an abort option. It's mimicked by 43074 // comparing the request reference in on the instance, which is 43075 // reset or deleted on subsequent requests or unmounting. 43076 if (this.suggestionsRequest !== request) { 43077 return; 43078 } 43079 43080 this.setState({ 43081 suggestions, 43082 loading: false, 43083 showSuggestions: !!suggestions.length 43084 }); 43085 43086 if (!!suggestions.length) { 43087 this.props.debouncedSpeak((0,external_wp_i18n_namespaceObject.sprintf)( 43088 /* translators: %s: number of results. */ 43089 (0,external_wp_i18n_namespaceObject._n)('%d result found, use up and down arrow keys to navigate.', '%d results found, use up and down arrow keys to navigate.', suggestions.length), suggestions.length), 'assertive'); 43090 } else { 43091 this.props.debouncedSpeak((0,external_wp_i18n_namespaceObject.__)('No results.'), 'assertive'); 43092 } 43093 43094 this.isUpdatingSuggestions = false; 43095 }).catch(() => { 43096 if (this.suggestionsRequest === request) { 43097 this.setState({ 43098 loading: false 43099 }); 43100 this.isUpdatingSuggestions = false; 43101 } 43102 }); // Note that this assignment is handled *before* the async search request 43103 // as a Promise always resolves on the next tick of the event loop. 43104 43105 this.suggestionsRequest = request; 43106 } 43107 43108 onChange(event) { 43109 const inputValue = event.target.value; 43110 this.props.onChange(inputValue); 43111 43112 if (!this.props.disableSuggestions) { 43113 this.updateSuggestions(inputValue); 43114 } 43115 } 43116 43117 onFocus() { 43118 const { 43119 suggestions 43120 } = this.state; 43121 const { 43122 disableSuggestions, 43123 value 43124 } = this.props; // When opening the link editor, if there's a value present, we want to load the suggestions pane with the results for this input search value 43125 // Don't re-run the suggestions on focus if there are already suggestions present (prevents searching again when tabbing between the input and buttons) 43126 43127 if (value && !disableSuggestions && !this.isUpdatingSuggestions && !(suggestions && suggestions.length)) { 43128 // Ensure the suggestions are updated with the current input value. 43129 this.updateSuggestions(value); 43130 } 43131 } 43132 43133 onKeyDown(event) { 43134 const { 43135 showSuggestions, 43136 selectedSuggestion, 43137 suggestions, 43138 loading 43139 } = this.state; // If the suggestions are not shown or loading, we shouldn't handle the arrow keys 43140 // We shouldn't preventDefault to allow block arrow keys navigation. 43141 43142 if (!showSuggestions || !suggestions.length || loading) { 43143 // In the Windows version of Firefox the up and down arrows don't move the caret 43144 // within an input field like they do for Mac Firefox/Chrome/Safari. This causes 43145 // a form of focus trapping that is disruptive to the user experience. This disruption 43146 // only happens if the caret is not in the first or last position in the text input. 43147 // See: https://github.com/WordPress/gutenberg/issues/5693#issuecomment-436684747 43148 switch (event.keyCode) { 43149 // When UP is pressed, if the caret is at the start of the text, move it to the 0 43150 // position. 43151 case external_wp_keycodes_namespaceObject.UP: 43152 { 43153 if (0 !== event.target.selectionStart) { 43154 event.preventDefault(); // Set the input caret to position 0. 43155 43156 event.target.setSelectionRange(0, 0); 43157 } 43158 43159 break; 43160 } 43161 // When DOWN is pressed, if the caret is not at the end of the text, move it to the 43162 // last position. 43163 43164 case external_wp_keycodes_namespaceObject.DOWN: 43165 { 43166 if (this.props.value.length !== event.target.selectionStart) { 43167 event.preventDefault(); // Set the input caret to the last position. 43168 43169 event.target.setSelectionRange(this.props.value.length, this.props.value.length); 43170 } 43171 43172 break; 43173 } 43174 // Submitting while loading should trigger onSubmit. 43175 43176 case external_wp_keycodes_namespaceObject.ENTER: 43177 { 43178 if (this.props.onSubmit) { 43179 this.props.onSubmit(null, event); 43180 } 43181 43182 break; 43183 } 43184 } 43185 43186 return; 43187 } 43188 43189 const suggestion = this.state.suggestions[this.state.selectedSuggestion]; 43190 43191 switch (event.keyCode) { 43192 case external_wp_keycodes_namespaceObject.UP: 43193 { 43194 event.preventDefault(); 43195 const previousIndex = !selectedSuggestion ? suggestions.length - 1 : selectedSuggestion - 1; 43196 this.setState({ 43197 selectedSuggestion: previousIndex 43198 }); 43199 break; 43200 } 43201 43202 case external_wp_keycodes_namespaceObject.DOWN: 43203 { 43204 event.preventDefault(); 43205 const nextIndex = selectedSuggestion === null || selectedSuggestion === suggestions.length - 1 ? 0 : selectedSuggestion + 1; 43206 this.setState({ 43207 selectedSuggestion: nextIndex 43208 }); 43209 break; 43210 } 43211 43212 case external_wp_keycodes_namespaceObject.TAB: 43213 { 43214 if (this.state.selectedSuggestion !== null) { 43215 this.selectLink(suggestion); // Announce a link has been selected when tabbing away from the input field. 43216 43217 this.props.speak((0,external_wp_i18n_namespaceObject.__)('Link selected.')); 43218 } 43219 43220 break; 43221 } 43222 43223 case external_wp_keycodes_namespaceObject.ENTER: 43224 { 43225 if (this.state.selectedSuggestion !== null) { 43226 this.selectLink(suggestion); 43227 43228 if (this.props.onSubmit) { 43229 this.props.onSubmit(suggestion, event); 43230 } 43231 } else if (this.props.onSubmit) { 43232 this.props.onSubmit(null, event); 43233 } 43234 43235 break; 43236 } 43237 } 43238 } 43239 43240 selectLink(suggestion) { 43241 this.props.onChange(suggestion.url, suggestion); 43242 this.setState({ 43243 selectedSuggestion: null, 43244 showSuggestions: false 43245 }); 43246 } 43247 43248 handleOnClick(suggestion) { 43249 this.selectLink(suggestion); // Move focus to the input field when a link suggestion is clicked. 43250 43251 this.inputRef.current.focus(); 43252 } 43253 43254 static getDerivedStateFromProps(_ref, _ref2) { 43255 let { 43256 value, 43257 instanceId, 43258 disableSuggestions, 43259 __experimentalShowInitialSuggestions = false 43260 } = _ref; 43261 let { 43262 showSuggestions 43263 } = _ref2; 43264 let shouldShowSuggestions = showSuggestions; 43265 const hasValue = value && value.length; 43266 43267 if (!__experimentalShowInitialSuggestions && !hasValue) { 43268 shouldShowSuggestions = false; 43269 } 43270 43271 if (disableSuggestions === true) { 43272 shouldShowSuggestions = false; 43273 } 43274 43275 return { 43276 showSuggestions: shouldShowSuggestions, 43277 suggestionsListboxId: `block-editor-url-input-suggestions-$instanceId}`, 43278 suggestionOptionIdPrefix: `block-editor-url-input-suggestion-$instanceId}` 43279 }; 43280 } 43281 43282 render() { 43283 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, this.renderControl(), this.renderSuggestions()); 43284 } 43285 43286 renderControl() { 43287 const { 43288 label, 43289 className, 43290 isFullWidth, 43291 instanceId, 43292 placeholder = (0,external_wp_i18n_namespaceObject.__)('Paste URL or type to search'), 43293 __experimentalRenderControl: renderControl, 43294 value = '' 43295 } = this.props; 43296 const { 43297 loading, 43298 showSuggestions, 43299 selectedSuggestion, 43300 suggestionsListboxId, 43301 suggestionOptionIdPrefix 43302 } = this.state; 43303 const controlProps = { 43304 id: `url-input-control-$instanceId}`, 43305 label, 43306 className: classnames_default()('block-editor-url-input', className, { 43307 'is-full-width': isFullWidth 43308 }) 43309 }; 43310 const inputProps = { 43311 value, 43312 required: true, 43313 className: 'block-editor-url-input__input', 43314 type: 'text', 43315 onChange: this.onChange, 43316 onFocus: this.onFocus, 43317 placeholder, 43318 onKeyDown: this.onKeyDown, 43319 role: 'combobox', 43320 'aria-label': (0,external_wp_i18n_namespaceObject.__)('URL'), 43321 'aria-expanded': showSuggestions, 43322 'aria-autocomplete': 'list', 43323 'aria-owns': suggestionsListboxId, 43324 'aria-activedescendant': selectedSuggestion !== null ? `$suggestionOptionIdPrefix}-$selectedSuggestion}` : undefined, 43325 ref: this.inputRef 43326 }; 43327 43328 if (renderControl) { 43329 return renderControl(controlProps, inputProps, loading); 43330 } 43331 43332 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.BaseControl, controlProps, (0,external_wp_element_namespaceObject.createElement)("input", inputProps), loading && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Spinner, null)); 43333 } 43334 43335 renderSuggestions() { 43336 const { 43337 className, 43338 __experimentalRenderSuggestions: renderSuggestions, 43339 value = '', 43340 __experimentalShowInitialSuggestions = false 43341 } = this.props; 43342 const { 43343 showSuggestions, 43344 suggestions, 43345 selectedSuggestion, 43346 suggestionsListboxId, 43347 suggestionOptionIdPrefix, 43348 loading 43349 } = this.state; 43350 const suggestionsListProps = { 43351 id: suggestionsListboxId, 43352 ref: this.autocompleteRef, 43353 role: 'listbox' 43354 }; 43355 43356 const buildSuggestionItemProps = (suggestion, index) => { 43357 return { 43358 role: 'option', 43359 tabIndex: '-1', 43360 id: `$suggestionOptionIdPrefix}-$index}`, 43361 ref: this.bindSuggestionNode(index), 43362 'aria-selected': index === selectedSuggestion 43363 }; 43364 }; 43365 43366 if ((0,external_lodash_namespaceObject.isFunction)(renderSuggestions) && showSuggestions && !!suggestions.length) { 43367 return renderSuggestions({ 43368 suggestions, 43369 selectedSuggestion, 43370 suggestionsListProps, 43371 buildSuggestionItemProps, 43372 isLoading: loading, 43373 handleSuggestionClick: this.handleOnClick, 43374 isInitialSuggestions: __experimentalShowInitialSuggestions && !(value && value.length) 43375 }); 43376 } 43377 43378 if (!(0,external_lodash_namespaceObject.isFunction)(renderSuggestions) && showSuggestions && !!suggestions.length) { 43379 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Popover, { 43380 position: "bottom", 43381 noArrow: true, 43382 focusOnMount: false 43383 }, (0,external_wp_element_namespaceObject.createElement)("div", _extends({}, suggestionsListProps, { 43384 className: classnames_default()('block-editor-url-input__suggestions', `$className}__suggestions`) 43385 }), suggestions.map((suggestion, index) => (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, _extends({}, buildSuggestionItemProps(suggestion, index), { 43386 key: suggestion.id, 43387 className: classnames_default()('block-editor-url-input__suggestion', { 43388 'is-selected': index === selectedSuggestion 43389 }), 43390 onClick: () => this.handleOnClick(suggestion) 43391 }), suggestion.title)))); 43392 } 43393 43394 return null; 43395 } 43396 43397 } 43398 /** 43399 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/url-input/README.md 43400 */ 43401 43402 43403 /* harmony default export */ var url_input = ((0,external_wp_compose_namespaceObject.compose)(external_wp_compose_namespaceObject.withSafeTimeout, external_wp_components_namespaceObject.withSpokenMessages, external_wp_compose_namespaceObject.withInstanceId, (0,external_wp_data_namespaceObject.withSelect)((select, props) => { 43404 // If a link suggestions handler is already provided then 43405 // bail. 43406 if ((0,external_lodash_namespaceObject.isFunction)(props.__experimentalFetchLinkSuggestions)) { 43407 return; 43408 } 43409 43410 const { 43411 getSettings 43412 } = select(store); 43413 return { 43414 __experimentalFetchLinkSuggestions: getSettings().__experimentalFetchLinkSuggestions 43415 }; 43416 }))(URLInput)); 43417 43418 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/link-control/search-create-button.js 43419 43420 43421 43422 /** 43423 * External dependencies 43424 */ 43425 43426 43427 /** 43428 * WordPress dependencies 43429 */ 43430 43431 43432 43433 43434 43435 const LinkControlSearchCreate = _ref => { 43436 let { 43437 searchTerm, 43438 onClick, 43439 itemProps, 43440 isSelected, 43441 buttonText 43442 } = _ref; 43443 43444 if (!searchTerm) { 43445 return null; 43446 } 43447 43448 let text; 43449 43450 if (buttonText) { 43451 text = (0,external_lodash_namespaceObject.isFunction)(buttonText) ? buttonText(searchTerm) : buttonText; 43452 } else { 43453 text = (0,external_wp_element_namespaceObject.createInterpolateElement)((0,external_wp_i18n_namespaceObject.sprintf)( 43454 /* translators: %s: search term. */ 43455 (0,external_wp_i18n_namespaceObject.__)('Create: <mark>%s</mark>'), searchTerm), { 43456 mark: (0,external_wp_element_namespaceObject.createElement)("mark", null) 43457 }); 43458 } 43459 43460 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, _extends({}, itemProps, { 43461 className: classnames_default()('block-editor-link-control__search-create block-editor-link-control__search-item', { 43462 'is-selected': isSelected 43463 }), 43464 onClick: onClick 43465 }), (0,external_wp_element_namespaceObject.createElement)(build_module_icon, { 43466 className: "block-editor-link-control__search-item-icon", 43467 icon: library_plus 43468 }), (0,external_wp_element_namespaceObject.createElement)("span", { 43469 className: "block-editor-link-control__search-item-header" 43470 }, (0,external_wp_element_namespaceObject.createElement)("span", { 43471 className: "block-editor-link-control__search-item-title" 43472 }, text))); 43473 }; 43474 /* harmony default export */ var search_create_button = (LinkControlSearchCreate); 43475 43476 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/globe.js 43477 43478 43479 /** 43480 * WordPress dependencies 43481 */ 43482 43483 const globe = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 43484 xmlns: "http://www.w3.org/2000/svg", 43485 viewBox: "0 0 24 24" 43486 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 43487 d: "M12 3.3c-4.8 0-8.8 3.9-8.8 8.8 0 4.8 3.9 8.8 8.8 8.8 4.8 0 8.8-3.9 8.8-8.8s-4-8.8-8.8-8.8zm6.5 5.5h-2.6C15.4 7.3 14.8 6 14 5c2 .6 3.6 2 4.5 3.8zm.7 3.2c0 .6-.1 1.2-.2 1.8h-2.9c.1-.6.1-1.2.1-1.8s-.1-1.2-.1-1.8H19c.2.6.2 1.2.2 1.8zM12 18.7c-1-.7-1.8-1.9-2.3-3.5h4.6c-.5 1.6-1.3 2.9-2.3 3.5zm-2.6-4.9c-.1-.6-.1-1.1-.1-1.8 0-.6.1-1.2.1-1.8h5.2c.1.6.1 1.1.1 1.8s-.1 1.2-.1 1.8H9.4zM4.8 12c0-.6.1-1.2.2-1.8h2.9c-.1.6-.1 1.2-.1 1.8 0 .6.1 1.2.1 1.8H5c-.2-.6-.2-1.2-.2-1.8zM12 5.3c1 .7 1.8 1.9 2.3 3.5H9.7c.5-1.6 1.3-2.9 2.3-3.5zM10 5c-.8 1-1.4 2.3-1.8 3.8H5.5C6.4 7 8 5.6 10 5zM5.5 15.3h2.6c.4 1.5 1 2.8 1.8 3.7-1.8-.6-3.5-2-4.4-3.7zM14 19c.8-1 1.4-2.2 1.8-3.7h2.6C17.6 17 16 18.4 14 19z" 43488 })); 43489 /* harmony default export */ var library_globe = (globe); 43490 43491 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/link-control/search-item.js 43492 43493 43494 43495 /** 43496 * External dependencies 43497 */ 43498 43499 /** 43500 * WordPress dependencies 43501 */ 43502 43503 43504 43505 43506 43507 const LinkControlSearchItem = _ref => { 43508 let { 43509 itemProps, 43510 suggestion, 43511 isSelected = false, 43512 onClick, 43513 isURL = false, 43514 searchTerm = '', 43515 shouldShowType = false 43516 } = _ref; 43517 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, _extends({}, itemProps, { 43518 onClick: onClick, 43519 className: classnames_default()('block-editor-link-control__search-item', { 43520 'is-selected': isSelected, 43521 'is-url': isURL, 43522 'is-entity': !isURL 43523 }) 43524 }), isURL && (0,external_wp_element_namespaceObject.createElement)(build_module_icon, { 43525 className: "block-editor-link-control__search-item-icon", 43526 icon: library_globe 43527 }), (0,external_wp_element_namespaceObject.createElement)("span", { 43528 className: "block-editor-link-control__search-item-header" 43529 }, (0,external_wp_element_namespaceObject.createElement)("span", { 43530 className: "block-editor-link-control__search-item-title" 43531 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextHighlight, { 43532 text: suggestion.title, 43533 highlight: searchTerm 43534 })), (0,external_wp_element_namespaceObject.createElement)("span", { 43535 "aria-hidden": !isURL, 43536 className: "block-editor-link-control__search-item-info" 43537 }, !isURL && ((0,external_wp_url_namespaceObject.filterURLForDisplay)((0,external_wp_url_namespaceObject.safeDecodeURI)(suggestion.url)) || ''), isURL && (0,external_wp_i18n_namespaceObject.__)('Press ENTER to add this link'))), shouldShowType && suggestion.type && (0,external_wp_element_namespaceObject.createElement)("span", { 43538 className: "block-editor-link-control__search-item-type" 43539 }, getVisualTypeName(suggestion))); 43540 }; 43541 43542 function getVisualTypeName(suggestion) { 43543 if (suggestion.isFrontPage) { 43544 return 'front page'; 43545 } // Rename 'post_tag' to 'tag'. Ideally, the API would return the localised CPT or taxonomy label. 43546 43547 43548 return suggestion.type === 'post_tag' ? 'tag' : suggestion.type; 43549 } 43550 43551 /* harmony default export */ var search_item = (LinkControlSearchItem); 43552 43553 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/link-control/constants.js 43554 /** 43555 * WordPress dependencies 43556 */ 43557 // Used as a unique identifier for the "Create" option within search results. 43558 // Used to help distinguish the "Create" suggestion within the search results in 43559 // order to handle it as a unique case. 43560 43561 const CREATE_TYPE = '__CREATE__'; 43562 const DEFAULT_LINK_SETTINGS = [{ 43563 id: 'opensInNewTab', 43564 title: (0,external_wp_i18n_namespaceObject.__)('Open in new tab') 43565 }]; 43566 43567 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/link-control/search-results.js 43568 43569 43570 /** 43571 * WordPress dependencies 43572 */ 43573 43574 43575 /** 43576 * External dependencies 43577 */ 43578 43579 43580 43581 /** 43582 * Internal dependencies 43583 */ 43584 43585 43586 43587 43588 function LinkControlSearchResults(_ref) { 43589 let { 43590 instanceId, 43591 withCreateSuggestion, 43592 currentInputValue, 43593 handleSuggestionClick, 43594 suggestionsListProps, 43595 buildSuggestionItemProps, 43596 suggestions, 43597 selectedSuggestion, 43598 isLoading, 43599 isInitialSuggestions, 43600 createSuggestionButtonText, 43601 suggestionsQuery 43602 } = _ref; 43603 const resultsListClasses = classnames_default()('block-editor-link-control__search-results', { 43604 'is-loading': isLoading 43605 }); 43606 const directLinkEntryTypes = ['url', 'mailto', 'tel', 'internal']; 43607 const isSingleDirectEntryResult = suggestions.length === 1 && directLinkEntryTypes.includes(suggestions[0].type.toLowerCase()); 43608 const shouldShowCreateSuggestion = withCreateSuggestion && !isSingleDirectEntryResult && !isInitialSuggestions; // If the query has a specified type, then we can skip showing them in the result. See #24839. 43609 43610 const shouldShowSuggestionsTypes = !(suggestionsQuery !== null && suggestionsQuery !== void 0 && suggestionsQuery.type); // According to guidelines aria-label should be added if the label 43611 // itself is not visible. 43612 // See: https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Roles/listbox_role 43613 43614 const searchResultsLabelId = `block-editor-link-control-search-results-label-$instanceId}`; 43615 const labelText = isInitialSuggestions ? (0,external_wp_i18n_namespaceObject.__)('Recently updated') : (0,external_wp_i18n_namespaceObject.sprintf)( 43616 /* translators: %s: search term. */ 43617 (0,external_wp_i18n_namespaceObject.__)('Search results for "%s"'), currentInputValue); // VisuallyHidden rightly doesn't accept custom classNames 43618 // so we conditionally render it as a wrapper to visually hide the label 43619 // when that is required. 43620 43621 const searchResultsLabel = (0,external_wp_element_namespaceObject.createElement)(isInitialSuggestions ? external_wp_element_namespaceObject.Fragment : external_wp_components_namespaceObject.VisuallyHidden, {}, // Empty props. 43622 (0,external_wp_element_namespaceObject.createElement)("span", { 43623 className: "block-editor-link-control__search-results-label", 43624 id: searchResultsLabelId 43625 }, labelText)); 43626 return (0,external_wp_element_namespaceObject.createElement)("div", { 43627 className: "block-editor-link-control__search-results-wrapper" 43628 }, searchResultsLabel, (0,external_wp_element_namespaceObject.createElement)("div", _extends({}, suggestionsListProps, { 43629 className: resultsListClasses, 43630 "aria-labelledby": searchResultsLabelId 43631 }), suggestions.map((suggestion, index) => { 43632 if (shouldShowCreateSuggestion && CREATE_TYPE === suggestion.type) { 43633 return (0,external_wp_element_namespaceObject.createElement)(search_create_button, { 43634 searchTerm: currentInputValue, 43635 buttonText: createSuggestionButtonText, 43636 onClick: () => handleSuggestionClick(suggestion) // Intentionally only using `type` here as 43637 // the constant is enough to uniquely 43638 // identify the single "CREATE" suggestion. 43639 , 43640 key: suggestion.type, 43641 itemProps: buildSuggestionItemProps(suggestion, index), 43642 isSelected: index === selectedSuggestion 43643 }); 43644 } // If we're not handling "Create" suggestions above then 43645 // we don't want them in the main results so exit early. 43646 43647 43648 if (CREATE_TYPE === suggestion.type) { 43649 return null; 43650 } 43651 43652 return (0,external_wp_element_namespaceObject.createElement)(search_item, { 43653 key: `$suggestion.id}-$suggestion.type}`, 43654 itemProps: buildSuggestionItemProps(suggestion, index), 43655 suggestion: suggestion, 43656 index: index, 43657 onClick: () => { 43658 handleSuggestionClick(suggestion); 43659 }, 43660 isSelected: index === selectedSuggestion, 43661 isURL: directLinkEntryTypes.includes(suggestion.type.toLowerCase()), 43662 searchTerm: currentInputValue, 43663 shouldShowType: shouldShowSuggestionsTypes, 43664 isFrontPage: suggestion === null || suggestion === void 0 ? void 0 : suggestion.isFrontPage 43665 }); 43666 }))); 43667 } 43668 43669 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/link-control/is-url-like.js 43670 /** 43671 * External dependencies 43672 */ 43673 43674 /** 43675 * WordPress dependencies 43676 */ 43677 43678 43679 /** 43680 * Determines whether a given value could be a URL. Note this does not 43681 * guarantee the value is a URL only that it looks like it might be one. For 43682 * example, just because a string has `www.` in it doesn't make it a URL, 43683 * but it does make it highly likely that it will be so in the context of 43684 * creating a link it makes sense to treat it like one. 43685 * 43686 * @param {string} val the candidate for being URL-like (or not). 43687 * 43688 * @return {boolean} whether or not the value is potentially a URL. 43689 */ 43690 43691 function isURLLike(val) { 43692 const isInternal = (0,external_lodash_namespaceObject.startsWith)(val, '#'); 43693 return (0,external_wp_url_namespaceObject.isURL)(val) || val && val.includes('www.') || isInternal; 43694 } 43695 43696 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/link-control/use-search-handler.js 43697 /** 43698 * WordPress dependencies 43699 */ 43700 43701 43702 43703 /** 43704 * External dependencies 43705 */ 43706 43707 43708 /** 43709 * Internal dependencies 43710 */ 43711 43712 43713 43714 43715 const handleNoop = () => Promise.resolve([]); 43716 const handleDirectEntry = val => { 43717 let type = 'URL'; 43718 const protocol = (0,external_wp_url_namespaceObject.getProtocol)(val) || ''; 43719 43720 if (protocol.includes('mailto')) { 43721 type = 'mailto'; 43722 } 43723 43724 if (protocol.includes('tel')) { 43725 type = 'tel'; 43726 } 43727 43728 if ((0,external_lodash_namespaceObject.startsWith)(val, '#')) { 43729 type = 'internal'; 43730 } 43731 43732 return Promise.resolve([{ 43733 id: val, 43734 title: val, 43735 url: type === 'URL' ? (0,external_wp_url_namespaceObject.prependHTTP)(val) : val, 43736 type 43737 }]); 43738 }; 43739 43740 const handleEntitySearch = async (val, suggestionsQuery, fetchSearchSuggestions, directEntryHandler, withCreateSuggestion, withURLSuggestion, pageOnFront) => { 43741 const { 43742 isInitialSuggestions 43743 } = suggestionsQuery; 43744 let resultsIncludeFrontPage = false; 43745 let results = await Promise.all([fetchSearchSuggestions(val, suggestionsQuery), directEntryHandler(val)]); // Identify front page and update type to match. 43746 43747 results[0] = results[0].map(result => { 43748 if (Number(result.id) === pageOnFront) { 43749 resultsIncludeFrontPage = true; 43750 result.isFrontPage = true; 43751 return result; 43752 } 43753 43754 return result; 43755 }); 43756 const couldBeURL = !val.includes(' '); // If it's potentially a URL search then concat on a URL search suggestion 43757 // just for good measure. That way once the actual results run out we always 43758 // have a URL option to fallback on. 43759 43760 if (!resultsIncludeFrontPage && couldBeURL && withURLSuggestion && !isInitialSuggestions) { 43761 results = results[0].concat(results[1]); 43762 } else { 43763 results = results[0]; 43764 } // If displaying initial suggestions just return plain results. 43765 43766 43767 if (isInitialSuggestions) { 43768 return results; 43769 } // Here we append a faux suggestion to represent a "CREATE" option. This 43770 // is detected in the rendering of the search results and handled as a 43771 // special case. This is currently necessary because the suggestions 43772 // dropdown will only appear if there are valid suggestions and 43773 // therefore unless the create option is a suggestion it will not 43774 // display in scenarios where there are no results returned from the 43775 // API. In addition promoting CREATE to a first class suggestion affords 43776 // the a11y benefits afforded by `URLInput` to all suggestions (eg: 43777 // keyboard handling, ARIA roles...etc). 43778 // 43779 // Note also that the value of the `title` and `url` properties must correspond 43780 // to the text value of the `<input>`. This is because `title` is used 43781 // when creating the suggestion. Similarly `url` is used when using keyboard to select 43782 // the suggestion (the <form> `onSubmit` handler falls-back to `url`). 43783 43784 43785 return isURLLike(val) || !withCreateSuggestion ? results : results.concat({ 43786 // the `id` prop is intentionally ommitted here because it 43787 // is never exposed as part of the component's public API. 43788 // see: https://github.com/WordPress/gutenberg/pull/19775#discussion_r378931316. 43789 title: val, 43790 // Must match the existing `<input>`s text value. 43791 url: val, 43792 // Must match the existing `<input>`s text value. 43793 type: CREATE_TYPE 43794 }); 43795 }; 43796 43797 function useSearchHandler(suggestionsQuery, allowDirectEntry, withCreateSuggestion, withURLSuggestion) { 43798 const { 43799 fetchSearchSuggestions, 43800 pageOnFront 43801 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 43802 const { 43803 getSettings 43804 } = select(store); 43805 return { 43806 pageOnFront: getSettings().pageOnFront, 43807 fetchSearchSuggestions: getSettings().__experimentalFetchLinkSuggestions 43808 }; 43809 }, []); 43810 const directEntryHandler = allowDirectEntry ? handleDirectEntry : handleNoop; 43811 return (0,external_wp_element_namespaceObject.useCallback)((val, _ref) => { 43812 let { 43813 isInitialSuggestions 43814 } = _ref; 43815 return isURLLike(val) ? directEntryHandler(val, { 43816 isInitialSuggestions 43817 }) : handleEntitySearch(val, { ...suggestionsQuery, 43818 isInitialSuggestions 43819 }, fetchSearchSuggestions, directEntryHandler, withCreateSuggestion, withURLSuggestion, pageOnFront); 43820 }, [directEntryHandler, fetchSearchSuggestions, withCreateSuggestion]); 43821 } 43822 43823 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/link-control/search-input.js 43824 43825 43826 /** 43827 * External dependencies 43828 */ 43829 43830 43831 /** 43832 * WordPress dependencies 43833 */ 43834 43835 43836 43837 43838 /** 43839 * Internal dependencies 43840 */ 43841 43842 43843 43844 43845 // Must be a function as otherwise URLInput will default 43846 // to the fetchLinkSuggestions passed in block editor settings 43847 // which will cause an unintended http request. 43848 43849 const noopSearchHandler = () => Promise.resolve([]); 43850 43851 const LinkControlSearchInput = (0,external_wp_element_namespaceObject.forwardRef)((_ref, ref) => { 43852 let { 43853 value, 43854 children, 43855 currentLink = {}, 43856 className = null, 43857 placeholder = null, 43858 withCreateSuggestion = false, 43859 onCreateSuggestion = external_lodash_namespaceObject.noop, 43860 onChange = external_lodash_namespaceObject.noop, 43861 onSelect = external_lodash_namespaceObject.noop, 43862 showSuggestions = true, 43863 renderSuggestions = props => (0,external_wp_element_namespaceObject.createElement)(LinkControlSearchResults, props), 43864 fetchSuggestions = null, 43865 allowDirectEntry = true, 43866 showInitialSuggestions = false, 43867 suggestionsQuery = {}, 43868 withURLSuggestion = true, 43869 createSuggestionButtonText, 43870 useLabel = false 43871 } = _ref; 43872 const genericSearchHandler = useSearchHandler(suggestionsQuery, allowDirectEntry, withCreateSuggestion, withURLSuggestion); 43873 const searchHandler = showSuggestions ? fetchSuggestions || genericSearchHandler : noopSearchHandler; 43874 const instanceId = (0,external_wp_compose_namespaceObject.useInstanceId)(LinkControlSearchInput); 43875 const [focusedSuggestion, setFocusedSuggestion] = (0,external_wp_element_namespaceObject.useState)(); 43876 /** 43877 * Handles the user moving between different suggestions. Does not handle 43878 * choosing an individual item. 43879 * 43880 * @param {string} selection the url of the selected suggestion. 43881 * @param {Object} suggestion the suggestion object. 43882 */ 43883 43884 const onInputChange = (selection, suggestion) => { 43885 onChange(selection); 43886 setFocusedSuggestion(suggestion); 43887 }; 43888 43889 const handleRenderSuggestions = props => renderSuggestions({ ...props, 43890 instanceId, 43891 withCreateSuggestion, 43892 currentInputValue: value, 43893 createSuggestionButtonText, 43894 suggestionsQuery, 43895 handleSuggestionClick: suggestion => { 43896 if (props.handleSuggestionClick) { 43897 props.handleSuggestionClick(suggestion); 43898 } 43899 43900 onSuggestionSelected(suggestion); 43901 } 43902 }); 43903 43904 const onSuggestionSelected = async selectedSuggestion => { 43905 let suggestion = selectedSuggestion; 43906 43907 if (CREATE_TYPE === selectedSuggestion.type) { 43908 // Create a new page and call onSelect with the output from the onCreateSuggestion callback. 43909 try { 43910 var _suggestion; 43911 43912 suggestion = await onCreateSuggestion(selectedSuggestion.title); 43913 43914 if ((_suggestion = suggestion) !== null && _suggestion !== void 0 && _suggestion.url) { 43915 onSelect(suggestion); 43916 } 43917 } catch (e) {} 43918 43919 return; 43920 } 43921 43922 if (allowDirectEntry || suggestion && Object.keys(suggestion).length >= 1) { 43923 onSelect( // Some direct entries don't have types or IDs, and we still need to clear the previous ones. 43924 { ...(0,external_lodash_namespaceObject.omit)(currentLink, 'id', 'url'), 43925 ...suggestion 43926 }, suggestion); 43927 } 43928 }; 43929 43930 const inputClasses = classnames_default()(className, { 43931 'has-no-label': !useLabel 43932 }); 43933 return (0,external_wp_element_namespaceObject.createElement)("div", { 43934 className: "block-editor-link-control__search-input-container" 43935 }, (0,external_wp_element_namespaceObject.createElement)(url_input, { 43936 label: useLabel ? 'URL' : undefined, 43937 className: inputClasses, 43938 value: value, 43939 onChange: onInputChange, 43940 placeholder: placeholder !== null && placeholder !== void 0 ? placeholder : (0,external_wp_i18n_namespaceObject.__)('Search or type url'), 43941 __experimentalRenderSuggestions: showSuggestions ? handleRenderSuggestions : null, 43942 __experimentalFetchLinkSuggestions: searchHandler, 43943 __experimentalHandleURLSuggestions: true, 43944 __experimentalShowInitialSuggestions: showInitialSuggestions, 43945 onSubmit: (suggestion, event) => { 43946 var _value$trim; 43947 43948 const hasSuggestion = suggestion || focusedSuggestion; // If there is no suggestion and the value (ie: any manually entered URL) is empty 43949 // then don't allow submission otherwise we get empty links. 43950 43951 if (!hasSuggestion && !(value !== null && value !== void 0 && (_value$trim = value.trim()) !== null && _value$trim !== void 0 && _value$trim.length)) { 43952 event.preventDefault(); 43953 } else { 43954 onSuggestionSelected(hasSuggestion || { 43955 url: value 43956 }); 43957 } 43958 }, 43959 ref: ref 43960 }), children); 43961 }); 43962 /* harmony default export */ var search_input = (LinkControlSearchInput); 43963 43964 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/info.js 43965 43966 43967 /** 43968 * WordPress dependencies 43969 */ 43970 43971 const info = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 43972 xmlns: "http://www.w3.org/2000/svg", 43973 viewBox: "0 0 24 24" 43974 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 43975 d: "M12 3.2c-4.8 0-8.8 3.9-8.8 8.8 0 4.8 3.9 8.8 8.8 8.8 4.8 0 8.8-3.9 8.8-8.8 0-4.8-4-8.8-8.8-8.8zm0 16c-4 0-7.2-3.3-7.2-7.2C4.8 8 8 4.8 12 4.8s7.2 3.3 7.2 7.2c0 4-3.2 7.2-7.2 7.2zM11 17h2v-6h-2v6zm0-8h2V7h-2v2z" 43976 })); 43977 /* harmony default export */ var library_info = (info); 43978 43979 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/pencil.js 43980 43981 43982 /** 43983 * WordPress dependencies 43984 */ 43985 43986 const pencil = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 43987 xmlns: "http://www.w3.org/2000/svg", 43988 viewBox: "0 0 24 24" 43989 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 43990 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" 43991 })); 43992 /* harmony default export */ var library_pencil = (pencil); 43993 43994 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/edit.js 43995 /** 43996 * Internal dependencies 43997 */ 43998 43999 /* harmony default export */ var library_edit = (library_pencil); 44000 44001 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/link-control/viewer-slot.js 44002 /** 44003 * WordPress dependencies 44004 */ 44005 44006 const { 44007 Slot: ViewerSlot, 44008 Fill: ViewerFill 44009 } = (0,external_wp_components_namespaceObject.createSlotFill)('BlockEditorLinkControlViewer'); 44010 44011 /* harmony default export */ var viewer_slot = ((/* unused pure expression or super */ null && (ViewerSlot))); 44012 44013 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/link-control/use-rich-url-data.js 44014 /** 44015 * Internal dependencies 44016 */ 44017 44018 /** 44019 * WordPress dependencies 44020 */ 44021 44022 44023 44024 44025 function use_rich_url_data_reducer(state, action) { 44026 switch (action.type) { 44027 case 'RESOLVED': 44028 return { ...state, 44029 isFetching: false, 44030 richData: action.richData 44031 }; 44032 44033 case 'ERROR': 44034 return { ...state, 44035 isFetching: false, 44036 richData: null 44037 }; 44038 44039 case 'LOADING': 44040 return { ...state, 44041 isFetching: true 44042 }; 44043 44044 default: 44045 throw new Error(`Unexpected action type $action.type}`); 44046 } 44047 } 44048 44049 function useRemoteUrlData(url) { 44050 const [state, dispatch] = (0,external_wp_element_namespaceObject.useReducer)(use_rich_url_data_reducer, { 44051 richData: null, 44052 isFetching: false 44053 }); 44054 const { 44055 fetchRichUrlData 44056 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 44057 const { 44058 getSettings 44059 } = select(store); 44060 return { 44061 fetchRichUrlData: getSettings().__experimentalFetchRichUrlData 44062 }; 44063 }, []); 44064 (0,external_wp_element_namespaceObject.useEffect)(() => { 44065 // Only make the request if we have an actual URL 44066 // and the fetching util is available. In some editors 44067 // there may not be such a util. 44068 if (url !== null && url !== void 0 && url.length && fetchRichUrlData && typeof AbortController !== 'undefined') { 44069 dispatch({ 44070 type: 'LOADING' 44071 }); 44072 const controller = new window.AbortController(); 44073 const signal = controller.signal; 44074 fetchRichUrlData(url, { 44075 signal 44076 }).then(urlData => { 44077 dispatch({ 44078 type: 'RESOLVED', 44079 richData: urlData 44080 }); 44081 }).catch(() => { 44082 // Avoid setting state on unmounted component 44083 if (!signal.aborted) { 44084 dispatch({ 44085 type: 'ERROR' 44086 }); 44087 } 44088 }); // Cleanup: when the URL changes the abort the current request. 44089 44090 return () => { 44091 controller.abort(); 44092 }; 44093 } 44094 }, [url]); 44095 return state; 44096 } 44097 44098 /* harmony default export */ var use_rich_url_data = (useRemoteUrlData); 44099 44100 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/link-control/link-preview.js 44101 44102 44103 /** 44104 * External dependencies 44105 */ 44106 44107 /** 44108 * WordPress dependencies 44109 */ 44110 44111 44112 44113 44114 44115 44116 /** 44117 * Internal dependencies 44118 */ 44119 44120 44121 44122 function LinkPreview(_ref) { 44123 var _value$url; 44124 44125 let { 44126 value, 44127 onEditClick, 44128 hasRichPreviews = false, 44129 hasUnlinkControl = false, 44130 onRemove 44131 } = _ref; 44132 // Avoid fetching if rich previews are not desired. 44133 const showRichPreviews = hasRichPreviews ? value === null || value === void 0 ? void 0 : value.url : null; 44134 const { 44135 richData, 44136 isFetching 44137 } = use_rich_url_data(showRichPreviews); // Rich data may be an empty object so test for that. 44138 44139 const hasRichData = richData && Object.keys(richData).length; 44140 const displayURL = value && (0,external_wp_url_namespaceObject.filterURLForDisplay)((0,external_wp_url_namespaceObject.safeDecodeURI)(value.url), 16) || ''; 44141 const displayTitle = (richData === null || richData === void 0 ? void 0 : richData.title) || (value === null || value === void 0 ? void 0 : value.title) || displayURL; // url can be undefined if the href attribute is unset 44142 44143 const isEmptyURL = !(value !== null && value !== void 0 && (_value$url = value.url) !== null && _value$url !== void 0 && _value$url.length); 44144 let icon; 44145 44146 if (richData !== null && richData !== void 0 && richData.icon) { 44147 icon = (0,external_wp_element_namespaceObject.createElement)("img", { 44148 src: richData === null || richData === void 0 ? void 0 : richData.icon, 44149 alt: "" 44150 }); 44151 } else if (isEmptyURL) { 44152 icon = (0,external_wp_element_namespaceObject.createElement)(build_module_icon, { 44153 icon: library_info, 44154 size: 32 44155 }); 44156 } else { 44157 icon = (0,external_wp_element_namespaceObject.createElement)(build_module_icon, { 44158 icon: library_globe 44159 }); 44160 } 44161 44162 return (0,external_wp_element_namespaceObject.createElement)("div", { 44163 "aria-label": (0,external_wp_i18n_namespaceObject.__)('Currently selected'), 44164 "aria-selected": "true", 44165 className: classnames_default()('block-editor-link-control__search-item', { 44166 'is-current': true, 44167 'is-rich': hasRichData, 44168 'is-fetching': !!isFetching, 44169 'is-preview': true, 44170 'is-error': isEmptyURL 44171 }) 44172 }, (0,external_wp_element_namespaceObject.createElement)("div", { 44173 className: "block-editor-link-control__search-item-top" 44174 }, (0,external_wp_element_namespaceObject.createElement)("span", { 44175 className: "block-editor-link-control__search-item-header" 44176 }, (0,external_wp_element_namespaceObject.createElement)("span", { 44177 className: classnames_default()('block-editor-link-control__search-item-icon', { 44178 'is-image': richData === null || richData === void 0 ? void 0 : richData.icon 44179 }) 44180 }, icon), (0,external_wp_element_namespaceObject.createElement)("span", { 44181 className: "block-editor-link-control__search-item-details" 44182 }, !isEmptyURL ? (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ExternalLink, { 44183 className: "block-editor-link-control__search-item-title", 44184 href: value.url 44185 }, (0,external_wp_dom_namespaceObject.__unstableStripHTML)(displayTitle)), (value === null || value === void 0 ? void 0 : value.url) && (0,external_wp_element_namespaceObject.createElement)("span", { 44186 className: "block-editor-link-control__search-item-info" 44187 }, displayURL)) : (0,external_wp_element_namespaceObject.createElement)("span", { 44188 className: "block-editor-link-control__search-item-error-notice" 44189 }, (0,external_wp_i18n_namespaceObject.__)('Link is empty')))), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 44190 icon: library_edit, 44191 label: (0,external_wp_i18n_namespaceObject.__)('Edit'), 44192 className: "block-editor-link-control__search-item-action", 44193 onClick: onEditClick, 44194 iconSize: 24 44195 }), hasUnlinkControl && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 44196 icon: link_off, 44197 label: (0,external_wp_i18n_namespaceObject.__)('Unlink'), 44198 className: "block-editor-link-control__search-item-action block-editor-link-control__unlink", 44199 onClick: onRemove, 44200 iconSize: 24 44201 }), (0,external_wp_element_namespaceObject.createElement)(ViewerSlot, { 44202 fillProps: value 44203 })), (hasRichData && ((richData === null || richData === void 0 ? void 0 : richData.image) || (richData === null || richData === void 0 ? void 0 : richData.description)) || isFetching) && (0,external_wp_element_namespaceObject.createElement)("div", { 44204 className: "block-editor-link-control__search-item-bottom" 44205 }, ((richData === null || richData === void 0 ? void 0 : richData.image) || isFetching) && (0,external_wp_element_namespaceObject.createElement)("div", { 44206 "aria-hidden": !(richData !== null && richData !== void 0 && richData.image), 44207 className: classnames_default()('block-editor-link-control__search-item-image', { 44208 'is-placeholder': !(richData !== null && richData !== void 0 && richData.image) 44209 }) 44210 }, (richData === null || richData === void 0 ? void 0 : richData.image) && (0,external_wp_element_namespaceObject.createElement)("img", { 44211 src: richData === null || richData === void 0 ? void 0 : richData.image, 44212 alt: "" 44213 })), ((richData === null || richData === void 0 ? void 0 : richData.description) || isFetching) && (0,external_wp_element_namespaceObject.createElement)("div", { 44214 "aria-hidden": !(richData !== null && richData !== void 0 && richData.description), 44215 className: classnames_default()('block-editor-link-control__search-item-description', { 44216 'is-placeholder': !(richData !== null && richData !== void 0 && richData.description) 44217 }) 44218 }, (richData === null || richData === void 0 ? void 0 : richData.description) && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalText, { 44219 truncate: true, 44220 numberOfLines: "2" 44221 }, richData.description)))); 44222 } 44223 44224 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/link-control/use-create-page.js 44225 /** 44226 * WordPress dependencies 44227 */ 44228 44229 44230 function useCreatePage(handleCreatePage) { 44231 const cancelableCreateSuggestion = (0,external_wp_element_namespaceObject.useRef)(); 44232 const [isCreatingPage, setIsCreatingPage] = (0,external_wp_element_namespaceObject.useState)(false); 44233 const [errorMessage, setErrorMessage] = (0,external_wp_element_namespaceObject.useState)(null); 44234 44235 const createPage = async function (suggestionTitle) { 44236 setIsCreatingPage(true); 44237 setErrorMessage(null); 44238 44239 try { 44240 // Make cancellable in order that we can avoid setting State 44241 // if the component unmounts during the call to `createSuggestion` 44242 cancelableCreateSuggestion.current = makeCancelable( // Using Promise.resolve to allow createSuggestion to return a 44243 // non-Promise based value. 44244 Promise.resolve(handleCreatePage(suggestionTitle))); 44245 return await cancelableCreateSuggestion.current.promise; 44246 } catch (error) { 44247 if (error && error.isCanceled) { 44248 return; // bail if canceled to avoid setting state 44249 } 44250 44251 setErrorMessage(error.message || (0,external_wp_i18n_namespaceObject.__)('An unknown error occurred during creation. Please try again.')); 44252 throw error; 44253 } finally { 44254 setIsCreatingPage(false); 44255 } 44256 }; 44257 /** 44258 * Handles cancelling any pending Promises that have been made cancelable. 44259 */ 44260 44261 44262 (0,external_wp_element_namespaceObject.useEffect)(() => { 44263 return () => { 44264 // componentDidUnmount 44265 if (cancelableCreateSuggestion.current) { 44266 cancelableCreateSuggestion.current.cancel(); 44267 } 44268 }; 44269 }, []); 44270 return { 44271 createPage, 44272 isCreatingPage, 44273 errorMessage 44274 }; 44275 } 44276 /** 44277 * Creates a wrapper around a promise which allows it to be programmatically 44278 * cancelled. 44279 * See: https://reactjs.org/blog/2015/12/16/ismounted-antipattern.html 44280 * 44281 * @param {Promise} promise the Promise to make cancelable 44282 */ 44283 44284 const makeCancelable = promise => { 44285 let hasCanceled_ = false; 44286 const wrappedPromise = new Promise((resolve, reject) => { 44287 promise.then(val => hasCanceled_ ? reject({ 44288 isCanceled: true 44289 }) : resolve(val), error => hasCanceled_ ? reject({ 44290 isCanceled: true 44291 }) : reject(error)); 44292 }); 44293 return { 44294 promise: wrappedPromise, 44295 44296 cancel() { 44297 hasCanceled_ = true; 44298 } 44299 44300 }; 44301 }; 44302 44303 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/link-control/index.js 44304 44305 44306 /** 44307 * External dependencies 44308 */ 44309 44310 44311 /** 44312 * WordPress dependencies 44313 */ 44314 44315 44316 44317 44318 44319 44320 44321 /** 44322 * Internal dependencies 44323 */ 44324 44325 44326 44327 44328 44329 44330 44331 /** 44332 * Default properties associated with a link control value. 44333 * 44334 * @typedef WPLinkControlDefaultValue 44335 * 44336 * @property {string} url Link URL. 44337 * @property {string=} title Link title. 44338 * @property {boolean=} opensInNewTab Whether link should open in a new browser 44339 * tab. This value is only assigned if not 44340 * providing a custom `settings` prop. 44341 */ 44342 44343 /* eslint-disable jsdoc/valid-types */ 44344 44345 /** 44346 * Custom settings values associated with a link. 44347 * 44348 * @typedef {{[setting:string]:any}} WPLinkControlSettingsValue 44349 */ 44350 44351 /* eslint-enable */ 44352 44353 /** 44354 * Custom settings values associated with a link. 44355 * 44356 * @typedef WPLinkControlSetting 44357 * 44358 * @property {string} id Identifier to use as property for setting value. 44359 * @property {string} title Human-readable label to show in user interface. 44360 */ 44361 44362 /** 44363 * Properties associated with a link control value, composed as a union of the 44364 * default properties and any custom settings values. 44365 * 44366 * @typedef {WPLinkControlDefaultValue&WPLinkControlSettingsValue} WPLinkControlValue 44367 */ 44368 44369 /** @typedef {(nextValue:WPLinkControlValue)=>void} WPLinkControlOnChangeProp */ 44370 44371 /** 44372 * Properties associated with a search suggestion used within the LinkControl. 44373 * 44374 * @typedef WPLinkControlSuggestion 44375 * 44376 * @property {string} id Identifier to use to uniquely identify the suggestion. 44377 * @property {string} type Identifies the type of the suggestion (eg: `post`, 44378 * `page`, `url`...etc) 44379 * @property {string} title Human-readable label to show in user interface. 44380 * @property {string} url A URL for the suggestion. 44381 */ 44382 44383 /** @typedef {(title:string)=>WPLinkControlSuggestion} WPLinkControlCreateSuggestionProp */ 44384 44385 /** 44386 * @typedef WPLinkControlProps 44387 * 44388 * @property {(WPLinkControlSetting[])=} settings An array of settings objects. Each object will used to 44389 * render a `ToggleControl` for that setting. 44390 * @property {boolean=} forceIsEditingLink If passed as either `true` or `false`, controls the 44391 * internal editing state of the component to respective 44392 * show or not show the URL input field. 44393 * @property {WPLinkControlValue=} value Current link value. 44394 * @property {WPLinkControlOnChangeProp=} onChange Value change handler, called with the updated value if 44395 * the user selects a new link or updates settings. 44396 * @property {boolean=} noDirectEntry Whether to allow turning a URL-like search query directly into a link. 44397 * @property {boolean=} showSuggestions Whether to present suggestions when typing the URL. 44398 * @property {boolean=} showInitialSuggestions Whether to present initial suggestions immediately. 44399 * @property {boolean=} withCreateSuggestion Whether to allow creation of link value from suggestion. 44400 * @property {Object=} suggestionsQuery Query parameters to pass along to wp.blockEditor.__experimentalFetchLinkSuggestions. 44401 * @property {boolean=} noURLSuggestion Whether to add a fallback suggestion which treats the search query as a URL. 44402 * @property {string|Function|undefined} createSuggestionButtonText The text to use in the button that calls createSuggestion. 44403 * @property {Function} renderControlBottom Optional controls to be rendered at the bottom of the component. 44404 */ 44405 44406 /** 44407 * Renders a link control. A link control is a controlled input which maintains 44408 * a value associated with a link (HTML anchor element) and relevant settings 44409 * for how that link is expected to behave. 44410 * 44411 * @param {WPLinkControlProps} props Component props. 44412 */ 44413 44414 function LinkControl(_ref) { 44415 var _currentInputValue$tr, _value$url, _value$url$trim; 44416 44417 let { 44418 searchInputPlaceholder, 44419 value, 44420 settings = DEFAULT_LINK_SETTINGS, 44421 onChange = external_lodash_namespaceObject.noop, 44422 onRemove, 44423 noDirectEntry = false, 44424 showSuggestions = true, 44425 showInitialSuggestions, 44426 forceIsEditingLink, 44427 createSuggestion, 44428 withCreateSuggestion, 44429 inputValue: propInputValue = '', 44430 suggestionsQuery = {}, 44431 noURLSuggestion = false, 44432 createSuggestionButtonText, 44433 hasRichPreviews = false, 44434 hasTextControl = false, 44435 renderControlBottom = null 44436 } = _ref; 44437 44438 if (withCreateSuggestion === undefined && createSuggestion) { 44439 withCreateSuggestion = true; 44440 } 44441 44442 const isMounting = (0,external_wp_element_namespaceObject.useRef)(true); 44443 const wrapperNode = (0,external_wp_element_namespaceObject.useRef)(); 44444 const textInputRef = (0,external_wp_element_namespaceObject.useRef)(); 44445 const [internalInputValue, setInternalInputValue] = (0,external_wp_element_namespaceObject.useState)((value === null || value === void 0 ? void 0 : value.url) || ''); 44446 const [internalTextValue, setInternalTextValue] = (0,external_wp_element_namespaceObject.useState)((value === null || value === void 0 ? void 0 : value.title) || ''); 44447 const currentInputValue = propInputValue || internalInputValue; 44448 const [isEditingLink, setIsEditingLink] = (0,external_wp_element_namespaceObject.useState)(forceIsEditingLink !== undefined ? forceIsEditingLink : !value || !value.url); 44449 const isEndingEditWithFocus = (0,external_wp_element_namespaceObject.useRef)(false); 44450 const currentInputIsEmpty = !(currentInputValue !== null && currentInputValue !== void 0 && (_currentInputValue$tr = currentInputValue.trim()) !== null && _currentInputValue$tr !== void 0 && _currentInputValue$tr.length); 44451 const { 44452 createPage, 44453 isCreatingPage, 44454 errorMessage 44455 } = useCreatePage(createSuggestion); 44456 (0,external_wp_element_namespaceObject.useEffect)(() => { 44457 if (forceIsEditingLink !== undefined && forceIsEditingLink !== isEditingLink) { 44458 setIsEditingLink(forceIsEditingLink); 44459 } 44460 }, [forceIsEditingLink]); 44461 (0,external_wp_element_namespaceObject.useEffect)(() => { 44462 // We don't auto focus into the Link UI on mount 44463 // because otherwise using the keyboard to select text 44464 // *within* the link format is not possible. 44465 if (isMounting.current) { 44466 isMounting.current = false; 44467 return; 44468 } // Unless we are mounting, we always want to focus either: 44469 // - the URL input 44470 // - the first focusable element in the Link UI. 44471 // But in editing mode if there is a text input present then 44472 // the URL input is at index 1. If not then it is at index 0. 44473 44474 44475 const whichFocusTargetIndex = textInputRef !== null && textInputRef !== void 0 && textInputRef.current ? 1 : 0; // Scenario - when: 44476 // - switching between editable and non editable LinkControl 44477 // - clicking on a link 44478 // ...then move focus to the *first* element to avoid focus loss 44479 // and to ensure focus is *within* the Link UI. 44480 44481 const nextFocusTarget = external_wp_dom_namespaceObject.focus.focusable.find(wrapperNode.current)[whichFocusTargetIndex] || wrapperNode.current; 44482 nextFocusTarget.focus(); 44483 isEndingEditWithFocus.current = false; 44484 }, [isEditingLink, isCreatingPage]); 44485 (0,external_wp_element_namespaceObject.useEffect)(() => { 44486 /** 44487 * If the value's `text` property changes then sync this 44488 * back up with state. 44489 */ 44490 if (value !== null && value !== void 0 && value.title && value.title !== internalTextValue) { 44491 setInternalTextValue(value.title); 44492 } 44493 /** 44494 * Update the state value internalInputValue if the url value changes 44495 * for example when clicking on another anchor 44496 */ 44497 44498 44499 if (value !== null && value !== void 0 && value.url) { 44500 setInternalInputValue(value.url); 44501 } 44502 }, [value]); 44503 /** 44504 * Cancels editing state and marks that focus may need to be restored after 44505 * the next render, if focus was within the wrapper when editing finished. 44506 */ 44507 44508 function stopEditing() { 44509 var _wrapperNode$current; 44510 44511 isEndingEditWithFocus.current = !!((_wrapperNode$current = wrapperNode.current) !== null && _wrapperNode$current !== void 0 && _wrapperNode$current.contains(wrapperNode.current.ownerDocument.activeElement)); 44512 setIsEditingLink(false); 44513 } 44514 44515 const handleSelectSuggestion = updatedValue => { 44516 onChange({ ...updatedValue, 44517 title: internalTextValue || (updatedValue === null || updatedValue === void 0 ? void 0 : updatedValue.title) 44518 }); 44519 stopEditing(); 44520 }; 44521 44522 const handleSubmit = () => { 44523 if (currentInputValue !== (value === null || value === void 0 ? void 0 : value.url) || internalTextValue !== (value === null || value === void 0 ? void 0 : value.title)) { 44524 onChange({ 44525 url: currentInputValue, 44526 title: internalTextValue 44527 }); 44528 } 44529 44530 stopEditing(); 44531 }; 44532 44533 const handleSubmitWithEnter = event => { 44534 const { 44535 keyCode 44536 } = event; 44537 44538 if (keyCode === external_wp_keycodes_namespaceObject.ENTER && !currentInputIsEmpty // Disallow submitting empty values. 44539 ) { 44540 event.preventDefault(); 44541 handleSubmit(); 44542 } 44543 }; 44544 44545 const shownUnlinkControl = onRemove && value && !isEditingLink && !isCreatingPage; 44546 const showSettingsDrawer = !!(settings !== null && settings !== void 0 && settings.length); // Only show text control once a URL value has been committed 44547 // and it isn't just empty whitespace. 44548 // See https://github.com/WordPress/gutenberg/pull/33849/#issuecomment-932194927. 44549 44550 const showTextControl = (value === null || value === void 0 ? void 0 : (_value$url = value.url) === null || _value$url === void 0 ? void 0 : (_value$url$trim = _value$url.trim()) === null || _value$url$trim === void 0 ? void 0 : _value$url$trim.length) > 0 && hasTextControl; 44551 return (0,external_wp_element_namespaceObject.createElement)("div", { 44552 tabIndex: -1, 44553 ref: wrapperNode, 44554 className: "block-editor-link-control" 44555 }, isCreatingPage && (0,external_wp_element_namespaceObject.createElement)("div", { 44556 className: "block-editor-link-control__loading" 44557 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Spinner, null), " ", (0,external_wp_i18n_namespaceObject.__)('Creating'), "\u2026"), (isEditingLink || !value) && !isCreatingPage && (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("div", { 44558 className: classnames_default()({ 44559 'block-editor-link-control__search-input-wrapper': true, 44560 'has-text-control': showTextControl 44561 }) 44562 }, showTextControl && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, { 44563 ref: textInputRef, 44564 className: "block-editor-link-control__field block-editor-link-control__text-content", 44565 label: "Text", 44566 value: internalTextValue, 44567 onChange: setInternalTextValue, 44568 onKeyDown: handleSubmitWithEnter 44569 }), (0,external_wp_element_namespaceObject.createElement)(search_input, { 44570 currentLink: value, 44571 className: "block-editor-link-control__field block-editor-link-control__search-input", 44572 placeholder: searchInputPlaceholder, 44573 value: currentInputValue, 44574 withCreateSuggestion: withCreateSuggestion, 44575 onCreateSuggestion: createPage, 44576 onChange: setInternalInputValue, 44577 onSelect: handleSelectSuggestion, 44578 showInitialSuggestions: showInitialSuggestions, 44579 allowDirectEntry: !noDirectEntry, 44580 showSuggestions: showSuggestions, 44581 suggestionsQuery: suggestionsQuery, 44582 withURLSuggestion: !noURLSuggestion, 44583 createSuggestionButtonText: createSuggestionButtonText, 44584 useLabel: showTextControl 44585 }, (0,external_wp_element_namespaceObject.createElement)("div", { 44586 className: "block-editor-link-control__search-actions" 44587 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 44588 onClick: handleSubmit, 44589 label: (0,external_wp_i18n_namespaceObject.__)('Submit'), 44590 icon: keyboard_return, 44591 className: "block-editor-link-control__search-submit", 44592 disabled: currentInputIsEmpty // Disallow submitting empty values. 44593 44594 })))), errorMessage && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Notice, { 44595 className: "block-editor-link-control__search-error", 44596 status: "error", 44597 isDismissible: false 44598 }, errorMessage)), value && !isEditingLink && !isCreatingPage && (0,external_wp_element_namespaceObject.createElement)(LinkPreview, { 44599 key: value === null || value === void 0 ? void 0 : value.url // force remount when URL changes to avoid race conditions for rich previews 44600 , 44601 value: value, 44602 onEditClick: () => setIsEditingLink(true), 44603 hasRichPreviews: hasRichPreviews, 44604 hasUnlinkControl: shownUnlinkControl, 44605 onRemove: onRemove 44606 }), showSettingsDrawer && (0,external_wp_element_namespaceObject.createElement)("div", { 44607 className: "block-editor-link-control__tools" 44608 }, (0,external_wp_element_namespaceObject.createElement)(settings_drawer, { 44609 value: value, 44610 settings: settings, 44611 onChange: onChange 44612 })), renderControlBottom && renderControlBottom()); 44613 } 44614 44615 LinkControl.ViewerFill = ViewerFill; 44616 /* harmony default export */ var link_control = (LinkControl); 44617 44618 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/media.js 44619 44620 44621 /** 44622 * WordPress dependencies 44623 */ 44624 44625 const media = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 44626 xmlns: "http://www.w3.org/2000/svg", 44627 viewBox: "0 0 24 24" 44628 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 44629 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" 44630 })); 44631 /* harmony default export */ var library_media = (media); 44632 44633 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/upload.js 44634 44635 44636 /** 44637 * WordPress dependencies 44638 */ 44639 44640 const upload = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 44641 xmlns: "http://www.w3.org/2000/svg", 44642 viewBox: "0 0 24 24" 44643 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 44644 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" 44645 })); 44646 /* harmony default export */ var library_upload = (upload); 44647 44648 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/media-upload/index.js 44649 /** 44650 * WordPress dependencies 44651 */ 44652 44653 /** 44654 * This is a placeholder for the media upload component necessary to make it possible to provide 44655 * an integration with the core blocks that handle media files. By default it renders nothing but 44656 * it provides a way to have it overridden with the `editor.MediaUpload` filter. 44657 * 44658 * @return {WPComponent} The component to be rendered. 44659 */ 44660 44661 const MediaUpload = () => null; 44662 /** 44663 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/media-upload/README.md 44664 */ 44665 44666 44667 /* harmony default export */ var media_upload = ((0,external_wp_components_namespaceObject.withFilters)('editor.MediaUpload')(MediaUpload)); 44668 44669 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/media-upload/check.js 44670 /** 44671 * WordPress dependencies 44672 */ 44673 44674 /** 44675 * Internal dependencies 44676 */ 44677 44678 44679 function MediaUploadCheck(_ref) { 44680 let { 44681 fallback = null, 44682 children 44683 } = _ref; 44684 const hasUploadPermissions = (0,external_wp_data_namespaceObject.useSelect)(select => { 44685 const { 44686 getSettings 44687 } = select(store); 44688 return !!getSettings().mediaUpload; 44689 }, []); 44690 return hasUploadPermissions ? children : fallback; 44691 } 44692 /** 44693 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/media-upload/README.md 44694 */ 44695 44696 /* harmony default export */ var media_upload_check = (MediaUploadCheck); 44697 44698 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/media-replace-flow/index.js 44699 44700 44701 /** 44702 * External dependencies 44703 */ 44704 44705 /** 44706 * WordPress dependencies 44707 */ 44708 44709 44710 44711 44712 44713 44714 44715 44716 44717 44718 44719 /** 44720 * Internal dependencies 44721 */ 44722 44723 44724 44725 44726 44727 44728 const MediaReplaceFlow = _ref => { 44729 let { 44730 mediaURL, 44731 mediaId, 44732 mediaIds, 44733 allowedTypes, 44734 accept, 44735 onError, 44736 onSelect, 44737 onSelectURL, 44738 onFilesUpload = external_lodash_namespaceObject.noop, 44739 onCloseModal = external_lodash_namespaceObject.noop, 44740 name = (0,external_wp_i18n_namespaceObject.__)('Replace'), 44741 createNotice, 44742 removeNotice, 44743 children, 44744 multiple = false, 44745 addToGallery, 44746 handleUpload = true 44747 } = _ref; 44748 const [mediaURLValue, setMediaURLValue] = (0,external_wp_element_namespaceObject.useState)(mediaURL); 44749 const mediaUpload = (0,external_wp_data_namespaceObject.useSelect)(select => { 44750 return select(store).getSettings().mediaUpload; 44751 }, []); 44752 const editMediaButtonRef = (0,external_wp_element_namespaceObject.useRef)(); 44753 const errorNoticeID = (0,external_lodash_namespaceObject.uniqueId)('block-editor/media-replace-flow/error-notice/'); 44754 44755 const onUploadError = message => { 44756 const safeMessage = (0,external_wp_dom_namespaceObject.__unstableStripHTML)(message); 44757 44758 if (onError) { 44759 onError(safeMessage); 44760 return; 44761 } // We need to set a timeout for showing the notice 44762 // so that VoiceOver and possibly other screen readers 44763 // can announce the error afer the toolbar button 44764 // regains focus once the upload dialog closes. 44765 // Otherwise VO simply skips over the notice and announces 44766 // the focused element and the open menu. 44767 44768 44769 setTimeout(() => { 44770 createNotice('error', safeMessage, { 44771 speak: true, 44772 id: errorNoticeID, 44773 isDismissible: true 44774 }); 44775 }, 1000); 44776 }; 44777 44778 const selectMedia = (media, closeMenu) => { 44779 closeMenu(); 44780 setMediaURLValue(media === null || media === void 0 ? void 0 : media.url); // Calling `onSelect` after the state update since it might unmount the component. 44781 44782 onSelect(media); 44783 (0,external_wp_a11y_namespaceObject.speak)((0,external_wp_i18n_namespaceObject.__)('The media file has been replaced')); 44784 removeNotice(errorNoticeID); 44785 }; 44786 44787 const uploadFiles = (event, closeMenu) => { 44788 const files = event.target.files; 44789 44790 if (!handleUpload) { 44791 closeMenu(); 44792 return onSelect(files); 44793 } 44794 44795 onFilesUpload(files); 44796 mediaUpload({ 44797 allowedTypes, 44798 filesList: files, 44799 onFileChange: _ref2 => { 44800 let [media] = _ref2; 44801 selectMedia(media, closeMenu); 44802 }, 44803 onError: onUploadError 44804 }); 44805 }; 44806 44807 const openOnArrowDown = event => { 44808 if (event.keyCode === external_wp_keycodes_namespaceObject.DOWN) { 44809 event.preventDefault(); 44810 event.target.click(); 44811 } 44812 }; 44813 44814 const onlyAllowsImages = () => { 44815 if (!allowedTypes || allowedTypes.length === 0) { 44816 return false; 44817 } 44818 44819 return allowedTypes.every(allowedType => allowedType === 'image' || allowedType.startsWith('image/')); 44820 }; 44821 44822 const gallery = multiple && onlyAllowsImages(); 44823 const POPOVER_PROPS = { 44824 isAlternate: true 44825 }; 44826 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Dropdown, { 44827 popoverProps: POPOVER_PROPS, 44828 contentClassName: "block-editor-media-replace-flow__options", 44829 renderToggle: _ref3 => { 44830 let { 44831 isOpen, 44832 onToggle 44833 } = _ref3; 44834 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, { 44835 ref: editMediaButtonRef, 44836 "aria-expanded": isOpen, 44837 "aria-haspopup": "true", 44838 onClick: onToggle, 44839 onKeyDown: openOnArrowDown 44840 }, name); 44841 }, 44842 renderContent: _ref4 => { 44843 let { 44844 onClose 44845 } = _ref4; 44846 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.NavigableMenu, { 44847 className: "block-editor-media-replace-flow__media-upload-menu" 44848 }, (0,external_wp_element_namespaceObject.createElement)(media_upload, { 44849 gallery: gallery, 44850 addToGallery: addToGallery, 44851 multiple: multiple, 44852 value: multiple ? mediaIds : mediaId, 44853 onSelect: media => selectMedia(media, onClose), 44854 allowedTypes: allowedTypes, 44855 onClose: onCloseModal, 44856 render: _ref5 => { 44857 let { 44858 open 44859 } = _ref5; 44860 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, { 44861 icon: library_media, 44862 onClick: open 44863 }, (0,external_wp_i18n_namespaceObject.__)('Open Media Library')); 44864 } 44865 }), (0,external_wp_element_namespaceObject.createElement)(media_upload_check, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FormFileUpload, { 44866 onChange: event => { 44867 uploadFiles(event, onClose); 44868 }, 44869 accept: accept, 44870 multiple: multiple, 44871 render: _ref6 => { 44872 let { 44873 openFileDialog 44874 } = _ref6; 44875 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, { 44876 icon: library_upload, 44877 onClick: () => { 44878 openFileDialog(); 44879 } 44880 }, (0,external_wp_i18n_namespaceObject.__)('Upload')); 44881 } 44882 })), children), onSelectURL && // eslint-disable-next-line jsx-a11y/no-noninteractive-element-interactions 44883 (0,external_wp_element_namespaceObject.createElement)("form", { 44884 className: "block-editor-media-flow__url-input" 44885 }, (0,external_wp_element_namespaceObject.createElement)("span", { 44886 className: "block-editor-media-replace-flow__image-url-label" 44887 }, (0,external_wp_i18n_namespaceObject.__)('Current media URL:')), (0,external_wp_element_namespaceObject.createElement)(link_control, { 44888 value: { 44889 url: mediaURLValue 44890 }, 44891 settings: [], 44892 showSuggestions: false, 44893 onChange: _ref7 => { 44894 let { 44895 url 44896 } = _ref7; 44897 setMediaURLValue(url); 44898 onSelectURL(url); 44899 editMediaButtonRef.current.focus(); 44900 } 44901 }))); 44902 } 44903 }); 44904 }; 44905 /** 44906 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/media-replace-flow/README.md 44907 */ 44908 44909 44910 /* harmony default export */ var media_replace_flow = ((0,external_wp_compose_namespaceObject.compose)([(0,external_wp_data_namespaceObject.withDispatch)(dispatch => { 44911 const { 44912 createNotice, 44913 removeNotice 44914 } = dispatch(external_wp_notices_namespaceObject.store); 44915 return { 44916 createNotice, 44917 removeNotice 44918 }; 44919 }), (0,external_wp_components_namespaceObject.withFilters)('editor.MediaReplaceFlow')])(MediaReplaceFlow)); 44920 44921 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/url-popover/link-viewer-url.js 44922 44923 44924 /** 44925 * External dependencies 44926 */ 44927 44928 /** 44929 * WordPress dependencies 44930 */ 44931 44932 44933 44934 function LinkViewerURL(_ref) { 44935 let { 44936 url, 44937 urlLabel, 44938 className 44939 } = _ref; 44940 const linkClassName = classnames_default()(className, 'block-editor-url-popover__link-viewer-url'); 44941 44942 if (!url) { 44943 return (0,external_wp_element_namespaceObject.createElement)("span", { 44944 className: linkClassName 44945 }); 44946 } 44947 44948 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ExternalLink, { 44949 className: linkClassName, 44950 href: url 44951 }, urlLabel || (0,external_wp_url_namespaceObject.filterURLForDisplay)((0,external_wp_url_namespaceObject.safeDecodeURI)(url))); 44952 } 44953 44954 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/url-popover/link-viewer.js 44955 44956 44957 44958 /** 44959 * External dependencies 44960 */ 44961 44962 /** 44963 * WordPress dependencies 44964 */ 44965 44966 44967 44968 44969 /** 44970 * Internal dependencies 44971 */ 44972 44973 44974 function LinkViewer(_ref) { 44975 let { 44976 className, 44977 linkClassName, 44978 onEditLinkClick, 44979 url, 44980 urlLabel, 44981 ...props 44982 } = _ref; 44983 return (0,external_wp_element_namespaceObject.createElement)("div", _extends({ 44984 className: classnames_default()('block-editor-url-popover__link-viewer', className) 44985 }, props), (0,external_wp_element_namespaceObject.createElement)(LinkViewerURL, { 44986 url: url, 44987 urlLabel: urlLabel, 44988 className: linkClassName 44989 }), onEditLinkClick && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 44990 icon: library_edit, 44991 label: (0,external_wp_i18n_namespaceObject.__)('Edit'), 44992 onClick: onEditLinkClick 44993 })); 44994 } 44995 44996 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/url-popover/link-editor.js 44997 44998 44999 45000 /** 45001 * External dependencies 45002 */ 45003 45004 /** 45005 * WordPress dependencies 45006 */ 45007 45008 45009 45010 45011 /** 45012 * Internal dependencies 45013 */ 45014 45015 45016 function LinkEditor(_ref) { 45017 let { 45018 autocompleteRef, 45019 className, 45020 onChangeInputValue, 45021 value, 45022 ...props 45023 } = _ref; 45024 return (0,external_wp_element_namespaceObject.createElement)("form", _extends({ 45025 className: classnames_default()('block-editor-url-popover__link-editor', className) 45026 }, props), (0,external_wp_element_namespaceObject.createElement)(url_input, { 45027 value: value, 45028 onChange: onChangeInputValue, 45029 autocompleteRef: autocompleteRef 45030 }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 45031 icon: keyboard_return, 45032 label: (0,external_wp_i18n_namespaceObject.__)('Apply'), 45033 type: "submit" 45034 })); 45035 } 45036 45037 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/url-popover/index.js 45038 45039 45040 45041 /** 45042 * WordPress dependencies 45043 */ 45044 45045 45046 45047 45048 /** 45049 * Internal dependencies 45050 */ 45051 45052 45053 45054 45055 function URLPopover(_ref) { 45056 let { 45057 additionalControls, 45058 children, 45059 renderSettings, 45060 position = 'bottom center', 45061 focusOnMount = 'firstElement', 45062 ...popoverProps 45063 } = _ref; 45064 const [isSettingsExpanded, setIsSettingsExpanded] = (0,external_wp_element_namespaceObject.useState)(false); 45065 const showSettings = !!renderSettings && isSettingsExpanded; 45066 45067 const toggleSettingsVisibility = () => { 45068 setIsSettingsExpanded(!isSettingsExpanded); 45069 }; 45070 45071 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Popover, _extends({ 45072 className: "block-editor-url-popover", 45073 focusOnMount: focusOnMount, 45074 position: position 45075 }, popoverProps), (0,external_wp_element_namespaceObject.createElement)("div", { 45076 className: "block-editor-url-popover__input-container" 45077 }, (0,external_wp_element_namespaceObject.createElement)("div", { 45078 className: "block-editor-url-popover__row" 45079 }, children, !!renderSettings && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 45080 className: "block-editor-url-popover__settings-toggle", 45081 icon: chevron_down, 45082 label: (0,external_wp_i18n_namespaceObject.__)('Link settings'), 45083 onClick: toggleSettingsVisibility, 45084 "aria-expanded": isSettingsExpanded 45085 })), showSettings && (0,external_wp_element_namespaceObject.createElement)("div", { 45086 className: "block-editor-url-popover__row block-editor-url-popover__settings" 45087 }, renderSettings())), additionalControls && !showSettings && (0,external_wp_element_namespaceObject.createElement)("div", { 45088 className: "block-editor-url-popover__additional-controls" 45089 }, additionalControls)); 45090 } 45091 45092 URLPopover.LinkEditor = LinkEditor; 45093 URLPopover.LinkViewer = LinkViewer; 45094 /** 45095 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/url-popover/README.md 45096 */ 45097 45098 /* harmony default export */ var url_popover = (URLPopover); 45099 45100 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/media-placeholder/index.js 45101 45102 45103 /** 45104 * External dependencies 45105 */ 45106 45107 45108 /** 45109 * WordPress dependencies 45110 */ 45111 45112 45113 45114 45115 45116 45117 /** 45118 * Internal dependencies 45119 */ 45120 45121 45122 45123 45124 45125 45126 const InsertFromURLPopover = _ref => { 45127 let { 45128 src, 45129 onChange, 45130 onSubmit, 45131 onClose 45132 } = _ref; 45133 return (0,external_wp_element_namespaceObject.createElement)(url_popover, { 45134 onClose: onClose 45135 }, (0,external_wp_element_namespaceObject.createElement)("form", { 45136 className: "block-editor-media-placeholder__url-input-form", 45137 onSubmit: onSubmit 45138 }, (0,external_wp_element_namespaceObject.createElement)("input", { 45139 className: "block-editor-media-placeholder__url-input-field", 45140 type: "text", 45141 "aria-label": (0,external_wp_i18n_namespaceObject.__)('URL'), 45142 placeholder: (0,external_wp_i18n_namespaceObject.__)('Paste or type URL'), 45143 onChange: onChange, 45144 value: src 45145 }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 45146 className: "block-editor-media-placeholder__url-input-submit-button", 45147 icon: keyboard_return, 45148 label: (0,external_wp_i18n_namespaceObject.__)('Apply'), 45149 type: "submit" 45150 }))); 45151 }; 45152 45153 function MediaPlaceholder(_ref2) { 45154 let { 45155 value = {}, 45156 allowedTypes, 45157 className, 45158 icon, 45159 labels = {}, 45160 mediaPreview, 45161 notices, 45162 isAppender, 45163 accept, 45164 addToGallery, 45165 multiple = false, 45166 handleUpload = true, 45167 disableDropZone, 45168 disableMediaButtons, 45169 onError, 45170 onSelect, 45171 onCancel, 45172 onSelectURL, 45173 onDoubleClick, 45174 onFilesPreUpload = external_lodash_namespaceObject.noop, 45175 onHTMLDrop = external_lodash_namespaceObject.noop, 45176 onClose = external_lodash_namespaceObject.noop, 45177 children, 45178 mediaLibraryButton, 45179 placeholder, 45180 style 45181 } = _ref2; 45182 const mediaUpload = (0,external_wp_data_namespaceObject.useSelect)(select => { 45183 const { 45184 getSettings 45185 } = select(store); 45186 return getSettings().mediaUpload; 45187 }, []); 45188 const [src, setSrc] = (0,external_wp_element_namespaceObject.useState)(''); 45189 const [isURLInputVisible, setIsURLInputVisible] = (0,external_wp_element_namespaceObject.useState)(false); 45190 (0,external_wp_element_namespaceObject.useEffect)(() => { 45191 var _value$src; 45192 45193 setSrc((_value$src = value === null || value === void 0 ? void 0 : value.src) !== null && _value$src !== void 0 ? _value$src : ''); 45194 }, [value === null || value === void 0 ? void 0 : value.src]); 45195 45196 const onlyAllowsImages = () => { 45197 if (!allowedTypes || allowedTypes.length === 0) { 45198 return false; 45199 } 45200 45201 return allowedTypes.every(allowedType => allowedType === 'image' || allowedType.startsWith('image/')); 45202 }; 45203 45204 const onChangeSrc = event => { 45205 setSrc(event.target.value); 45206 }; 45207 45208 const openURLInput = () => { 45209 setIsURLInputVisible(true); 45210 }; 45211 45212 const closeURLInput = () => { 45213 setIsURLInputVisible(false); 45214 }; 45215 45216 const onSubmitSrc = event => { 45217 event.preventDefault(); 45218 45219 if (src && onSelectURL) { 45220 onSelectURL(src); 45221 closeURLInput(); 45222 } 45223 }; 45224 45225 const onFilesUpload = files => { 45226 if (!handleUpload) { 45227 return onSelect(files); 45228 } 45229 45230 onFilesPreUpload(files); 45231 let setMedia; 45232 45233 if (multiple) { 45234 if (addToGallery) { 45235 // Since the setMedia function runs multiple times per upload group 45236 // and is passed newMedia containing every item in its group each time, we must 45237 // filter out whatever this upload group had previously returned to the 45238 // gallery before adding and returning the image array with replacement newMedia 45239 // values. 45240 // Define an array to store urls from newMedia between subsequent function calls. 45241 let lastMediaPassed = []; 45242 45243 setMedia = newMedia => { 45244 // Remove any images this upload group is responsible for (lastMediaPassed). 45245 // Their replacements are contained in newMedia. 45246 const filteredMedia = (value !== null && value !== void 0 ? value : []).filter(item => { 45247 // If Item has id, only remove it if lastMediaPassed has an item with that id. 45248 if (item.id) { 45249 return !lastMediaPassed.some( // Be sure to convert to number for comparison. 45250 _ref3 => { 45251 let { 45252 id 45253 } = _ref3; 45254 return Number(id) === Number(item.id); 45255 }); 45256 } // Compare transient images via .includes since gallery may append extra info onto the url. 45257 45258 45259 return !lastMediaPassed.some(_ref4 => { 45260 let { 45261 urlSlug 45262 } = _ref4; 45263 return item.url.includes(urlSlug); 45264 }); 45265 }); // Return the filtered media array along with newMedia. 45266 45267 onSelect(filteredMedia.concat(newMedia)); // Reset lastMediaPassed and set it with ids and urls from newMedia. 45268 45269 lastMediaPassed = newMedia.map(media => { 45270 // Add everything up to '.fileType' to compare via .includes. 45271 const cutOffIndex = media.url.lastIndexOf('.'); 45272 const urlSlug = media.url.slice(0, cutOffIndex); 45273 return { 45274 id: media.id, 45275 urlSlug 45276 }; 45277 }); 45278 }; 45279 } else { 45280 setMedia = onSelect; 45281 } 45282 } else { 45283 setMedia = _ref5 => { 45284 let [media] = _ref5; 45285 return onSelect(media); 45286 }; 45287 } 45288 45289 mediaUpload({ 45290 allowedTypes, 45291 filesList: files, 45292 onFileChange: setMedia, 45293 onError 45294 }); 45295 }; 45296 45297 const onUpload = event => { 45298 onFilesUpload(event.target.files); 45299 }; 45300 45301 const defaultRenderPlaceholder = content => { 45302 let { 45303 instructions, 45304 title 45305 } = labels; 45306 45307 if (!mediaUpload && !onSelectURL) { 45308 instructions = (0,external_wp_i18n_namespaceObject.__)('To edit this block, you need permission to upload media.'); 45309 } 45310 45311 if (instructions === undefined || title === undefined) { 45312 const typesAllowed = allowedTypes !== null && allowedTypes !== void 0 ? allowedTypes : []; 45313 const [firstAllowedType] = typesAllowed; 45314 const isOneType = 1 === typesAllowed.length; 45315 const isAudio = isOneType && 'audio' === firstAllowedType; 45316 const isImage = isOneType && 'image' === firstAllowedType; 45317 const isVideo = isOneType && 'video' === firstAllowedType; 45318 45319 if (instructions === undefined && mediaUpload) { 45320 instructions = (0,external_wp_i18n_namespaceObject.__)('Upload a media file or pick one from your media library.'); 45321 45322 if (isAudio) { 45323 instructions = (0,external_wp_i18n_namespaceObject.__)('Upload an audio file, pick one from your media library, or add one with a URL.'); 45324 } else if (isImage) { 45325 instructions = (0,external_wp_i18n_namespaceObject.__)('Upload an image file, pick one from your media library, or add one with a URL.'); 45326 } else if (isVideo) { 45327 instructions = (0,external_wp_i18n_namespaceObject.__)('Upload a video file, pick one from your media library, or add one with a URL.'); 45328 } 45329 } 45330 45331 if (title === undefined) { 45332 title = (0,external_wp_i18n_namespaceObject.__)('Media'); 45333 45334 if (isAudio) { 45335 title = (0,external_wp_i18n_namespaceObject.__)('Audio'); 45336 } else if (isImage) { 45337 title = (0,external_wp_i18n_namespaceObject.__)('Image'); 45338 } else if (isVideo) { 45339 title = (0,external_wp_i18n_namespaceObject.__)('Video'); 45340 } 45341 } 45342 } 45343 45344 const placeholderClassName = classnames_default()('block-editor-media-placeholder', className, { 45345 'is-appender': isAppender 45346 }); 45347 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Placeholder, { 45348 icon: icon, 45349 label: title, 45350 instructions: instructions, 45351 className: placeholderClassName, 45352 notices: notices, 45353 onDoubleClick: onDoubleClick, 45354 preview: mediaPreview, 45355 style: style 45356 }, content, children); 45357 }; 45358 45359 const renderPlaceholder = placeholder !== null && placeholder !== void 0 ? placeholder : defaultRenderPlaceholder; 45360 45361 const renderDropZone = () => { 45362 if (disableDropZone) { 45363 return null; 45364 } 45365 45366 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.DropZone, { 45367 onFilesDrop: onFilesUpload, 45368 onHTMLDrop: onHTMLDrop 45369 }); 45370 }; 45371 45372 const renderCancelLink = () => { 45373 return onCancel && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 45374 className: "block-editor-media-placeholder__cancel-button", 45375 title: (0,external_wp_i18n_namespaceObject.__)('Cancel'), 45376 variant: "link", 45377 onClick: onCancel 45378 }, (0,external_wp_i18n_namespaceObject.__)('Cancel')); 45379 }; 45380 45381 const renderUrlSelectionUI = () => { 45382 return onSelectURL && (0,external_wp_element_namespaceObject.createElement)("div", { 45383 className: "block-editor-media-placeholder__url-input-container" 45384 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 45385 className: "block-editor-media-placeholder__button", 45386 onClick: openURLInput, 45387 isPressed: isURLInputVisible, 45388 variant: "tertiary" 45389 }, (0,external_wp_i18n_namespaceObject.__)('Insert from URL')), isURLInputVisible && (0,external_wp_element_namespaceObject.createElement)(InsertFromURLPopover, { 45390 src: src, 45391 onChange: onChangeSrc, 45392 onSubmit: onSubmitSrc, 45393 onClose: closeURLInput 45394 })); 45395 }; 45396 45397 const renderMediaUploadChecked = () => { 45398 const defaultButton = _ref6 => { 45399 let { 45400 open 45401 } = _ref6; 45402 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 45403 variant: "tertiary", 45404 onClick: () => { 45405 open(); 45406 } 45407 }, (0,external_wp_i18n_namespaceObject.__)('Media Library')); 45408 }; 45409 45410 const libraryButton = mediaLibraryButton !== null && mediaLibraryButton !== void 0 ? mediaLibraryButton : defaultButton; 45411 const uploadMediaLibraryButton = (0,external_wp_element_namespaceObject.createElement)(media_upload, { 45412 addToGallery: addToGallery, 45413 gallery: multiple && onlyAllowsImages(), 45414 multiple: multiple, 45415 onSelect: onSelect, 45416 onClose: onClose, 45417 allowedTypes: allowedTypes, 45418 value: Array.isArray(value) ? value.map(_ref7 => { 45419 let { 45420 id 45421 } = _ref7; 45422 return id; 45423 }) : value.id, 45424 render: libraryButton 45425 }); 45426 45427 if (mediaUpload && isAppender) { 45428 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, renderDropZone(), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FormFileUpload, { 45429 onChange: onUpload, 45430 accept: accept, 45431 multiple: multiple, 45432 render: _ref8 => { 45433 let { 45434 openFileDialog 45435 } = _ref8; 45436 const content = (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 45437 variant: "primary", 45438 className: classnames_default()('block-editor-media-placeholder__button', 'block-editor-media-placeholder__upload-button'), 45439 onClick: openFileDialog 45440 }, (0,external_wp_i18n_namespaceObject.__)('Upload')), uploadMediaLibraryButton, renderUrlSelectionUI(), renderCancelLink()); 45441 return renderPlaceholder(content); 45442 } 45443 })); 45444 } 45445 45446 if (mediaUpload) { 45447 const content = (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, renderDropZone(), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FormFileUpload, { 45448 variant: "primary", 45449 className: classnames_default()('block-editor-media-placeholder__button', 'block-editor-media-placeholder__upload-button'), 45450 onChange: onUpload, 45451 accept: accept, 45452 multiple: multiple 45453 }, (0,external_wp_i18n_namespaceObject.__)('Upload')), uploadMediaLibraryButton, renderUrlSelectionUI(), renderCancelLink()); 45454 return renderPlaceholder(content); 45455 } 45456 45457 return renderPlaceholder(uploadMediaLibraryButton); 45458 }; 45459 45460 if (disableMediaButtons) { 45461 return (0,external_wp_element_namespaceObject.createElement)(media_upload_check, null, renderDropZone()); 45462 } 45463 45464 return (0,external_wp_element_namespaceObject.createElement)(media_upload_check, { 45465 fallback: renderPlaceholder(renderUrlSelectionUI()) 45466 }, renderMediaUploadChecked()); 45467 } 45468 /** 45469 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/media-placeholder/README.md 45470 */ 45471 45472 /* harmony default export */ var media_placeholder = ((0,external_wp_components_namespaceObject.withFilters)('editor.MediaPlaceholder')(MediaPlaceholder)); 45473 45474 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/panel-color-settings/index.js 45475 45476 45477 45478 /** 45479 * Internal dependencies 45480 */ 45481 45482 45483 const PanelColorSettings = _ref => { 45484 let { 45485 colorSettings, 45486 ...props 45487 } = _ref; 45488 const settings = colorSettings.map(setting => { 45489 if (!setting) { 45490 return setting; 45491 } 45492 45493 const { 45494 value, 45495 onChange, 45496 ...otherSettings 45497 } = setting; 45498 return { ...otherSettings, 45499 colorValue: value, 45500 onColorChange: onChange 45501 }; 45502 }); 45503 return (0,external_wp_element_namespaceObject.createElement)(panel_color_gradient_settings, _extends({ 45504 settings: settings, 45505 gradients: [], 45506 disableCustomGradients: true 45507 }, props)); 45508 }; 45509 45510 /* harmony default export */ var panel_color_settings = (PanelColorSettings); 45511 45512 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/rich-text/format-toolbar/index.js 45513 45514 45515 /** 45516 * External dependencies 45517 */ 45518 45519 45520 /** 45521 * WordPress dependencies 45522 */ 45523 45524 45525 45526 45527 const format_toolbar_POPOVER_PROPS = { 45528 position: 'bottom right', 45529 isAlternate: true 45530 }; 45531 45532 const FormatToolbar = () => { 45533 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, ['bold', 'italic', 'link'].map(format => (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Slot, { 45534 name: `RichText.ToolbarControls.$format}`, 45535 key: format 45536 })), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Slot, { 45537 name: "RichText.ToolbarControls" 45538 }, fills => { 45539 if (!fills.length) { 45540 return null; 45541 } 45542 45543 const allProps = fills.map(_ref => { 45544 let [{ 45545 props 45546 }] = _ref; 45547 return props; 45548 }); 45549 const hasActive = allProps.some(_ref2 => { 45550 let { 45551 isActive 45552 } = _ref2; 45553 return isActive; 45554 }); 45555 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarItem, null, toggleProps => (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.DropdownMenu, { 45556 icon: chevron_down 45557 /* translators: button label text should, if possible, be under 16 characters. */ 45558 , 45559 label: (0,external_wp_i18n_namespaceObject.__)('More'), 45560 toggleProps: { ...toggleProps, 45561 className: classnames_default()(toggleProps.className, { 45562 'is-pressed': hasActive 45563 }), 45564 describedBy: (0,external_wp_i18n_namespaceObject.__)('Displays more block tools') 45565 }, 45566 controls: (0,external_lodash_namespaceObject.orderBy)(fills.map(_ref3 => { 45567 let [{ 45568 props 45569 }] = _ref3; 45570 return props; 45571 }), 'title'), 45572 popoverProps: format_toolbar_POPOVER_PROPS 45573 })); 45574 })); 45575 }; 45576 45577 /* harmony default export */ var format_toolbar = (FormatToolbar); 45578 45579 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/rich-text/format-toolbar-container.js 45580 45581 45582 /** 45583 * WordPress dependencies 45584 */ 45585 45586 /** 45587 * Internal dependencies 45588 */ 45589 45590 45591 45592 45593 const FormatToolbarContainer = _ref => { 45594 let { 45595 inline, 45596 anchorRef 45597 } = _ref; 45598 45599 if (inline) { 45600 // Render in popover. 45601 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Popover, { 45602 noArrow: true, 45603 position: "top center", 45604 focusOnMount: false, 45605 anchorRef: anchorRef, 45606 className: "block-editor-rich-text__inline-format-toolbar", 45607 __unstableSlotName: "block-toolbar" 45608 }, (0,external_wp_element_namespaceObject.createElement)("div", { 45609 className: "block-editor-rich-text__inline-format-toolbar-group" 45610 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarGroup, null, (0,external_wp_element_namespaceObject.createElement)(format_toolbar, null)))); 45611 } // Render regular toolbar. 45612 45613 45614 return (0,external_wp_element_namespaceObject.createElement)(block_controls, { 45615 group: "inline" 45616 }, (0,external_wp_element_namespaceObject.createElement)(format_toolbar, null)); 45617 }; 45618 45619 /* harmony default export */ var format_toolbar_container = (FormatToolbarContainer); 45620 45621 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/rich-text/use-undo-automatic-change.js 45622 /** 45623 * WordPress dependencies 45624 */ 45625 45626 45627 45628 /** 45629 * Internal dependencies 45630 */ 45631 45632 45633 function useUndoAutomaticChange() { 45634 const { 45635 didAutomaticChange, 45636 getSettings 45637 } = (0,external_wp_data_namespaceObject.useSelect)(store); 45638 return (0,external_wp_compose_namespaceObject.useRefEffect)(element => { 45639 function onKeyDown(event) { 45640 const { 45641 keyCode 45642 } = event; 45643 45644 if (event.defaultPrevented) { 45645 return; 45646 } 45647 45648 if (keyCode !== external_wp_keycodes_namespaceObject.DELETE && keyCode !== external_wp_keycodes_namespaceObject.BACKSPACE && keyCode !== external_wp_keycodes_namespaceObject.ESCAPE) { 45649 return; 45650 } 45651 45652 if (!didAutomaticChange()) { 45653 return; 45654 } 45655 45656 event.preventDefault(); 45657 45658 getSettings().__experimentalUndo(); 45659 } 45660 45661 element.addEventListener('keydown', onKeyDown); 45662 return () => { 45663 element.removeEventListener('keydown', onKeyDown); 45664 }; 45665 }, []); 45666 } 45667 45668 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/rich-text/use-caret-in-format.js 45669 /** 45670 * WordPress dependencies 45671 */ 45672 45673 45674 /** 45675 * Internal dependencies 45676 */ 45677 45678 45679 function useCaretInFormat(_ref) { 45680 let { 45681 value 45682 } = _ref; 45683 const hasActiveFormats = value.activeFormats && !!value.activeFormats.length; 45684 const { 45685 isCaretWithinFormattedText 45686 } = (0,external_wp_data_namespaceObject.useSelect)(store); 45687 const { 45688 enterFormattedText, 45689 exitFormattedText 45690 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 45691 (0,external_wp_element_namespaceObject.useEffect)(() => { 45692 if (hasActiveFormats) { 45693 if (!isCaretWithinFormattedText()) { 45694 enterFormattedText(); 45695 } 45696 } else if (isCaretWithinFormattedText()) { 45697 exitFormattedText(); 45698 } 45699 }, [hasActiveFormats]); 45700 } 45701 45702 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/rich-text/use-mark-persistent.js 45703 /** 45704 * WordPress dependencies 45705 */ 45706 45707 45708 /** 45709 * Internal dependencies 45710 */ 45711 45712 45713 function useMarkPersistent(_ref) { 45714 let { 45715 html, 45716 value 45717 } = _ref; 45718 const previousText = (0,external_wp_element_namespaceObject.useRef)(); 45719 const hasActiveFormats = value.activeFormats && !!value.activeFormats.length; 45720 const { 45721 __unstableMarkLastChangeAsPersistent 45722 } = (0,external_wp_data_namespaceObject.useDispatch)(store); // Must be set synchronously to make sure it applies to the last change. 45723 45724 (0,external_wp_element_namespaceObject.useLayoutEffect)(() => { 45725 // Ignore mount. 45726 if (!previousText.current) { 45727 previousText.current = value.text; 45728 return; 45729 } // Text input, so don't create an undo level for every character. 45730 // Create an undo level after 1 second of no input. 45731 45732 45733 if (previousText.current !== value.text) { 45734 const timeout = window.setTimeout(() => { 45735 __unstableMarkLastChangeAsPersistent(); 45736 }, 1000); 45737 previousText.current = value.text; 45738 return () => { 45739 window.clearTimeout(timeout); 45740 }; 45741 } 45742 45743 __unstableMarkLastChangeAsPersistent(); 45744 }, [html, hasActiveFormats]); 45745 } 45746 45747 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/rich-text/file-paste-handler.js 45748 /** 45749 * WordPress dependencies 45750 */ 45751 45752 function filePasteHandler(files) { 45753 return files.filter(_ref => { 45754 let { 45755 type 45756 } = _ref; 45757 return /^image\/(?:jpe?g|png|gif|webp)$/.test(type); 45758 }).map(file => `<img src="${(0,external_wp_blob_namespaceObject.createBlobURL)(file)}">`).join(''); 45759 } 45760 45761 ;// CONCATENATED MODULE: external ["wp","shortcode"] 45762 var external_wp_shortcode_namespaceObject = window["wp"]["shortcode"]; 45763 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/rich-text/utils.js 45764 45765 45766 /** 45767 * WordPress dependencies 45768 */ 45769 45770 45771 45772 45773 function addActiveFormats(value, activeFormats) { 45774 if (activeFormats !== null && activeFormats !== void 0 && activeFormats.length) { 45775 let index = value.formats.length; 45776 45777 while (index--) { 45778 value.formats[index] = [...activeFormats, ...(value.formats[index] || [])]; 45779 } 45780 } 45781 } 45782 /** 45783 * Get the multiline tag based on the multiline prop. 45784 * 45785 * @param {?(string|boolean)} multiline The multiline prop. 45786 * 45787 * @return {?string} The multiline tag. 45788 */ 45789 45790 function getMultilineTag(multiline) { 45791 if (multiline !== true && multiline !== 'p' && multiline !== 'li') { 45792 return; 45793 } 45794 45795 return multiline === true ? 'p' : multiline; 45796 } 45797 function getAllowedFormats(_ref) { 45798 let { 45799 allowedFormats, 45800 formattingControls, 45801 disableFormats 45802 } = _ref; 45803 45804 if (disableFormats) { 45805 return getAllowedFormats.EMPTY_ARRAY; 45806 } 45807 45808 if (!allowedFormats && !formattingControls) { 45809 return; 45810 } 45811 45812 if (allowedFormats) { 45813 return allowedFormats; 45814 } 45815 45816 external_wp_deprecated_default()('wp.blockEditor.RichText formattingControls prop', { 45817 since: '5.4', 45818 alternative: 'allowedFormats', 45819 version: '6.2' 45820 }); 45821 return formattingControls.map(name => `core/$name}`); 45822 } 45823 getAllowedFormats.EMPTY_ARRAY = []; 45824 const isShortcode = text => (0,external_wp_shortcode_namespaceObject.regexp)('.*').test(text); 45825 /** 45826 * Creates a link from pasted URL. 45827 * Creates a paragraph block containing a link to the URL, and calls `onReplace`. 45828 * 45829 * @param {string} url The URL that could not be embedded. 45830 * @param {Function} onReplace Function to call with the created fallback block. 45831 */ 45832 45833 function createLinkInParagraph(url, onReplace) { 45834 const link = createElement("a", { 45835 href: url 45836 }, url); 45837 onReplace(createBlock('core/paragraph', { 45838 content: renderToString(link) 45839 })); 45840 } 45841 45842 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/rich-text/split-value.js 45843 /** 45844 * WordPress dependencies 45845 */ 45846 45847 /* 45848 * Signals to the RichText owner that the block can be replaced with two blocks 45849 * as a result of splitting the block by pressing enter, or with blocks as a 45850 * result of splitting the block by pasting block content in the instance. 45851 */ 45852 45853 function splitValue(_ref) { 45854 let { 45855 value, 45856 pastedBlocks = [], 45857 onReplace, 45858 onSplit, 45859 onSplitMiddle, 45860 multilineTag 45861 } = _ref; 45862 45863 if (!onReplace || !onSplit) { 45864 return; 45865 } // Ensure the value has a selection. This might happen when trying to split 45866 // an empty value before there was a `selectionchange` event. 45867 45868 45869 const { 45870 start = 0, 45871 end = 0 45872 } = value; 45873 const valueWithEnsuredSelection = { ...value, 45874 start, 45875 end 45876 }; 45877 const blocks = []; 45878 const [before, after] = (0,external_wp_richText_namespaceObject.split)(valueWithEnsuredSelection); 45879 const hasPastedBlocks = pastedBlocks.length > 0; 45880 let lastPastedBlockIndex = -1; // Consider the after value to be the original it is not empty and the 45881 // before value *is* empty. 45882 45883 const isAfterOriginal = (0,external_wp_richText_namespaceObject.isEmpty)(before) && !(0,external_wp_richText_namespaceObject.isEmpty)(after); // Create a block with the content before the caret if there's no pasted 45884 // blocks, or if there are pasted blocks and the value is not empty. We do 45885 // not want a leading empty block on paste, but we do if split with e.g. the 45886 // enter key. 45887 45888 if (!hasPastedBlocks || !(0,external_wp_richText_namespaceObject.isEmpty)(before)) { 45889 blocks.push(onSplit((0,external_wp_richText_namespaceObject.toHTMLString)({ 45890 value: before, 45891 multilineTag 45892 }), !isAfterOriginal)); 45893 lastPastedBlockIndex += 1; 45894 } 45895 45896 if (hasPastedBlocks) { 45897 blocks.push(...pastedBlocks); 45898 lastPastedBlockIndex += pastedBlocks.length; 45899 } else if (onSplitMiddle) { 45900 blocks.push(onSplitMiddle()); 45901 } // If there's pasted blocks, append a block with non empty content / after 45902 // the caret. Otherwise, do append an empty block if there is no 45903 // `onSplitMiddle` prop, but if there is and the content is empty, the 45904 // middle block is enough to set focus in. 45905 45906 45907 if (hasPastedBlocks ? !(0,external_wp_richText_namespaceObject.isEmpty)(after) : !onSplitMiddle || !(0,external_wp_richText_namespaceObject.isEmpty)(after)) { 45908 blocks.push(onSplit((0,external_wp_richText_namespaceObject.toHTMLString)({ 45909 value: after, 45910 multilineTag 45911 }), isAfterOriginal)); 45912 } // If there are pasted blocks, set the selection to the last one. Otherwise, 45913 // set the selection to the second block. 45914 45915 45916 const indexToSelect = hasPastedBlocks ? lastPastedBlockIndex : 1; // If there are pasted blocks, move the caret to the end of the selected 45917 // block Otherwise, retain the default value. 45918 45919 const initialPosition = hasPastedBlocks ? -1 : 0; 45920 onReplace(blocks, indexToSelect, initialPosition); 45921 } 45922 45923 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/rich-text/use-paste-handler.js 45924 /** 45925 * WordPress dependencies 45926 */ 45927 45928 45929 45930 45931 45932 45933 /** 45934 * Internal dependencies 45935 */ 45936 45937 45938 45939 45940 45941 /** @typedef {import('@wordpress/rich-text').RichTextValue} RichTextValue */ 45942 45943 /** 45944 * Replaces line separators with line breaks if not multiline. 45945 * Replaces line breaks with line separators if multiline. 45946 * 45947 * @param {RichTextValue} value Value to adjust. 45948 * @param {boolean} isMultiline Whether to adjust to multiline or not. 45949 * 45950 * @return {RichTextValue} Adjusted value. 45951 */ 45952 45953 function adjustLines(value, isMultiline) { 45954 if (isMultiline) { 45955 return (0,external_wp_richText_namespaceObject.replace)(value, /\n+/g, external_wp_richText_namespaceObject.__UNSTABLE_LINE_SEPARATOR); 45956 } 45957 45958 return (0,external_wp_richText_namespaceObject.replace)(value, new RegExp(external_wp_richText_namespaceObject.__UNSTABLE_LINE_SEPARATOR, 'g'), '\n'); 45959 } 45960 45961 function usePasteHandler(props) { 45962 const propsRef = (0,external_wp_element_namespaceObject.useRef)(props); 45963 propsRef.current = props; 45964 return (0,external_wp_compose_namespaceObject.useRefEffect)(element => { 45965 function _onPaste(event) { 45966 const { 45967 isSelected, 45968 disableFormats, 45969 onChange, 45970 value, 45971 formatTypes, 45972 tagName, 45973 onReplace, 45974 onSplit, 45975 onSplitMiddle, 45976 __unstableEmbedURLOnPaste, 45977 multilineTag, 45978 preserveWhiteSpace, 45979 pastePlainText 45980 } = propsRef.current; 45981 45982 if (!isSelected) { 45983 return; 45984 } 45985 45986 const { 45987 clipboardData 45988 } = event; 45989 let plainText = ''; 45990 let html = ''; // IE11 only supports `Text` as an argument for `getData` and will 45991 // otherwise throw an invalid argument error, so we try the standard 45992 // arguments first, then fallback to `Text` if they fail. 45993 45994 try { 45995 plainText = clipboardData.getData('text/plain'); 45996 html = clipboardData.getData('text/html'); 45997 } catch (error1) { 45998 try { 45999 html = clipboardData.getData('Text'); 46000 } catch (error2) { 46001 // Some browsers like UC Browser paste plain text by default and 46002 // don't support clipboardData at all, so allow default 46003 // behaviour. 46004 return; 46005 } 46006 } // Remove Windows-specific metadata appended within copied HTML text. 46007 46008 46009 html = removeWindowsFragments(html); // Strip meta tag. 46010 46011 html = removeCharsetMetaTag(html); 46012 event.preventDefault(); // Allows us to ask for this information when we get a report. 46013 46014 window.console.log('Received HTML:\n\n', html); 46015 window.console.log('Received plain text:\n\n', plainText); 46016 46017 if (disableFormats) { 46018 onChange((0,external_wp_richText_namespaceObject.insert)(value, plainText)); 46019 return; 46020 } 46021 46022 const transformed = formatTypes.reduce((accumlator, _ref) => { 46023 let { 46024 __unstablePasteRule 46025 } = _ref; 46026 46027 // Only allow one transform. 46028 if (__unstablePasteRule && accumlator === value) { 46029 accumlator = __unstablePasteRule(value, { 46030 html, 46031 plainText 46032 }); 46033 } 46034 46035 return accumlator; 46036 }, value); 46037 46038 if (transformed !== value) { 46039 onChange(transformed); 46040 return; 46041 } 46042 46043 const files = [...(0,external_wp_dom_namespaceObject.getFilesFromDataTransfer)(clipboardData)]; 46044 const isInternal = clipboardData.getData('rich-text') === 'true'; // If the data comes from a rich text instance, we can directly use it 46045 // without filtering the data. The filters are only meant for externally 46046 // pasted content and remove inline styles. 46047 46048 if (isInternal) { 46049 const pastedMultilineTag = clipboardData.getData('rich-text-multi-line-tag') || undefined; 46050 let pastedValue = (0,external_wp_richText_namespaceObject.create)({ 46051 html, 46052 multilineTag: pastedMultilineTag, 46053 multilineWrapperTags: pastedMultilineTag === 'li' ? ['ul', 'ol'] : undefined, 46054 preserveWhiteSpace 46055 }); 46056 pastedValue = adjustLines(pastedValue, !!multilineTag); 46057 addActiveFormats(pastedValue, value.activeFormats); 46058 onChange((0,external_wp_richText_namespaceObject.insert)(value, pastedValue)); 46059 return; 46060 } 46061 46062 if (pastePlainText) { 46063 onChange((0,external_wp_richText_namespaceObject.insert)(value, (0,external_wp_richText_namespaceObject.create)({ 46064 text: plainText 46065 }))); 46066 return; 46067 } // Process any attached files, unless we infer that the files in 46068 // question are redundant "screenshots" of the actual HTML payload, 46069 // as created by certain office-type programs. 46070 // 46071 // @see shouldDismissPastedFiles 46072 46073 46074 if (files !== null && files !== void 0 && files.length && !shouldDismissPastedFiles(files, html, plainText)) { 46075 const content = (0,external_wp_blocks_namespaceObject.pasteHandler)({ 46076 HTML: filePasteHandler(files), 46077 mode: 'BLOCKS', 46078 tagName, 46079 preserveWhiteSpace 46080 }); // Allows us to ask for this information when we get a report. 46081 // eslint-disable-next-line no-console 46082 46083 window.console.log('Received items:\n\n', files); 46084 46085 if (onReplace && (0,external_wp_richText_namespaceObject.isEmpty)(value)) { 46086 onReplace(content); 46087 } else { 46088 splitValue({ 46089 value, 46090 pastedBlocks: content, 46091 onReplace, 46092 onSplit, 46093 onSplitMiddle, 46094 multilineTag 46095 }); 46096 } 46097 46098 return; 46099 } 46100 46101 let mode = onReplace && onSplit ? 'AUTO' : 'INLINE'; // Force the blocks mode when the user is pasting 46102 // on a new line & the content resembles a shortcode. 46103 // Otherwise it's going to be detected as inline 46104 // and the shortcode won't be replaced. 46105 46106 if (mode === 'AUTO' && (0,external_wp_richText_namespaceObject.isEmpty)(value) && isShortcode(plainText)) { 46107 mode = 'BLOCKS'; 46108 } 46109 46110 if (__unstableEmbedURLOnPaste && (0,external_wp_richText_namespaceObject.isEmpty)(value) && (0,external_wp_url_namespaceObject.isURL)(plainText.trim())) { 46111 mode = 'BLOCKS'; 46112 } 46113 46114 const content = (0,external_wp_blocks_namespaceObject.pasteHandler)({ 46115 HTML: html, 46116 plainText, 46117 mode, 46118 tagName, 46119 preserveWhiteSpace 46120 }); 46121 46122 if (typeof content === 'string') { 46123 let valueToInsert = (0,external_wp_richText_namespaceObject.create)({ 46124 html: content 46125 }); // If the content should be multiline, we should process text 46126 // separated by a line break as separate lines. 46127 46128 valueToInsert = adjustLines(valueToInsert, !!multilineTag); 46129 addActiveFormats(valueToInsert, value.activeFormats); 46130 onChange((0,external_wp_richText_namespaceObject.insert)(value, valueToInsert)); 46131 } else if (content.length > 0) { 46132 if (onReplace && (0,external_wp_richText_namespaceObject.isEmpty)(value)) { 46133 onReplace(content, content.length - 1, -1); 46134 } else { 46135 splitValue({ 46136 value, 46137 pastedBlocks: content, 46138 onReplace, 46139 onSplit, 46140 onSplitMiddle, 46141 multilineTag 46142 }); 46143 } 46144 } 46145 } 46146 46147 element.addEventListener('paste', _onPaste); 46148 return () => { 46149 element.removeEventListener('paste', _onPaste); 46150 }; 46151 }, []); 46152 } 46153 /** 46154 * Normalizes a given string of HTML to remove the Windows specific "Fragment" comments 46155 * and any preceeding and trailing whitespace. 46156 * 46157 * @param {string} html the html to be normalized 46158 * @return {string} the normalized html 46159 */ 46160 46161 function removeWindowsFragments(html) { 46162 const startReg = /.*<!--StartFragment-->/s; 46163 const endReg = /<!--EndFragment-->.*/s; 46164 return html.replace(startReg, '').replace(endReg, ''); 46165 } 46166 /** 46167 * Removes the charset meta tag inserted by Chromium. 46168 * See: 46169 * - https://github.com/WordPress/gutenberg/issues/33585 46170 * - https://bugs.chromium.org/p/chromium/issues/detail?id=1264616#c4 46171 * 46172 * @param {string} html the html to be stripped of the meta tag. 46173 * @return {string} the cleaned html 46174 */ 46175 46176 46177 function removeCharsetMetaTag(html) { 46178 const metaTag = `<meta charset='utf-8'>`; 46179 46180 if (html.startsWith(metaTag)) { 46181 return html.slice(metaTag.length); 46182 } 46183 46184 return html; 46185 } 46186 46187 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/rich-text/prevent-event-discovery.js 46188 /** 46189 * WordPress dependencies 46190 */ 46191 46192 function preventEventDiscovery(value) { 46193 const searchText = 'tales of gutenberg'; 46194 const addText = ' 🐡🐢🦀🐤🦋🐘🐧🐹🦁🦄🦍🐼🐿🎃🐴🐝🐆🦕🦔🌱🍇π🍌🐉💧🥨🌌🍂🍠🥦🥚🥝🎟🥥🥒🛵🥖🍒🍯🎾🎲🐺🐚🐮⌛️'; 46195 const { 46196 start, 46197 text 46198 } = value; 46199 46200 if (start < searchText.length) { 46201 return value; 46202 } 46203 46204 const charactersBefore = text.slice(start - searchText.length, start); 46205 46206 if (charactersBefore.toLowerCase() !== searchText) { 46207 return value; 46208 } 46209 46210 return (0,external_wp_richText_namespaceObject.insert)(value, addText); 46211 } 46212 46213 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/rich-text/use-input-rules.js 46214 /** 46215 * External dependencies 46216 */ 46217 46218 /** 46219 * WordPress dependencies 46220 */ 46221 46222 46223 46224 46225 46226 46227 /** 46228 * Internal dependencies 46229 */ 46230 46231 46232 // A robust way to retain selection position through various 46233 // transforms is to insert a special character at the position and 46234 // then recover it. 46235 46236 const START_OF_SELECTED_AREA = '\u0086'; 46237 46238 function findSelection(blocks) { 46239 let i = blocks.length; 46240 46241 while (i--) { 46242 const attributeKey = (0,external_lodash_namespaceObject.findKey)(blocks[i].attributes, v => typeof v === 'string' && v.indexOf(START_OF_SELECTED_AREA) !== -1); 46243 46244 if (attributeKey) { 46245 blocks[i].attributes[attributeKey] = blocks[i].attributes[attributeKey].replace(START_OF_SELECTED_AREA, ''); 46246 return blocks[i].clientId; 46247 } 46248 46249 const nestedSelection = findSelection(blocks[i].innerBlocks); 46250 46251 if (nestedSelection) { 46252 return nestedSelection; 46253 } 46254 } 46255 } 46256 46257 function useInputRules(props) { 46258 const { 46259 __unstableMarkLastChangeAsPersistent, 46260 __unstableMarkAutomaticChange 46261 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 46262 const propsRef = (0,external_wp_element_namespaceObject.useRef)(props); 46263 propsRef.current = props; 46264 return (0,external_wp_compose_namespaceObject.useRefEffect)(element => { 46265 function inputRule() { 46266 const { 46267 value, 46268 onReplace, 46269 selectionChange 46270 } = propsRef.current; 46271 46272 if (!onReplace) { 46273 return; 46274 } 46275 46276 const { 46277 start, 46278 text 46279 } = value; 46280 const characterBefore = text.slice(start - 1, start); // The character right before the caret must be a plain space. 46281 46282 if (characterBefore !== ' ') { 46283 return; 46284 } 46285 46286 const trimmedTextBefore = text.slice(0, start).trim(); 46287 const prefixTransforms = (0,external_wp_blocks_namespaceObject.getBlockTransforms)('from').filter(_ref => { 46288 let { 46289 type 46290 } = _ref; 46291 return type === 'prefix'; 46292 }); 46293 const transformation = (0,external_wp_blocks_namespaceObject.findTransform)(prefixTransforms, _ref2 => { 46294 let { 46295 prefix 46296 } = _ref2; 46297 return trimmedTextBefore === prefix; 46298 }); 46299 46300 if (!transformation) { 46301 return; 46302 } 46303 46304 const content = (0,external_wp_richText_namespaceObject.toHTMLString)({ 46305 value: (0,external_wp_richText_namespaceObject.insert)(value, START_OF_SELECTED_AREA, 0, start) 46306 }); 46307 const block = transformation.transform(content); 46308 selectionChange(findSelection([block])); 46309 onReplace([block]); 46310 46311 __unstableMarkAutomaticChange(); 46312 } 46313 46314 function onInput(event) { 46315 const { 46316 inputType, 46317 type 46318 } = event; 46319 const { 46320 value, 46321 onChange, 46322 __unstableAllowPrefixTransformations, 46323 formatTypes 46324 } = propsRef.current; // Only run input rules when inserting text. 46325 46326 if (inputType !== 'insertText' && type !== 'compositionend') { 46327 return; 46328 } 46329 46330 if (__unstableAllowPrefixTransformations && inputRule) { 46331 inputRule(); 46332 } 46333 46334 const transformed = formatTypes.reduce((accumlator, _ref3) => { 46335 let { 46336 __unstableInputRule 46337 } = _ref3; 46338 46339 if (__unstableInputRule) { 46340 accumlator = __unstableInputRule(accumlator); 46341 } 46342 46343 return accumlator; 46344 }, preventEventDiscovery(value)); 46345 46346 if (transformed !== value) { 46347 __unstableMarkLastChangeAsPersistent(); 46348 46349 onChange({ ...transformed, 46350 activeFormats: value.activeFormats 46351 }); 46352 46353 __unstableMarkAutomaticChange(); 46354 } 46355 } 46356 46357 element.addEventListener('input', onInput); 46358 element.addEventListener('compositionend', onInput); 46359 return () => { 46360 element.removeEventListener('input', onInput); 46361 element.removeEventListener('compositionend', onInput); 46362 }; 46363 }, []); 46364 } 46365 46366 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/rich-text/use-enter.js 46367 /** 46368 * WordPress dependencies 46369 */ 46370 46371 /** 46372 * WordPress dependencies 46373 */ 46374 46375 46376 46377 46378 46379 46380 /** 46381 * Internal dependencies 46382 */ 46383 46384 46385 46386 function useEnter(props) { 46387 const { 46388 __unstableMarkAutomaticChange 46389 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 46390 const propsRef = (0,external_wp_element_namespaceObject.useRef)(props); 46391 propsRef.current = props; 46392 return (0,external_wp_compose_namespaceObject.useRefEffect)(element => { 46393 function onKeyDown(event) { 46394 if (event.defaultPrevented) { 46395 return; 46396 } 46397 46398 const { 46399 removeEditorOnlyFormats, 46400 value, 46401 onReplace, 46402 onSplit, 46403 onSplitMiddle, 46404 multilineTag, 46405 onChange, 46406 disableLineBreaks, 46407 onSplitAtEnd 46408 } = propsRef.current; 46409 46410 if (event.keyCode !== external_wp_keycodes_namespaceObject.ENTER) { 46411 return; 46412 } 46413 46414 event.preventDefault(); 46415 const _value = { ...value 46416 }; 46417 _value.formats = removeEditorOnlyFormats(value); 46418 const canSplit = onReplace && onSplit; 46419 46420 if (onReplace) { 46421 const transforms = (0,external_wp_blocks_namespaceObject.getBlockTransforms)('from').filter(_ref => { 46422 let { 46423 type 46424 } = _ref; 46425 return type === 'enter'; 46426 }); 46427 const transformation = (0,external_wp_blocks_namespaceObject.findTransform)(transforms, item => { 46428 return item.regExp.test(_value.text); 46429 }); 46430 46431 if (transformation) { 46432 onReplace([transformation.transform({ 46433 content: _value.text 46434 })]); 46435 46436 __unstableMarkAutomaticChange(); 46437 } 46438 } 46439 46440 if (multilineTag) { 46441 if (event.shiftKey) { 46442 if (!disableLineBreaks) { 46443 onChange((0,external_wp_richText_namespaceObject.insert)(_value, '\n')); 46444 } 46445 } else if (canSplit && (0,external_wp_richText_namespaceObject.__unstableIsEmptyLine)(_value)) { 46446 splitValue({ 46447 value: _value, 46448 onReplace, 46449 onSplit, 46450 onSplitMiddle, 46451 multilineTag 46452 }); 46453 } else { 46454 onChange((0,external_wp_richText_namespaceObject.__unstableInsertLineSeparator)(_value)); 46455 } 46456 } else { 46457 const { 46458 text, 46459 start, 46460 end 46461 } = _value; 46462 const canSplitAtEnd = onSplitAtEnd && start === end && end === text.length; 46463 46464 if (event.shiftKey || !canSplit && !canSplitAtEnd) { 46465 if (!disableLineBreaks) { 46466 onChange((0,external_wp_richText_namespaceObject.insert)(_value, '\n')); 46467 } 46468 } else if (!canSplit && canSplitAtEnd) { 46469 onSplitAtEnd(); 46470 } else if (canSplit) { 46471 splitValue({ 46472 value: _value, 46473 onReplace, 46474 onSplit, 46475 onSplitMiddle, 46476 multilineTag 46477 }); 46478 } 46479 } 46480 } 46481 46482 element.addEventListener('keydown', onKeyDown); 46483 return () => { 46484 element.removeEventListener('keydown', onKeyDown); 46485 }; 46486 }, []); 46487 } 46488 46489 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/rich-text/use-format-types.js 46490 /** 46491 * WordPress dependencies 46492 */ 46493 46494 46495 /** 46496 * Internal dependencies 46497 */ 46498 46499 46500 46501 function formatTypesSelector(select) { 46502 return select(external_wp_richText_namespaceObject.store).getFormatTypes(); 46503 } 46504 /** 46505 * Set of all interactive content tags. 46506 * 46507 * @see https://html.spec.whatwg.org/multipage/dom.html#interactive-content 46508 */ 46509 46510 46511 const interactiveContentTags = new Set(['a', 'audio', 'button', 'details', 'embed', 'iframe', 'input', 'label', 'select', 'textarea', 'video']); 46512 /** 46513 * This hook provides RichText with the `formatTypes` and its derived props from 46514 * experimental format type settings. 46515 * 46516 * @param {Object} $0 Options 46517 * @param {string} $0.clientId Block client ID. 46518 * @param {string} $0.identifier Block attribute. 46519 * @param {boolean} $0.withoutInteractiveFormatting Whether to clean the interactive formattings or not. 46520 * @param {Array} $0.allowedFormats Allowed formats 46521 */ 46522 46523 function useFormatTypes(_ref) { 46524 let { 46525 clientId, 46526 identifier, 46527 withoutInteractiveFormatting, 46528 allowedFormats 46529 } = _ref; 46530 const allFormatTypes = (0,external_wp_data_namespaceObject.useSelect)(formatTypesSelector, []); 46531 const formatTypes = (0,external_wp_element_namespaceObject.useMemo)(() => { 46532 return allFormatTypes.filter(_ref2 => { 46533 let { 46534 name, 46535 tagName 46536 } = _ref2; 46537 46538 if (allowedFormats && !allowedFormats.includes(name)) { 46539 return false; 46540 } 46541 46542 if (withoutInteractiveFormatting && interactiveContentTags.has(tagName)) { 46543 return false; 46544 } 46545 46546 return true; 46547 }); 46548 }, [allFormatTypes, allowedFormats, interactiveContentTags]); 46549 const keyedSelected = (0,external_wp_data_namespaceObject.useSelect)(select => formatTypes.reduce((accumulator, type) => { 46550 if (type.__experimentalGetPropsForEditableTreePreparation) { 46551 accumulator[type.name] = type.__experimentalGetPropsForEditableTreePreparation(select, { 46552 richTextIdentifier: identifier, 46553 blockClientId: clientId 46554 }); 46555 } 46556 46557 return accumulator; 46558 }, {}), [formatTypes, clientId, identifier]); 46559 const dispatch = (0,external_wp_data_namespaceObject.useDispatch)(); 46560 const prepareHandlers = []; 46561 const valueHandlers = []; 46562 const changeHandlers = []; 46563 const dependencies = []; 46564 formatTypes.forEach(type => { 46565 if (type.__experimentalCreatePrepareEditableTree) { 46566 const selected = keyedSelected[type.name]; 46567 46568 const handler = type.__experimentalCreatePrepareEditableTree(selected, { 46569 richTextIdentifier: identifier, 46570 blockClientId: clientId 46571 }); 46572 46573 if (type.__experimentalCreateOnChangeEditableValue) { 46574 valueHandlers.push(handler); 46575 } else { 46576 prepareHandlers.push(handler); 46577 } 46578 46579 for (const key in selected) { 46580 dependencies.push(selected[key]); 46581 } 46582 } 46583 46584 if (type.__experimentalCreateOnChangeEditableValue) { 46585 let dispatchers = {}; 46586 46587 if (type.__experimentalGetPropsForEditableTreeChangeHandler) { 46588 dispatchers = type.__experimentalGetPropsForEditableTreeChangeHandler(dispatch, { 46589 richTextIdentifier: identifier, 46590 blockClientId: clientId 46591 }); 46592 } 46593 46594 changeHandlers.push(type.__experimentalCreateOnChangeEditableValue({ ...(keyedSelected[type.name] || {}), 46595 ...dispatchers 46596 }, { 46597 richTextIdentifier: identifier, 46598 blockClientId: clientId 46599 })); 46600 } 46601 }); 46602 return { 46603 formatTypes, 46604 prepareHandlers, 46605 valueHandlers, 46606 changeHandlers, 46607 dependencies 46608 }; 46609 } 46610 46611 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/rich-text/use-remove-browser-shortcuts.js 46612 /** 46613 * WordPress dependencies 46614 */ 46615 46616 46617 /** 46618 * Hook to prevent default behaviors for key combinations otherwise handled 46619 * internally by RichText. 46620 * 46621 * @return {import('react').RefObject} The component to be rendered. 46622 */ 46623 46624 function useRemoveBrowserShortcuts() { 46625 return (0,external_wp_compose_namespaceObject.useRefEffect)(node => { 46626 function onKeydown(event) { 46627 if (external_wp_keycodes_namespaceObject.isKeyboardEvent.primary(event, 'z') || external_wp_keycodes_namespaceObject.isKeyboardEvent.primary(event, 'y') || external_wp_keycodes_namespaceObject.isKeyboardEvent.primaryShift(event, 'z')) { 46628 event.preventDefault(); 46629 } 46630 } 46631 46632 node.addEventListener('keydown', onKeydown); 46633 return () => { 46634 node.addEventListener('keydown', onKeydown); 46635 }; 46636 }, []); 46637 } 46638 46639 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/rich-text/use-shortcuts.js 46640 /** 46641 * WordPress dependencies 46642 */ 46643 46644 function useShortcuts(keyboardShortcuts) { 46645 return (0,external_wp_compose_namespaceObject.useRefEffect)(element => { 46646 function onKeyDown(event) { 46647 for (const keyboardShortcut of keyboardShortcuts.current) { 46648 keyboardShortcut(event); 46649 } 46650 } 46651 46652 element.addEventListener('keydown', onKeyDown); 46653 return () => { 46654 element.removeEventListener('keydown', onKeyDown); 46655 }; 46656 }, []); 46657 } 46658 46659 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/rich-text/use-input-events.js 46660 /** 46661 * WordPress dependencies 46662 */ 46663 46664 function useInputEvents(inputEvents) { 46665 return (0,external_wp_compose_namespaceObject.useRefEffect)(element => { 46666 function onInput(event) { 46667 for (const keyboardShortcut of inputEvents.current) { 46668 keyboardShortcut(event); 46669 } 46670 } 46671 46672 element.addEventListener('input', onInput); 46673 return () => { 46674 element.removeEventListener('input', onInput); 46675 }; 46676 }, []); 46677 } 46678 46679 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/rich-text/use-firefox-compat.js 46680 /** 46681 * WordPress dependencies 46682 */ 46683 46684 46685 /** 46686 * Internal dependencies 46687 */ 46688 46689 46690 function useFirefoxCompat() { 46691 const { 46692 isMultiSelecting 46693 } = (0,external_wp_data_namespaceObject.useSelect)(store); 46694 return (0,external_wp_compose_namespaceObject.useRefEffect)(element => { 46695 function onFocus() { 46696 if (!isMultiSelecting()) { 46697 return; 46698 } // This is a little hack to work around focus issues with nested 46699 // editable elements in Firefox. For some reason the editable child 46700 // element sometimes regains focus, while it should not be focusable 46701 // and focus should remain on the editable parent element. 46702 // To do: try to find the cause of the shifting focus. 46703 46704 46705 const parentEditable = element.parentElement.closest('[contenteditable="true"]'); 46706 46707 if (parentEditable) { 46708 parentEditable.focus(); 46709 } 46710 } 46711 46712 element.addEventListener('focus', onFocus); 46713 return () => { 46714 element.removeEventListener('focus', onFocus); 46715 }; 46716 }, []); 46717 } 46718 46719 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/rich-text/format-edit.js 46720 46721 46722 /** 46723 * WordPress dependencies 46724 */ 46725 46726 /** 46727 * External dependencies 46728 */ 46729 46730 46731 function FormatEdit(_ref) { 46732 let { 46733 formatTypes, 46734 onChange, 46735 onFocus, 46736 value, 46737 forwardedRef 46738 } = _ref; 46739 return formatTypes.map(settings => { 46740 const { 46741 name, 46742 edit: Edit 46743 } = settings; 46744 46745 if (!Edit) { 46746 return null; 46747 } 46748 46749 const activeFormat = (0,external_wp_richText_namespaceObject.getActiveFormat)(value, name); 46750 let isActive = activeFormat !== undefined; 46751 const activeObject = (0,external_wp_richText_namespaceObject.getActiveObject)(value); 46752 const isObjectActive = activeObject !== undefined && activeObject.type === name; // Edge case: un-collapsed link formats. 46753 // If there is a missing link format at either end of the selection 46754 // then we shouldn't show the Edit UI because the selection has exceeded 46755 // the bounds of the link format. 46756 // Also if the format objects don't match then we're dealing with two separate 46757 // links so we should not allow the link to be modified over the top. 46758 46759 if (name === 'core/link' && !(0,external_wp_richText_namespaceObject.isCollapsed)(value)) { 46760 const formats = value.formats; 46761 const linkFormatAtStart = (0,external_lodash_namespaceObject.find)(formats[value.start], { 46762 type: 'core/link' 46763 }); 46764 const linkFormatAtEnd = (0,external_lodash_namespaceObject.find)(formats[value.end - 1], { 46765 type: 'core/link' 46766 }); 46767 46768 if (!linkFormatAtStart || !linkFormatAtEnd || linkFormatAtStart !== linkFormatAtEnd) { 46769 isActive = false; 46770 } 46771 } 46772 46773 return (0,external_wp_element_namespaceObject.createElement)(Edit, { 46774 key: name, 46775 isActive: isActive, 46776 activeAttributes: isActive ? activeFormat.attributes || {} : {}, 46777 isObjectActive: isObjectActive, 46778 activeObjectAttributes: isObjectActive ? activeObject.attributes || {} : {}, 46779 value: value, 46780 onChange: onChange, 46781 onFocus: onFocus, 46782 contentRef: forwardedRef 46783 }); 46784 }); 46785 } 46786 46787 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/rich-text/index.js 46788 46789 46790 46791 /** 46792 * External dependencies 46793 */ 46794 46795 46796 /** 46797 * WordPress dependencies 46798 */ 46799 46800 46801 46802 46803 46804 46805 46806 46807 46808 /** 46809 * Internal dependencies 46810 */ 46811 46812 46813 46814 46815 46816 46817 46818 46819 46820 46821 46822 46823 46824 46825 46826 46827 46828 46829 const keyboardShortcutContext = (0,external_wp_element_namespaceObject.createContext)(); 46830 const inputEventContext = (0,external_wp_element_namespaceObject.createContext)(); 46831 /** 46832 * Removes props used for the native version of RichText so that they are not 46833 * passed to the DOM element and log warnings. 46834 * 46835 * @param {Object} props Props to filter. 46836 * 46837 * @return {Object} Filtered props. 46838 */ 46839 46840 function removeNativeProps(props) { 46841 return (0,external_lodash_namespaceObject.omit)(props, ['__unstableMobileNoFocusOnMount', 'deleteEnter', 'placeholderTextColor', 'textAlign', 'selectionColor', 'tagsToEliminate', 'rootTagsToEliminate', 'disableEditingMenu', 'fontSize', 'fontFamily', 'fontWeight', 'fontStyle', 'minWidth', 'maxWidth', 'setRef']); 46842 } 46843 46844 function RichTextWrapper(_ref, forwardedRef) { 46845 let { 46846 children, 46847 tagName = 'div', 46848 value: originalValue = '', 46849 onChange: originalOnChange, 46850 isSelected: originalIsSelected, 46851 multiline, 46852 inlineToolbar, 46853 wrapperClassName, 46854 autocompleters, 46855 onReplace, 46856 placeholder, 46857 allowedFormats, 46858 formattingControls, 46859 withoutInteractiveFormatting, 46860 onRemove, 46861 onMerge, 46862 onSplit, 46863 __unstableOnSplitAtEnd: onSplitAtEnd, 46864 __unstableOnSplitMiddle: onSplitMiddle, 46865 identifier, 46866 preserveWhiteSpace, 46867 __unstablePastePlainText: pastePlainText, 46868 __unstableEmbedURLOnPaste, 46869 __unstableDisableFormats: disableFormats, 46870 disableLineBreaks, 46871 unstableOnFocus, 46872 __unstableAllowPrefixTransformations, 46873 ...props 46874 } = _ref; 46875 const instanceId = (0,external_wp_compose_namespaceObject.useInstanceId)(RichTextWrapper); 46876 identifier = identifier || instanceId; 46877 props = removeNativeProps(props); 46878 const anchorRef = (0,external_wp_element_namespaceObject.useRef)(); 46879 const { 46880 clientId 46881 } = useBlockEditContext(); 46882 46883 const selector = select => { 46884 const { 46885 getSelectionStart, 46886 getSelectionEnd 46887 } = select(store); 46888 const selectionStart = getSelectionStart(); 46889 const selectionEnd = getSelectionEnd(); 46890 let isSelected; 46891 46892 if (originalIsSelected === undefined) { 46893 isSelected = selectionStart.clientId === clientId && selectionEnd.clientId === clientId && selectionStart.attributeKey === identifier; 46894 } else if (originalIsSelected) { 46895 isSelected = selectionStart.clientId === clientId; 46896 } 46897 46898 return { 46899 selectionStart: isSelected ? selectionStart.offset : undefined, 46900 selectionEnd: isSelected ? selectionEnd.offset : undefined, 46901 isSelected 46902 }; 46903 }; // This selector must run on every render so the right selection state is 46904 // retreived from the store on merge. 46905 // To do: fix this somehow. 46906 46907 46908 const { 46909 selectionStart, 46910 selectionEnd, 46911 isSelected 46912 } = (0,external_wp_data_namespaceObject.useSelect)(selector); 46913 const { 46914 selectionChange 46915 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 46916 const multilineTag = getMultilineTag(multiline); 46917 const adjustedAllowedFormats = getAllowedFormats({ 46918 allowedFormats, 46919 formattingControls, 46920 disableFormats 46921 }); 46922 const hasFormats = !adjustedAllowedFormats || adjustedAllowedFormats.length > 0; 46923 let adjustedValue = originalValue; 46924 let adjustedOnChange = originalOnChange; // Handle deprecated format. 46925 46926 if (Array.isArray(originalValue)) { 46927 adjustedValue = external_wp_blocks_namespaceObject.children.toHTML(originalValue); 46928 46929 adjustedOnChange = newValue => originalOnChange(external_wp_blocks_namespaceObject.children.fromDOM((0,external_wp_richText_namespaceObject.__unstableCreateElement)(document, newValue).childNodes)); 46930 } 46931 46932 const onSelectionChange = (0,external_wp_element_namespaceObject.useCallback)((start, end) => { 46933 const selection = {}; 46934 const unset = start === undefined && end === undefined; 46935 46936 if (typeof start === 'number' || unset) { 46937 selection.start = { 46938 clientId, 46939 attributeKey: identifier, 46940 offset: start 46941 }; 46942 } 46943 46944 if (typeof end === 'number' || unset) { 46945 selection.end = { 46946 clientId, 46947 attributeKey: identifier, 46948 offset: end 46949 }; 46950 } 46951 46952 selectionChange(selection); 46953 }, [clientId, identifier]); 46954 const { 46955 formatTypes, 46956 prepareHandlers, 46957 valueHandlers, 46958 changeHandlers, 46959 dependencies 46960 } = useFormatTypes({ 46961 clientId, 46962 identifier, 46963 withoutInteractiveFormatting, 46964 allowedFormats: adjustedAllowedFormats 46965 }); 46966 46967 function addEditorOnlyFormats(value) { 46968 return valueHandlers.reduce((accumulator, fn) => fn(accumulator, value.text), value.formats); 46969 } 46970 46971 function removeEditorOnlyFormats(value) { 46972 formatTypes.forEach(formatType => { 46973 // Remove formats created by prepareEditableTree, because they are editor only. 46974 if (formatType.__experimentalCreatePrepareEditableTree) { 46975 value = (0,external_wp_richText_namespaceObject.removeFormat)(value, formatType.name, 0, value.text.length); 46976 } 46977 }); 46978 return value.formats; 46979 } 46980 46981 function addInvisibleFormats(value) { 46982 return prepareHandlers.reduce((accumulator, fn) => fn(accumulator, value.text), value.formats); 46983 } 46984 46985 const { 46986 value, 46987 onChange, 46988 ref: richTextRef 46989 } = (0,external_wp_richText_namespaceObject.__unstableUseRichText)({ 46990 value: adjustedValue, 46991 46992 onChange(html, _ref2) { 46993 let { 46994 __unstableFormats, 46995 __unstableText 46996 } = _ref2; 46997 adjustedOnChange(html); 46998 Object.values(changeHandlers).forEach(changeHandler => { 46999 changeHandler(__unstableFormats, __unstableText); 47000 }); 47001 }, 47002 47003 selectionStart, 47004 selectionEnd, 47005 onSelectionChange, 47006 placeholder, 47007 __unstableIsSelected: isSelected, 47008 __unstableMultilineTag: multilineTag, 47009 __unstableDisableFormats: disableFormats, 47010 preserveWhiteSpace, 47011 __unstableDependencies: [...dependencies, tagName], 47012 __unstableAfterParse: addEditorOnlyFormats, 47013 __unstableBeforeSerialize: removeEditorOnlyFormats, 47014 __unstableAddInvisibleFormats: addInvisibleFormats 47015 }); 47016 const autocompleteProps = useBlockEditorAutocompleteProps({ 47017 onReplace, 47018 completers: autocompleters, 47019 record: value, 47020 onChange 47021 }); 47022 useCaretInFormat({ 47023 value 47024 }); 47025 useMarkPersistent({ 47026 html: adjustedValue, 47027 value 47028 }); 47029 const keyboardShortcuts = (0,external_wp_element_namespaceObject.useRef)(new Set()); 47030 const inputEvents = (0,external_wp_element_namespaceObject.useRef)(new Set()); 47031 47032 function onKeyDown(event) { 47033 const { 47034 keyCode 47035 } = event; 47036 47037 if (event.defaultPrevented) { 47038 return; 47039 } 47040 47041 if (keyCode === external_wp_keycodes_namespaceObject.DELETE || keyCode === external_wp_keycodes_namespaceObject.BACKSPACE) { 47042 const { 47043 start, 47044 end, 47045 text 47046 } = value; 47047 const isReverse = keyCode === external_wp_keycodes_namespaceObject.BACKSPACE; 47048 const hasActiveFormats = value.activeFormats && !!value.activeFormats.length; // Only process delete if the key press occurs at an uncollapsed edge. 47049 47050 if (!(0,external_wp_richText_namespaceObject.isCollapsed)(value) || hasActiveFormats || isReverse && start !== 0 || !isReverse && end !== text.length) { 47051 return; 47052 } 47053 47054 if (onMerge) { 47055 onMerge(!isReverse); 47056 } // Only handle remove on Backspace. This serves dual-purpose of being 47057 // an intentional user interaction distinguishing between Backspace and 47058 // Delete to remove the empty field, but also to avoid merge & remove 47059 // causing destruction of two fields (merge, then removed merged). 47060 47061 47062 if (onRemove && (0,external_wp_richText_namespaceObject.isEmpty)(value) && isReverse) { 47063 onRemove(!isReverse); 47064 } 47065 47066 event.preventDefault(); 47067 } 47068 } 47069 47070 function onFocus() { 47071 anchorRef.current.focus(); 47072 } 47073 47074 const TagName = tagName; 47075 const content = (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, isSelected && (0,external_wp_element_namespaceObject.createElement)(keyboardShortcutContext.Provider, { 47076 value: keyboardShortcuts 47077 }, (0,external_wp_element_namespaceObject.createElement)(inputEventContext.Provider, { 47078 value: inputEvents 47079 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Popover.__unstableSlotNameProvider, { 47080 value: "__unstable-block-tools-after" 47081 }, children && children({ 47082 value, 47083 onChange, 47084 onFocus 47085 }), (0,external_wp_element_namespaceObject.createElement)(FormatEdit, { 47086 value: value, 47087 onChange: onChange, 47088 onFocus: onFocus, 47089 formatTypes: formatTypes, 47090 forwardedRef: anchorRef 47091 })))), isSelected && hasFormats && (0,external_wp_element_namespaceObject.createElement)(format_toolbar_container, { 47092 inline: inlineToolbar, 47093 anchorRef: anchorRef.current 47094 }), (0,external_wp_element_namespaceObject.createElement)(TagName // Overridable props. 47095 , _extends({ 47096 role: "textbox", 47097 "aria-multiline": !disableLineBreaks, 47098 "aria-label": placeholder 47099 }, props, autocompleteProps, { 47100 ref: (0,external_wp_compose_namespaceObject.useMergeRefs)([forwardedRef, autocompleteProps.ref, props.ref, richTextRef, useInputRules({ 47101 value, 47102 onChange, 47103 __unstableAllowPrefixTransformations, 47104 formatTypes, 47105 onReplace, 47106 selectionChange 47107 }), useRemoveBrowserShortcuts(), useShortcuts(keyboardShortcuts), useInputEvents(inputEvents), useUndoAutomaticChange(), usePasteHandler({ 47108 isSelected, 47109 disableFormats, 47110 onChange, 47111 value, 47112 formatTypes, 47113 tagName, 47114 onReplace, 47115 onSplit, 47116 onSplitMiddle, 47117 __unstableEmbedURLOnPaste, 47118 multilineTag, 47119 preserveWhiteSpace, 47120 pastePlainText 47121 }), useEnter({ 47122 removeEditorOnlyFormats, 47123 value, 47124 onReplace, 47125 onSplit, 47126 onSplitMiddle, 47127 multilineTag, 47128 onChange, 47129 disableLineBreaks, 47130 onSplitAtEnd 47131 }), useFirefoxCompat(), anchorRef]), 47132 contentEditable: true, 47133 suppressContentEditableWarning: true, 47134 className: classnames_default()('block-editor-rich-text__editable', props.className, 'rich-text'), 47135 onFocus: unstableOnFocus, 47136 onKeyDown: onKeyDown 47137 }))); 47138 47139 if (!wrapperClassName) { 47140 return content; 47141 } 47142 47143 external_wp_deprecated_default()('wp.blockEditor.RichText wrapperClassName prop', { 47144 since: '5.4', 47145 alternative: 'className prop or create your own wrapper div', 47146 version: '6.2' 47147 }); 47148 const className = classnames_default()('block-editor-rich-text', wrapperClassName); 47149 return (0,external_wp_element_namespaceObject.createElement)("div", { 47150 className: className 47151 }, content); 47152 } 47153 47154 const ForwardedRichTextContainer = (0,external_wp_element_namespaceObject.forwardRef)(RichTextWrapper); 47155 47156 ForwardedRichTextContainer.Content = _ref3 => { 47157 let { 47158 value, 47159 tagName: Tag, 47160 multiline, 47161 ...props 47162 } = _ref3; 47163 47164 // Handle deprecated `children` and `node` sources. 47165 if (Array.isArray(value)) { 47166 value = external_wp_blocks_namespaceObject.children.toHTML(value); 47167 } 47168 47169 const MultilineTag = getMultilineTag(multiline); 47170 47171 if (!value && MultilineTag) { 47172 value = `<$MultilineTag}></$MultilineTag}>`; 47173 } 47174 47175 const content = (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.RawHTML, null, value); 47176 47177 if (Tag) { 47178 return (0,external_wp_element_namespaceObject.createElement)(Tag, (0,external_lodash_namespaceObject.omit)(props, ['format']), content); 47179 } 47180 47181 return content; 47182 }; 47183 47184 ForwardedRichTextContainer.isEmpty = value => { 47185 return !value || value.length === 0; 47186 }; 47187 /** 47188 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/rich-text/README.md 47189 */ 47190 47191 47192 /* harmony default export */ var rich_text = (ForwardedRichTextContainer); 47193 47194 47195 47196 47197 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/editable-text/index.js 47198 47199 47200 47201 /** 47202 * WordPress dependencies 47203 */ 47204 47205 /** 47206 * Internal dependencies 47207 */ 47208 47209 47210 const EditableText = (0,external_wp_element_namespaceObject.forwardRef)((props, ref) => { 47211 return (0,external_wp_element_namespaceObject.createElement)(rich_text, _extends({ 47212 ref: ref 47213 }, props, { 47214 __unstableDisableFormats: true, 47215 preserveWhiteSpace: true 47216 })); 47217 }); 47218 47219 EditableText.Content = _ref => { 47220 let { 47221 value = '', 47222 tagName: Tag = 'div', 47223 ...props 47224 } = _ref; 47225 return (0,external_wp_element_namespaceObject.createElement)(Tag, props, value); 47226 }; 47227 /** 47228 * Renders an editable text input in which text formatting is not allowed. 47229 */ 47230 47231 47232 /* harmony default export */ var editable_text = (EditableText); 47233 47234 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/plain-text/index.js 47235 47236 47237 47238 /** 47239 * External dependencies 47240 */ 47241 47242 47243 /** 47244 * WordPress dependencies 47245 */ 47246 47247 47248 /** 47249 * Internal dependencies 47250 */ 47251 47252 47253 /** 47254 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/plain-text/README.md 47255 */ 47256 47257 const PlainText = (0,external_wp_element_namespaceObject.forwardRef)((_ref, ref) => { 47258 let { 47259 __experimentalVersion, 47260 ...props 47261 } = _ref; 47262 47263 if (__experimentalVersion === 2) { 47264 return (0,external_wp_element_namespaceObject.createElement)(editable_text, _extends({ 47265 ref: ref 47266 }, props)); 47267 } 47268 47269 const { 47270 className, 47271 onChange, 47272 ...remainingProps 47273 } = props; 47274 return (0,external_wp_element_namespaceObject.createElement)(lib/* default */.Z, _extends({ 47275 ref: ref, 47276 className: classnames_default()('block-editor-plain-text', className), 47277 onChange: event => onChange(event.target.value) 47278 }, remainingProps)); 47279 }); 47280 /* harmony default export */ var plain_text = (PlainText); 47281 47282 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/responsive-block-control/label.js 47283 47284 47285 /** 47286 * WordPress dependencies 47287 */ 47288 47289 47290 47291 47292 function ResponsiveBlockControlLabel(_ref) { 47293 let { 47294 property, 47295 viewport, 47296 desc 47297 } = _ref; 47298 const instanceId = (0,external_wp_compose_namespaceObject.useInstanceId)(ResponsiveBlockControlLabel); 47299 const accessibleLabel = desc || (0,external_wp_i18n_namespaceObject.sprintf)( 47300 /* translators: 1: property name. 2: viewport name. */ 47301 (0,external_wp_i18n_namespaceObject._x)('Controls the %1$s property for %2$s viewports.', 'Text labelling a interface as controlling a given layout property (eg: margin) for a given screen size.'), property, viewport.label); 47302 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("span", { 47303 "aria-describedby": `rbc-desc-$instanceId}` 47304 }, viewport.label), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.VisuallyHidden, { 47305 as: "span", 47306 id: `rbc-desc-$instanceId}` 47307 }, accessibleLabel)); 47308 } 47309 47310 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/responsive-block-control/index.js 47311 47312 47313 /** 47314 * External dependencies 47315 */ 47316 47317 /** 47318 * WordPress dependencies 47319 */ 47320 47321 47322 47323 47324 /** 47325 * Internal dependencies 47326 */ 47327 47328 47329 47330 function ResponsiveBlockControl(props) { 47331 const { 47332 title, 47333 property, 47334 toggleLabel, 47335 onIsResponsiveChange, 47336 renderDefaultControl, 47337 renderResponsiveControls, 47338 isResponsive = false, 47339 defaultLabel = { 47340 id: 'all', 47341 47342 /* translators: 'Label. Used to signify a layout property (eg: margin, padding) will apply uniformly to all screensizes.' */ 47343 label: (0,external_wp_i18n_namespaceObject.__)('All') 47344 }, 47345 viewports = [{ 47346 id: 'small', 47347 label: (0,external_wp_i18n_namespaceObject.__)('Small screens') 47348 }, { 47349 id: 'medium', 47350 label: (0,external_wp_i18n_namespaceObject.__)('Medium screens') 47351 }, { 47352 id: 'large', 47353 label: (0,external_wp_i18n_namespaceObject.__)('Large screens') 47354 }] 47355 } = props; 47356 47357 if (!title || !property || !renderDefaultControl) { 47358 return null; 47359 } 47360 47361 const toggleControlLabel = toggleLabel || (0,external_wp_i18n_namespaceObject.sprintf)( 47362 /* translators: 'Toggle control label. Should the property be the same across all screen sizes or unique per screen size.'. %s property value for the control (eg: margin, padding...etc) */ 47363 (0,external_wp_i18n_namespaceObject.__)('Use the same %s on all screensizes.'), property); 47364 /* translators: 'Help text for the responsive mode toggle control.' */ 47365 47366 const toggleHelpText = (0,external_wp_i18n_namespaceObject.__)('Toggle between using the same value for all screen sizes or using a unique value per screen size.'); 47367 47368 const defaultControl = renderDefaultControl((0,external_wp_element_namespaceObject.createElement)(ResponsiveBlockControlLabel, { 47369 property: property, 47370 viewport: defaultLabel 47371 }), defaultLabel); 47372 47373 const defaultResponsiveControls = () => { 47374 return viewports.map(viewport => (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, { 47375 key: viewport.id 47376 }, renderDefaultControl((0,external_wp_element_namespaceObject.createElement)(ResponsiveBlockControlLabel, { 47377 property: property, 47378 viewport: viewport 47379 }), viewport))); 47380 }; 47381 47382 return (0,external_wp_element_namespaceObject.createElement)("fieldset", { 47383 className: "block-editor-responsive-block-control" 47384 }, (0,external_wp_element_namespaceObject.createElement)("legend", { 47385 className: "block-editor-responsive-block-control__title" 47386 }, title), (0,external_wp_element_namespaceObject.createElement)("div", { 47387 className: "block-editor-responsive-block-control__inner" 47388 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, { 47389 className: "block-editor-responsive-block-control__toggle", 47390 label: toggleControlLabel, 47391 checked: !isResponsive, 47392 onChange: onIsResponsiveChange, 47393 help: toggleHelpText 47394 }), (0,external_wp_element_namespaceObject.createElement)("div", { 47395 className: classnames_default()('block-editor-responsive-block-control__group', { 47396 'is-responsive': isResponsive 47397 }) 47398 }, !isResponsive && defaultControl, isResponsive && (renderResponsiveControls ? renderResponsiveControls(viewports) : defaultResponsiveControls())))); 47399 } 47400 47401 /* harmony default export */ var responsive_block_control = (ResponsiveBlockControl); 47402 47403 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/rich-text/shortcut.js 47404 /** 47405 * WordPress dependencies 47406 */ 47407 47408 47409 /** 47410 * Internal dependencies 47411 */ 47412 47413 47414 function RichTextShortcut(_ref) { 47415 let { 47416 character, 47417 type, 47418 onUse 47419 } = _ref; 47420 const keyboardShortcuts = (0,external_wp_element_namespaceObject.useContext)(keyboardShortcutContext); 47421 const onUseRef = (0,external_wp_element_namespaceObject.useRef)(); 47422 onUseRef.current = onUse; 47423 (0,external_wp_element_namespaceObject.useEffect)(() => { 47424 function callback(event) { 47425 if (external_wp_keycodes_namespaceObject.isKeyboardEvent[type](event, character)) { 47426 onUseRef.current(); 47427 event.preventDefault(); 47428 } 47429 } 47430 47431 keyboardShortcuts.current.add(callback); 47432 return () => { 47433 keyboardShortcuts.current.delete(callback); 47434 }; 47435 }, [character, type]); 47436 return null; 47437 } 47438 47439 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/rich-text/toolbar-button.js 47440 47441 47442 47443 /** 47444 * WordPress dependencies 47445 */ 47446 47447 47448 function RichTextToolbarButton(_ref) { 47449 let { 47450 name, 47451 shortcutType, 47452 shortcutCharacter, 47453 ...props 47454 } = _ref; 47455 let shortcut; 47456 let fillName = 'RichText.ToolbarControls'; 47457 47458 if (name) { 47459 fillName += `.$name}`; 47460 } 47461 47462 if (shortcutType && shortcutCharacter) { 47463 shortcut = external_wp_keycodes_namespaceObject.displayShortcut[shortcutType](shortcutCharacter); 47464 } 47465 47466 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Fill, { 47467 name: fillName 47468 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, _extends({}, props, { 47469 shortcut: shortcut 47470 }))); 47471 } 47472 47473 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/rich-text/input-event.js 47474 /** 47475 * WordPress dependencies 47476 */ 47477 47478 /** 47479 * Internal dependencies 47480 */ 47481 47482 47483 function __unstableRichTextInputEvent(_ref) { 47484 let { 47485 inputType, 47486 onInput 47487 } = _ref; 47488 const callbacks = (0,external_wp_element_namespaceObject.useContext)(inputEventContext); 47489 const onInputRef = (0,external_wp_element_namespaceObject.useRef)(); 47490 onInputRef.current = onInput; 47491 (0,external_wp_element_namespaceObject.useEffect)(() => { 47492 function callback(event) { 47493 if (event.inputType === inputType) { 47494 onInputRef.current(); 47495 event.preventDefault(); 47496 } 47497 } 47498 47499 callbacks.current.add(callback); 47500 return () => { 47501 callbacks.current.delete(callback); 47502 }; 47503 }, [inputType]); 47504 return null; 47505 } 47506 47507 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/tool-selector/index.js 47508 47509 47510 47511 /** 47512 * WordPress dependencies 47513 */ 47514 47515 47516 47517 47518 47519 /** 47520 * Internal dependencies 47521 */ 47522 47523 47524 const selectIcon = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, { 47525 xmlns: "http://www.w3.org/2000/svg", 47526 width: "24", 47527 height: "24", 47528 viewBox: "0 0 24 24" 47529 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, { 47530 d: "M9.4 20.5L5.2 3.8l14.6 9-2 .3c-.2 0-.4.1-.7.1-.9.2-1.6.3-2.2.5-.8.3-1.4.5-1.8.8-.4.3-.8.8-1.3 1.5-.4.5-.8 1.2-1.2 2l-.3.6-.9 1.9zM7.6 7.1l2.4 9.3c.2-.4.5-.8.7-1.1.6-.8 1.1-1.4 1.6-1.8.5-.4 1.3-.8 2.2-1.1l1.2-.3-8.1-5z" 47531 })); 47532 47533 function ToolSelector(props, ref) { 47534 const isNavigationTool = (0,external_wp_data_namespaceObject.useSelect)(select => select(store).isNavigationMode(), []); 47535 const { 47536 setNavigationMode 47537 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 47538 47539 const onSwitchMode = mode => { 47540 setNavigationMode(mode === 'edit' ? false : true); 47541 }; 47542 47543 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Dropdown, { 47544 renderToggle: _ref => { 47545 let { 47546 isOpen, 47547 onToggle 47548 } = _ref; 47549 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, _extends({}, props, { 47550 ref: ref, 47551 icon: isNavigationTool ? selectIcon : library_edit, 47552 "aria-expanded": isOpen, 47553 "aria-haspopup": "true", 47554 onClick: onToggle 47555 /* translators: button label text should, if possible, be under 16 characters. */ 47556 , 47557 label: (0,external_wp_i18n_namespaceObject.__)('Tools') 47558 })); 47559 }, 47560 position: "bottom right", 47561 renderContent: () => (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.NavigableMenu, { 47562 role: "menu", 47563 "aria-label": (0,external_wp_i18n_namespaceObject.__)('Tools') 47564 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItemsChoice, { 47565 value: isNavigationTool ? 'select' : 'edit', 47566 onSelect: onSwitchMode, 47567 choices: [{ 47568 value: 'edit', 47569 label: (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(build_module_icon, { 47570 icon: library_edit 47571 }), (0,external_wp_i18n_namespaceObject.__)('Edit')) 47572 }, { 47573 value: 'select', 47574 label: (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, selectIcon, (0,external_wp_i18n_namespaceObject.__)('Select')) 47575 }] 47576 })), (0,external_wp_element_namespaceObject.createElement)("div", { 47577 className: "block-editor-tool-selector__help" 47578 }, (0,external_wp_i18n_namespaceObject.__)('Tools provide different interactions for selecting, navigating, and editing blocks. Toggle between select and edit by pressing Escape and Enter.'))) 47579 }); 47580 } 47581 47582 /* harmony default export */ var tool_selector = ((0,external_wp_element_namespaceObject.forwardRef)(ToolSelector)); 47583 47584 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/unit-control/index.js 47585 47586 47587 47588 /** 47589 * WordPress dependencies 47590 */ 47591 47592 /** 47593 * Internal dependencies 47594 */ 47595 47596 47597 function UnitControl(_ref) { 47598 let { 47599 units: unitsProp, 47600 ...props 47601 } = _ref; 47602 const units = (0,external_wp_components_namespaceObject.__experimentalUseCustomUnits)({ 47603 availableUnits: useSetting('spacing.units') || ['%', 'px', 'em', 'rem', 'vw'], 47604 units: unitsProp 47605 }); 47606 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalUnitControl, _extends({ 47607 units: units 47608 }, props)); 47609 } 47610 47611 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/arrow-left.js 47612 47613 47614 /** 47615 * WordPress dependencies 47616 */ 47617 47618 const arrowLeft = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 47619 xmlns: "http://www.w3.org/2000/svg", 47620 viewBox: "0 0 24 24" 47621 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 47622 d: "M20 10.8H6.7l4.1-4.5-1.1-1.1-5.8 6.3 5.8 5.8 1.1-1.1-4-3.9H20z" 47623 })); 47624 /* harmony default export */ var arrow_left = (arrowLeft); 47625 47626 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/url-input/button.js 47627 47628 47629 /** 47630 * WordPress dependencies 47631 */ 47632 47633 47634 47635 47636 /** 47637 * Internal dependencies 47638 */ 47639 47640 47641 47642 class URLInputButton extends external_wp_element_namespaceObject.Component { 47643 constructor() { 47644 super(...arguments); 47645 this.toggle = this.toggle.bind(this); 47646 this.submitLink = this.submitLink.bind(this); 47647 this.state = { 47648 expanded: false 47649 }; 47650 } 47651 47652 toggle() { 47653 this.setState({ 47654 expanded: !this.state.expanded 47655 }); 47656 } 47657 47658 submitLink(event) { 47659 event.preventDefault(); 47660 this.toggle(); 47661 } 47662 47663 render() { 47664 const { 47665 url, 47666 onChange 47667 } = this.props; 47668 const { 47669 expanded 47670 } = this.state; 47671 const buttonLabel = url ? (0,external_wp_i18n_namespaceObject.__)('Edit link') : (0,external_wp_i18n_namespaceObject.__)('Insert link'); 47672 return (0,external_wp_element_namespaceObject.createElement)("div", { 47673 className: "block-editor-url-input__button" 47674 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 47675 icon: library_link, 47676 label: buttonLabel, 47677 onClick: this.toggle, 47678 className: "components-toolbar__control", 47679 isPressed: !!url 47680 }), expanded && (0,external_wp_element_namespaceObject.createElement)("form", { 47681 className: "block-editor-url-input__button-modal", 47682 onSubmit: this.submitLink 47683 }, (0,external_wp_element_namespaceObject.createElement)("div", { 47684 className: "block-editor-url-input__button-modal-line" 47685 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 47686 className: "block-editor-url-input__back", 47687 icon: arrow_left, 47688 label: (0,external_wp_i18n_namespaceObject.__)('Close'), 47689 onClick: this.toggle 47690 }), (0,external_wp_element_namespaceObject.createElement)(url_input, { 47691 value: url || '', 47692 onChange: onChange 47693 }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 47694 icon: keyboard_return, 47695 label: (0,external_wp_i18n_namespaceObject.__)('Submit'), 47696 type: "submit" 47697 })))); 47698 } 47699 47700 } 47701 /** 47702 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/url-input/README.md 47703 */ 47704 47705 47706 /* harmony default export */ var url_input_button = (URLInputButton); 47707 47708 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/close.js 47709 47710 47711 /** 47712 * WordPress dependencies 47713 */ 47714 47715 const close_close = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 47716 xmlns: "http://www.w3.org/2000/svg", 47717 viewBox: "0 0 24 24" 47718 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 47719 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" 47720 })); 47721 /* harmony default export */ var library_close = (close_close); 47722 47723 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/url-popover/image-url-input-ui.js 47724 47725 47726 /** 47727 * External dependencies 47728 */ 47729 47730 /** 47731 * WordPress dependencies 47732 */ 47733 47734 47735 47736 47737 47738 /** 47739 * Internal dependencies 47740 */ 47741 47742 47743 const LINK_DESTINATION_NONE = 'none'; 47744 const LINK_DESTINATION_CUSTOM = 'custom'; 47745 const LINK_DESTINATION_MEDIA = 'media'; 47746 const LINK_DESTINATION_ATTACHMENT = 'attachment'; 47747 const NEW_TAB_REL = ['noreferrer', 'noopener']; 47748 const icon = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, { 47749 viewBox: "0 0 24 24", 47750 xmlns: "http://www.w3.org/2000/svg" 47751 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, { 47752 d: "M0,0h24v24H0V0z", 47753 fill: "none" 47754 }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, { 47755 d: "m19 5v14h-14v-14h14m0-2h-14c-1.1 0-2 0.9-2 2v14c0 1.1 0.9 2 2 2h14c1.1 0 2-0.9 2-2v-14c0-1.1-0.9-2-2-2z" 47756 }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, { 47757 d: "m14.14 11.86l-3 3.87-2.14-2.59-3 3.86h12l-3.86-5.14z" 47758 })); 47759 47760 const ImageURLInputUI = _ref => { 47761 let { 47762 linkDestination, 47763 onChangeUrl, 47764 url, 47765 mediaType = 'image', 47766 mediaUrl, 47767 mediaLink, 47768 linkTarget, 47769 linkClass, 47770 rel 47771 } = _ref; 47772 const [isOpen, setIsOpen] = (0,external_wp_element_namespaceObject.useState)(false); 47773 const openLinkUI = (0,external_wp_element_namespaceObject.useCallback)(() => { 47774 setIsOpen(true); 47775 }); 47776 const [isEditingLink, setIsEditingLink] = (0,external_wp_element_namespaceObject.useState)(false); 47777 const [urlInput, setUrlInput] = (0,external_wp_element_namespaceObject.useState)(null); 47778 const autocompleteRef = (0,external_wp_element_namespaceObject.useRef)(null); 47779 const startEditLink = (0,external_wp_element_namespaceObject.useCallback)(() => { 47780 if (linkDestination === LINK_DESTINATION_MEDIA || linkDestination === LINK_DESTINATION_ATTACHMENT) { 47781 setUrlInput(''); 47782 } 47783 47784 setIsEditingLink(true); 47785 }); 47786 const stopEditLink = (0,external_wp_element_namespaceObject.useCallback)(() => { 47787 setIsEditingLink(false); 47788 }); 47789 const closeLinkUI = (0,external_wp_element_namespaceObject.useCallback)(() => { 47790 setUrlInput(null); 47791 stopEditLink(); 47792 setIsOpen(false); 47793 }); 47794 47795 const getUpdatedLinkTargetSettings = value => { 47796 const newLinkTarget = value ? '_blank' : undefined; 47797 let updatedRel; 47798 47799 if (newLinkTarget) { 47800 const rels = (rel !== null && rel !== void 0 ? rel : '').split(' '); 47801 NEW_TAB_REL.forEach(relVal => { 47802 if (!rels.includes(relVal)) { 47803 rels.push(relVal); 47804 } 47805 }); 47806 updatedRel = rels.join(' '); 47807 } else { 47808 const rels = (rel !== null && rel !== void 0 ? rel : '').split(' ').filter(relVal => NEW_TAB_REL.includes(relVal) === false); 47809 updatedRel = rels.length ? rels.join(' ') : undefined; 47810 } 47811 47812 return { 47813 linkTarget: newLinkTarget, 47814 rel: updatedRel 47815 }; 47816 }; 47817 47818 const onFocusOutside = (0,external_wp_element_namespaceObject.useCallback)(() => { 47819 return event => { 47820 // The autocomplete suggestions list renders in a separate popover (in a portal), 47821 // so onFocusOutside fails to detect that a click on a suggestion occurred in the 47822 // LinkContainer. Detect clicks on autocomplete suggestions using a ref here, and 47823 // return to avoid the popover being closed. 47824 const autocompleteElement = autocompleteRef.current; 47825 47826 if (autocompleteElement && autocompleteElement.contains(event.target)) { 47827 return; 47828 } 47829 47830 setIsOpen(false); 47831 setUrlInput(null); 47832 stopEditLink(); 47833 }; 47834 }); 47835 const onSubmitLinkChange = (0,external_wp_element_namespaceObject.useCallback)(() => { 47836 return event => { 47837 if (urlInput) { 47838 var _getLinkDestinations$; 47839 47840 // It is possible the entered URL actually matches a named link destination. 47841 // This check will ensure our link destination is correct. 47842 const selectedDestination = ((_getLinkDestinations$ = getLinkDestinations().find(destination => destination.url === urlInput)) === null || _getLinkDestinations$ === void 0 ? void 0 : _getLinkDestinations$.linkDestination) || LINK_DESTINATION_CUSTOM; 47843 onChangeUrl({ 47844 href: urlInput, 47845 linkDestination: selectedDestination 47846 }); 47847 } 47848 47849 stopEditLink(); 47850 setUrlInput(null); 47851 event.preventDefault(); 47852 }; 47853 }); 47854 const onLinkRemove = (0,external_wp_element_namespaceObject.useCallback)(() => { 47855 onChangeUrl({ 47856 linkDestination: LINK_DESTINATION_NONE, 47857 href: '' 47858 }); 47859 }); 47860 47861 const getLinkDestinations = () => { 47862 const linkDestinations = [{ 47863 linkDestination: LINK_DESTINATION_MEDIA, 47864 title: (0,external_wp_i18n_namespaceObject.__)('Media File'), 47865 url: mediaType === 'image' ? mediaUrl : undefined, 47866 icon 47867 }]; 47868 47869 if (mediaType === 'image' && mediaLink) { 47870 linkDestinations.push({ 47871 linkDestination: LINK_DESTINATION_ATTACHMENT, 47872 title: (0,external_wp_i18n_namespaceObject.__)('Attachment Page'), 47873 url: mediaType === 'image' ? mediaLink : undefined, 47874 icon: (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, { 47875 viewBox: "0 0 24 24", 47876 xmlns: "http://www.w3.org/2000/svg" 47877 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, { 47878 d: "M0 0h24v24H0V0z", 47879 fill: "none" 47880 }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, { 47881 d: "M14 2H6c-1.1 0-1.99.9-1.99 2L4 20c0 1.1.89 2 1.99 2H18c1.1 0 2-.9 2-2V8l-6-6zM6 20V4h7v5h5v11H6z" 47882 })) 47883 }); 47884 } 47885 47886 return linkDestinations; 47887 }; 47888 47889 const onSetHref = value => { 47890 const linkDestinations = getLinkDestinations(); 47891 let linkDestinationInput; 47892 47893 if (!value) { 47894 linkDestinationInput = LINK_DESTINATION_NONE; 47895 } else { 47896 linkDestinationInput = ((0,external_lodash_namespaceObject.find)(linkDestinations, destination => { 47897 return destination.url === value; 47898 }) || { 47899 linkDestination: LINK_DESTINATION_CUSTOM 47900 }).linkDestination; 47901 } 47902 47903 onChangeUrl({ 47904 linkDestination: linkDestinationInput, 47905 href: value 47906 }); 47907 }; 47908 47909 const onSetNewTab = value => { 47910 const updatedLinkTarget = getUpdatedLinkTargetSettings(value); 47911 onChangeUrl(updatedLinkTarget); 47912 }; 47913 47914 const onSetLinkRel = value => { 47915 onChangeUrl({ 47916 rel: value 47917 }); 47918 }; 47919 47920 const onSetLinkClass = value => { 47921 onChangeUrl({ 47922 linkClass: value 47923 }); 47924 }; 47925 47926 const advancedOptions = (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, { 47927 label: (0,external_wp_i18n_namespaceObject.__)('Open in new tab'), 47928 onChange: onSetNewTab, 47929 checked: linkTarget === '_blank' 47930 }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, { 47931 label: (0,external_wp_i18n_namespaceObject.__)('Link Rel'), 47932 value: rel !== null && rel !== void 0 ? rel : '', 47933 onChange: onSetLinkRel 47934 }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, { 47935 label: (0,external_wp_i18n_namespaceObject.__)('Link CSS Class'), 47936 value: linkClass || '', 47937 onChange: onSetLinkClass 47938 })); 47939 const linkEditorValue = urlInput !== null ? urlInput : url; 47940 const urlLabel = ((0,external_lodash_namespaceObject.find)(getLinkDestinations(), ['linkDestination', linkDestination]) || {}).title; 47941 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, { 47942 icon: library_link, 47943 className: "components-toolbar__control", 47944 label: url ? (0,external_wp_i18n_namespaceObject.__)('Edit link') : (0,external_wp_i18n_namespaceObject.__)('Insert link'), 47945 "aria-expanded": isOpen, 47946 onClick: openLinkUI 47947 }), isOpen && (0,external_wp_element_namespaceObject.createElement)(url_popover, { 47948 onFocusOutside: onFocusOutside(), 47949 onClose: closeLinkUI, 47950 renderSettings: () => advancedOptions, 47951 additionalControls: !linkEditorValue && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.NavigableMenu, null, (0,external_lodash_namespaceObject.map)(getLinkDestinations(), link => (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, { 47952 key: link.linkDestination, 47953 icon: link.icon, 47954 onClick: () => { 47955 setUrlInput(null); 47956 onSetHref(link.url); 47957 stopEditLink(); 47958 } 47959 }, link.title))) 47960 }, (!url || isEditingLink) && (0,external_wp_element_namespaceObject.createElement)(url_popover.LinkEditor, { 47961 className: "block-editor-format-toolbar__link-container-content", 47962 value: linkEditorValue, 47963 onChangeInputValue: setUrlInput, 47964 onSubmit: onSubmitLinkChange(), 47965 autocompleteRef: autocompleteRef 47966 }), url && !isEditingLink && (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(url_popover.LinkViewer, { 47967 className: "block-editor-format-toolbar__link-container-content", 47968 url: url, 47969 onEditLinkClick: startEditLink, 47970 urlLabel: urlLabel 47971 }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 47972 icon: library_close, 47973 label: (0,external_wp_i18n_namespaceObject.__)('Remove link'), 47974 onClick: onLinkRemove 47975 })))); 47976 }; 47977 47978 47979 47980 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/preview-options/index.js 47981 47982 47983 /** 47984 * External dependencies 47985 */ 47986 47987 /** 47988 * WordPress dependencies 47989 */ 47990 47991 47992 47993 47994 47995 function PreviewOptions(_ref) { 47996 let { 47997 children, 47998 className, 47999 isEnabled = true, 48000 deviceType, 48001 setDeviceType 48002 } = _ref; 48003 const isMobile = (0,external_wp_compose_namespaceObject.useViewportMatch)('small', '<'); 48004 if (isMobile) return null; 48005 const popoverProps = { 48006 className: classnames_default()(className, 'block-editor-post-preview__dropdown-content'), 48007 position: 'bottom left' 48008 }; 48009 const toggleProps = { 48010 variant: 'tertiary', 48011 className: 'block-editor-post-preview__button-toggle', 48012 disabled: !isEnabled, 48013 48014 /* translators: button label text should, if possible, be under 16 characters. */ 48015 children: (0,external_wp_i18n_namespaceObject.__)('Preview') 48016 }; 48017 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.DropdownMenu, { 48018 className: "block-editor-post-preview__dropdown", 48019 popoverProps: popoverProps, 48020 toggleProps: toggleProps, 48021 icon: null 48022 }, () => (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuGroup, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, { 48023 className: "block-editor-post-preview__button-resize", 48024 onClick: () => setDeviceType('Desktop'), 48025 icon: deviceType === 'Desktop' && library_check 48026 }, (0,external_wp_i18n_namespaceObject.__)('Desktop')), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, { 48027 className: "block-editor-post-preview__button-resize", 48028 onClick: () => setDeviceType('Tablet'), 48029 icon: deviceType === 'Tablet' && library_check 48030 }, (0,external_wp_i18n_namespaceObject.__)('Tablet')), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, { 48031 className: "block-editor-post-preview__button-resize", 48032 onClick: () => setDeviceType('Mobile'), 48033 icon: deviceType === 'Mobile' && library_check 48034 }, (0,external_wp_i18n_namespaceObject.__)('Mobile'))), children)); 48035 } 48036 48037 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/use-resize-canvas/index.js 48038 /** 48039 * WordPress dependencies 48040 */ 48041 48042 /** 48043 * Function to resize the editor window. 48044 * 48045 * @param {string} deviceType Used for determining the size of the container (e.g. Desktop, Tablet, Mobile) 48046 * 48047 * @return {Object} Inline styles to be added to resizable container. 48048 */ 48049 48050 function useResizeCanvas(deviceType) { 48051 const [actualWidth, updateActualWidth] = (0,external_wp_element_namespaceObject.useState)(window.innerWidth); 48052 (0,external_wp_element_namespaceObject.useEffect)(() => { 48053 if (deviceType === 'Desktop') { 48054 return; 48055 } 48056 48057 const resizeListener = () => updateActualWidth(window.innerWidth); 48058 48059 window.addEventListener('resize', resizeListener); 48060 return () => { 48061 window.removeEventListener('resize', resizeListener); 48062 }; 48063 }, [deviceType]); 48064 48065 const getCanvasWidth = device => { 48066 let deviceWidth; 48067 48068 switch (device) { 48069 case 'Tablet': 48070 deviceWidth = 780; 48071 break; 48072 48073 case 'Mobile': 48074 deviceWidth = 360; 48075 break; 48076 48077 default: 48078 return null; 48079 } 48080 48081 return deviceWidth < actualWidth ? deviceWidth : actualWidth; 48082 }; 48083 48084 const marginValue = () => window.innerHeight < 800 ? 36 : 72; 48085 48086 const contentInlineStyles = device => { 48087 const height = device === 'Mobile' ? '768px' : '1024px'; 48088 48089 switch (device) { 48090 case 'Tablet': 48091 case 'Mobile': 48092 return { 48093 width: getCanvasWidth(device), 48094 margin: marginValue() + 'px auto', 48095 height, 48096 borderRadius: '2px 2px 2px 2px', 48097 border: '1px solid #ddd', 48098 overflowY: 'auto' 48099 }; 48100 48101 default: 48102 return null; 48103 } 48104 }; 48105 48106 return contentInlineStyles(deviceType); 48107 } 48108 48109 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/skip-to-selected-block/index.js 48110 48111 48112 /** 48113 * WordPress dependencies 48114 */ 48115 48116 48117 48118 /** 48119 * Internal dependencies 48120 */ 48121 48122 48123 48124 48125 const SkipToSelectedBlock = _ref => { 48126 let { 48127 selectedBlockClientId 48128 } = _ref; 48129 const ref = useBlockRef(selectedBlockClientId); 48130 48131 const onClick = () => { 48132 ref.current.focus(); 48133 }; 48134 48135 return selectedBlockClientId ? (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 48136 variant: "secondary", 48137 className: "block-editor-skip-to-selected-block", 48138 onClick: onClick 48139 }, (0,external_wp_i18n_namespaceObject.__)('Skip to the selected block')) : null; 48140 }; 48141 /** 48142 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/skip-to-selected-block/README.md 48143 */ 48144 48145 48146 /* harmony default export */ var skip_to_selected_block = ((0,external_wp_data_namespaceObject.withSelect)(select => { 48147 return { 48148 selectedBlockClientId: select(store).getBlockSelectionStart() 48149 }; 48150 })(SkipToSelectedBlock)); 48151 48152 ;// CONCATENATED MODULE: external ["wp","wordcount"] 48153 var external_wp_wordcount_namespaceObject = window["wp"]["wordcount"]; 48154 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/multi-selection-inspector/index.js 48155 48156 48157 /** 48158 * WordPress dependencies 48159 */ 48160 48161 48162 48163 48164 48165 /** 48166 * Internal dependencies 48167 */ 48168 48169 48170 48171 48172 function MultiSelectionInspector(_ref) { 48173 let { 48174 blocks 48175 } = _ref; 48176 const words = (0,external_wp_wordcount_namespaceObject.count)((0,external_wp_blocks_namespaceObject.serialize)(blocks), 'words'); 48177 return (0,external_wp_element_namespaceObject.createElement)("div", { 48178 className: "block-editor-multi-selection-inspector__card" 48179 }, (0,external_wp_element_namespaceObject.createElement)(block_icon, { 48180 icon: library_copy, 48181 showColors: true 48182 }), (0,external_wp_element_namespaceObject.createElement)("div", { 48183 className: "block-editor-multi-selection-inspector__card-content" 48184 }, (0,external_wp_element_namespaceObject.createElement)("div", { 48185 className: "block-editor-multi-selection-inspector__card-title" 48186 }, (0,external_wp_i18n_namespaceObject.sprintf)( 48187 /* translators: %d: number of blocks */ 48188 (0,external_wp_i18n_namespaceObject._n)('%d block', '%d blocks', blocks.length), blocks.length)), (0,external_wp_element_namespaceObject.createElement)("div", { 48189 className: "block-editor-multi-selection-inspector__card-description" 48190 }, (0,external_wp_i18n_namespaceObject.sprintf)( 48191 /* translators: %d: number of words */ 48192 (0,external_wp_i18n_namespaceObject._n)('%d word', '%d words', words), words)))); 48193 } 48194 48195 /* harmony default export */ var multi_selection_inspector = ((0,external_wp_data_namespaceObject.withSelect)(select => { 48196 const { 48197 getMultiSelectedBlocks 48198 } = select(store); 48199 return { 48200 blocks: getMultiSelectedBlocks() 48201 }; 48202 })(MultiSelectionInspector)); 48203 48204 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/default-style-picker/index.js 48205 48206 48207 /** 48208 * WordPress dependencies 48209 */ 48210 48211 48212 48213 48214 48215 /** 48216 * Internal dependencies 48217 */ 48218 48219 48220 48221 function DefaultStylePicker(_ref) { 48222 let { 48223 blockName 48224 } = _ref; 48225 const { 48226 preferredStyle, 48227 onUpdatePreferredStyleVariations, 48228 styles 48229 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 48230 var _preferredStyleVariat, _preferredStyleVariat2; 48231 48232 const settings = select(store).getSettings(); 48233 const preferredStyleVariations = settings.__experimentalPreferredStyleVariations; 48234 return { 48235 preferredStyle: preferredStyleVariations === null || preferredStyleVariations === void 0 ? void 0 : (_preferredStyleVariat = preferredStyleVariations.value) === null || _preferredStyleVariat === void 0 ? void 0 : _preferredStyleVariat[blockName], 48236 onUpdatePreferredStyleVariations: (_preferredStyleVariat2 = preferredStyleVariations === null || preferredStyleVariations === void 0 ? void 0 : preferredStyleVariations.onChange) !== null && _preferredStyleVariat2 !== void 0 ? _preferredStyleVariat2 : null, 48237 styles: select(external_wp_blocks_namespaceObject.store).getBlockStyles(blockName) 48238 }; 48239 }, [blockName]); 48240 const selectOptions = (0,external_wp_element_namespaceObject.useMemo)(() => [{ 48241 label: (0,external_wp_i18n_namespaceObject.__)('Not set'), 48242 value: '' 48243 }, ...styles.map(_ref2 => { 48244 let { 48245 label, 48246 name 48247 } = _ref2; 48248 return { 48249 label, 48250 value: name 48251 }; 48252 })], [styles]); 48253 const defaultStyleName = (0,external_wp_element_namespaceObject.useMemo)(() => { 48254 var _getDefaultStyle; 48255 48256 return (_getDefaultStyle = getDefaultStyle(styles)) === null || _getDefaultStyle === void 0 ? void 0 : _getDefaultStyle.name; 48257 }, [styles]); 48258 const selectOnChange = (0,external_wp_element_namespaceObject.useCallback)(blockStyle => { 48259 onUpdatePreferredStyleVariations(blockName, blockStyle); 48260 }, [blockName, onUpdatePreferredStyleVariations]); // Until the functionality is migrated to global styles, 48261 // only show the default style picker if a non-default style has already been selected. 48262 48263 if (!preferredStyle || preferredStyle === defaultStyleName) { 48264 return null; 48265 } 48266 48267 return onUpdatePreferredStyleVariations && (0,external_wp_element_namespaceObject.createElement)("div", { 48268 className: "default-style-picker__default-switcher" 48269 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SelectControl, { 48270 options: selectOptions, 48271 value: preferredStyle || '', 48272 label: (0,external_wp_i18n_namespaceObject.__)('Default Style'), 48273 onChange: selectOnChange 48274 })); 48275 } 48276 48277 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-inspector/index.js 48278 48279 48280 /** 48281 * WordPress dependencies 48282 */ 48283 48284 48285 48286 48287 /** 48288 * Internal dependencies 48289 */ 48290 48291 48292 48293 48294 48295 48296 48297 48298 48299 48300 48301 const BlockInspector = _ref => { 48302 let { 48303 showNoBlockSelectedMessage = true 48304 } = _ref; 48305 const { 48306 count, 48307 hasBlockStyles, 48308 selectedBlockName, 48309 selectedBlockClientId, 48310 blockType 48311 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 48312 const { 48313 getSelectedBlockClientId, 48314 getSelectedBlockCount, 48315 getBlockName 48316 } = select(store); 48317 const { 48318 getBlockStyles 48319 } = select(external_wp_blocks_namespaceObject.store); 48320 48321 const _selectedBlockClientId = getSelectedBlockClientId(); 48322 48323 const _selectedBlockName = _selectedBlockClientId && getBlockName(_selectedBlockClientId); 48324 48325 const _blockType = _selectedBlockName && (0,external_wp_blocks_namespaceObject.getBlockType)(_selectedBlockName); 48326 48327 const blockStyles = _selectedBlockName && getBlockStyles(_selectedBlockName); 48328 48329 return { 48330 count: getSelectedBlockCount(), 48331 selectedBlockClientId: _selectedBlockClientId, 48332 selectedBlockName: _selectedBlockName, 48333 blockType: _blockType, 48334 hasBlockStyles: blockStyles && blockStyles.length > 0 48335 }; 48336 }, []); 48337 48338 if (count > 1) { 48339 return (0,external_wp_element_namespaceObject.createElement)("div", { 48340 className: "block-editor-block-inspector" 48341 }, (0,external_wp_element_namespaceObject.createElement)(multi_selection_inspector, null), (0,external_wp_element_namespaceObject.createElement)(inspector_controls.Slot, null), (0,external_wp_element_namespaceObject.createElement)(inspector_controls.Slot, { 48342 __experimentalGroup: "color", 48343 label: (0,external_wp_i18n_namespaceObject.__)('Color'), 48344 className: "color-block-support-panel__inner-wrapper" 48345 }), (0,external_wp_element_namespaceObject.createElement)(inspector_controls.Slot, { 48346 __experimentalGroup: "typography", 48347 label: (0,external_wp_i18n_namespaceObject.__)('Typography') 48348 }), (0,external_wp_element_namespaceObject.createElement)(inspector_controls.Slot, { 48349 __experimentalGroup: "dimensions", 48350 label: (0,external_wp_i18n_namespaceObject.__)('Dimensions') 48351 }), (0,external_wp_element_namespaceObject.createElement)(inspector_controls.Slot, { 48352 __experimentalGroup: "border", 48353 label: (0,external_wp_i18n_namespaceObject.__)('Border') 48354 })); 48355 } 48356 48357 const isSelectedBlockUnregistered = selectedBlockName === (0,external_wp_blocks_namespaceObject.getUnregisteredTypeHandlerName)(); 48358 /* 48359 * If the selected block is of an unregistered type, avoid showing it as an actual selection 48360 * because we want the user to focus on the unregistered block warning, not block settings. 48361 */ 48362 48363 if (!blockType || !selectedBlockClientId || isSelectedBlockUnregistered) { 48364 if (showNoBlockSelectedMessage) { 48365 return (0,external_wp_element_namespaceObject.createElement)("span", { 48366 className: "block-editor-block-inspector__no-blocks" 48367 }, (0,external_wp_i18n_namespaceObject.__)('No block selected.')); 48368 } 48369 48370 return null; 48371 } 48372 48373 return (0,external_wp_element_namespaceObject.createElement)(BlockInspectorSingleBlock, { 48374 clientId: selectedBlockClientId, 48375 blockName: blockType.name, 48376 hasBlockStyles: hasBlockStyles 48377 }); 48378 }; 48379 48380 const BlockInspectorSingleBlock = _ref2 => { 48381 let { 48382 clientId, 48383 blockName, 48384 hasBlockStyles 48385 } = _ref2; 48386 const blockInformation = useBlockDisplayInformation(clientId); 48387 return (0,external_wp_element_namespaceObject.createElement)("div", { 48388 className: "block-editor-block-inspector" 48389 }, (0,external_wp_element_namespaceObject.createElement)(block_card, blockInformation), (0,external_wp_element_namespaceObject.createElement)(block_variation_transforms, { 48390 blockClientId: clientId 48391 }), hasBlockStyles && (0,external_wp_element_namespaceObject.createElement)("div", null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, { 48392 title: (0,external_wp_i18n_namespaceObject.__)('Styles') 48393 }, (0,external_wp_element_namespaceObject.createElement)(block_styles, { 48394 scope: "core/block-inspector", 48395 clientId: clientId 48396 }), (0,external_wp_blocks_namespaceObject.hasBlockSupport)(blockName, 'defaultStylePicker', true) && (0,external_wp_element_namespaceObject.createElement)(DefaultStylePicker, { 48397 blockName: blockName 48398 }))), (0,external_wp_element_namespaceObject.createElement)(inspector_controls.Slot, null), (0,external_wp_element_namespaceObject.createElement)(inspector_controls.Slot, { 48399 __experimentalGroup: "color", 48400 label: (0,external_wp_i18n_namespaceObject.__)('Color'), 48401 className: "color-block-support-panel__inner-wrapper" 48402 }), (0,external_wp_element_namespaceObject.createElement)(inspector_controls.Slot, { 48403 __experimentalGroup: "typography", 48404 label: (0,external_wp_i18n_namespaceObject.__)('Typography') 48405 }), (0,external_wp_element_namespaceObject.createElement)(inspector_controls.Slot, { 48406 __experimentalGroup: "dimensions", 48407 label: (0,external_wp_i18n_namespaceObject.__)('Dimensions') 48408 }), (0,external_wp_element_namespaceObject.createElement)(inspector_controls.Slot, { 48409 __experimentalGroup: "border", 48410 label: (0,external_wp_i18n_namespaceObject.__)('Border') 48411 }), (0,external_wp_element_namespaceObject.createElement)("div", null, (0,external_wp_element_namespaceObject.createElement)(AdvancedControls, null)), (0,external_wp_element_namespaceObject.createElement)(skip_to_selected_block, { 48412 key: "back" 48413 })); 48414 }; 48415 48416 const AdvancedControls = () => { 48417 const slot = (0,external_wp_components_namespaceObject.__experimentalUseSlot)(InspectorAdvancedControls.slotName); 48418 const hasFills = Boolean(slot.fills && slot.fills.length); 48419 48420 if (!hasFills) { 48421 return null; 48422 } 48423 48424 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, { 48425 className: "block-editor-block-inspector__advanced", 48426 title: (0,external_wp_i18n_namespaceObject.__)('Advanced'), 48427 initialOpen: false 48428 }, (0,external_wp_element_namespaceObject.createElement)(inspector_controls.Slot, { 48429 __experimentalGroup: "advanced" 48430 })); 48431 }; 48432 /** 48433 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/block-inspector/README.md 48434 */ 48435 48436 48437 /* harmony default export */ var block_inspector = (BlockInspector); 48438 48439 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/block-tools/index.js 48440 48441 48442 48443 /** 48444 * External dependencies 48445 */ 48446 48447 /** 48448 * WordPress dependencies 48449 */ 48450 48451 48452 48453 48454 48455 /** 48456 * Internal dependencies 48457 */ 48458 48459 48460 48461 48462 48463 48464 /** 48465 * Renders block tools (the block toolbar, select/navigation mode toolbar, the 48466 * insertion point and a slot for the inline rich text toolbar). Must be wrapped 48467 * around the block content and editor styles wrapper or iframe. 48468 * 48469 * @param {Object} $0 Props. 48470 * @param {Object} $0.children The block content and style container. 48471 * @param {Object} $0.__unstableContentRef Ref holding the content scroll container. 48472 */ 48473 48474 function BlockTools(_ref) { 48475 let { 48476 children, 48477 __unstableContentRef, 48478 ...props 48479 } = _ref; 48480 const isLargeViewport = (0,external_wp_compose_namespaceObject.useViewportMatch)('medium'); 48481 const hasFixedToolbar = (0,external_wp_data_namespaceObject.useSelect)(select => select(store).getSettings().hasFixedToolbar, []); 48482 const isMatch = (0,external_wp_keyboardShortcuts_namespaceObject.__unstableUseShortcutEventMatch)(); 48483 const { 48484 getSelectedBlockClientIds, 48485 getBlockRootClientId 48486 } = (0,external_wp_data_namespaceObject.useSelect)(store); 48487 const { 48488 duplicateBlocks, 48489 removeBlocks, 48490 insertAfterBlock, 48491 insertBeforeBlock, 48492 clearSelectedBlock, 48493 moveBlocksUp, 48494 moveBlocksDown 48495 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 48496 48497 function onKeyDown(event) { 48498 if (isMatch('core/block-editor/move-up', event)) { 48499 const clientIds = getSelectedBlockClientIds(); 48500 48501 if (clientIds.length) { 48502 event.preventDefault(); 48503 const rootClientId = getBlockRootClientId((0,external_lodash_namespaceObject.first)(clientIds)); 48504 moveBlocksUp(clientIds, rootClientId); 48505 } 48506 } else if (isMatch('core/block-editor/move-down', event)) { 48507 const clientIds = getSelectedBlockClientIds(); 48508 48509 if (clientIds.length) { 48510 event.preventDefault(); 48511 const rootClientId = getBlockRootClientId((0,external_lodash_namespaceObject.first)(clientIds)); 48512 moveBlocksDown(clientIds, rootClientId); 48513 } 48514 } else if (isMatch('core/block-editor/duplicate', event)) { 48515 const clientIds = getSelectedBlockClientIds(); 48516 48517 if (clientIds.length) { 48518 event.preventDefault(); 48519 duplicateBlocks(clientIds); 48520 } 48521 } else if (isMatch('core/block-editor/remove', event)) { 48522 const clientIds = getSelectedBlockClientIds(); 48523 48524 if (clientIds.length) { 48525 event.preventDefault(); 48526 removeBlocks(clientIds); 48527 } 48528 } else if (isMatch('core/block-editor/insert-after', event)) { 48529 const clientIds = getSelectedBlockClientIds(); 48530 48531 if (clientIds.length) { 48532 event.preventDefault(); 48533 insertAfterBlock((0,external_lodash_namespaceObject.last)(clientIds)); 48534 } 48535 } else if (isMatch('core/block-editor/insert-before', event)) { 48536 const clientIds = getSelectedBlockClientIds(); 48537 48538 if (clientIds.length) { 48539 event.preventDefault(); 48540 insertBeforeBlock((0,external_lodash_namespaceObject.first)(clientIds)); 48541 } 48542 } else if (isMatch('core/block-editor/unselect', event)) { 48543 const clientIds = getSelectedBlockClientIds(); 48544 48545 if (clientIds.length > 1) { 48546 event.preventDefault(); 48547 clearSelectedBlock(); 48548 event.target.ownerDocument.defaultView.getSelection().removeAllRanges(); 48549 } 48550 } 48551 } 48552 48553 return (// eslint-disable-next-line jsx-a11y/no-static-element-interactions 48554 (0,external_wp_element_namespaceObject.createElement)("div", _extends({}, props, { 48555 onKeyDown: onKeyDown 48556 }), (0,external_wp_element_namespaceObject.createElement)(InsertionPoint, { 48557 __unstableContentRef: __unstableContentRef 48558 }, (hasFixedToolbar || !isLargeViewport) && (0,external_wp_element_namespaceObject.createElement)(block_contextual_toolbar, { 48559 isFixed: true 48560 }), (0,external_wp_element_namespaceObject.createElement)(WrappedBlockPopover, { 48561 __unstableContentRef: __unstableContentRef 48562 }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Popover.Slot, { 48563 name: "block-toolbar", 48564 ref: usePopoverScroll(__unstableContentRef) 48565 }), children, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Popover.Slot, { 48566 name: "__unstable-block-tools-after", 48567 ref: usePopoverScroll(__unstableContentRef) 48568 }))) 48569 ); 48570 } 48571 48572 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/inserter/library.js 48573 48574 48575 /** 48576 * External dependencies 48577 */ 48578 48579 /** 48580 * WordPress dependencies 48581 */ 48582 48583 48584 48585 /** 48586 * Internal dependencies 48587 */ 48588 48589 48590 48591 48592 function InserterLibrary(_ref, ref) { 48593 let { 48594 rootClientId, 48595 clientId, 48596 isAppender, 48597 showInserterHelpPanel, 48598 showMostUsedBlocks = false, 48599 __experimentalInsertionIndex, 48600 __experimentalFilterValue, 48601 onSelect = external_lodash_namespaceObject.noop, 48602 shouldFocusBlock = false 48603 } = _ref; 48604 const destinationRootClientId = (0,external_wp_data_namespaceObject.useSelect)(select => { 48605 const { 48606 getBlockRootClientId 48607 } = select(store); 48608 return rootClientId || getBlockRootClientId(clientId) || undefined; 48609 }, [clientId, rootClientId]); 48610 return (0,external_wp_element_namespaceObject.createElement)(menu, { 48611 onSelect: onSelect, 48612 rootClientId: destinationRootClientId, 48613 clientId: clientId, 48614 isAppender: isAppender, 48615 showInserterHelpPanel: showInserterHelpPanel, 48616 showMostUsedBlocks: showMostUsedBlocks, 48617 __experimentalInsertionIndex: __experimentalInsertionIndex, 48618 __experimentalFilterValue: __experimentalFilterValue, 48619 shouldFocusBlock: shouldFocusBlock, 48620 ref: ref 48621 }); 48622 } 48623 48624 /* harmony default export */ var library = ((0,external_wp_element_namespaceObject.forwardRef)(InserterLibrary)); 48625 48626 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/keyboard-shortcuts/index.js 48627 /** 48628 * WordPress dependencies 48629 */ 48630 48631 48632 48633 48634 48635 function KeyboardShortcuts() { 48636 return null; 48637 } 48638 48639 function KeyboardShortcutsRegister() { 48640 // Registering the shortcuts. 48641 const { 48642 registerShortcut 48643 } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_keyboardShortcuts_namespaceObject.store); 48644 (0,external_wp_element_namespaceObject.useEffect)(() => { 48645 registerShortcut({ 48646 name: 'core/block-editor/duplicate', 48647 category: 'block', 48648 description: (0,external_wp_i18n_namespaceObject.__)('Duplicate the selected block(s).'), 48649 keyCombination: { 48650 modifier: 'primaryShift', 48651 character: 'd' 48652 } 48653 }); 48654 registerShortcut({ 48655 name: 'core/block-editor/remove', 48656 category: 'block', 48657 description: (0,external_wp_i18n_namespaceObject.__)('Remove the selected block(s).'), 48658 keyCombination: { 48659 modifier: 'access', 48660 character: 'z' 48661 } 48662 }); 48663 registerShortcut({ 48664 name: 'core/block-editor/insert-before', 48665 category: 'block', 48666 description: (0,external_wp_i18n_namespaceObject.__)('Insert a new block before the selected block(s).'), 48667 keyCombination: { 48668 modifier: 'primaryAlt', 48669 character: 't' 48670 } 48671 }); 48672 registerShortcut({ 48673 name: 'core/block-editor/insert-after', 48674 category: 'block', 48675 description: (0,external_wp_i18n_namespaceObject.__)('Insert a new block after the selected block(s).'), 48676 keyCombination: { 48677 modifier: 'primaryAlt', 48678 character: 'y' 48679 } 48680 }); 48681 registerShortcut({ 48682 name: 'core/block-editor/delete-multi-selection', 48683 category: 'block', 48684 description: (0,external_wp_i18n_namespaceObject.__)('Delete selection.'), 48685 keyCombination: { 48686 character: 'del' 48687 }, 48688 aliases: [{ 48689 character: 'backspace' 48690 }] 48691 }); 48692 registerShortcut({ 48693 name: 'core/block-editor/select-all', 48694 category: 'selection', 48695 description: (0,external_wp_i18n_namespaceObject.__)('Select all text when typing. Press again to select all blocks.'), 48696 keyCombination: { 48697 modifier: 'primary', 48698 character: 'a' 48699 } 48700 }); 48701 registerShortcut({ 48702 name: 'core/block-editor/unselect', 48703 category: 'selection', 48704 description: (0,external_wp_i18n_namespaceObject.__)('Clear selection.'), 48705 keyCombination: { 48706 character: 'escape' 48707 } 48708 }); 48709 registerShortcut({ 48710 name: 'core/block-editor/focus-toolbar', 48711 category: 'global', 48712 description: (0,external_wp_i18n_namespaceObject.__)('Navigate to the nearest toolbar.'), 48713 keyCombination: { 48714 modifier: 'alt', 48715 character: 'F10' 48716 } 48717 }); 48718 registerShortcut({ 48719 name: 'core/block-editor/move-up', 48720 category: 'block', 48721 description: (0,external_wp_i18n_namespaceObject.__)('Move the selected block(s) up.'), 48722 keyCombination: { 48723 modifier: 'secondary', 48724 character: 't' 48725 } 48726 }); 48727 registerShortcut({ 48728 name: 'core/block-editor/move-down', 48729 category: 'block', 48730 description: (0,external_wp_i18n_namespaceObject.__)('Move the selected block(s) down.'), 48731 keyCombination: { 48732 modifier: 'secondary', 48733 character: 'y' 48734 } 48735 }); 48736 }, [registerShortcut]); 48737 return null; 48738 } 48739 48740 KeyboardShortcuts.Register = KeyboardShortcutsRegister; 48741 /* harmony default export */ var keyboard_shortcuts = (KeyboardShortcuts); 48742 48743 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/selection-scroll-into-view/index.js 48744 /** 48745 * WordPress dependencies 48746 */ 48747 48748 /** 48749 * Scrolls the multi block selection end into view if not in view already. This 48750 * is important to do after selection by keyboard. 48751 * 48752 * @deprecated 48753 */ 48754 48755 function MultiSelectScrollIntoView() { 48756 external_wp_deprecated_default()('wp.blockEditor.MultiSelectScrollIntoView', { 48757 hint: 'This behaviour is now built-in.', 48758 since: '5.8' 48759 }); 48760 return null; 48761 } 48762 48763 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/observe-typing/index.js 48764 48765 48766 /** 48767 * WordPress dependencies 48768 */ 48769 48770 48771 48772 48773 /** 48774 * Internal dependencies 48775 */ 48776 48777 48778 /** 48779 * Set of key codes upon which typing is to be initiated on a keydown event. 48780 * 48781 * @type {Set<number>} 48782 */ 48783 48784 const KEY_DOWN_ELIGIBLE_KEY_CODES = new Set([external_wp_keycodes_namespaceObject.UP, external_wp_keycodes_namespaceObject.RIGHT, external_wp_keycodes_namespaceObject.DOWN, external_wp_keycodes_namespaceObject.LEFT, external_wp_keycodes_namespaceObject.ENTER, external_wp_keycodes_namespaceObject.BACKSPACE]); 48785 /** 48786 * Returns true if a given keydown event can be inferred as intent to start 48787 * typing, or false otherwise. A keydown is considered eligible if it is a 48788 * text navigation without shift active. 48789 * 48790 * @param {KeyboardEvent} event Keydown event to test. 48791 * 48792 * @return {boolean} Whether event is eligible to start typing. 48793 */ 48794 48795 function isKeyDownEligibleForStartTyping(event) { 48796 const { 48797 keyCode, 48798 shiftKey 48799 } = event; 48800 return !shiftKey && KEY_DOWN_ELIGIBLE_KEY_CODES.has(keyCode); 48801 } 48802 /** 48803 * Removes the `isTyping` flag when the mouse moves in the document of the given 48804 * element. 48805 */ 48806 48807 48808 function useMouseMoveTypingReset() { 48809 const isTyping = (0,external_wp_data_namespaceObject.useSelect)(select => select(store).isTyping(), []); 48810 const { 48811 stopTyping 48812 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 48813 return (0,external_wp_compose_namespaceObject.useRefEffect)(node => { 48814 if (!isTyping) { 48815 return; 48816 } 48817 48818 const { 48819 ownerDocument 48820 } = node; 48821 let lastClientX; 48822 let lastClientY; 48823 /** 48824 * On mouse move, unset typing flag if user has moved cursor. 48825 * 48826 * @param {MouseEvent} event Mousemove event. 48827 */ 48828 48829 function stopTypingOnMouseMove(event) { 48830 const { 48831 clientX, 48832 clientY 48833 } = event; // We need to check that the mouse really moved because Safari 48834 // triggers mousemove events when shift or ctrl are pressed. 48835 48836 if (lastClientX && lastClientY && (lastClientX !== clientX || lastClientY !== clientY)) { 48837 stopTyping(); 48838 } 48839 48840 lastClientX = clientX; 48841 lastClientY = clientY; 48842 } 48843 48844 ownerDocument.addEventListener('mousemove', stopTypingOnMouseMove); 48845 return () => { 48846 ownerDocument.removeEventListener('mousemove', stopTypingOnMouseMove); 48847 }; 48848 }, [isTyping, stopTyping]); 48849 } 48850 /** 48851 * Sets and removes the `isTyping` flag based on user actions: 48852 * 48853 * - Sets the flag if the user types within the given element. 48854 * - Removes the flag when the user selects some text, focusses a non-text 48855 * field, presses ESC or TAB, or moves the mouse in the document. 48856 */ 48857 48858 function useTypingObserver() { 48859 const isTyping = (0,external_wp_data_namespaceObject.useSelect)(select => select(store).isTyping()); 48860 const { 48861 startTyping, 48862 stopTyping 48863 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 48864 const ref1 = useMouseMoveTypingReset(); 48865 const ref2 = (0,external_wp_compose_namespaceObject.useRefEffect)(node => { 48866 const { 48867 ownerDocument 48868 } = node; 48869 const { 48870 defaultView 48871 } = ownerDocument; // Listeners to stop typing should only be added when typing. 48872 // Listeners to start typing should only be added when not typing. 48873 48874 if (isTyping) { 48875 let timerId; 48876 /** 48877 * Stops typing when focus transitions to a non-text field element. 48878 * 48879 * @param {FocusEvent} event Focus event. 48880 */ 48881 48882 function stopTypingOnNonTextField(event) { 48883 const { 48884 target 48885 } = event; // Since focus to a non-text field via arrow key will trigger 48886 // before the keydown event, wait until after current stack 48887 // before evaluating whether typing is to be stopped. Otherwise, 48888 // typing will re-start. 48889 48890 timerId = defaultView.setTimeout(() => { 48891 if (!(0,external_wp_dom_namespaceObject.isTextField)(target)) { 48892 stopTyping(); 48893 } 48894 }); 48895 } 48896 /** 48897 * Unsets typing flag if user presses Escape while typing flag is 48898 * active. 48899 * 48900 * @param {KeyboardEvent} event Keypress or keydown event to 48901 * interpret. 48902 */ 48903 48904 48905 function stopTypingOnEscapeKey(event) { 48906 const { 48907 keyCode 48908 } = event; 48909 48910 if (keyCode === external_wp_keycodes_namespaceObject.ESCAPE || keyCode === external_wp_keycodes_namespaceObject.TAB) { 48911 stopTyping(); 48912 } 48913 } 48914 /** 48915 * On selection change, unset typing flag if user has made an 48916 * uncollapsed (shift) selection. 48917 */ 48918 48919 48920 function stopTypingOnSelectionUncollapse() { 48921 const selection = defaultView.getSelection(); 48922 const isCollapsed = selection.rangeCount > 0 && selection.getRangeAt(0).collapsed; 48923 48924 if (!isCollapsed) { 48925 stopTyping(); 48926 } 48927 } 48928 48929 node.addEventListener('focus', stopTypingOnNonTextField); 48930 node.addEventListener('keydown', stopTypingOnEscapeKey); 48931 ownerDocument.addEventListener('selectionchange', stopTypingOnSelectionUncollapse); 48932 return () => { 48933 defaultView.clearTimeout(timerId); 48934 node.removeEventListener('focus', stopTypingOnNonTextField); 48935 node.removeEventListener('keydown', stopTypingOnEscapeKey); 48936 ownerDocument.removeEventListener('selectionchange', stopTypingOnSelectionUncollapse); 48937 }; 48938 } 48939 /** 48940 * Handles a keypress or keydown event to infer intention to start 48941 * typing. 48942 * 48943 * @param {KeyboardEvent} event Keypress or keydown event to interpret. 48944 */ 48945 48946 48947 function startTypingInTextField(event) { 48948 const { 48949 type, 48950 target 48951 } = event; // Abort early if already typing, or key press is incurred outside a 48952 // text field (e.g. arrow-ing through toolbar buttons). 48953 // Ignore typing if outside the current DOM container 48954 48955 if (!(0,external_wp_dom_namespaceObject.isTextField)(target) || !node.contains(target)) { 48956 return; 48957 } // Special-case keydown because certain keys do not emit a keypress 48958 // event. Conversely avoid keydown as the canonical event since 48959 // there are many keydown which are explicitly not targeted for 48960 // typing. 48961 48962 48963 if (type === 'keydown' && !isKeyDownEligibleForStartTyping(event)) { 48964 return; 48965 } 48966 48967 startTyping(); 48968 } 48969 48970 node.addEventListener('keypress', startTypingInTextField); 48971 node.addEventListener('keydown', startTypingInTextField); 48972 return () => { 48973 node.removeEventListener('keypress', startTypingInTextField); 48974 node.removeEventListener('keydown', startTypingInTextField); 48975 }; 48976 }, [isTyping, startTyping, stopTyping]); 48977 return (0,external_wp_compose_namespaceObject.useMergeRefs)([ref1, ref2]); 48978 } 48979 48980 function ObserveTyping(_ref) { 48981 let { 48982 children 48983 } = _ref; 48984 return (0,external_wp_element_namespaceObject.createElement)("div", { 48985 ref: useTypingObserver() 48986 }, children); 48987 } 48988 /** 48989 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/observe-typing/README.md 48990 */ 48991 48992 48993 /* harmony default export */ var observe_typing = (ObserveTyping); 48994 48995 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/typewriter/index.js 48996 48997 48998 /** 48999 * WordPress dependencies 49000 */ 49001 49002 49003 49004 49005 /** 49006 * Internal dependencies 49007 */ 49008 49009 49010 const isIE = window.navigator.userAgent.indexOf('Trident') !== -1; 49011 const arrowKeyCodes = new Set([external_wp_keycodes_namespaceObject.UP, external_wp_keycodes_namespaceObject.DOWN, external_wp_keycodes_namespaceObject.LEFT, external_wp_keycodes_namespaceObject.RIGHT]); 49012 const initialTriggerPercentage = 0.75; 49013 function useTypewriter() { 49014 const hasSelectedBlock = (0,external_wp_data_namespaceObject.useSelect)(select => select(store).hasSelectedBlock(), []); 49015 return (0,external_wp_compose_namespaceObject.useRefEffect)(node => { 49016 if (!hasSelectedBlock) { 49017 return; 49018 } 49019 49020 const { 49021 ownerDocument 49022 } = node; 49023 const { 49024 defaultView 49025 } = ownerDocument; 49026 let scrollResizeRafId; 49027 let onKeyDownRafId; 49028 let caretRect; 49029 49030 function onScrollResize() { 49031 if (scrollResizeRafId) { 49032 return; 49033 } 49034 49035 scrollResizeRafId = defaultView.requestAnimationFrame(() => { 49036 computeCaretRectangle(); 49037 scrollResizeRafId = null; 49038 }); 49039 } 49040 49041 function onKeyDown(event) { 49042 // Ensure the any remaining request is cancelled. 49043 if (onKeyDownRafId) { 49044 defaultView.cancelAnimationFrame(onKeyDownRafId); 49045 } // Use an animation frame for a smooth result. 49046 49047 49048 onKeyDownRafId = defaultView.requestAnimationFrame(() => { 49049 maintainCaretPosition(event); 49050 onKeyDownRafId = null; 49051 }); 49052 } 49053 /** 49054 * Maintains the scroll position after a selection change caused by a 49055 * keyboard event. 49056 * 49057 * @param {KeyboardEvent} event Keyboard event. 49058 */ 49059 49060 49061 function maintainCaretPosition(_ref) { 49062 let { 49063 keyCode 49064 } = _ref; 49065 49066 if (!isSelectionEligibleForScroll()) { 49067 return; 49068 } 49069 49070 const currentCaretRect = (0,external_wp_dom_namespaceObject.computeCaretRect)(defaultView); 49071 49072 if (!currentCaretRect) { 49073 return; 49074 } // If for some reason there is no position set to be scrolled to, let 49075 // this be the position to be scrolled to in the future. 49076 49077 49078 if (!caretRect) { 49079 caretRect = currentCaretRect; 49080 return; 49081 } // Even though enabling the typewriter effect for arrow keys results in 49082 // a pleasant experience, it may not be the case for everyone, so, for 49083 // now, let's disable it. 49084 49085 49086 if (arrowKeyCodes.has(keyCode)) { 49087 // Reset the caret position to maintain. 49088 caretRect = currentCaretRect; 49089 return; 49090 } 49091 49092 const diff = currentCaretRect.top - caretRect.top; 49093 49094 if (diff === 0) { 49095 return; 49096 } 49097 49098 const scrollContainer = (0,external_wp_dom_namespaceObject.getScrollContainer)(node); // The page must be scrollable. 49099 49100 if (!scrollContainer) { 49101 return; 49102 } 49103 49104 const windowScroll = scrollContainer === ownerDocument.body; 49105 const scrollY = windowScroll ? defaultView.scrollY : scrollContainer.scrollTop; 49106 const scrollContainerY = windowScroll ? 0 : scrollContainer.getBoundingClientRect().top; 49107 const relativeScrollPosition = windowScroll ? caretRect.top / defaultView.innerHeight : (caretRect.top - scrollContainerY) / (defaultView.innerHeight - scrollContainerY); // If the scroll position is at the start, the active editable element 49108 // is the last one, and the caret is positioned within the initial 49109 // trigger percentage of the page, do not scroll the page. 49110 // The typewriter effect should not kick in until an empty page has been 49111 // filled with the initial trigger percentage or the user scrolls 49112 // intentionally down. 49113 49114 if (scrollY === 0 && relativeScrollPosition < initialTriggerPercentage && isLastEditableNode()) { 49115 // Reset the caret position to maintain. 49116 caretRect = currentCaretRect; 49117 return; 49118 } 49119 49120 const scrollContainerHeight = windowScroll ? defaultView.innerHeight : scrollContainer.clientHeight; // Abort if the target scroll position would scroll the caret out of 49121 // view. 49122 49123 if ( // The caret is under the lower fold. 49124 caretRect.top + caretRect.height > scrollContainerY + scrollContainerHeight || // The caret is above the upper fold. 49125 caretRect.top < scrollContainerY) { 49126 // Reset the caret position to maintain. 49127 caretRect = currentCaretRect; 49128 return; 49129 } 49130 49131 if (windowScroll) { 49132 defaultView.scrollBy(0, diff); 49133 } else { 49134 scrollContainer.scrollTop += diff; 49135 } 49136 } 49137 /** 49138 * Adds a `selectionchange` listener to reset the scroll position to be 49139 * maintained. 49140 */ 49141 49142 49143 function addSelectionChangeListener() { 49144 ownerDocument.addEventListener('selectionchange', computeCaretRectOnSelectionChange); 49145 } 49146 /** 49147 * Resets the scroll position to be maintained during a `selectionchange` 49148 * event. Also removes the listener, so it acts as a one-time listener. 49149 */ 49150 49151 49152 function computeCaretRectOnSelectionChange() { 49153 ownerDocument.removeEventListener('selectionchange', computeCaretRectOnSelectionChange); 49154 computeCaretRectangle(); 49155 } 49156 /** 49157 * Resets the scroll position to be maintained. 49158 */ 49159 49160 49161 function computeCaretRectangle() { 49162 if (isSelectionEligibleForScroll()) { 49163 caretRect = (0,external_wp_dom_namespaceObject.computeCaretRect)(defaultView); 49164 } 49165 } 49166 /** 49167 * Checks if the current situation is elegible for scroll: 49168 * - There should be one and only one block selected. 49169 * - The component must contain the selection. 49170 * - The active element must be contenteditable. 49171 */ 49172 49173 49174 function isSelectionEligibleForScroll() { 49175 return node.contains(ownerDocument.activeElement) && ownerDocument.activeElement.isContentEditable; 49176 } 49177 49178 function isLastEditableNode() { 49179 const editableNodes = node.querySelectorAll('[contenteditable="true"]'); 49180 const lastEditableNode = editableNodes[editableNodes.length - 1]; 49181 return lastEditableNode === ownerDocument.activeElement; 49182 } // When the user scrolls or resizes, the scroll position should be 49183 // reset. 49184 49185 49186 defaultView.addEventListener('scroll', onScrollResize, true); 49187 defaultView.addEventListener('resize', onScrollResize, true); 49188 node.addEventListener('keydown', onKeyDown); 49189 node.addEventListener('keyup', maintainCaretPosition); 49190 node.addEventListener('mousedown', addSelectionChangeListener); 49191 node.addEventListener('touchstart', addSelectionChangeListener); 49192 return () => { 49193 defaultView.removeEventListener('scroll', onScrollResize, true); 49194 defaultView.removeEventListener('resize', onScrollResize, true); 49195 node.removeEventListener('keydown', onKeyDown); 49196 node.removeEventListener('keyup', maintainCaretPosition); 49197 node.removeEventListener('mousedown', addSelectionChangeListener); 49198 node.removeEventListener('touchstart', addSelectionChangeListener); 49199 ownerDocument.removeEventListener('selectionchange', computeCaretRectOnSelectionChange); 49200 defaultView.cancelAnimationFrame(scrollResizeRafId); 49201 defaultView.cancelAnimationFrame(onKeyDownRafId); 49202 }; 49203 }, [hasSelectedBlock]); 49204 } 49205 49206 function Typewriter(_ref2) { 49207 let { 49208 children 49209 } = _ref2; 49210 return (0,external_wp_element_namespaceObject.createElement)("div", { 49211 ref: useTypewriter(), 49212 className: "block-editor__typewriter" 49213 }, children); 49214 } 49215 /** 49216 * The exported component. The implementation of Typewriter faced technical 49217 * challenges in Internet Explorer, and is simply skipped, rendering the given 49218 * props children instead. 49219 * 49220 * @type {WPComponent} 49221 */ 49222 49223 49224 const TypewriterOrIEBypass = isIE ? props => props.children : Typewriter; 49225 /** 49226 * Ensures that the text selection keeps the same vertical distance from the 49227 * viewport during keyboard events within this component. The vertical distance 49228 * can vary. It is the last clicked or scrolled to position. 49229 */ 49230 49231 /* harmony default export */ var typewriter = (TypewriterOrIEBypass); 49232 49233 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/use-no-recursive-renders/index.js 49234 49235 49236 /** 49237 * WordPress dependencies 49238 */ 49239 49240 /** 49241 * Internal dependencies 49242 */ 49243 49244 49245 const RenderedRefsContext = (0,external_wp_element_namespaceObject.createContext)({}); 49246 /** 49247 * Immutably adds an unique identifier to a set scoped for a given block type. 49248 * 49249 * @param {Object} renderedBlocks Rendered blocks grouped by block name 49250 * @param {string} blockName Name of the block. 49251 * @param {*} uniqueId Any value that acts as a unique identifier for a block instance. 49252 * 49253 * @return {Object} The list of rendered blocks grouped by block name. 49254 */ 49255 49256 function addToBlockType(renderedBlocks, blockName, uniqueId) { 49257 const result = { ...renderedBlocks, 49258 [blockName]: renderedBlocks[blockName] ? new Set(renderedBlocks[blockName]) : new Set() 49259 }; 49260 result[blockName].add(uniqueId); 49261 return result; 49262 } 49263 /** 49264 * A React hook for keeping track of blocks previously rendered up in the block 49265 * tree. Blocks susceptible to recursion can use this hook in their `Edit` 49266 * function to prevent said recursion. 49267 * 49268 * @param {*} uniqueId Any value that acts as a unique identifier for a block instance. 49269 * @param {string} blockName Optional block name. 49270 * 49271 * @return {[boolean, Function]} A tuple of: 49272 * - a boolean describing whether the provided id 49273 * has already been rendered; 49274 * - a React context provider to be used to wrap 49275 * other elements. 49276 */ 49277 49278 49279 function useNoRecursiveRenders(uniqueId) { 49280 var _previouslyRenderedBl; 49281 49282 let blockName = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : ''; 49283 const previouslyRenderedBlocks = (0,external_wp_element_namespaceObject.useContext)(RenderedRefsContext); 49284 const { 49285 name 49286 } = useBlockEditContext(); 49287 blockName = blockName || name; 49288 const hasAlreadyRendered = Boolean((_previouslyRenderedBl = previouslyRenderedBlocks[blockName]) === null || _previouslyRenderedBl === void 0 ? void 0 : _previouslyRenderedBl.has(uniqueId)); 49289 const newRenderedBlocks = (0,external_wp_element_namespaceObject.useMemo)(() => addToBlockType(previouslyRenderedBlocks, blockName, uniqueId), [previouslyRenderedBlocks, blockName, uniqueId]); 49290 const Provider = (0,external_wp_element_namespaceObject.useCallback)(_ref => { 49291 let { 49292 children 49293 } = _ref; 49294 return (0,external_wp_element_namespaceObject.createElement)(RenderedRefsContext.Provider, { 49295 value: newRenderedBlocks 49296 }, children); 49297 }, [newRenderedBlocks]); 49298 return [hasAlreadyRendered, Provider]; 49299 } 49300 49301 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/components/index.js 49302 /* 49303 * Block Creation Components 49304 */ 49305 49306 49307 49308 49309 49310 49311 49312 49313 49314 49315 49316 49317 49318 49319 49320 49321 49322 49323 49324 49325 49326 49327 49328 49329 49330 49331 49332 49333 49334 49335 49336 49337 49338 49339 49340 49341 49342 49343 49344 49345 49346 49347 49348 49349 49350 49351 49352 49353 49354 49355 49356 49357 49358 49359 49360 49361 49362 49363 49364 49365 49366 49367 49368 49369 /* 49370 * Content Related Components 49371 */ 49372 49373 49374 49375 49376 49377 49378 49379 49380 49381 49382 49383 49384 49385 49386 49387 49388 49389 49390 49391 49392 49393 49394 49395 49396 49397 49398 49399 49400 49401 49402 49403 49404 49405 49406 49407 49408 /* 49409 * State Related Components 49410 */ 49411 49412 49413 49414 49415 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/utils/block-variation-transforms.js 49416 /** 49417 * External dependencies 49418 */ 49419 49420 /** @typedef {import('@wordpress/blocks').WPBlockVariation} WPBlockVariation */ 49421 49422 /** 49423 * Matches the provided block variations with a block's attributes. If no match 49424 * or more than one matches are found it returns `undefined`. If a single match is 49425 * found it returns it. 49426 * 49427 * This is a simple implementation for now as it takes into account only the attributes 49428 * of a block variation and not `InnerBlocks`. 49429 * 49430 * @param {Object} blockAttributes - The block attributes to try to find a match. 49431 * @param {WPBlockVariation[]} variations - A list of block variations to test for a match. 49432 * @return {?WPBlockVariation} - If a match is found returns it. If not or more than one matches are found returns `undefined`. 49433 */ 49434 49435 const __experimentalGetMatchingVariation = (blockAttributes, variations) => { 49436 if (!variations || !blockAttributes) return; 49437 const matches = variations.filter(_ref => { 49438 let { 49439 attributes 49440 } = _ref; 49441 if (!attributes || !Object.keys(attributes).length) return false; 49442 return (0,external_lodash_namespaceObject.isMatch)(blockAttributes, attributes); 49443 }); 49444 if (matches.length !== 1) return; 49445 return matches[0]; 49446 }; 49447 49448 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/utils/parse-css-unit-to-px.js 49449 /** 49450 * Converts string to object { value, unit }. 49451 * 49452 * @param {string} cssUnit 49453 * @return {Object} parsedUnit 49454 */ 49455 function parseUnit(cssUnit) { 49456 const match = cssUnit === null || cssUnit === void 0 ? void 0 : cssUnit.trim().match(/^(0?[-.]?\d*\.?\d+)(r?e[m|x]|v[h|w|min|max]+|p[x|t|c]|[c|m]m|%|in|ch|Q|lh)$/); 49457 49458 if (!isNaN(cssUnit) && !isNaN(parseFloat(cssUnit))) { 49459 return { 49460 value: parseFloat(cssUnit), 49461 unit: 'px' 49462 }; 49463 } 49464 49465 return match ? { 49466 value: parseFloat(match[1]) || match[1], 49467 unit: match[2] 49468 } : { 49469 value: cssUnit, 49470 unit: undefined 49471 }; 49472 } 49473 /** 49474 * Evaluate a math expression. 49475 * 49476 * @param {string} expression 49477 * @return {number} evaluated expression. 49478 */ 49479 49480 49481 function calculate(expression) { 49482 return Function(`'use strict'; return ($expression})`)(); 49483 } 49484 /** 49485 * Calculates the css function value for the supported css functions such as max, min, clamp and calc. 49486 * 49487 * @param {string} functionUnitValue string should be in a particular format (for example min(12px,12px) ) no nested loops. 49488 * @param {Object} options 49489 * @return {string} unit containing the unit in PX. 49490 */ 49491 49492 49493 function getFunctionUnitValue(functionUnitValue, options) { 49494 const functionUnit = functionUnitValue.split(/[(),]/g).filter(Boolean); 49495 const units = functionUnit.slice(1).map(unit => parseUnit(getPxFromCssUnit(unit, options)).value).filter(Boolean); 49496 49497 switch (functionUnit[0]) { 49498 case 'min': 49499 return Math.min(...units) + 'px'; 49500 49501 case 'max': 49502 return Math.max(...units) + 'px'; 49503 49504 case 'clamp': 49505 if (units.length !== 3) { 49506 return null; 49507 } 49508 49509 if (units[1] < units[0]) { 49510 return units[0] + 'px'; 49511 } 49512 49513 if (units[1] > units[2]) { 49514 return units[2] + 'px'; 49515 } 49516 49517 return units[1] + 'px'; 49518 49519 case 'calc': 49520 return units[0] + 'px'; 49521 } 49522 } 49523 /** 49524 * Take a css function such as min, max, calc, clamp and returns parsedUnit 49525 * 49526 * How this works for the nested function is that it first replaces the inner function call. 49527 * Then it tackles the outer onces. 49528 * So for example: min( max(25px, 35px), 40px ) 49529 * in the first pass we would replace max(25px, 35px) with 35px. 49530 * then we would try to evaluate min( 35px, 40px ) 49531 * and then finally return 35px. 49532 * 49533 * @param {string} cssUnit 49534 * @return {Object} parsedUnit object. 49535 */ 49536 49537 49538 function parseUnitFunction(cssUnit) { 49539 while (true) { 49540 const currentCssUnit = cssUnit; 49541 const regExp = /(max|min|calc|clamp)\(([^()]*)\)/g; 49542 const matches = regExp.exec(cssUnit) || []; 49543 49544 if (matches[0]) { 49545 const functionUnitValue = getFunctionUnitValue(matches[0]); 49546 cssUnit = cssUnit.replace(matches[0], functionUnitValue); 49547 } // If the unit hasn't been modified or we have a single value break free. 49548 49549 49550 if (cssUnit === currentCssUnit || parseFloat(cssUnit)) { 49551 break; 49552 } 49553 } 49554 49555 return parseUnit(cssUnit); 49556 } 49557 /** 49558 * Return true if we think this is a math expression. 49559 * 49560 * @param {string} cssUnit the cssUnit value being evaluted. 49561 * @return {boolean} Whether the cssUnit is a math expression. 49562 */ 49563 49564 49565 function isMathExpression(cssUnit) { 49566 for (let i = 0; i < cssUnit.length; i++) { 49567 if (['+', '-', '/', '*'].includes(cssUnit[i])) { 49568 return true; 49569 } 49570 } 49571 49572 return false; 49573 } 49574 /** 49575 * Evaluates the math expression and return a px value. 49576 * 49577 * @param {string} cssUnit the cssUnit value being evaluted. 49578 * @return {string} return a converfted value to px. 49579 */ 49580 49581 49582 function evalMathExpression(cssUnit) { 49583 let errorFound = false; // Convert every part of the expression to px values. 49584 49585 const cssUnitsBits = cssUnit.split(/[+-/*/]/g).filter(Boolean); 49586 49587 for (const unit of cssUnitsBits) { 49588 // Standardize the unit to px and extract the value. 49589 const parsedUnit = parseUnit(getPxFromCssUnit(unit)); 49590 49591 if (!parseFloat(parsedUnit.value)) { 49592 errorFound = true; // End early since we are dealing with a null value. 49593 49594 break; 49595 } 49596 49597 cssUnit = cssUnit.replace(unit, parsedUnit.value); 49598 } 49599 49600 return errorFound ? null : calculate(cssUnit).toFixed(0) + 'px'; 49601 } 49602 /** 49603 * Convert a parsedUnit object to px value. 49604 * 49605 * @param {Object} parsedUnit 49606 * @param {Object} options 49607 * @return {string} or {null} returns the converted with in a px value format. 49608 */ 49609 49610 49611 function convertParsedUnitToPx(parsedUnit, options) { 49612 const PIXELS_PER_INCH = 96; 49613 const ONE_PERCENT = 0.01; 49614 const defaultProperties = { 49615 fontSize: 16, 49616 lineHeight: 16, 49617 width: 375, 49618 height: 812, 49619 type: 'font' 49620 }; 49621 const setOptions = Object.assign({}, defaultProperties, options); 49622 const relativeUnits = { 49623 em: setOptions.fontSize, 49624 rem: setOptions.fontSize, 49625 vh: setOptions.height * ONE_PERCENT, 49626 vw: setOptions.width * ONE_PERCENT, 49627 vmin: (setOptions.width < setOptions.height ? setOptions.width : setOptions.height) * ONE_PERCENT, 49628 vmax: (setOptions.width > setOptions.height ? setOptions.width : setOptions.height) * ONE_PERCENT, 49629 '%': (setOptions.type === 'font' ? setOptions.fontSize : setOptions.width) * ONE_PERCENT, 49630 ch: 8, 49631 // The advance measure (width) of the glyph "0" of the element's font. Approximate 49632 ex: 7.15625, 49633 // X-height of the element's font. Approximate. 49634 lh: setOptions.lineHeight 49635 }; 49636 const absoluteUnits = { 49637 in: PIXELS_PER_INCH, 49638 cm: PIXELS_PER_INCH / 2.54, 49639 mm: PIXELS_PER_INCH / 25.4, 49640 pt: PIXELS_PER_INCH / 72, 49641 pc: PIXELS_PER_INCH / 6, 49642 px: 1, 49643 Q: PIXELS_PER_INCH / 2.54 / 40 49644 }; 49645 49646 if (relativeUnits[parsedUnit.unit]) { 49647 return (relativeUnits[parsedUnit.unit] * parsedUnit.value).toFixed(0) + 'px'; 49648 } 49649 49650 if (absoluteUnits[parsedUnit.unit]) { 49651 return (absoluteUnits[parsedUnit.unit] * parsedUnit.value).toFixed(0) + 'px'; 49652 } 49653 49654 return null; 49655 } 49656 /** 49657 * Returns the px value of a cssUnit. 49658 * 49659 * @param {string} cssUnit 49660 * @param {Object} options 49661 * @return {string} returns the cssUnit value in a simple px format. 49662 */ 49663 49664 49665 function getPxFromCssUnit(cssUnit) { 49666 let options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; 49667 49668 if (Number.isFinite(cssUnit)) { 49669 return cssUnit.toFixed(0) + 'px'; 49670 } 49671 49672 if (cssUnit === undefined) { 49673 return null; 49674 } 49675 49676 let parsedUnit = parseUnit(cssUnit); 49677 49678 if (!parsedUnit.unit) { 49679 parsedUnit = parseUnitFunction(cssUnit, options); 49680 } 49681 49682 if (isMathExpression(cssUnit) && !parsedUnit.unit) { 49683 return evalMathExpression(cssUnit); 49684 } 49685 49686 return convertParsedUnitToPx(parsedUnit, options); 49687 } // Use simple cache. 49688 49689 const cache = {}; 49690 /** 49691 * Returns the px value of a cssUnit. The memoized version of getPxFromCssUnit; 49692 * 49693 * @param {string} cssUnit 49694 * @param {Object} options 49695 * @return {string} returns the cssUnit value in a simple px format. 49696 */ 49697 49698 function memoizedGetPxFromCssUnit(cssUnit) { 49699 let options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; 49700 const hash = cssUnit + hashOptions(options); 49701 49702 if (!cache[hash]) { 49703 cache[hash] = getPxFromCssUnit(cssUnit, options); 49704 } 49705 49706 return cache[hash]; 49707 } 49708 49709 function hashOptions(options) { 49710 let hash = ''; 49711 49712 if (options.hasOwnProperty('fontSize')) { 49713 hash = ':' + options.width; 49714 } 49715 49716 if (options.hasOwnProperty('lineHeight')) { 49717 hash = ':' + options.lineHeight; 49718 } 49719 49720 if (options.hasOwnProperty('width')) { 49721 hash = ':' + options.width; 49722 } 49723 49724 if (options.hasOwnProperty('height')) { 49725 hash = ':' + options.height; 49726 } 49727 49728 if (options.hasOwnProperty('type')) { 49729 hash = ':' + options.type; 49730 } 49731 49732 return hash; 49733 } 49734 49735 /* harmony default export */ var parse_css_unit_to_px = (memoizedGetPxFromCssUnit); 49736 49737 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/utils/index.js 49738 49739 49740 49741 49742 ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-editor/build-module/index.js 49743 /** 49744 * Internal dependencies 49745 */ 49746 49747 49748 49749 49750 49751 49752 49753 }(); 49754 (window.wp = window.wp || {}).blockEditor = __webpack_exports__; 49755 /******/ })() 49756 ;
title
Description
Body
title
Description
Body
title
Description
Body
title
Body
Generated: Wed Jan 22 01:00:02 2025 | Cross-referenced by PHPXref 0.7.1 |