[ Index ] |
PHP Cross Reference of WordPress Trunk (Updated Daily) |
[Summary view] [Print] [Text view]
1 /******/ (() => { // webpackBootstrap 2 /******/ "use strict"; 3 /******/ var __webpack_modules__ = ({ 4 5 /***/ 7734: 6 /***/ ((module) => { 7 8 9 10 // do not edit .js files directly - edit src/index.jst 11 12 13 var envHasBigInt64Array = typeof BigInt64Array !== 'undefined'; 14 15 16 module.exports = function equal(a, b) { 17 if (a === b) return true; 18 19 if (a && b && typeof a == 'object' && typeof b == 'object') { 20 if (a.constructor !== b.constructor) return false; 21 22 var length, i, keys; 23 if (Array.isArray(a)) { 24 length = a.length; 25 if (length != b.length) return false; 26 for (i = length; i-- !== 0;) 27 if (!equal(a[i], b[i])) return false; 28 return true; 29 } 30 31 32 if ((a instanceof Map) && (b instanceof Map)) { 33 if (a.size !== b.size) return false; 34 for (i of a.entries()) 35 if (!b.has(i[0])) return false; 36 for (i of a.entries()) 37 if (!equal(i[1], b.get(i[0]))) return false; 38 return true; 39 } 40 41 if ((a instanceof Set) && (b instanceof Set)) { 42 if (a.size !== b.size) return false; 43 for (i of a.entries()) 44 if (!b.has(i[0])) return false; 45 return true; 46 } 47 48 if (ArrayBuffer.isView(a) && ArrayBuffer.isView(b)) { 49 length = a.length; 50 if (length != b.length) return false; 51 for (i = length; i-- !== 0;) 52 if (a[i] !== b[i]) return false; 53 return true; 54 } 55 56 57 if (a.constructor === RegExp) return a.source === b.source && a.flags === b.flags; 58 if (a.valueOf !== Object.prototype.valueOf) return a.valueOf() === b.valueOf(); 59 if (a.toString !== Object.prototype.toString) return a.toString() === b.toString(); 60 61 keys = Object.keys(a); 62 length = keys.length; 63 if (length !== Object.keys(b).length) return false; 64 65 for (i = length; i-- !== 0;) 66 if (!Object.prototype.hasOwnProperty.call(b, keys[i])) return false; 67 68 for (i = length; i-- !== 0;) { 69 var key = keys[i]; 70 71 if (!equal(a[key], b[key])) return false; 72 } 73 74 return true; 75 } 76 77 // true if both NaN, false otherwise 78 return a!==a && b!==b; 79 }; 80 81 82 /***/ }) 83 84 /******/ }); 85 /************************************************************************/ 86 /******/ // The module cache 87 /******/ var __webpack_module_cache__ = {}; 88 /******/ 89 /******/ // The require function 90 /******/ function __webpack_require__(moduleId) { 91 /******/ // Check if module is in cache 92 /******/ var cachedModule = __webpack_module_cache__[moduleId]; 93 /******/ if (cachedModule !== undefined) { 94 /******/ return cachedModule.exports; 95 /******/ } 96 /******/ // Create a new module (and put it into the cache) 97 /******/ var module = __webpack_module_cache__[moduleId] = { 98 /******/ // no module.id needed 99 /******/ // no module.loaded needed 100 /******/ exports: {} 101 /******/ }; 102 /******/ 103 /******/ // Execute the module function 104 /******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); 105 /******/ 106 /******/ // Return the exports of the module 107 /******/ return module.exports; 108 /******/ } 109 /******/ 110 /************************************************************************/ 111 /******/ /* webpack/runtime/compat get default export */ 112 /******/ (() => { 113 /******/ // getDefaultExport function for compatibility with non-harmony modules 114 /******/ __webpack_require__.n = (module) => { 115 /******/ var getter = module && module.__esModule ? 116 /******/ () => (module['default']) : 117 /******/ () => (module); 118 /******/ __webpack_require__.d(getter, { a: getter }); 119 /******/ return getter; 120 /******/ }; 121 /******/ })(); 122 /******/ 123 /******/ /* webpack/runtime/define property getters */ 124 /******/ (() => { 125 /******/ // define getter functions for harmony exports 126 /******/ __webpack_require__.d = (exports, definition) => { 127 /******/ for(var key in definition) { 128 /******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { 129 /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); 130 /******/ } 131 /******/ } 132 /******/ }; 133 /******/ })(); 134 /******/ 135 /******/ /* webpack/runtime/hasOwnProperty shorthand */ 136 /******/ (() => { 137 /******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) 138 /******/ })(); 139 /******/ 140 /******/ /* webpack/runtime/make namespace object */ 141 /******/ (() => { 142 /******/ // define __esModule on exports 143 /******/ __webpack_require__.r = (exports) => { 144 /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { 145 /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); 146 /******/ } 147 /******/ Object.defineProperty(exports, '__esModule', { value: true }); 148 /******/ }; 149 /******/ })(); 150 /******/ 151 /************************************************************************/ 152 var __webpack_exports__ = {}; 153 // ESM COMPAT FLAG 154 __webpack_require__.r(__webpack_exports__); 155 156 // EXPORTS 157 __webpack_require__.d(__webpack_exports__, { 158 initialize: () => (/* binding */ initialize), 159 store: () => (/* reexport */ store) 160 }); 161 162 // NAMESPACE OBJECT: ./node_modules/@wordpress/customize-widgets/build-module/store/selectors.js 163 var selectors_namespaceObject = {}; 164 __webpack_require__.r(selectors_namespaceObject); 165 __webpack_require__.d(selectors_namespaceObject, { 166 __experimentalGetInsertionPoint: () => (__experimentalGetInsertionPoint), 167 isInserterOpened: () => (isInserterOpened) 168 }); 169 170 // NAMESPACE OBJECT: ./node_modules/@wordpress/customize-widgets/build-module/store/actions.js 171 var actions_namespaceObject = {}; 172 __webpack_require__.r(actions_namespaceObject); 173 __webpack_require__.d(actions_namespaceObject, { 174 setIsInserterOpened: () => (setIsInserterOpened) 175 }); 176 177 ;// external ["wp","element"] 178 const external_wp_element_namespaceObject = window["wp"]["element"]; 179 ;// external ["wp","blockLibrary"] 180 const external_wp_blockLibrary_namespaceObject = window["wp"]["blockLibrary"]; 181 ;// external ["wp","widgets"] 182 const external_wp_widgets_namespaceObject = window["wp"]["widgets"]; 183 ;// external ["wp","blocks"] 184 const external_wp_blocks_namespaceObject = window["wp"]["blocks"]; 185 ;// external ["wp","data"] 186 const external_wp_data_namespaceObject = window["wp"]["data"]; 187 ;// external ["wp","preferences"] 188 const external_wp_preferences_namespaceObject = window["wp"]["preferences"]; 189 ;// external ["wp","components"] 190 const external_wp_components_namespaceObject = window["wp"]["components"]; 191 ;// external ["wp","i18n"] 192 const external_wp_i18n_namespaceObject = window["wp"]["i18n"]; 193 ;// external ["wp","blockEditor"] 194 const external_wp_blockEditor_namespaceObject = window["wp"]["blockEditor"]; 195 ;// external ["wp","compose"] 196 const external_wp_compose_namespaceObject = window["wp"]["compose"]; 197 ;// external ["wp","hooks"] 198 const external_wp_hooks_namespaceObject = window["wp"]["hooks"]; 199 ;// external "ReactJSXRuntime" 200 const external_ReactJSXRuntime_namespaceObject = window["ReactJSXRuntime"]; 201 ;// ./node_modules/@wordpress/customize-widgets/build-module/components/error-boundary/index.js 202 /** 203 * WordPress dependencies 204 */ 205 206 207 208 209 210 211 212 function CopyButton({ 213 text, 214 children 215 }) { 216 const ref = (0,external_wp_compose_namespaceObject.useCopyToClipboard)(text); 217 return /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_components_namespaceObject.Button 218 // TODO: Switch to `true` (40px size) if possible 219 , { 220 __next40pxDefaultSize: false, 221 variant: "secondary", 222 ref: ref, 223 children: children 224 }); 225 } 226 class ErrorBoundary extends external_wp_element_namespaceObject.Component { 227 constructor() { 228 super(...arguments); 229 this.state = { 230 error: null 231 }; 232 } 233 componentDidCatch(error) { 234 this.setState({ 235 error 236 }); 237 (0,external_wp_hooks_namespaceObject.doAction)('editor.ErrorBoundary.errorLogged', error); 238 } 239 render() { 240 const { 241 error 242 } = this.state; 243 if (!error) { 244 return this.props.children; 245 } 246 return /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_blockEditor_namespaceObject.Warning, { 247 className: "customize-widgets-error-boundary", 248 actions: [/*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(CopyButton, { 249 text: error.stack, 250 children: (0,external_wp_i18n_namespaceObject.__)('Copy Error') 251 }, "copy-error")], 252 children: (0,external_wp_i18n_namespaceObject.__)('The editor has encountered an unexpected error.') 253 }); 254 } 255 } 256 257 ;// external ["wp","coreData"] 258 const external_wp_coreData_namespaceObject = window["wp"]["coreData"]; 259 ;// external ["wp","mediaUtils"] 260 const external_wp_mediaUtils_namespaceObject = window["wp"]["mediaUtils"]; 261 ;// ./node_modules/@wordpress/customize-widgets/build-module/components/block-inspector-button/index.js 262 /** 263 * WordPress dependencies 264 */ 265 266 267 268 269 270 271 function BlockInspectorButton({ 272 inspector, 273 closeMenu, 274 ...props 275 }) { 276 const selectedBlockClientId = (0,external_wp_data_namespaceObject.useSelect)(select => select(external_wp_blockEditor_namespaceObject.store).getSelectedBlockClientId(), []); 277 const selectedBlock = (0,external_wp_element_namespaceObject.useMemo)(() => document.getElementById(`block-$selectedBlockClientId}`), [selectedBlockClientId]); 278 return /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_components_namespaceObject.MenuItem, { 279 onClick: () => { 280 // Open the inspector. 281 inspector.open({ 282 returnFocusWhenClose: selectedBlock 283 }); 284 // Then close the dropdown menu. 285 closeMenu(); 286 }, 287 ...props, 288 children: (0,external_wp_i18n_namespaceObject.__)('Show more settings') 289 }); 290 } 291 /* harmony default export */ const block_inspector_button = (BlockInspectorButton); 292 293 ;// ./node_modules/clsx/dist/clsx.mjs 294 function r(e){var t,f,n="";if("string"==typeof e||"number"==typeof e)n+=e;else if("object"==typeof e)if(Array.isArray(e)){var o=e.length;for(t=0;t<o;t++)e[t]&&(f=r(e[t]))&&(n&&(n+=" "),n+=f)}else for(f in e)e[f]&&(n&&(n+=" "),n+=f);return n}function clsx(){for(var e,t,f=0,n="",o=arguments.length;f<o;f++)(e=arguments[f])&&(t=r(e))&&(n&&(n+=" "),n+=t);return n}/* harmony default export */ const dist_clsx = (clsx); 295 ;// external ["wp","keycodes"] 296 const external_wp_keycodes_namespaceObject = window["wp"]["keycodes"]; 297 ;// external ["wp","primitives"] 298 const external_wp_primitives_namespaceObject = window["wp"]["primitives"]; 299 ;// ./node_modules/@wordpress/icons/build-module/library/undo.js 300 /** 301 * WordPress dependencies 302 */ 303 304 305 const undo = /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_primitives_namespaceObject.SVG, { 306 xmlns: "http://www.w3.org/2000/svg", 307 viewBox: "0 0 24 24", 308 children: /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_primitives_namespaceObject.Path, { 309 d: "M18.3 11.7c-.6-.6-1.4-.9-2.3-.9H6.7l2.9-3.3-1.1-1-4.5 5L8.5 16l1-1-2.7-2.7H16c.5 0 .9.2 1.3.5 1 1 1 3.4 1 4.5v.3h1.5v-.2c0-1.5 0-4.3-1.5-5.7z" 310 }) 311 }); 312 /* harmony default export */ const library_undo = (undo); 313 314 ;// ./node_modules/@wordpress/icons/build-module/library/redo.js 315 /** 316 * WordPress dependencies 317 */ 318 319 320 const redo = /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_primitives_namespaceObject.SVG, { 321 xmlns: "http://www.w3.org/2000/svg", 322 viewBox: "0 0 24 24", 323 children: /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_primitives_namespaceObject.Path, { 324 d: "M15.6 6.5l-1.1 1 2.9 3.3H8c-.9 0-1.7.3-2.3.9-1.4 1.5-1.4 4.2-1.4 5.6v.2h1.5v-.3c0-1.1 0-3.5 1-4.5.3-.3.7-.5 1.3-.5h9.2L14.5 15l1.1 1.1 4.6-4.6-4.6-5z" 325 }) 326 }); 327 /* harmony default export */ const library_redo = (redo); 328 329 ;// ./node_modules/@wordpress/icons/build-module/library/plus.js 330 /** 331 * WordPress dependencies 332 */ 333 334 335 const plus = /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_primitives_namespaceObject.SVG, { 336 xmlns: "http://www.w3.org/2000/svg", 337 viewBox: "0 0 24 24", 338 children: /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_primitives_namespaceObject.Path, { 339 d: "M11 12.5V17.5H12.5V12.5H17.5V11H12.5V6H11V11H6V12.5H11Z" 340 }) 341 }); 342 /* harmony default export */ const library_plus = (plus); 343 344 ;// ./node_modules/@wordpress/icons/build-module/library/close-small.js 345 /** 346 * WordPress dependencies 347 */ 348 349 350 const closeSmall = /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_primitives_namespaceObject.SVG, { 351 xmlns: "http://www.w3.org/2000/svg", 352 viewBox: "0 0 24 24", 353 children: /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_primitives_namespaceObject.Path, { 354 d: "M12 13.06l3.712 3.713 1.061-1.06L13.061 12l3.712-3.712-1.06-1.06L12 10.938 8.288 7.227l-1.061 1.06L10.939 12l-3.712 3.712 1.06 1.061L12 13.061z" 355 }) 356 }); 357 /* harmony default export */ const close_small = (closeSmall); 358 359 ;// ./node_modules/@wordpress/customize-widgets/build-module/store/reducer.js 360 /** 361 * WordPress dependencies 362 */ 363 364 365 /** 366 * Reducer tracking whether the inserter is open. 367 * 368 * @param {boolean|Object} state 369 * @param {Object} action 370 */ 371 function blockInserterPanel(state = false, action) { 372 switch (action.type) { 373 case 'SET_IS_INSERTER_OPENED': 374 return action.value; 375 } 376 return state; 377 } 378 /* harmony default export */ const reducer = ((0,external_wp_data_namespaceObject.combineReducers)({ 379 blockInserterPanel 380 })); 381 382 ;// ./node_modules/@wordpress/customize-widgets/build-module/store/selectors.js 383 const EMPTY_INSERTION_POINT = { 384 rootClientId: undefined, 385 insertionIndex: undefined 386 }; 387 388 /** 389 * Returns true if the inserter is opened. 390 * 391 * @param {Object} state Global application state. 392 * 393 * @example 394 * ```js 395 * import { store as customizeWidgetsStore } from '@wordpress/customize-widgets'; 396 * import { __ } from '@wordpress/i18n'; 397 * import { useSelect } from '@wordpress/data'; 398 * 399 * const ExampleComponent = () => { 400 * const { isInserterOpened } = useSelect( 401 * ( select ) => select( customizeWidgetsStore ), 402 * [] 403 * ); 404 * 405 * return isInserterOpened() 406 * ? __( 'Inserter is open' ) 407 * : __( 'Inserter is closed.' ); 408 * }; 409 * ``` 410 * 411 * @return {boolean} Whether the inserter is opened. 412 */ 413 function isInserterOpened(state) { 414 return !!state.blockInserterPanel; 415 } 416 417 /** 418 * Get the insertion point for the inserter. 419 * 420 * @param {Object} state Global application state. 421 * 422 * @return {Object} The root client ID and index to insert at. 423 */ 424 function __experimentalGetInsertionPoint(state) { 425 if (typeof state.blockInserterPanel === 'boolean') { 426 return EMPTY_INSERTION_POINT; 427 } 428 return state.blockInserterPanel; 429 } 430 431 ;// ./node_modules/@wordpress/customize-widgets/build-module/store/actions.js 432 /** 433 * Returns an action object used to open/close the inserter. 434 * 435 * @param {boolean|Object} value Whether the inserter should be 436 * opened (true) or closed (false). 437 * To specify an insertion point, 438 * use an object. 439 * @param {string} value.rootClientId The root client ID to insert at. 440 * @param {number} value.insertionIndex The index to insert at. 441 * 442 * @example 443 * ```js 444 * import { useState } from 'react'; 445 * import { store as customizeWidgetsStore } from '@wordpress/customize-widgets'; 446 * import { __ } from '@wordpress/i18n'; 447 * import { useDispatch } from '@wordpress/data'; 448 * import { Button } from '@wordpress/components'; 449 * 450 * const ExampleComponent = () => { 451 * const { setIsInserterOpened } = useDispatch( customizeWidgetsStore ); 452 * const [ isOpen, setIsOpen ] = useState( false ); 453 * 454 * return ( 455 * <Button 456 * onClick={ () => { 457 * setIsInserterOpened( ! isOpen ); 458 * setIsOpen( ! isOpen ); 459 * } } 460 * > 461 * { __( 'Open/close inserter' ) } 462 * </Button> 463 * ); 464 * }; 465 * ``` 466 * 467 * @return {Object} Action object. 468 */ 469 function setIsInserterOpened(value) { 470 return { 471 type: 'SET_IS_INSERTER_OPENED', 472 value 473 }; 474 } 475 476 ;// ./node_modules/@wordpress/customize-widgets/build-module/store/constants.js 477 /** 478 * Module Constants 479 */ 480 const STORE_NAME = 'core/customize-widgets'; 481 482 ;// ./node_modules/@wordpress/customize-widgets/build-module/store/index.js 483 /** 484 * WordPress dependencies 485 */ 486 487 488 /** 489 * Internal dependencies 490 */ 491 492 493 494 495 496 /** 497 * Block editor data store configuration. 498 * 499 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/data/README.md#registering-a-store 500 * 501 * @type {Object} 502 */ 503 const storeConfig = { 504 reducer: reducer, 505 selectors: selectors_namespaceObject, 506 actions: actions_namespaceObject 507 }; 508 509 /** 510 * Store definition for the edit widgets namespace. 511 * 512 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/data/README.md#createReduxStore 513 * 514 * @type {Object} 515 */ 516 const store = (0,external_wp_data_namespaceObject.createReduxStore)(STORE_NAME, storeConfig); 517 (0,external_wp_data_namespaceObject.register)(store); 518 519 ;// ./node_modules/@wordpress/customize-widgets/build-module/components/inserter/index.js 520 /** 521 * WordPress dependencies 522 */ 523 524 525 526 527 528 529 530 /** 531 * Internal dependencies 532 */ 533 534 535 536 function Inserter({ 537 setIsOpened 538 }) { 539 const inserterTitleId = (0,external_wp_compose_namespaceObject.useInstanceId)(Inserter, 'customize-widget-layout__inserter-panel-title'); 540 const insertionPoint = (0,external_wp_data_namespaceObject.useSelect)(select => select(store).__experimentalGetInsertionPoint(), []); 541 return /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsxs)("div", { 542 className: "customize-widgets-layout__inserter-panel", 543 "aria-labelledby": inserterTitleId, 544 children: [/*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsxs)("div", { 545 className: "customize-widgets-layout__inserter-panel-header", 546 children: [/*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)("h2", { 547 id: inserterTitleId, 548 className: "customize-widgets-layout__inserter-panel-header-title", 549 children: (0,external_wp_i18n_namespaceObject.__)('Add a block') 550 }), /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_components_namespaceObject.Button 551 // TODO: Switch to `true` (40px size) if possible 552 , { 553 __next40pxDefaultSize: false, 554 className: "customize-widgets-layout__inserter-panel-header-close-button", 555 icon: close_small, 556 onClick: () => setIsOpened(false), 557 "aria-label": (0,external_wp_i18n_namespaceObject.__)('Close inserter') 558 })] 559 }), /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)("div", { 560 className: "customize-widgets-layout__inserter-panel-content", 561 children: /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_blockEditor_namespaceObject.__experimentalLibrary, { 562 rootClientId: insertionPoint.rootClientId, 563 __experimentalInsertionIndex: insertionPoint.insertionIndex, 564 showInserterHelpPanel: true, 565 onSelect: () => setIsOpened(false) 566 }) 567 })] 568 }); 569 } 570 /* harmony default export */ const components_inserter = (Inserter); 571 572 ;// ./node_modules/@wordpress/icons/build-module/library/more-vertical.js 573 /** 574 * WordPress dependencies 575 */ 576 577 578 const moreVertical = /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_primitives_namespaceObject.SVG, { 579 xmlns: "http://www.w3.org/2000/svg", 580 viewBox: "0 0 24 24", 581 children: /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_primitives_namespaceObject.Path, { 582 d: "M13 19h-2v-2h2v2zm0-6h-2v-2h2v2zm0-6h-2V5h2v2z" 583 }) 584 }); 585 /* harmony default export */ const more_vertical = (moreVertical); 586 587 ;// ./node_modules/@wordpress/icons/build-module/library/external.js 588 /** 589 * WordPress dependencies 590 */ 591 592 593 const external = /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_primitives_namespaceObject.SVG, { 594 xmlns: "http://www.w3.org/2000/svg", 595 viewBox: "0 0 24 24", 596 children: /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_primitives_namespaceObject.Path, { 597 d: "M19.5 4.5h-7V6h4.44l-5.97 5.97 1.06 1.06L18 7.06v4.44h1.5v-7Zm-13 1a2 2 0 0 0-2 2v10a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2v-3H17v3a.5.5 0 0 1-.5.5h-10a.5.5 0 0 1-.5-.5v-10a.5.5 0 0 1 .5-.5h3V5.5h-3Z" 598 }) 599 }); 600 /* harmony default export */ const library_external = (external); 601 602 ;// external ["wp","keyboardShortcuts"] 603 const external_wp_keyboardShortcuts_namespaceObject = window["wp"]["keyboardShortcuts"]; 604 ;// ./node_modules/@wordpress/customize-widgets/build-module/components/keyboard-shortcut-help-modal/config.js 605 /** 606 * WordPress dependencies 607 */ 608 609 const textFormattingShortcuts = [{ 610 keyCombination: { 611 modifier: 'primary', 612 character: 'b' 613 }, 614 description: (0,external_wp_i18n_namespaceObject.__)('Make the selected text bold.') 615 }, { 616 keyCombination: { 617 modifier: 'primary', 618 character: 'i' 619 }, 620 description: (0,external_wp_i18n_namespaceObject.__)('Make the selected text italic.') 621 }, { 622 keyCombination: { 623 modifier: 'primary', 624 character: 'k' 625 }, 626 description: (0,external_wp_i18n_namespaceObject.__)('Convert the selected text into a link.') 627 }, { 628 keyCombination: { 629 modifier: 'primaryShift', 630 character: 'k' 631 }, 632 description: (0,external_wp_i18n_namespaceObject.__)('Remove a link.') 633 }, { 634 keyCombination: { 635 character: '[[' 636 }, 637 description: (0,external_wp_i18n_namespaceObject.__)('Insert a link to a post or page.') 638 }, { 639 keyCombination: { 640 modifier: 'primary', 641 character: 'u' 642 }, 643 description: (0,external_wp_i18n_namespaceObject.__)('Underline the selected text.') 644 }, { 645 keyCombination: { 646 modifier: 'access', 647 character: 'd' 648 }, 649 description: (0,external_wp_i18n_namespaceObject.__)('Strikethrough the selected text.') 650 }, { 651 keyCombination: { 652 modifier: 'access', 653 character: 'x' 654 }, 655 description: (0,external_wp_i18n_namespaceObject.__)('Make the selected text inline code.') 656 }, { 657 keyCombination: { 658 modifier: 'access', 659 character: '0' 660 }, 661 aliases: [{ 662 modifier: 'access', 663 character: '7' 664 }], 665 description: (0,external_wp_i18n_namespaceObject.__)('Convert the current heading to a paragraph.') 666 }, { 667 keyCombination: { 668 modifier: 'access', 669 character: '1-6' 670 }, 671 description: (0,external_wp_i18n_namespaceObject.__)('Convert the current paragraph or heading to a heading of level 1 to 6.') 672 }, { 673 keyCombination: { 674 modifier: 'primaryShift', 675 character: 'SPACE' 676 }, 677 description: (0,external_wp_i18n_namespaceObject.__)('Add non breaking space.') 678 }]; 679 680 ;// ./node_modules/@wordpress/customize-widgets/build-module/components/keyboard-shortcut-help-modal/shortcut.js 681 /** 682 * WordPress dependencies 683 */ 684 685 686 687 688 689 function KeyCombination({ 690 keyCombination, 691 forceAriaLabel 692 }) { 693 const shortcut = keyCombination.modifier ? external_wp_keycodes_namespaceObject.displayShortcutList[keyCombination.modifier](keyCombination.character) : keyCombination.character; 694 const ariaLabel = keyCombination.modifier ? external_wp_keycodes_namespaceObject.shortcutAriaLabel[keyCombination.modifier](keyCombination.character) : keyCombination.character; 695 return /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)("kbd", { 696 className: "customize-widgets-keyboard-shortcut-help-modal__shortcut-key-combination", 697 "aria-label": forceAriaLabel || ariaLabel, 698 children: (Array.isArray(shortcut) ? shortcut : [shortcut]).map((character, index) => { 699 if (character === '+') { 700 return /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_element_namespaceObject.Fragment, { 701 children: character 702 }, index); 703 } 704 return /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)("kbd", { 705 className: "customize-widgets-keyboard-shortcut-help-modal__shortcut-key", 706 children: character 707 }, index); 708 }) 709 }); 710 } 711 function Shortcut({ 712 description, 713 keyCombination, 714 aliases = [], 715 ariaLabel 716 }) { 717 return /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsxs)(external_ReactJSXRuntime_namespaceObject.Fragment, { 718 children: [/*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)("div", { 719 className: "customize-widgets-keyboard-shortcut-help-modal__shortcut-description", 720 children: description 721 }), /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsxs)("div", { 722 className: "customize-widgets-keyboard-shortcut-help-modal__shortcut-term", 723 children: [/*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(KeyCombination, { 724 keyCombination: keyCombination, 725 forceAriaLabel: ariaLabel 726 }), aliases.map((alias, index) => /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(KeyCombination, { 727 keyCombination: alias, 728 forceAriaLabel: ariaLabel 729 }, index))] 730 })] 731 }); 732 } 733 /* harmony default export */ const keyboard_shortcut_help_modal_shortcut = (Shortcut); 734 735 ;// ./node_modules/@wordpress/customize-widgets/build-module/components/keyboard-shortcut-help-modal/dynamic-shortcut.js 736 /** 737 * WordPress dependencies 738 */ 739 740 741 742 /** 743 * Internal dependencies 744 */ 745 746 747 function DynamicShortcut({ 748 name 749 }) { 750 const { 751 keyCombination, 752 description, 753 aliases 754 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 755 const { 756 getShortcutKeyCombination, 757 getShortcutDescription, 758 getShortcutAliases 759 } = select(external_wp_keyboardShortcuts_namespaceObject.store); 760 return { 761 keyCombination: getShortcutKeyCombination(name), 762 aliases: getShortcutAliases(name), 763 description: getShortcutDescription(name) 764 }; 765 }, [name]); 766 if (!keyCombination) { 767 return null; 768 } 769 return /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(keyboard_shortcut_help_modal_shortcut, { 770 keyCombination: keyCombination, 771 description: description, 772 aliases: aliases 773 }); 774 } 775 /* harmony default export */ const dynamic_shortcut = (DynamicShortcut); 776 777 ;// ./node_modules/@wordpress/customize-widgets/build-module/components/keyboard-shortcut-help-modal/index.js 778 /** 779 * External dependencies 780 */ 781 782 783 /** 784 * WordPress dependencies 785 */ 786 787 788 789 790 791 /** 792 * Internal dependencies 793 */ 794 795 796 797 798 799 const ShortcutList = ({ 800 shortcuts 801 }) => 802 /*#__PURE__*/ 803 /* 804 * Disable reason: The `list` ARIA role is redundant but 805 * Safari+VoiceOver won't announce the list otherwise. 806 */ 807 /* eslint-disable jsx-a11y/no-redundant-roles */ 808 (0,external_ReactJSXRuntime_namespaceObject.jsx)("ul", { 809 className: "customize-widgets-keyboard-shortcut-help-modal__shortcut-list", 810 role: "list", 811 children: shortcuts.map((shortcut, index) => /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)("li", { 812 className: "customize-widgets-keyboard-shortcut-help-modal__shortcut", 813 children: typeof shortcut === 'string' ? /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(dynamic_shortcut, { 814 name: shortcut 815 }) : /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(keyboard_shortcut_help_modal_shortcut, { 816 ...shortcut 817 }) 818 }, index)) 819 }) 820 /* eslint-enable jsx-a11y/no-redundant-roles */; 821 const ShortcutSection = ({ 822 title, 823 shortcuts, 824 className 825 }) => /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsxs)("section", { 826 className: dist_clsx('customize-widgets-keyboard-shortcut-help-modal__section', className), 827 children: [!!title && /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)("h2", { 828 className: "customize-widgets-keyboard-shortcut-help-modal__section-title", 829 children: title 830 }), /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(ShortcutList, { 831 shortcuts: shortcuts 832 })] 833 }); 834 const ShortcutCategorySection = ({ 835 title, 836 categoryName, 837 additionalShortcuts = [] 838 }) => { 839 const categoryShortcuts = (0,external_wp_data_namespaceObject.useSelect)(select => { 840 return select(external_wp_keyboardShortcuts_namespaceObject.store).getCategoryShortcuts(categoryName); 841 }, [categoryName]); 842 return /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(ShortcutSection, { 843 title: title, 844 shortcuts: categoryShortcuts.concat(additionalShortcuts) 845 }); 846 }; 847 function KeyboardShortcutHelpModal({ 848 isModalActive, 849 toggleModal 850 }) { 851 const { 852 registerShortcut 853 } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_keyboardShortcuts_namespaceObject.store); 854 registerShortcut({ 855 name: 'core/customize-widgets/keyboard-shortcuts', 856 category: 'main', 857 description: (0,external_wp_i18n_namespaceObject.__)('Display these keyboard shortcuts.'), 858 keyCombination: { 859 modifier: 'access', 860 character: 'h' 861 } 862 }); 863 (0,external_wp_keyboardShortcuts_namespaceObject.useShortcut)('core/customize-widgets/keyboard-shortcuts', toggleModal); 864 if (!isModalActive) { 865 return null; 866 } 867 return /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsxs)(external_wp_components_namespaceObject.Modal, { 868 className: "customize-widgets-keyboard-shortcut-help-modal", 869 title: (0,external_wp_i18n_namespaceObject.__)('Keyboard shortcuts'), 870 onRequestClose: toggleModal, 871 children: [/*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(ShortcutSection, { 872 className: "customize-widgets-keyboard-shortcut-help-modal__main-shortcuts", 873 shortcuts: ['core/customize-widgets/keyboard-shortcuts'] 874 }), /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(ShortcutCategorySection, { 875 title: (0,external_wp_i18n_namespaceObject.__)('Global shortcuts'), 876 categoryName: "global" 877 }), /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(ShortcutCategorySection, { 878 title: (0,external_wp_i18n_namespaceObject.__)('Selection shortcuts'), 879 categoryName: "selection" 880 }), /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(ShortcutCategorySection, { 881 title: (0,external_wp_i18n_namespaceObject.__)('Block shortcuts'), 882 categoryName: "block", 883 additionalShortcuts: [{ 884 keyCombination: { 885 character: '/' 886 }, 887 description: (0,external_wp_i18n_namespaceObject.__)('Change the block type after adding a new paragraph.'), 888 /* translators: The forward-slash character. e.g. '/'. */ 889 ariaLabel: (0,external_wp_i18n_namespaceObject.__)('Forward-slash') 890 }] 891 }), /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(ShortcutSection, { 892 title: (0,external_wp_i18n_namespaceObject.__)('Text formatting'), 893 shortcuts: textFormattingShortcuts 894 })] 895 }); 896 } 897 898 ;// ./node_modules/@wordpress/customize-widgets/build-module/components/more-menu/index.js 899 /** 900 * WordPress dependencies 901 */ 902 903 904 905 906 907 908 909 910 /** 911 * Internal dependencies 912 */ 913 914 915 916 917 function MoreMenu() { 918 const [isKeyboardShortcutsModalActive, setIsKeyboardShortcutsModalVisible] = (0,external_wp_element_namespaceObject.useState)(false); 919 const toggleKeyboardShortcutsModal = () => setIsKeyboardShortcutsModalVisible(!isKeyboardShortcutsModalActive); 920 (0,external_wp_keyboardShortcuts_namespaceObject.useShortcut)('core/customize-widgets/keyboard-shortcuts', toggleKeyboardShortcutsModal); 921 return /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsxs)(external_ReactJSXRuntime_namespaceObject.Fragment, { 922 children: [/*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_components_namespaceObject.ToolbarDropdownMenu, { 923 icon: more_vertical, 924 label: (0,external_wp_i18n_namespaceObject.__)('Options'), 925 popoverProps: { 926 placement: 'bottom-end', 927 className: 'more-menu-dropdown__content' 928 }, 929 toggleProps: { 930 tooltipPosition: 'bottom', 931 size: 'compact' 932 }, 933 children: () => /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsxs)(external_ReactJSXRuntime_namespaceObject.Fragment, { 934 children: [/*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_components_namespaceObject.MenuGroup, { 935 label: (0,external_wp_i18n_namespaceObject._x)('View', 'noun'), 936 children: /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_preferences_namespaceObject.PreferenceToggleMenuItem, { 937 scope: "core/customize-widgets", 938 name: "fixedToolbar", 939 label: (0,external_wp_i18n_namespaceObject.__)('Top toolbar'), 940 info: (0,external_wp_i18n_namespaceObject.__)('Access all block and document tools in a single place'), 941 messageActivated: (0,external_wp_i18n_namespaceObject.__)('Top toolbar activated'), 942 messageDeactivated: (0,external_wp_i18n_namespaceObject.__)('Top toolbar deactivated') 943 }) 944 }), /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsxs)(external_wp_components_namespaceObject.MenuGroup, { 945 label: (0,external_wp_i18n_namespaceObject.__)('Tools'), 946 children: [/*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_components_namespaceObject.MenuItem, { 947 onClick: () => { 948 setIsKeyboardShortcutsModalVisible(true); 949 }, 950 shortcut: external_wp_keycodes_namespaceObject.displayShortcut.access('h'), 951 children: (0,external_wp_i18n_namespaceObject.__)('Keyboard shortcuts') 952 }), /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_preferences_namespaceObject.PreferenceToggleMenuItem, { 953 scope: "core/customize-widgets", 954 name: "welcomeGuide", 955 label: (0,external_wp_i18n_namespaceObject.__)('Welcome Guide') 956 }), /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsxs)(external_wp_components_namespaceObject.MenuItem, { 957 role: "menuitem", 958 icon: library_external, 959 href: (0,external_wp_i18n_namespaceObject.__)('https://wordpress.org/documentation/article/block-based-widgets-editor/'), 960 target: "_blank", 961 rel: "noopener noreferrer", 962 children: [(0,external_wp_i18n_namespaceObject.__)('Help'), /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_components_namespaceObject.VisuallyHidden, { 963 as: "span", 964 children: /* translators: accessibility text */ 965 (0,external_wp_i18n_namespaceObject.__)('(opens in a new tab)') 966 })] 967 })] 968 }), /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_components_namespaceObject.MenuGroup, { 969 label: (0,external_wp_i18n_namespaceObject.__)('Preferences'), 970 children: /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_preferences_namespaceObject.PreferenceToggleMenuItem, { 971 scope: "core/customize-widgets", 972 name: "keepCaretInsideBlock", 973 label: (0,external_wp_i18n_namespaceObject.__)('Contain text cursor inside block'), 974 info: (0,external_wp_i18n_namespaceObject.__)('Aids screen readers by stopping text caret from leaving blocks.'), 975 messageActivated: (0,external_wp_i18n_namespaceObject.__)('Contain text cursor inside block activated'), 976 messageDeactivated: (0,external_wp_i18n_namespaceObject.__)('Contain text cursor inside block deactivated') 977 }) 978 })] 979 }) 980 }), /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(KeyboardShortcutHelpModal, { 981 isModalActive: isKeyboardShortcutsModalActive, 982 toggleModal: toggleKeyboardShortcutsModal 983 })] 984 }); 985 } 986 987 ;// ./node_modules/@wordpress/customize-widgets/build-module/components/header/index.js 988 /** 989 * External dependencies 990 */ 991 992 993 /** 994 * WordPress dependencies 995 */ 996 997 998 999 1000 1001 1002 1003 /** 1004 * Internal dependencies 1005 */ 1006 1007 1008 1009 1010 1011 function Header({ 1012 sidebar, 1013 inserter, 1014 isInserterOpened, 1015 setIsInserterOpened, 1016 isFixedToolbarActive 1017 }) { 1018 const [[hasUndo, hasRedo], setUndoRedo] = (0,external_wp_element_namespaceObject.useState)([sidebar.hasUndo(), sidebar.hasRedo()]); 1019 const shortcut = (0,external_wp_keycodes_namespaceObject.isAppleOS)() ? external_wp_keycodes_namespaceObject.displayShortcut.primaryShift('z') : external_wp_keycodes_namespaceObject.displayShortcut.primary('y'); 1020 (0,external_wp_element_namespaceObject.useEffect)(() => { 1021 return sidebar.subscribeHistory(() => { 1022 setUndoRedo([sidebar.hasUndo(), sidebar.hasRedo()]); 1023 }); 1024 }, [sidebar]); 1025 return /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsxs)(external_ReactJSXRuntime_namespaceObject.Fragment, { 1026 children: [/*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)("div", { 1027 className: dist_clsx('customize-widgets-header', { 1028 'is-fixed-toolbar-active': isFixedToolbarActive 1029 }), 1030 children: /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsxs)(external_wp_blockEditor_namespaceObject.NavigableToolbar, { 1031 className: "customize-widgets-header-toolbar", 1032 "aria-label": (0,external_wp_i18n_namespaceObject.__)('Document tools'), 1033 children: [/*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_components_namespaceObject.ToolbarButton, { 1034 icon: !(0,external_wp_i18n_namespaceObject.isRTL)() ? library_undo : library_redo 1035 /* translators: button label text should, if possible, be under 16 characters. */, 1036 label: (0,external_wp_i18n_namespaceObject.__)('Undo'), 1037 shortcut: external_wp_keycodes_namespaceObject.displayShortcut.primary('z'), 1038 disabled: !hasUndo, 1039 onClick: sidebar.undo, 1040 className: "customize-widgets-editor-history-button undo-button" 1041 }), /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_components_namespaceObject.ToolbarButton, { 1042 icon: !(0,external_wp_i18n_namespaceObject.isRTL)() ? library_redo : library_undo 1043 /* translators: button label text should, if possible, be under 16 characters. */, 1044 label: (0,external_wp_i18n_namespaceObject.__)('Redo'), 1045 shortcut: shortcut, 1046 disabled: !hasRedo, 1047 onClick: sidebar.redo, 1048 className: "customize-widgets-editor-history-button redo-button" 1049 }), /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_components_namespaceObject.ToolbarButton, { 1050 className: "customize-widgets-header-toolbar__inserter-toggle", 1051 isPressed: isInserterOpened, 1052 variant: "primary", 1053 icon: library_plus, 1054 label: (0,external_wp_i18n_namespaceObject._x)('Add block', 'Generic label for block inserter button'), 1055 onClick: () => { 1056 setIsInserterOpened(isOpen => !isOpen); 1057 } 1058 }), /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(MoreMenu, {})] 1059 }) 1060 }), (0,external_wp_element_namespaceObject.createPortal)( /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(components_inserter, { 1061 setIsOpened: setIsInserterOpened 1062 }), inserter.contentContainer[0])] 1063 }); 1064 } 1065 /* harmony default export */ const header = (Header); 1066 1067 ;// ./node_modules/@wordpress/customize-widgets/build-module/components/inserter/use-inserter.js 1068 /** 1069 * WordPress dependencies 1070 */ 1071 1072 1073 1074 /** 1075 * Internal dependencies 1076 */ 1077 1078 function useInserter(inserter) { 1079 const isInserterOpened = (0,external_wp_data_namespaceObject.useSelect)(select => select(store).isInserterOpened(), []); 1080 const { 1081 setIsInserterOpened 1082 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 1083 (0,external_wp_element_namespaceObject.useEffect)(() => { 1084 if (isInserterOpened) { 1085 inserter.open(); 1086 } else { 1087 inserter.close(); 1088 } 1089 }, [inserter, isInserterOpened]); 1090 return [isInserterOpened, (0,external_wp_element_namespaceObject.useCallback)(updater => { 1091 let isOpen = updater; 1092 if (typeof updater === 'function') { 1093 isOpen = updater((0,external_wp_data_namespaceObject.select)(store).isInserterOpened()); 1094 } 1095 setIsInserterOpened(isOpen); 1096 }, [setIsInserterOpened])]; 1097 } 1098 1099 // EXTERNAL MODULE: ./node_modules/fast-deep-equal/es6/index.js 1100 var es6 = __webpack_require__(7734); 1101 var es6_default = /*#__PURE__*/__webpack_require__.n(es6); 1102 ;// external ["wp","isShallowEqual"] 1103 const external_wp_isShallowEqual_namespaceObject = window["wp"]["isShallowEqual"]; 1104 var external_wp_isShallowEqual_default = /*#__PURE__*/__webpack_require__.n(external_wp_isShallowEqual_namespaceObject); 1105 ;// ./node_modules/@wordpress/customize-widgets/build-module/utils.js 1106 // @ts-check 1107 /** 1108 * WordPress dependencies 1109 */ 1110 1111 1112 1113 /** 1114 * Convert settingId to widgetId. 1115 * 1116 * @param {string} settingId The setting id. 1117 * @return {string} The widget id. 1118 */ 1119 function settingIdToWidgetId(settingId) { 1120 const matches = settingId.match(/^widget_(.+)(?:\[(\d+)\])$/); 1121 if (matches) { 1122 const idBase = matches[1]; 1123 const number = parseInt(matches[2], 10); 1124 return `$idBase}-$number}`; 1125 } 1126 return settingId; 1127 } 1128 1129 /** 1130 * Transform a block to a customizable widget. 1131 * 1132 * @param {WPBlock} block The block to be transformed from. 1133 * @param {Object} existingWidget The widget to be extended from. 1134 * @return {Object} The transformed widget. 1135 */ 1136 function blockToWidget(block, existingWidget = null) { 1137 let widget; 1138 const isValidLegacyWidgetBlock = block.name === 'core/legacy-widget' && (block.attributes.id || block.attributes.instance); 1139 if (isValidLegacyWidgetBlock) { 1140 if (block.attributes.id) { 1141 // Widget that does not extend WP_Widget. 1142 widget = { 1143 id: block.attributes.id 1144 }; 1145 } else { 1146 const { 1147 encoded, 1148 hash, 1149 raw, 1150 ...rest 1151 } = block.attributes.instance; 1152 1153 // Widget that extends WP_Widget. 1154 widget = { 1155 idBase: block.attributes.idBase, 1156 instance: { 1157 ...existingWidget?.instance, 1158 // Required only for the customizer. 1159 is_widget_customizer_js_value: true, 1160 encoded_serialized_instance: encoded, 1161 instance_hash_key: hash, 1162 raw_instance: raw, 1163 ...rest 1164 } 1165 }; 1166 } 1167 } else { 1168 const instance = { 1169 content: (0,external_wp_blocks_namespaceObject.serialize)(block) 1170 }; 1171 widget = { 1172 idBase: 'block', 1173 widgetClass: 'WP_Widget_Block', 1174 instance: { 1175 raw_instance: instance 1176 } 1177 }; 1178 } 1179 const { 1180 form, 1181 rendered, 1182 ...restExistingWidget 1183 } = existingWidget || {}; 1184 return { 1185 ...restExistingWidget, 1186 ...widget 1187 }; 1188 } 1189 1190 /** 1191 * Transform a widget to a block. 1192 * 1193 * @param {Object} widget The widget to be transformed from. 1194 * @param {string} widget.id The widget id. 1195 * @param {string} widget.idBase The id base of the widget. 1196 * @param {number} widget.number The number/index of the widget. 1197 * @param {Object} widget.instance The instance of the widget. 1198 * @return {WPBlock} The transformed block. 1199 */ 1200 function widgetToBlock({ 1201 id, 1202 idBase, 1203 number, 1204 instance 1205 }) { 1206 let block; 1207 const { 1208 encoded_serialized_instance: encoded, 1209 instance_hash_key: hash, 1210 raw_instance: raw, 1211 ...rest 1212 } = instance; 1213 if (idBase === 'block') { 1214 var _raw$content; 1215 const parsedBlocks = (0,external_wp_blocks_namespaceObject.parse)((_raw$content = raw.content) !== null && _raw$content !== void 0 ? _raw$content : '', { 1216 __unstableSkipAutop: true 1217 }); 1218 block = parsedBlocks.length ? parsedBlocks[0] : (0,external_wp_blocks_namespaceObject.createBlock)('core/paragraph', {}); 1219 } else if (number) { 1220 // Widget that extends WP_Widget. 1221 block = (0,external_wp_blocks_namespaceObject.createBlock)('core/legacy-widget', { 1222 idBase, 1223 instance: { 1224 encoded, 1225 hash, 1226 raw, 1227 ...rest 1228 } 1229 }); 1230 } else { 1231 // Widget that does not extend WP_Widget. 1232 block = (0,external_wp_blocks_namespaceObject.createBlock)('core/legacy-widget', { 1233 id 1234 }); 1235 } 1236 return (0,external_wp_widgets_namespaceObject.addWidgetIdToBlock)(block, id); 1237 } 1238 1239 ;// ./node_modules/@wordpress/customize-widgets/build-module/components/sidebar-block-editor/use-sidebar-block-editor.js 1240 /** 1241 * External dependencies 1242 */ 1243 1244 1245 /** 1246 * WordPress dependencies 1247 */ 1248 1249 1250 1251 1252 /** 1253 * Internal dependencies 1254 */ 1255 1256 function widgetsToBlocks(widgets) { 1257 return widgets.map(widget => widgetToBlock(widget)); 1258 } 1259 function useSidebarBlockEditor(sidebar) { 1260 const [blocks, setBlocks] = (0,external_wp_element_namespaceObject.useState)(() => widgetsToBlocks(sidebar.getWidgets())); 1261 (0,external_wp_element_namespaceObject.useEffect)(() => { 1262 return sidebar.subscribe((prevWidgets, nextWidgets) => { 1263 setBlocks(prevBlocks => { 1264 const prevWidgetsMap = new Map(prevWidgets.map(widget => [widget.id, widget])); 1265 const prevBlocksMap = new Map(prevBlocks.map(block => [(0,external_wp_widgets_namespaceObject.getWidgetIdFromBlock)(block), block])); 1266 const nextBlocks = nextWidgets.map(nextWidget => { 1267 const prevWidget = prevWidgetsMap.get(nextWidget.id); 1268 1269 // Bail out updates. 1270 if (prevWidget && prevWidget === nextWidget) { 1271 return prevBlocksMap.get(nextWidget.id); 1272 } 1273 return widgetToBlock(nextWidget); 1274 }); 1275 1276 // Bail out updates. 1277 if (external_wp_isShallowEqual_default()(prevBlocks, nextBlocks)) { 1278 return prevBlocks; 1279 } 1280 return nextBlocks; 1281 }); 1282 }); 1283 }, [sidebar]); 1284 const onChangeBlocks = (0,external_wp_element_namespaceObject.useCallback)(nextBlocks => { 1285 setBlocks(prevBlocks => { 1286 if (external_wp_isShallowEqual_default()(prevBlocks, nextBlocks)) { 1287 return prevBlocks; 1288 } 1289 const prevBlocksMap = new Map(prevBlocks.map(block => [(0,external_wp_widgets_namespaceObject.getWidgetIdFromBlock)(block), block])); 1290 const nextWidgets = nextBlocks.map(nextBlock => { 1291 const widgetId = (0,external_wp_widgets_namespaceObject.getWidgetIdFromBlock)(nextBlock); 1292 1293 // Update existing widgets. 1294 if (widgetId && prevBlocksMap.has(widgetId)) { 1295 const prevBlock = prevBlocksMap.get(widgetId); 1296 const prevWidget = sidebar.getWidget(widgetId); 1297 1298 // Bail out updates by returning the previous widgets. 1299 // Deep equality is necessary until the block editor's internals changes. 1300 if (es6_default()(nextBlock, prevBlock) && prevWidget) { 1301 return prevWidget; 1302 } 1303 return blockToWidget(nextBlock, prevWidget); 1304 } 1305 1306 // Add a new widget. 1307 return blockToWidget(nextBlock); 1308 }); 1309 1310 // Bail out updates if the updated widgets are the same. 1311 if (external_wp_isShallowEqual_default()(sidebar.getWidgets(), nextWidgets)) { 1312 return prevBlocks; 1313 } 1314 const addedWidgetIds = sidebar.setWidgets(nextWidgets); 1315 return nextBlocks.reduce((updatedNextBlocks, nextBlock, index) => { 1316 const addedWidgetId = addedWidgetIds[index]; 1317 if (addedWidgetId !== null) { 1318 // Only create a new instance if necessary to prevent 1319 // the whole editor from re-rendering on every edit. 1320 if (updatedNextBlocks === nextBlocks) { 1321 updatedNextBlocks = nextBlocks.slice(); 1322 } 1323 updatedNextBlocks[index] = (0,external_wp_widgets_namespaceObject.addWidgetIdToBlock)(nextBlock, addedWidgetId); 1324 } 1325 return updatedNextBlocks; 1326 }, nextBlocks); 1327 }); 1328 }, [sidebar]); 1329 return [blocks, onChangeBlocks, onChangeBlocks]; 1330 } 1331 1332 ;// ./node_modules/@wordpress/customize-widgets/build-module/components/focus-control/index.js 1333 /** 1334 * WordPress dependencies 1335 */ 1336 1337 1338 /** 1339 * Internal dependencies 1340 */ 1341 1342 1343 const FocusControlContext = (0,external_wp_element_namespaceObject.createContext)(); 1344 function FocusControl({ 1345 api, 1346 sidebarControls, 1347 children 1348 }) { 1349 const [focusedWidgetIdRef, setFocusedWidgetIdRef] = (0,external_wp_element_namespaceObject.useState)({ 1350 current: null 1351 }); 1352 const focusWidget = (0,external_wp_element_namespaceObject.useCallback)(widgetId => { 1353 for (const sidebarControl of sidebarControls) { 1354 const widgets = sidebarControl.setting.get(); 1355 if (widgets.includes(widgetId)) { 1356 sidebarControl.sectionInstance.expand({ 1357 // Schedule it after the complete callback so that 1358 // it won't be overridden by the "Back" button focus. 1359 completeCallback() { 1360 // Create a "ref-like" object every time to ensure 1361 // the same widget id can also triggers the focus control. 1362 setFocusedWidgetIdRef({ 1363 current: widgetId 1364 }); 1365 } 1366 }); 1367 break; 1368 } 1369 } 1370 }, [sidebarControls]); 1371 (0,external_wp_element_namespaceObject.useEffect)(() => { 1372 function handleFocus(settingId) { 1373 const widgetId = settingIdToWidgetId(settingId); 1374 focusWidget(widgetId); 1375 } 1376 let previewBound = false; 1377 function handleReady() { 1378 api.previewer.preview.bind('focus-control-for-setting', handleFocus); 1379 previewBound = true; 1380 } 1381 api.previewer.bind('ready', handleReady); 1382 return () => { 1383 api.previewer.unbind('ready', handleReady); 1384 if (previewBound) { 1385 api.previewer.preview.unbind('focus-control-for-setting', handleFocus); 1386 } 1387 }; 1388 }, [api, focusWidget]); 1389 const context = (0,external_wp_element_namespaceObject.useMemo)(() => [focusedWidgetIdRef, focusWidget], [focusedWidgetIdRef, focusWidget]); 1390 return /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(FocusControlContext.Provider, { 1391 value: context, 1392 children: children 1393 }); 1394 } 1395 const useFocusControl = () => (0,external_wp_element_namespaceObject.useContext)(FocusControlContext); 1396 1397 ;// ./node_modules/@wordpress/customize-widgets/build-module/components/focus-control/use-blocks-focus-control.js 1398 /** 1399 * WordPress dependencies 1400 */ 1401 1402 1403 1404 1405 1406 /** 1407 * Internal dependencies 1408 */ 1409 1410 function useBlocksFocusControl(blocks) { 1411 const { 1412 selectBlock 1413 } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_blockEditor_namespaceObject.store); 1414 const [focusedWidgetIdRef] = useFocusControl(); 1415 const blocksRef = (0,external_wp_element_namespaceObject.useRef)(blocks); 1416 (0,external_wp_element_namespaceObject.useEffect)(() => { 1417 blocksRef.current = blocks; 1418 }, [blocks]); 1419 (0,external_wp_element_namespaceObject.useEffect)(() => { 1420 if (focusedWidgetIdRef.current) { 1421 const focusedBlock = blocksRef.current.find(block => (0,external_wp_widgets_namespaceObject.getWidgetIdFromBlock)(block) === focusedWidgetIdRef.current); 1422 if (focusedBlock) { 1423 selectBlock(focusedBlock.clientId); 1424 // If the block is already being selected, the DOM node won't 1425 // get focused again automatically. 1426 // We select the DOM and focus it manually here. 1427 const blockNode = document.querySelector(`[data-block="$focusedBlock.clientId}"]`); 1428 blockNode?.focus(); 1429 } 1430 } 1431 }, [focusedWidgetIdRef, selectBlock]); 1432 } 1433 1434 ;// external ["wp","privateApis"] 1435 const external_wp_privateApis_namespaceObject = window["wp"]["privateApis"]; 1436 ;// ./node_modules/@wordpress/customize-widgets/build-module/lock-unlock.js 1437 /** 1438 * WordPress dependencies 1439 */ 1440 1441 const { 1442 lock, 1443 unlock 1444 } = (0,external_wp_privateApis_namespaceObject.__dangerousOptInToUnstableAPIsOnlyForCoreModules)('I acknowledge private features are not for use in themes or plugins and doing so will break in the next version of WordPress.', '@wordpress/customize-widgets'); 1445 1446 ;// ./node_modules/@wordpress/customize-widgets/build-module/components/sidebar-block-editor/sidebar-editor-provider.js 1447 /** 1448 * WordPress dependencies 1449 */ 1450 1451 1452 /** 1453 * Internal dependencies 1454 */ 1455 1456 1457 1458 1459 const { 1460 ExperimentalBlockEditorProvider 1461 } = unlock(external_wp_blockEditor_namespaceObject.privateApis); 1462 function SidebarEditorProvider({ 1463 sidebar, 1464 settings, 1465 children 1466 }) { 1467 const [blocks, onInput, onChange] = useSidebarBlockEditor(sidebar); 1468 useBlocksFocusControl(blocks); 1469 return /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(ExperimentalBlockEditorProvider, { 1470 value: blocks, 1471 onInput: onInput, 1472 onChange: onChange, 1473 settings: settings, 1474 useSubRegistry: false, 1475 children: children 1476 }); 1477 } 1478 1479 ;// ./node_modules/@wordpress/customize-widgets/build-module/components/welcome-guide/index.js 1480 /** 1481 * WordPress dependencies 1482 */ 1483 1484 1485 1486 1487 1488 1489 function WelcomeGuide({ 1490 sidebar 1491 }) { 1492 const { 1493 toggle 1494 } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_preferences_namespaceObject.store); 1495 const isEntirelyBlockWidgets = sidebar.getWidgets().every(widget => widget.id.startsWith('block-')); 1496 return /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsxs)("div", { 1497 className: "customize-widgets-welcome-guide", 1498 children: [/*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)("div", { 1499 className: "customize-widgets-welcome-guide__image__wrapper", 1500 children: /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsxs)("picture", { 1501 children: [/*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)("source", { 1502 srcSet: "https://s.w.org/images/block-editor/welcome-editor.svg", 1503 media: "(prefers-reduced-motion: reduce)" 1504 }), /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)("img", { 1505 className: "customize-widgets-welcome-guide__image", 1506 src: "https://s.w.org/images/block-editor/welcome-editor.gif", 1507 width: "312", 1508 height: "240", 1509 alt: "" 1510 })] 1511 }) 1512 }), /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)("h1", { 1513 className: "customize-widgets-welcome-guide__heading", 1514 children: (0,external_wp_i18n_namespaceObject.__)('Welcome to block Widgets') 1515 }), /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)("p", { 1516 className: "customize-widgets-welcome-guide__text", 1517 children: isEntirelyBlockWidgets ? (0,external_wp_i18n_namespaceObject.__)('Your theme provides different “block” areas for you to add and edit content. Try adding a search bar, social icons, or other types of blocks here and see how they’ll look on your site.') : (0,external_wp_i18n_namespaceObject.__)('You can now add any block to your site’s widget areas. Don’t worry, all of your favorite widgets still work flawlessly.') 1518 }), /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_components_namespaceObject.Button 1519 // TODO: Switch to `true` (40px size) if possible 1520 , { 1521 __next40pxDefaultSize: false, 1522 className: "customize-widgets-welcome-guide__button", 1523 variant: "primary", 1524 onClick: () => toggle('core/customize-widgets', 'welcomeGuide'), 1525 children: (0,external_wp_i18n_namespaceObject.__)('Got it') 1526 }), /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)("hr", { 1527 className: "customize-widgets-welcome-guide__separator" 1528 }), !isEntirelyBlockWidgets && /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsxs)("p", { 1529 className: "customize-widgets-welcome-guide__more-info", 1530 children: [(0,external_wp_i18n_namespaceObject.__)('Want to stick with the old widgets?'), /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)("br", {}), /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_components_namespaceObject.ExternalLink, { 1531 href: (0,external_wp_i18n_namespaceObject.__)('https://wordpress.org/plugins/classic-widgets/'), 1532 children: (0,external_wp_i18n_namespaceObject.__)('Get the Classic Widgets plugin.') 1533 })] 1534 }), /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsxs)("p", { 1535 className: "customize-widgets-welcome-guide__more-info", 1536 children: [(0,external_wp_i18n_namespaceObject.__)('New to the block editor?'), /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)("br", {}), /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_components_namespaceObject.ExternalLink, { 1537 href: (0,external_wp_i18n_namespaceObject.__)('https://wordpress.org/documentation/article/wordpress-block-editor/'), 1538 children: (0,external_wp_i18n_namespaceObject.__)("Here's a detailed guide.") 1539 })] 1540 })] 1541 }); 1542 } 1543 1544 ;// ./node_modules/@wordpress/customize-widgets/build-module/components/keyboard-shortcuts/index.js 1545 /** 1546 * WordPress dependencies 1547 */ 1548 1549 1550 1551 1552 1553 function KeyboardShortcuts({ 1554 undo, 1555 redo, 1556 save 1557 }) { 1558 (0,external_wp_keyboardShortcuts_namespaceObject.useShortcut)('core/customize-widgets/undo', event => { 1559 undo(); 1560 event.preventDefault(); 1561 }); 1562 (0,external_wp_keyboardShortcuts_namespaceObject.useShortcut)('core/customize-widgets/redo', event => { 1563 redo(); 1564 event.preventDefault(); 1565 }); 1566 (0,external_wp_keyboardShortcuts_namespaceObject.useShortcut)('core/customize-widgets/save', event => { 1567 event.preventDefault(); 1568 save(); 1569 }); 1570 return null; 1571 } 1572 function KeyboardShortcutsRegister() { 1573 const { 1574 registerShortcut, 1575 unregisterShortcut 1576 } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_keyboardShortcuts_namespaceObject.store); 1577 (0,external_wp_element_namespaceObject.useEffect)(() => { 1578 registerShortcut({ 1579 name: 'core/customize-widgets/undo', 1580 category: 'global', 1581 description: (0,external_wp_i18n_namespaceObject.__)('Undo your last changes.'), 1582 keyCombination: { 1583 modifier: 'primary', 1584 character: 'z' 1585 } 1586 }); 1587 registerShortcut({ 1588 name: 'core/customize-widgets/redo', 1589 category: 'global', 1590 description: (0,external_wp_i18n_namespaceObject.__)('Redo your last undo.'), 1591 keyCombination: { 1592 modifier: 'primaryShift', 1593 character: 'z' 1594 }, 1595 // Disable on Apple OS because it conflicts with the browser's 1596 // history shortcut. It's a fine alias for both Windows and Linux. 1597 // Since there's no conflict for Ctrl+Shift+Z on both Windows and 1598 // Linux, we keep it as the default for consistency. 1599 aliases: (0,external_wp_keycodes_namespaceObject.isAppleOS)() ? [] : [{ 1600 modifier: 'primary', 1601 character: 'y' 1602 }] 1603 }); 1604 registerShortcut({ 1605 name: 'core/customize-widgets/save', 1606 category: 'global', 1607 description: (0,external_wp_i18n_namespaceObject.__)('Save your changes.'), 1608 keyCombination: { 1609 modifier: 'primary', 1610 character: 's' 1611 } 1612 }); 1613 return () => { 1614 unregisterShortcut('core/customize-widgets/undo'); 1615 unregisterShortcut('core/customize-widgets/redo'); 1616 unregisterShortcut('core/customize-widgets/save'); 1617 }; 1618 }, [registerShortcut]); 1619 return null; 1620 } 1621 KeyboardShortcuts.Register = KeyboardShortcutsRegister; 1622 /* harmony default export */ const keyboard_shortcuts = (KeyboardShortcuts); 1623 1624 ;// ./node_modules/@wordpress/customize-widgets/build-module/components/block-appender/index.js 1625 /** 1626 * WordPress dependencies 1627 */ 1628 1629 1630 1631 1632 function BlockAppender(props) { 1633 const ref = (0,external_wp_element_namespaceObject.useRef)(); 1634 const isBlocksListEmpty = (0,external_wp_data_namespaceObject.useSelect)(select => select(external_wp_blockEditor_namespaceObject.store).getBlockCount() === 0); 1635 1636 // Move the focus to the block appender to prevent focus from 1637 // being lost when emptying the widget area. 1638 (0,external_wp_element_namespaceObject.useEffect)(() => { 1639 if (isBlocksListEmpty && ref.current) { 1640 const { 1641 ownerDocument 1642 } = ref.current; 1643 if (!ownerDocument.activeElement || ownerDocument.activeElement === ownerDocument.body) { 1644 ref.current.focus(); 1645 } 1646 } 1647 }, [isBlocksListEmpty]); 1648 return /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_blockEditor_namespaceObject.ButtonBlockAppender, { 1649 ...props, 1650 ref: ref 1651 }); 1652 } 1653 1654 ;// ./node_modules/@wordpress/customize-widgets/build-module/components/sidebar-block-editor/index.js 1655 /** 1656 * WordPress dependencies 1657 */ 1658 1659 1660 1661 1662 1663 1664 1665 1666 1667 /** 1668 * Internal dependencies 1669 */ 1670 1671 1672 1673 1674 1675 1676 1677 1678 1679 1680 1681 const { 1682 ExperimentalBlockCanvas: BlockCanvas 1683 } = unlock(external_wp_blockEditor_namespaceObject.privateApis); 1684 const { 1685 BlockKeyboardShortcuts 1686 } = unlock(external_wp_blockLibrary_namespaceObject.privateApis); 1687 function SidebarBlockEditor({ 1688 blockEditorSettings, 1689 sidebar, 1690 inserter, 1691 inspector 1692 }) { 1693 const [isInserterOpened, setIsInserterOpened] = useInserter(inserter); 1694 const isMediumViewport = (0,external_wp_compose_namespaceObject.useViewportMatch)('small'); 1695 const { 1696 hasUploadPermissions, 1697 isFixedToolbarActive, 1698 keepCaretInsideBlock, 1699 isWelcomeGuideActive 1700 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 1701 var _select$canUser; 1702 const { 1703 get 1704 } = select(external_wp_preferences_namespaceObject.store); 1705 return { 1706 hasUploadPermissions: (_select$canUser = select(external_wp_coreData_namespaceObject.store).canUser('create', { 1707 kind: 'root', 1708 name: 'media' 1709 })) !== null && _select$canUser !== void 0 ? _select$canUser : true, 1710 isFixedToolbarActive: !!get('core/customize-widgets', 'fixedToolbar'), 1711 keepCaretInsideBlock: !!get('core/customize-widgets', 'keepCaretInsideBlock'), 1712 isWelcomeGuideActive: !!get('core/customize-widgets', 'welcomeGuide') 1713 }; 1714 }, []); 1715 const settings = (0,external_wp_element_namespaceObject.useMemo)(() => { 1716 let mediaUploadBlockEditor; 1717 if (hasUploadPermissions) { 1718 mediaUploadBlockEditor = ({ 1719 onError, 1720 ...argumentsObject 1721 }) => { 1722 (0,external_wp_mediaUtils_namespaceObject.uploadMedia)({ 1723 wpAllowedMimeTypes: blockEditorSettings.allowedMimeTypes, 1724 onError: ({ 1725 message 1726 }) => onError(message), 1727 ...argumentsObject 1728 }); 1729 }; 1730 } 1731 return { 1732 ...blockEditorSettings, 1733 __experimentalSetIsInserterOpened: setIsInserterOpened, 1734 mediaUpload: mediaUploadBlockEditor, 1735 hasFixedToolbar: isFixedToolbarActive || !isMediumViewport, 1736 keepCaretInsideBlock, 1737 __unstableHasCustomAppender: true 1738 }; 1739 }, [hasUploadPermissions, blockEditorSettings, isFixedToolbarActive, isMediumViewport, keepCaretInsideBlock, setIsInserterOpened]); 1740 if (isWelcomeGuideActive) { 1741 return /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(WelcomeGuide, { 1742 sidebar: sidebar 1743 }); 1744 } 1745 return /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsxs)(external_ReactJSXRuntime_namespaceObject.Fragment, { 1746 children: [/*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(keyboard_shortcuts.Register, {}), /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(BlockKeyboardShortcuts, {}), /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsxs)(SidebarEditorProvider, { 1747 sidebar: sidebar, 1748 settings: settings, 1749 children: [/*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(keyboard_shortcuts, { 1750 undo: sidebar.undo, 1751 redo: sidebar.redo, 1752 save: sidebar.save 1753 }), /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(header, { 1754 sidebar: sidebar, 1755 inserter: inserter, 1756 isInserterOpened: isInserterOpened, 1757 setIsInserterOpened: setIsInserterOpened, 1758 isFixedToolbarActive: isFixedToolbarActive || !isMediumViewport 1759 }), (isFixedToolbarActive || !isMediumViewport) && /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_blockEditor_namespaceObject.BlockToolbar, { 1760 hideDragHandle: true 1761 }), /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(BlockCanvas, { 1762 shouldIframe: false, 1763 styles: settings.defaultEditorStyles, 1764 height: "100%", 1765 children: /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_blockEditor_namespaceObject.BlockList, { 1766 renderAppender: BlockAppender 1767 }) 1768 }), (0,external_wp_element_namespaceObject.createPortal)( 1769 /*#__PURE__*/ 1770 // This is a temporary hack to prevent button component inside <BlockInspector> 1771 // from submitting form when type="button" is not specified. 1772 (0,external_ReactJSXRuntime_namespaceObject.jsx)("form", { 1773 onSubmit: event => event.preventDefault(), 1774 children: /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_blockEditor_namespaceObject.BlockInspector, {}) 1775 }), inspector.contentContainer[0])] 1776 }), /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_blockEditor_namespaceObject.__unstableBlockSettingsMenuFirstItem, { 1777 children: ({ 1778 onClose 1779 }) => /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(block_inspector_button, { 1780 inspector: inspector, 1781 closeMenu: onClose 1782 }) 1783 })] 1784 }); 1785 } 1786 1787 ;// ./node_modules/@wordpress/customize-widgets/build-module/components/sidebar-controls/index.js 1788 /** 1789 * WordPress dependencies 1790 */ 1791 1792 1793 const SidebarControlsContext = (0,external_wp_element_namespaceObject.createContext)(); 1794 function SidebarControls({ 1795 sidebarControls, 1796 activeSidebarControl, 1797 children 1798 }) { 1799 const context = (0,external_wp_element_namespaceObject.useMemo)(() => ({ 1800 sidebarControls, 1801 activeSidebarControl 1802 }), [sidebarControls, activeSidebarControl]); 1803 return /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(SidebarControlsContext.Provider, { 1804 value: context, 1805 children: children 1806 }); 1807 } 1808 function useSidebarControls() { 1809 const { 1810 sidebarControls 1811 } = (0,external_wp_element_namespaceObject.useContext)(SidebarControlsContext); 1812 return sidebarControls; 1813 } 1814 function useActiveSidebarControl() { 1815 const { 1816 activeSidebarControl 1817 } = (0,external_wp_element_namespaceObject.useContext)(SidebarControlsContext); 1818 return activeSidebarControl; 1819 } 1820 1821 ;// ./node_modules/@wordpress/customize-widgets/build-module/components/customize-widgets/use-clear-selected-block.js 1822 /** 1823 * WordPress dependencies 1824 */ 1825 1826 1827 1828 1829 /** 1830 * We can't just use <BlockSelectionClearer> because the customizer has 1831 * many root nodes rather than just one in the post editor. 1832 * We need to listen to the focus events in all those roots, and also in 1833 * the preview iframe. 1834 * This hook will clear the selected block when focusing outside the editor, 1835 * with a few exceptions: 1836 * 1. Focusing on popovers. 1837 * 2. Focusing on the inspector. 1838 * 3. Focusing on any modals/dialogs. 1839 * These cases are normally triggered by user interactions from the editor, 1840 * not by explicitly focusing outside the editor, hence no need for clearing. 1841 * 1842 * @param {Object} sidebarControl The sidebar control instance. 1843 * @param {Object} popoverRef The ref object of the popover node container. 1844 */ 1845 function useClearSelectedBlock(sidebarControl, popoverRef) { 1846 const { 1847 hasSelectedBlock, 1848 hasMultiSelection 1849 } = (0,external_wp_data_namespaceObject.useSelect)(external_wp_blockEditor_namespaceObject.store); 1850 const { 1851 clearSelectedBlock 1852 } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_blockEditor_namespaceObject.store); 1853 (0,external_wp_element_namespaceObject.useEffect)(() => { 1854 if (popoverRef.current && sidebarControl) { 1855 const inspector = sidebarControl.inspector; 1856 const container = sidebarControl.container[0]; 1857 const ownerDocument = container.ownerDocument; 1858 const ownerWindow = ownerDocument.defaultView; 1859 function handleClearSelectedBlock(element) { 1860 if ( 1861 // 1. Make sure there are blocks being selected. 1862 (hasSelectedBlock() || hasMultiSelection()) && 1863 // 2. The element should exist in the DOM (not deleted). 1864 element && ownerDocument.contains(element) && 1865 // 3. It should also not exist in the container, the popover, nor the dialog. 1866 !container.contains(element) && !popoverRef.current.contains(element) && !element.closest('[role="dialog"]') && 1867 // 4. The inspector should not be opened. 1868 !inspector.expanded()) { 1869 clearSelectedBlock(); 1870 } 1871 } 1872 1873 // Handle mouse down in the same document. 1874 function handleMouseDown(event) { 1875 handleClearSelectedBlock(event.target); 1876 } 1877 // Handle focusing outside the current document, like to iframes. 1878 function handleBlur() { 1879 handleClearSelectedBlock(ownerDocument.activeElement); 1880 } 1881 ownerDocument.addEventListener('mousedown', handleMouseDown); 1882 ownerWindow.addEventListener('blur', handleBlur); 1883 return () => { 1884 ownerDocument.removeEventListener('mousedown', handleMouseDown); 1885 ownerWindow.removeEventListener('blur', handleBlur); 1886 }; 1887 } 1888 }, [popoverRef, sidebarControl, hasSelectedBlock, hasMultiSelection, clearSelectedBlock]); 1889 } 1890 1891 ;// ./node_modules/@wordpress/customize-widgets/build-module/components/customize-widgets/index.js 1892 /** 1893 * WordPress dependencies 1894 */ 1895 1896 1897 1898 /** 1899 * Internal dependencies 1900 */ 1901 1902 1903 1904 1905 1906 1907 1908 function CustomizeWidgets({ 1909 api, 1910 sidebarControls, 1911 blockEditorSettings 1912 }) { 1913 const [activeSidebarControl, setActiveSidebarControl] = (0,external_wp_element_namespaceObject.useState)(null); 1914 const parentContainer = document.getElementById('customize-theme-controls'); 1915 const popoverRef = (0,external_wp_element_namespaceObject.useRef)(); 1916 useClearSelectedBlock(activeSidebarControl, popoverRef); 1917 (0,external_wp_element_namespaceObject.useEffect)(() => { 1918 const unsubscribers = sidebarControls.map(sidebarControl => sidebarControl.subscribe(expanded => { 1919 if (expanded) { 1920 setActiveSidebarControl(sidebarControl); 1921 } 1922 })); 1923 return () => { 1924 unsubscribers.forEach(unsubscriber => unsubscriber()); 1925 }; 1926 }, [sidebarControls]); 1927 const activeSidebar = activeSidebarControl && (0,external_wp_element_namespaceObject.createPortal)( /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(ErrorBoundary, { 1928 children: /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(SidebarBlockEditor, { 1929 blockEditorSettings: blockEditorSettings, 1930 sidebar: activeSidebarControl.sidebarAdapter, 1931 inserter: activeSidebarControl.inserter, 1932 inspector: activeSidebarControl.inspector 1933 }, activeSidebarControl.id) 1934 }), activeSidebarControl.container[0]); 1935 1936 // We have to portal this to the parent of both the editor and the inspector, 1937 // so that the popovers will appear above both of them. 1938 const popover = parentContainer && (0,external_wp_element_namespaceObject.createPortal)( /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)("div", { 1939 className: "customize-widgets-popover", 1940 ref: popoverRef, 1941 children: /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_components_namespaceObject.Popover.Slot, {}) 1942 }), parentContainer); 1943 return /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_components_namespaceObject.SlotFillProvider, { 1944 children: /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(SidebarControls, { 1945 sidebarControls: sidebarControls, 1946 activeSidebarControl: activeSidebarControl, 1947 children: /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsxs)(FocusControl, { 1948 api: api, 1949 sidebarControls: sidebarControls, 1950 children: [activeSidebar, popover] 1951 }) 1952 }) 1953 }); 1954 } 1955 1956 ;// ./node_modules/@wordpress/customize-widgets/build-module/controls/inspector-section.js 1957 function getInspectorSection() { 1958 const { 1959 wp: { 1960 customize 1961 } 1962 } = window; 1963 return class InspectorSection extends customize.Section { 1964 constructor(id, options) { 1965 super(id, options); 1966 this.parentSection = options.parentSection; 1967 this.returnFocusWhenClose = null; 1968 this._isOpen = false; 1969 } 1970 get isOpen() { 1971 return this._isOpen; 1972 } 1973 set isOpen(value) { 1974 this._isOpen = value; 1975 this.triggerActiveCallbacks(); 1976 } 1977 ready() { 1978 this.contentContainer[0].classList.add('customize-widgets-layout__inspector'); 1979 } 1980 isContextuallyActive() { 1981 return this.isOpen; 1982 } 1983 onChangeExpanded(expanded, args) { 1984 super.onChangeExpanded(expanded, args); 1985 if (this.parentSection && !args.unchanged) { 1986 if (expanded) { 1987 this.parentSection.collapse({ 1988 manualTransition: true 1989 }); 1990 } else { 1991 this.parentSection.expand({ 1992 manualTransition: true, 1993 completeCallback: () => { 1994 // Return focus after finishing the transition. 1995 if (this.returnFocusWhenClose && !this.contentContainer[0].contains(this.returnFocusWhenClose)) { 1996 this.returnFocusWhenClose.focus(); 1997 } 1998 } 1999 }); 2000 } 2001 } 2002 } 2003 open({ 2004 returnFocusWhenClose 2005 } = {}) { 2006 this.isOpen = true; 2007 this.returnFocusWhenClose = returnFocusWhenClose; 2008 this.expand({ 2009 allowMultiple: true 2010 }); 2011 } 2012 close() { 2013 this.collapse({ 2014 allowMultiple: true 2015 }); 2016 } 2017 collapse(options) { 2018 // Overridden collapse() function. Mostly call the parent collapse(), but also 2019 // move our .isOpen to false. 2020 // Initially, I tried tracking this with onChangeExpanded(), but it doesn't work 2021 // because the block settings sidebar is a layer "on top of" the G editor sidebar. 2022 // 2023 // For example, when closing the block settings sidebar, the G 2024 // editor sidebar would display, and onChangeExpanded in 2025 // inspector-section would run with expanded=true, but I want 2026 // isOpen to be false when the block settings is closed. 2027 this.isOpen = false; 2028 super.collapse(options); 2029 } 2030 triggerActiveCallbacks() { 2031 // Manually fire the callbacks associated with moving this.active 2032 // from false to true. "active" is always true for this section, 2033 // and "isContextuallyActive" reflects if the block settings 2034 // sidebar is currently visible, that is, it has replaced the main 2035 // Gutenberg view. 2036 // The WP customizer only checks ".isContextuallyActive()" when 2037 // ".active" changes values. But our ".active" never changes value. 2038 // The WP customizer never foresaw a section being used a way we 2039 // fit the block settings sidebar into a section. By manually 2040 // triggering the "this.active" callbacks, we force the WP 2041 // customizer to query our .isContextuallyActive() function and 2042 // update its view of our status. 2043 this.active.callbacks.fireWith(this.active, [false, true]); 2044 } 2045 }; 2046 } 2047 2048 ;// ./node_modules/@wordpress/customize-widgets/build-module/controls/sidebar-section.js 2049 /** 2050 * WordPress dependencies 2051 */ 2052 2053 2054 /** 2055 * Internal dependencies 2056 */ 2057 2058 const getInspectorSectionId = sidebarId => `widgets-inspector-$sidebarId}`; 2059 function getSidebarSection() { 2060 const { 2061 wp: { 2062 customize 2063 } 2064 } = window; 2065 const reduceMotionMediaQuery = window.matchMedia('(prefers-reduced-motion: reduce)'); 2066 let isReducedMotion = reduceMotionMediaQuery.matches; 2067 reduceMotionMediaQuery.addEventListener('change', event => { 2068 isReducedMotion = event.matches; 2069 }); 2070 return class SidebarSection extends customize.Section { 2071 ready() { 2072 const InspectorSection = getInspectorSection(); 2073 this.inspector = new InspectorSection(getInspectorSectionId(this.id), { 2074 title: (0,external_wp_i18n_namespaceObject.__)('Block Settings'), 2075 parentSection: this, 2076 customizeAction: [(0,external_wp_i18n_namespaceObject.__)('Customizing'), (0,external_wp_i18n_namespaceObject.__)('Widgets'), this.params.title].join(' ▸ ') 2077 }); 2078 customize.section.add(this.inspector); 2079 this.contentContainer[0].classList.add('customize-widgets__sidebar-section'); 2080 } 2081 hasSubSectionOpened() { 2082 return this.inspector.expanded(); 2083 } 2084 onChangeExpanded(expanded, _args) { 2085 const controls = this.controls(); 2086 const args = { 2087 ..._args, 2088 completeCallback() { 2089 controls.forEach(control => { 2090 control.onChangeSectionExpanded?.(expanded, args); 2091 }); 2092 _args.completeCallback?.(); 2093 } 2094 }; 2095 if (args.manualTransition) { 2096 if (expanded) { 2097 this.contentContainer.addClass(['busy', 'open']); 2098 this.contentContainer.removeClass('is-sub-section-open'); 2099 this.contentContainer.closest('.wp-full-overlay').addClass('section-open'); 2100 } else { 2101 this.contentContainer.addClass(['busy', 'is-sub-section-open']); 2102 this.contentContainer.closest('.wp-full-overlay').addClass('section-open'); 2103 this.contentContainer.removeClass('open'); 2104 } 2105 const handleTransitionEnd = () => { 2106 this.contentContainer.removeClass('busy'); 2107 args.completeCallback(); 2108 }; 2109 if (isReducedMotion) { 2110 handleTransitionEnd(); 2111 } else { 2112 this.contentContainer.one('transitionend', handleTransitionEnd); 2113 } 2114 } else { 2115 super.onChangeExpanded(expanded, args); 2116 } 2117 } 2118 }; 2119 } 2120 2121 ;// ./node_modules/@wordpress/customize-widgets/build-module/components/sidebar-block-editor/sidebar-adapter.js 2122 /** 2123 * Internal dependencies 2124 */ 2125 2126 const { 2127 wp 2128 } = window; 2129 function parseWidgetId(widgetId) { 2130 const matches = widgetId.match(/^(.+)-(\d+)$/); 2131 if (matches) { 2132 return { 2133 idBase: matches[1], 2134 number: parseInt(matches[2], 10) 2135 }; 2136 } 2137 2138 // Likely an old single widget. 2139 return { 2140 idBase: widgetId 2141 }; 2142 } 2143 function widgetIdToSettingId(widgetId) { 2144 const { 2145 idBase, 2146 number 2147 } = parseWidgetId(widgetId); 2148 if (number) { 2149 return `widget_$idBase}[$number}]`; 2150 } 2151 return `widget_$idBase}`; 2152 } 2153 2154 /** 2155 * This is a custom debounce function to call different callbacks depending on 2156 * whether it's the _leading_ call or not. 2157 * 2158 * @param {Function} leading The callback that gets called first. 2159 * @param {Function} callback The callback that gets called after the first time. 2160 * @param {number} timeout The debounced time in milliseconds. 2161 * @return {Function} The debounced function. 2162 */ 2163 function debounce(leading, callback, timeout) { 2164 let isLeading = false; 2165 let timerID; 2166 function debounced(...args) { 2167 const result = (isLeading ? callback : leading).apply(this, args); 2168 isLeading = true; 2169 clearTimeout(timerID); 2170 timerID = setTimeout(() => { 2171 isLeading = false; 2172 }, timeout); 2173 return result; 2174 } 2175 debounced.cancel = () => { 2176 isLeading = false; 2177 clearTimeout(timerID); 2178 }; 2179 return debounced; 2180 } 2181 class SidebarAdapter { 2182 constructor(setting, api) { 2183 this.setting = setting; 2184 this.api = api; 2185 this.locked = false; 2186 this.widgetsCache = new WeakMap(); 2187 this.subscribers = new Set(); 2188 this.history = [this._getWidgetIds().map(widgetId => this.getWidget(widgetId))]; 2189 this.historyIndex = 0; 2190 this.historySubscribers = new Set(); 2191 // Debounce the input for 1 second. 2192 this._debounceSetHistory = debounce(this._pushHistory, this._replaceHistory, 1000); 2193 this.setting.bind(this._handleSettingChange.bind(this)); 2194 this.api.bind('change', this._handleAllSettingsChange.bind(this)); 2195 this.undo = this.undo.bind(this); 2196 this.redo = this.redo.bind(this); 2197 this.save = this.save.bind(this); 2198 } 2199 subscribe(callback) { 2200 this.subscribers.add(callback); 2201 return () => { 2202 this.subscribers.delete(callback); 2203 }; 2204 } 2205 getWidgets() { 2206 return this.history[this.historyIndex]; 2207 } 2208 _emit(...args) { 2209 for (const callback of this.subscribers) { 2210 callback(...args); 2211 } 2212 } 2213 _getWidgetIds() { 2214 return this.setting.get(); 2215 } 2216 _pushHistory() { 2217 this.history = [...this.history.slice(0, this.historyIndex + 1), this._getWidgetIds().map(widgetId => this.getWidget(widgetId))]; 2218 this.historyIndex += 1; 2219 this.historySubscribers.forEach(listener => listener()); 2220 } 2221 _replaceHistory() { 2222 this.history[this.historyIndex] = this._getWidgetIds().map(widgetId => this.getWidget(widgetId)); 2223 } 2224 _handleSettingChange() { 2225 if (this.locked) { 2226 return; 2227 } 2228 const prevWidgets = this.getWidgets(); 2229 this._pushHistory(); 2230 this._emit(prevWidgets, this.getWidgets()); 2231 } 2232 _handleAllSettingsChange(setting) { 2233 if (this.locked) { 2234 return; 2235 } 2236 if (!setting.id.startsWith('widget_')) { 2237 return; 2238 } 2239 const widgetId = settingIdToWidgetId(setting.id); 2240 if (!this.setting.get().includes(widgetId)) { 2241 return; 2242 } 2243 const prevWidgets = this.getWidgets(); 2244 this._pushHistory(); 2245 this._emit(prevWidgets, this.getWidgets()); 2246 } 2247 _createWidget(widget) { 2248 const widgetModel = wp.customize.Widgets.availableWidgets.findWhere({ 2249 id_base: widget.idBase 2250 }); 2251 let number = widget.number; 2252 if (widgetModel.get('is_multi') && !number) { 2253 widgetModel.set('multi_number', widgetModel.get('multi_number') + 1); 2254 number = widgetModel.get('multi_number'); 2255 } 2256 const settingId = number ? `widget_$widget.idBase}[$number}]` : `widget_$widget.idBase}`; 2257 const settingArgs = { 2258 transport: wp.customize.Widgets.data.selectiveRefreshableWidgets[widgetModel.get('id_base')] ? 'postMessage' : 'refresh', 2259 previewer: this.setting.previewer 2260 }; 2261 const setting = this.api.create(settingId, settingId, '', settingArgs); 2262 setting.set(widget.instance); 2263 const widgetId = settingIdToWidgetId(settingId); 2264 return widgetId; 2265 } 2266 _removeWidget(widget) { 2267 const settingId = widgetIdToSettingId(widget.id); 2268 const setting = this.api(settingId); 2269 if (setting) { 2270 const instance = setting.get(); 2271 this.widgetsCache.delete(instance); 2272 } 2273 this.api.remove(settingId); 2274 } 2275 _updateWidget(widget) { 2276 const prevWidget = this.getWidget(widget.id); 2277 2278 // Bail out update if nothing changed. 2279 if (prevWidget === widget) { 2280 return widget.id; 2281 } 2282 2283 // Update existing setting if only the widget's instance changed. 2284 if (prevWidget.idBase && widget.idBase && prevWidget.idBase === widget.idBase) { 2285 const settingId = widgetIdToSettingId(widget.id); 2286 this.api(settingId).set(widget.instance); 2287 return widget.id; 2288 } 2289 2290 // Otherwise delete and re-create. 2291 this._removeWidget(widget); 2292 return this._createWidget(widget); 2293 } 2294 getWidget(widgetId) { 2295 if (!widgetId) { 2296 return null; 2297 } 2298 const { 2299 idBase, 2300 number 2301 } = parseWidgetId(widgetId); 2302 const settingId = widgetIdToSettingId(widgetId); 2303 const setting = this.api(settingId); 2304 if (!setting) { 2305 return null; 2306 } 2307 const instance = setting.get(); 2308 if (this.widgetsCache.has(instance)) { 2309 return this.widgetsCache.get(instance); 2310 } 2311 const widget = { 2312 id: widgetId, 2313 idBase, 2314 number, 2315 instance 2316 }; 2317 this.widgetsCache.set(instance, widget); 2318 return widget; 2319 } 2320 _updateWidgets(nextWidgets) { 2321 this.locked = true; 2322 const addedWidgetIds = []; 2323 const nextWidgetIds = nextWidgets.map(nextWidget => { 2324 if (nextWidget.id && this.getWidget(nextWidget.id)) { 2325 addedWidgetIds.push(null); 2326 return this._updateWidget(nextWidget); 2327 } 2328 const widgetId = this._createWidget(nextWidget); 2329 addedWidgetIds.push(widgetId); 2330 return widgetId; 2331 }); 2332 const deletedWidgets = this.getWidgets().filter(widget => !nextWidgetIds.includes(widget.id)); 2333 deletedWidgets.forEach(widget => this._removeWidget(widget)); 2334 this.setting.set(nextWidgetIds); 2335 this.locked = false; 2336 return addedWidgetIds; 2337 } 2338 setWidgets(nextWidgets) { 2339 const addedWidgetIds = this._updateWidgets(nextWidgets); 2340 this._debounceSetHistory(); 2341 return addedWidgetIds; 2342 } 2343 2344 /** 2345 * Undo/Redo related features 2346 */ 2347 hasUndo() { 2348 return this.historyIndex > 0; 2349 } 2350 hasRedo() { 2351 return this.historyIndex < this.history.length - 1; 2352 } 2353 _seek(historyIndex) { 2354 const currentWidgets = this.getWidgets(); 2355 this.historyIndex = historyIndex; 2356 const widgets = this.history[this.historyIndex]; 2357 this._updateWidgets(widgets); 2358 this._emit(currentWidgets, this.getWidgets()); 2359 this.historySubscribers.forEach(listener => listener()); 2360 this._debounceSetHistory.cancel(); 2361 } 2362 undo() { 2363 if (!this.hasUndo()) { 2364 return; 2365 } 2366 this._seek(this.historyIndex - 1); 2367 } 2368 redo() { 2369 if (!this.hasRedo()) { 2370 return; 2371 } 2372 this._seek(this.historyIndex + 1); 2373 } 2374 subscribeHistory(listener) { 2375 this.historySubscribers.add(listener); 2376 return () => { 2377 this.historySubscribers.delete(listener); 2378 }; 2379 } 2380 save() { 2381 this.api.previewer.save(); 2382 } 2383 } 2384 2385 ;// external ["wp","dom"] 2386 const external_wp_dom_namespaceObject = window["wp"]["dom"]; 2387 ;// ./node_modules/@wordpress/customize-widgets/build-module/controls/inserter-outer-section.js 2388 /** 2389 * WordPress dependencies 2390 */ 2391 2392 2393 2394 2395 /** 2396 * Internal dependencies 2397 */ 2398 2399 function getInserterOuterSection() { 2400 const { 2401 wp: { 2402 customize 2403 } 2404 } = window; 2405 const OuterSection = customize.OuterSection; 2406 // Override the OuterSection class to handle multiple outer sections. 2407 // It closes all the other outer sections whenever one is opened. 2408 // The result is that at most one outer section can be opened at the same time. 2409 customize.OuterSection = class extends OuterSection { 2410 onChangeExpanded(expanded, args) { 2411 if (expanded) { 2412 customize.section.each(section => { 2413 if (section.params.type === 'outer' && section.id !== this.id) { 2414 if (section.expanded()) { 2415 section.collapse(); 2416 } 2417 } 2418 }); 2419 } 2420 return super.onChangeExpanded(expanded, args); 2421 } 2422 }; 2423 // Handle constructor so that "params.type" can be correctly pointed to "outer". 2424 customize.sectionConstructor.outer = customize.OuterSection; 2425 return class InserterOuterSection extends customize.OuterSection { 2426 constructor(...args) { 2427 super(...args); 2428 2429 // This is necessary since we're creating a new class which is not identical to the original OuterSection. 2430 // @See https://github.com/WordPress/wordpress-develop/blob/42b05c397c50d9dc244083eff52991413909d4bd/src/js/_enqueues/wp/customize/controls.js#L1427-L1436 2431 this.params.type = 'outer'; 2432 this.activeElementBeforeExpanded = null; 2433 const ownerWindow = this.contentContainer[0].ownerDocument.defaultView; 2434 2435 // Handle closing the inserter when pressing the Escape key. 2436 ownerWindow.addEventListener('keydown', event => { 2437 if (this.expanded() && (event.keyCode === external_wp_keycodes_namespaceObject.ESCAPE || event.code === 'Escape') && !event.defaultPrevented) { 2438 event.preventDefault(); 2439 event.stopPropagation(); 2440 (0,external_wp_data_namespaceObject.dispatch)(store).setIsInserterOpened(false); 2441 } 2442 }, 2443 // Use capture mode to make this run before other event listeners. 2444 true); 2445 this.contentContainer.addClass('widgets-inserter'); 2446 2447 // Set a flag if the state is being changed from open() or close(). 2448 // Don't propagate the event if it's an internal action to prevent infinite loop. 2449 this.isFromInternalAction = false; 2450 this.expanded.bind(() => { 2451 if (!this.isFromInternalAction) { 2452 // Propagate the event to React to sync the state. 2453 (0,external_wp_data_namespaceObject.dispatch)(store).setIsInserterOpened(this.expanded()); 2454 } 2455 this.isFromInternalAction = false; 2456 }); 2457 } 2458 open() { 2459 if (!this.expanded()) { 2460 const contentContainer = this.contentContainer[0]; 2461 this.activeElementBeforeExpanded = contentContainer.ownerDocument.activeElement; 2462 this.isFromInternalAction = true; 2463 this.expand({ 2464 completeCallback() { 2465 // We have to do this in a "completeCallback" or else the elements will not yet be visible/tabbable. 2466 // The first one should be the close button, 2467 // we want to skip it and choose the second one instead, which is the search box. 2468 const searchBox = external_wp_dom_namespaceObject.focus.tabbable.find(contentContainer)[1]; 2469 if (searchBox) { 2470 searchBox.focus(); 2471 } 2472 } 2473 }); 2474 } 2475 } 2476 close() { 2477 if (this.expanded()) { 2478 const contentContainer = this.contentContainer[0]; 2479 const activeElement = contentContainer.ownerDocument.activeElement; 2480 this.isFromInternalAction = true; 2481 this.collapse({ 2482 completeCallback() { 2483 // Return back the focus when closing the inserter. 2484 // Only do this if the active element which triggers the action is inside the inserter, 2485 // (the close button for instance). In that case the focus will be lost. 2486 // Otherwise, we don't hijack the focus when the user is focusing on other elements 2487 // (like the quick inserter). 2488 if (contentContainer.contains(activeElement)) { 2489 // Return back the focus when closing the inserter. 2490 if (this.activeElementBeforeExpanded) { 2491 this.activeElementBeforeExpanded.focus(); 2492 } 2493 } 2494 } 2495 }); 2496 } 2497 } 2498 }; 2499 } 2500 2501 ;// ./node_modules/@wordpress/customize-widgets/build-module/controls/sidebar-control.js 2502 /** 2503 * WordPress dependencies 2504 */ 2505 2506 2507 /** 2508 * Internal dependencies 2509 */ 2510 2511 2512 2513 const getInserterId = controlId => `widgets-inserter-$controlId}`; 2514 function getSidebarControl() { 2515 const { 2516 wp: { 2517 customize 2518 } 2519 } = window; 2520 return class SidebarControl extends customize.Control { 2521 constructor(...args) { 2522 super(...args); 2523 this.subscribers = new Set(); 2524 } 2525 ready() { 2526 const InserterOuterSection = getInserterOuterSection(); 2527 this.inserter = new InserterOuterSection(getInserterId(this.id), {}); 2528 customize.section.add(this.inserter); 2529 this.sectionInstance = customize.section(this.section()); 2530 this.inspector = this.sectionInstance.inspector; 2531 this.sidebarAdapter = new SidebarAdapter(this.setting, customize); 2532 } 2533 subscribe(callback) { 2534 this.subscribers.add(callback); 2535 return () => { 2536 this.subscribers.delete(callback); 2537 }; 2538 } 2539 onChangeSectionExpanded(expanded, args) { 2540 if (!args.unchanged) { 2541 // Close the inserter when the section collapses. 2542 if (!expanded) { 2543 (0,external_wp_data_namespaceObject.dispatch)(store).setIsInserterOpened(false); 2544 } 2545 this.subscribers.forEach(subscriber => subscriber(expanded, args)); 2546 } 2547 } 2548 }; 2549 } 2550 2551 ;// ./node_modules/@wordpress/customize-widgets/build-module/filters/move-to-sidebar.js 2552 /** 2553 * WordPress dependencies 2554 */ 2555 2556 2557 2558 2559 2560 2561 /** 2562 * Internal dependencies 2563 */ 2564 2565 2566 2567 2568 2569 2570 const withMoveToSidebarToolbarItem = (0,external_wp_compose_namespaceObject.createHigherOrderComponent)(BlockEdit => props => { 2571 let widgetId = (0,external_wp_widgets_namespaceObject.getWidgetIdFromBlock)(props); 2572 const sidebarControls = useSidebarControls(); 2573 const activeSidebarControl = useActiveSidebarControl(); 2574 const hasMultipleSidebars = sidebarControls?.length > 1; 2575 const blockName = props.name; 2576 const clientId = props.clientId; 2577 const canInsertBlockInSidebar = (0,external_wp_data_namespaceObject.useSelect)(select => { 2578 // Use an empty string to represent the root block list, which 2579 // in the customizer editor represents a sidebar/widget area. 2580 return select(external_wp_blockEditor_namespaceObject.store).canInsertBlockType(blockName, ''); 2581 }, [blockName]); 2582 const block = (0,external_wp_data_namespaceObject.useSelect)(select => select(external_wp_blockEditor_namespaceObject.store).getBlock(clientId), [clientId]); 2583 const { 2584 removeBlock 2585 } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_blockEditor_namespaceObject.store); 2586 const [, focusWidget] = useFocusControl(); 2587 function moveToSidebar(sidebarControlId) { 2588 const newSidebarControl = sidebarControls.find(sidebarControl => sidebarControl.id === sidebarControlId); 2589 if (widgetId) { 2590 /** 2591 * If there's a widgetId, move it to the other sidebar. 2592 */ 2593 const oldSetting = activeSidebarControl.setting; 2594 const newSetting = newSidebarControl.setting; 2595 oldSetting(oldSetting().filter(id => id !== widgetId)); 2596 newSetting([...newSetting(), widgetId]); 2597 } else { 2598 /** 2599 * If there isn't a widgetId, it's most likely a inner block. 2600 * First, remove the block in the original sidebar, 2601 * then, create a new widget in the new sidebar and get back its widgetId. 2602 */ 2603 const sidebarAdapter = newSidebarControl.sidebarAdapter; 2604 removeBlock(clientId); 2605 const addedWidgetIds = sidebarAdapter.setWidgets([...sidebarAdapter.getWidgets(), blockToWidget(block)]); 2606 // The last non-null id is the added widget's id. 2607 widgetId = addedWidgetIds.reverse().find(id => !!id); 2608 } 2609 2610 // Move focus to the moved widget and expand the sidebar. 2611 focusWidget(widgetId); 2612 } 2613 return /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsxs)(external_ReactJSXRuntime_namespaceObject.Fragment, { 2614 children: [/*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(BlockEdit, { 2615 ...props 2616 }, "edit"), hasMultipleSidebars && canInsertBlockInSidebar && /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_blockEditor_namespaceObject.BlockControls, { 2617 children: /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_widgets_namespaceObject.MoveToWidgetArea, { 2618 widgetAreas: sidebarControls.map(sidebarControl => ({ 2619 id: sidebarControl.id, 2620 name: sidebarControl.params.label, 2621 description: sidebarControl.params.description 2622 })), 2623 currentWidgetAreaId: activeSidebarControl?.id, 2624 onSelect: moveToSidebar 2625 }) 2626 })] 2627 }); 2628 }, 'withMoveToSidebarToolbarItem'); 2629 (0,external_wp_hooks_namespaceObject.addFilter)('editor.BlockEdit', 'core/customize-widgets/block-edit', withMoveToSidebarToolbarItem); 2630 2631 ;// ./node_modules/@wordpress/customize-widgets/build-module/filters/replace-media-upload.js 2632 /** 2633 * WordPress dependencies 2634 */ 2635 2636 2637 const replaceMediaUpload = () => external_wp_mediaUtils_namespaceObject.MediaUpload; 2638 (0,external_wp_hooks_namespaceObject.addFilter)('editor.MediaUpload', 'core/edit-widgets/replace-media-upload', replaceMediaUpload); 2639 2640 ;// ./node_modules/@wordpress/customize-widgets/build-module/filters/wide-widget-display.js 2641 /** 2642 * WordPress dependencies 2643 */ 2644 2645 2646 2647 const { 2648 wp: wide_widget_display_wp 2649 } = window; 2650 const withWideWidgetDisplay = (0,external_wp_compose_namespaceObject.createHigherOrderComponent)(BlockEdit => props => { 2651 var _wp$customize$Widgets; 2652 const { 2653 idBase 2654 } = props.attributes; 2655 const isWide = (_wp$customize$Widgets = wide_widget_display_wp.customize.Widgets.data.availableWidgets.find(widget => widget.id_base === idBase)?.is_wide) !== null && _wp$customize$Widgets !== void 0 ? _wp$customize$Widgets : false; 2656 return /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(BlockEdit, { 2657 ...props, 2658 isWide: isWide 2659 }, "edit"); 2660 }, 'withWideWidgetDisplay'); 2661 (0,external_wp_hooks_namespaceObject.addFilter)('editor.BlockEdit', 'core/customize-widgets/wide-widget-display', withWideWidgetDisplay); 2662 2663 ;// ./node_modules/@wordpress/customize-widgets/build-module/filters/index.js 2664 /** 2665 * Internal dependencies 2666 */ 2667 2668 2669 2670 2671 ;// ./node_modules/@wordpress/customize-widgets/build-module/index.js 2672 /** 2673 * WordPress dependencies 2674 */ 2675 2676 2677 2678 2679 2680 2681 2682 /** 2683 * Internal dependencies 2684 */ 2685 2686 2687 2688 2689 2690 const { 2691 wp: build_module_wp 2692 } = window; 2693 const DISABLED_BLOCKS = ['core/more', 'core/block', 'core/freeform', 'core/template-part']; 2694 const ENABLE_EXPERIMENTAL_FSE_BLOCKS = false; 2695 2696 /** 2697 * Initializes the widgets block editor in the customizer. 2698 * 2699 * @param {string} editorName The editor name. 2700 * @param {Object} blockEditorSettings Block editor settings. 2701 */ 2702 function initialize(editorName, blockEditorSettings) { 2703 (0,external_wp_data_namespaceObject.dispatch)(external_wp_preferences_namespaceObject.store).setDefaults('core/customize-widgets', { 2704 fixedToolbar: false, 2705 welcomeGuide: true 2706 }); 2707 (0,external_wp_data_namespaceObject.dispatch)(external_wp_blocks_namespaceObject.store).reapplyBlockTypeFilters(); 2708 const coreBlocks = (0,external_wp_blockLibrary_namespaceObject.__experimentalGetCoreBlocks)().filter(block => { 2709 return !(DISABLED_BLOCKS.includes(block.name) || block.name.startsWith('core/post') || block.name.startsWith('core/query') || block.name.startsWith('core/site') || block.name.startsWith('core/navigation')); 2710 }); 2711 (0,external_wp_blockLibrary_namespaceObject.registerCoreBlocks)(coreBlocks); 2712 (0,external_wp_widgets_namespaceObject.registerLegacyWidgetBlock)(); 2713 if (false) {} 2714 (0,external_wp_widgets_namespaceObject.registerLegacyWidgetVariations)(blockEditorSettings); 2715 (0,external_wp_widgets_namespaceObject.registerWidgetGroupBlock)(); 2716 2717 // As we are unregistering `core/freeform` to avoid the Classic block, we must 2718 // replace it with something as the default freeform content handler. Failure to 2719 // do this will result in errors in the default block parser. 2720 // see: https://github.com/WordPress/gutenberg/issues/33097 2721 (0,external_wp_blocks_namespaceObject.setFreeformContentHandlerName)('core/html'); 2722 const SidebarControl = getSidebarControl(blockEditorSettings); 2723 build_module_wp.customize.sectionConstructor.sidebar = getSidebarSection(); 2724 build_module_wp.customize.controlConstructor.sidebar_block_editor = SidebarControl; 2725 const container = document.createElement('div'); 2726 document.body.appendChild(container); 2727 build_module_wp.customize.bind('ready', () => { 2728 const sidebarControls = []; 2729 build_module_wp.customize.control.each(control => { 2730 if (control instanceof SidebarControl) { 2731 sidebarControls.push(control); 2732 } 2733 }); 2734 (0,external_wp_element_namespaceObject.createRoot)(container).render( /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(external_wp_element_namespaceObject.StrictMode, { 2735 children: /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(CustomizeWidgets, { 2736 api: build_module_wp.customize, 2737 sidebarControls: sidebarControls, 2738 blockEditorSettings: blockEditorSettings 2739 }) 2740 })); 2741 }); 2742 } 2743 2744 2745 (window.wp = window.wp || {}).customizeWidgets = __webpack_exports__; 2746 /******/ })() 2747 ;
title
Description
Body
title
Description
Body
title
Description
Body
title
Body
Generated : Tue Jan 21 08:20:01 2025 | Cross-referenced by PHPXref |