[ Index ] |
PHP Cross Reference of WordPress |
[Summary view] [Print] [Text view]
1 /******/ (function() { // webpackBootstrap 2 /******/ var __webpack_modules__ = ({ 3 4 /***/ 4403: 5 /***/ (function(module, exports) { 6 7 var __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;/*! 8 Copyright (c) 2018 Jed Watson. 9 Licensed under the MIT License (MIT), see 10 http://jedwatson.github.io/classnames 11 */ 12 /* global define */ 13 14 (function () { 15 'use strict'; 16 17 var hasOwn = {}.hasOwnProperty; 18 19 function classNames() { 20 var classes = []; 21 22 for (var i = 0; i < arguments.length; i++) { 23 var arg = arguments[i]; 24 if (!arg) continue; 25 26 var argType = typeof arg; 27 28 if (argType === 'string' || argType === 'number') { 29 classes.push(arg); 30 } else if (Array.isArray(arg)) { 31 if (arg.length) { 32 var inner = classNames.apply(null, arg); 33 if (inner) { 34 classes.push(inner); 35 } 36 } 37 } else if (argType === 'object') { 38 if (arg.toString === Object.prototype.toString) { 39 for (var key in arg) { 40 if (hasOwn.call(arg, key) && arg[key]) { 41 classes.push(key); 42 } 43 } 44 } else { 45 classes.push(arg.toString()); 46 } 47 } 48 } 49 50 return classes.join(' '); 51 } 52 53 if ( true && module.exports) { 54 classNames.default = classNames; 55 module.exports = classNames; 56 } else if (true) { 57 // register as 'classnames', consistent with npm package name 58 !(__WEBPACK_AMD_DEFINE_ARRAY__ = [], __WEBPACK_AMD_DEFINE_RESULT__ = (function () { 59 return classNames; 60 }).apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__), 61 __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__)); 62 } else {} 63 }()); 64 65 66 /***/ }) 67 68 /******/ }); 69 /************************************************************************/ 70 /******/ // The module cache 71 /******/ var __webpack_module_cache__ = {}; 72 /******/ 73 /******/ // The require function 74 /******/ function __webpack_require__(moduleId) { 75 /******/ // Check if module is in cache 76 /******/ var cachedModule = __webpack_module_cache__[moduleId]; 77 /******/ if (cachedModule !== undefined) { 78 /******/ return cachedModule.exports; 79 /******/ } 80 /******/ // Create a new module (and put it into the cache) 81 /******/ var module = __webpack_module_cache__[moduleId] = { 82 /******/ // no module.id needed 83 /******/ // no module.loaded needed 84 /******/ exports: {} 85 /******/ }; 86 /******/ 87 /******/ // Execute the module function 88 /******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); 89 /******/ 90 /******/ // Return the exports of the module 91 /******/ return module.exports; 92 /******/ } 93 /******/ 94 /************************************************************************/ 95 /******/ /* webpack/runtime/compat get default export */ 96 /******/ !function() { 97 /******/ // getDefaultExport function for compatibility with non-harmony modules 98 /******/ __webpack_require__.n = function(module) { 99 /******/ var getter = module && module.__esModule ? 100 /******/ function() { return module['default']; } : 101 /******/ function() { return module; }; 102 /******/ __webpack_require__.d(getter, { a: getter }); 103 /******/ return getter; 104 /******/ }; 105 /******/ }(); 106 /******/ 107 /******/ /* webpack/runtime/define property getters */ 108 /******/ !function() { 109 /******/ // define getter functions for harmony exports 110 /******/ __webpack_require__.d = function(exports, definition) { 111 /******/ for(var key in definition) { 112 /******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { 113 /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); 114 /******/ } 115 /******/ } 116 /******/ }; 117 /******/ }(); 118 /******/ 119 /******/ /* webpack/runtime/hasOwnProperty shorthand */ 120 /******/ !function() { 121 /******/ __webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); } 122 /******/ }(); 123 /******/ 124 /******/ /* webpack/runtime/make namespace object */ 125 /******/ !function() { 126 /******/ // define __esModule on exports 127 /******/ __webpack_require__.r = function(exports) { 128 /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { 129 /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); 130 /******/ } 131 /******/ Object.defineProperty(exports, '__esModule', { value: true }); 132 /******/ }; 133 /******/ }(); 134 /******/ 135 /************************************************************************/ 136 var __webpack_exports__ = {}; 137 // This entry need to be wrapped in an IIFE because it need to be in strict mode. 138 !function() { 139 "use strict"; 140 // ESM COMPAT FLAG 141 __webpack_require__.r(__webpack_exports__); 142 143 // EXPORTS 144 __webpack_require__.d(__webpack_exports__, { 145 "PluginBlockSettingsMenuItem": function() { return /* reexport */ plugin_block_settings_menu_item; }, 146 "PluginDocumentSettingPanel": function() { return /* reexport */ plugin_document_setting_panel; }, 147 "PluginMoreMenuItem": function() { return /* reexport */ plugin_more_menu_item; }, 148 "PluginPostPublishPanel": function() { return /* reexport */ plugin_post_publish_panel; }, 149 "PluginPostStatusInfo": function() { return /* reexport */ plugin_post_status_info; }, 150 "PluginPrePublishPanel": function() { return /* reexport */ plugin_pre_publish_panel; }, 151 "PluginSidebar": function() { return /* reexport */ PluginSidebarEditPost; }, 152 "PluginSidebarMoreMenuItem": function() { return /* reexport */ PluginSidebarMoreMenuItem; }, 153 "__experimentalFullscreenModeClose": function() { return /* reexport */ fullscreen_mode_close; }, 154 "__experimentalMainDashboardButton": function() { return /* reexport */ main_dashboard_button; }, 155 "initializeEditor": function() { return /* binding */ initializeEditor; }, 156 "reinitializeEditor": function() { return /* binding */ reinitializeEditor; }, 157 "store": function() { return /* reexport */ store_store; } 158 }); 159 160 // NAMESPACE OBJECT: ./node_modules/@wordpress/interface/build-module/store/actions.js 161 var actions_namespaceObject = {}; 162 __webpack_require__.r(actions_namespaceObject); 163 __webpack_require__.d(actions_namespaceObject, { 164 "disableComplementaryArea": function() { return disableComplementaryArea; }, 165 "enableComplementaryArea": function() { return enableComplementaryArea; }, 166 "pinItem": function() { return pinItem; }, 167 "setFeatureDefaults": function() { return setFeatureDefaults; }, 168 "setFeatureValue": function() { return setFeatureValue; }, 169 "toggleFeature": function() { return toggleFeature; }, 170 "unpinItem": function() { return unpinItem; } 171 }); 172 173 // NAMESPACE OBJECT: ./node_modules/@wordpress/interface/build-module/store/selectors.js 174 var selectors_namespaceObject = {}; 175 __webpack_require__.r(selectors_namespaceObject); 176 __webpack_require__.d(selectors_namespaceObject, { 177 "getActiveComplementaryArea": function() { return getActiveComplementaryArea; }, 178 "isFeatureActive": function() { return isFeatureActive; }, 179 "isItemPinned": function() { return isItemPinned; } 180 }); 181 182 // NAMESPACE OBJECT: ./node_modules/@wordpress/edit-post/build-module/store/actions.js 183 var store_actions_namespaceObject = {}; 184 __webpack_require__.r(store_actions_namespaceObject); 185 __webpack_require__.d(store_actions_namespaceObject, { 186 "__experimentalSetPreviewDeviceType": function() { return __experimentalSetPreviewDeviceType; }, 187 "__unstableCreateTemplate": function() { return __unstableCreateTemplate; }, 188 "__unstableSwitchToTemplateMode": function() { return __unstableSwitchToTemplateMode; }, 189 "closeGeneralSidebar": function() { return closeGeneralSidebar; }, 190 "closeModal": function() { return closeModal; }, 191 "closePublishSidebar": function() { return closePublishSidebar; }, 192 "hideBlockTypes": function() { return hideBlockTypes; }, 193 "initializeMetaBoxes": function() { return initializeMetaBoxes; }, 194 "metaBoxUpdatesFailure": function() { return metaBoxUpdatesFailure; }, 195 "metaBoxUpdatesSuccess": function() { return metaBoxUpdatesSuccess; }, 196 "openGeneralSidebar": function() { return openGeneralSidebar; }, 197 "openModal": function() { return openModal; }, 198 "openPublishSidebar": function() { return openPublishSidebar; }, 199 "removeEditorPanel": function() { return removeEditorPanel; }, 200 "requestMetaBoxUpdates": function() { return requestMetaBoxUpdates; }, 201 "setAvailableMetaBoxesPerLocation": function() { return setAvailableMetaBoxesPerLocation; }, 202 "setIsEditingTemplate": function() { return setIsEditingTemplate; }, 203 "setIsInserterOpened": function() { return setIsInserterOpened; }, 204 "setIsListViewOpened": function() { return setIsListViewOpened; }, 205 "showBlockTypes": function() { return showBlockTypes; }, 206 "switchEditorMode": function() { return switchEditorMode; }, 207 "toggleEditorPanelEnabled": function() { return toggleEditorPanelEnabled; }, 208 "toggleEditorPanelOpened": function() { return toggleEditorPanelOpened; }, 209 "toggleFeature": function() { return actions_toggleFeature; }, 210 "togglePinnedPluginItem": function() { return togglePinnedPluginItem; }, 211 "togglePublishSidebar": function() { return togglePublishSidebar; }, 212 "updatePreferredStyleVariations": function() { return updatePreferredStyleVariations; } 213 }); 214 215 // NAMESPACE OBJECT: ./node_modules/@wordpress/edit-post/build-module/store/selectors.js 216 var store_selectors_namespaceObject = {}; 217 __webpack_require__.r(store_selectors_namespaceObject); 218 __webpack_require__.d(store_selectors_namespaceObject, { 219 "__experimentalGetInsertionPoint": function() { return __experimentalGetInsertionPoint; }, 220 "__experimentalGetPreviewDeviceType": function() { return __experimentalGetPreviewDeviceType; }, 221 "areMetaBoxesInitialized": function() { return areMetaBoxesInitialized; }, 222 "getActiveGeneralSidebarName": function() { return getActiveGeneralSidebarName; }, 223 "getActiveMetaBoxLocations": function() { return getActiveMetaBoxLocations; }, 224 "getAllMetaBoxes": function() { return getAllMetaBoxes; }, 225 "getEditedPostTemplate": function() { return getEditedPostTemplate; }, 226 "getEditorMode": function() { return getEditorMode; }, 227 "getHiddenBlockTypes": function() { return getHiddenBlockTypes; }, 228 "getMetaBoxesPerLocation": function() { return getMetaBoxesPerLocation; }, 229 "getPreference": function() { return getPreference; }, 230 "getPreferences": function() { return getPreferences; }, 231 "hasMetaBoxes": function() { return hasMetaBoxes; }, 232 "isEditingTemplate": function() { return selectors_isEditingTemplate; }, 233 "isEditorPanelEnabled": function() { return isEditorPanelEnabled; }, 234 "isEditorPanelOpened": function() { return isEditorPanelOpened; }, 235 "isEditorPanelRemoved": function() { return isEditorPanelRemoved; }, 236 "isEditorSidebarOpened": function() { return isEditorSidebarOpened; }, 237 "isFeatureActive": function() { return selectors_isFeatureActive; }, 238 "isInserterOpened": function() { return isInserterOpened; }, 239 "isListViewOpened": function() { return isListViewOpened; }, 240 "isMetaBoxLocationActive": function() { return isMetaBoxLocationActive; }, 241 "isMetaBoxLocationVisible": function() { return isMetaBoxLocationVisible; }, 242 "isModalActive": function() { return isModalActive; }, 243 "isPluginItemPinned": function() { return isPluginItemPinned; }, 244 "isPluginSidebarOpened": function() { return isPluginSidebarOpened; }, 245 "isPublishSidebarOpened": function() { return isPublishSidebarOpened; }, 246 "isSavingMetaBoxes": function() { return selectors_isSavingMetaBoxes; } 247 }); 248 249 ;// CONCATENATED MODULE: external ["wp","element"] 250 var external_wp_element_namespaceObject = window["wp"]["element"]; 251 ;// CONCATENATED MODULE: external ["wp","blocks"] 252 var external_wp_blocks_namespaceObject = window["wp"]["blocks"]; 253 ;// CONCATENATED MODULE: external ["wp","blockLibrary"] 254 var external_wp_blockLibrary_namespaceObject = window["wp"]["blockLibrary"]; 255 ;// CONCATENATED MODULE: external ["wp","data"] 256 var external_wp_data_namespaceObject = window["wp"]["data"]; 257 ;// CONCATENATED MODULE: external ["wp","hooks"] 258 var external_wp_hooks_namespaceObject = window["wp"]["hooks"]; 259 ;// CONCATENATED MODULE: external ["wp","preferences"] 260 var external_wp_preferences_namespaceObject = window["wp"]["preferences"]; 261 ;// CONCATENATED MODULE: external ["wp","mediaUtils"] 262 var external_wp_mediaUtils_namespaceObject = window["wp"]["mediaUtils"]; 263 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/hooks/components/index.js 264 /** 265 * WordPress dependencies 266 */ 267 268 269 270 const replaceMediaUpload = () => external_wp_mediaUtils_namespaceObject.MediaUpload; 271 272 (0,external_wp_hooks_namespaceObject.addFilter)('editor.MediaUpload', 'core/edit-post/replace-media-upload', replaceMediaUpload); 273 274 ;// CONCATENATED MODULE: ./node_modules/@babel/runtime/helpers/esm/extends.js 275 function _extends() { 276 _extends = Object.assign || function (target) { 277 for (var i = 1; i < arguments.length; i++) { 278 var source = arguments[i]; 279 280 for (var key in source) { 281 if (Object.prototype.hasOwnProperty.call(source, key)) { 282 target[key] = source[key]; 283 } 284 } 285 } 286 287 return target; 288 }; 289 290 return _extends.apply(this, arguments); 291 } 292 ;// CONCATENATED MODULE: external "lodash" 293 var external_lodash_namespaceObject = window["lodash"]; 294 ;// CONCATENATED MODULE: external ["wp","components"] 295 var external_wp_components_namespaceObject = window["wp"]["components"]; 296 ;// CONCATENATED MODULE: external ["wp","blockEditor"] 297 var external_wp_blockEditor_namespaceObject = window["wp"]["blockEditor"]; 298 ;// CONCATENATED MODULE: external ["wp","i18n"] 299 var external_wp_i18n_namespaceObject = window["wp"]["i18n"]; 300 ;// CONCATENATED MODULE: external ["wp","compose"] 301 var external_wp_compose_namespaceObject = window["wp"]["compose"]; 302 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/hooks/validate-multiple-use/index.js 303 304 305 306 /** 307 * External dependencies 308 */ 309 310 /** 311 * WordPress dependencies 312 */ 313 314 315 316 317 318 319 320 321 const enhance = (0,external_wp_compose_namespaceObject.compose)( 322 /** 323 * For blocks whose block type doesn't support `multiple`, provides the 324 * wrapped component with `originalBlockClientId` -- a reference to the 325 * first block of the same type in the content -- if and only if that 326 * "original" block is not the current one. Thus, an inexisting 327 * `originalBlockClientId` prop signals that the block is valid. 328 * 329 * @param {WPComponent} WrappedBlockEdit A filtered BlockEdit instance. 330 * 331 * @return {WPComponent} Enhanced component with merged state data props. 332 */ 333 (0,external_wp_data_namespaceObject.withSelect)((select, block) => { 334 const multiple = (0,external_wp_blocks_namespaceObject.hasBlockSupport)(block.name, 'multiple', true); // For block types with `multiple` support, there is no "original 335 // block" to be found in the content, as the block itself is valid. 336 337 if (multiple) { 338 return {}; 339 } // Otherwise, only pass `originalBlockClientId` if it refers to a different 340 // block from the current one. 341 342 343 const blocks = select(external_wp_blockEditor_namespaceObject.store).getBlocks(); 344 const firstOfSameType = (0,external_lodash_namespaceObject.find)(blocks, _ref => { 345 let { 346 name 347 } = _ref; 348 return block.name === name; 349 }); 350 const isInvalid = firstOfSameType && firstOfSameType.clientId !== block.clientId; 351 return { 352 originalBlockClientId: isInvalid && firstOfSameType.clientId 353 }; 354 }), (0,external_wp_data_namespaceObject.withDispatch)((dispatch, _ref2) => { 355 let { 356 originalBlockClientId 357 } = _ref2; 358 return { 359 selectFirst: () => dispatch(external_wp_blockEditor_namespaceObject.store).selectBlock(originalBlockClientId) 360 }; 361 })); 362 const withMultipleValidation = (0,external_wp_compose_namespaceObject.createHigherOrderComponent)(BlockEdit => { 363 return enhance(_ref3 => { 364 let { 365 originalBlockClientId, 366 selectFirst, 367 ...props 368 } = _ref3; 369 370 if (!originalBlockClientId) { 371 return (0,external_wp_element_namespaceObject.createElement)(BlockEdit, props); 372 } 373 374 const blockType = (0,external_wp_blocks_namespaceObject.getBlockType)(props.name); 375 const outboundType = getOutboundType(props.name); 376 return [(0,external_wp_element_namespaceObject.createElement)("div", { 377 key: "invalid-preview", 378 style: { 379 minHeight: '60px' 380 } 381 }, (0,external_wp_element_namespaceObject.createElement)(BlockEdit, _extends({ 382 key: "block-edit" 383 }, props))), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.Warning, { 384 key: "multiple-use-warning", 385 actions: [(0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 386 key: "find-original", 387 variant: "secondary", 388 onClick: selectFirst 389 }, (0,external_wp_i18n_namespaceObject.__)('Find original')), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 390 key: "remove", 391 variant: "secondary", 392 onClick: () => props.onReplace([]) 393 }, (0,external_wp_i18n_namespaceObject.__)('Remove')), outboundType && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 394 key: "transform", 395 variant: "secondary", 396 onClick: () => props.onReplace((0,external_wp_blocks_namespaceObject.createBlock)(outboundType.name, props.attributes)) 397 }, (0,external_wp_i18n_namespaceObject.__)('Transform into:'), " ", outboundType.title)] 398 }, (0,external_wp_element_namespaceObject.createElement)("strong", null, blockType === null || blockType === void 0 ? void 0 : blockType.title, ": "), (0,external_wp_i18n_namespaceObject.__)('This block can only be used once.'))]; 399 }); 400 }, 'withMultipleValidation'); 401 /** 402 * Given a base block name, returns the default block type to which to offer 403 * transforms. 404 * 405 * @param {string} blockName Base block name. 406 * 407 * @return {?Object} The chosen default block type. 408 */ 409 410 function getOutboundType(blockName) { 411 // Grab the first outbound transform. 412 const transform = (0,external_wp_blocks_namespaceObject.findTransform)((0,external_wp_blocks_namespaceObject.getBlockTransforms)('to', blockName), _ref4 => { 413 let { 414 type, 415 blocks 416 } = _ref4; 417 return type === 'block' && blocks.length === 1; 418 } // What about when .length > 1? 419 ); 420 421 if (!transform) { 422 return null; 423 } 424 425 return (0,external_wp_blocks_namespaceObject.getBlockType)(transform.blocks[0]); 426 } 427 428 (0,external_wp_hooks_namespaceObject.addFilter)('editor.BlockEdit', 'core/edit-post/validate-multiple-use/with-multiple-validation', withMultipleValidation); 429 430 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/hooks/index.js 431 /** 432 * Internal dependencies 433 */ 434 435 436 437 ;// CONCATENATED MODULE: external ["wp","primitives"] 438 var external_wp_primitives_namespaceObject = window["wp"]["primitives"]; 439 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/external.js 440 441 442 /** 443 * WordPress dependencies 444 */ 445 446 const external = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 447 xmlns: "http://www.w3.org/2000/svg", 448 viewBox: "0 0 24 24" 449 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 450 d: "M18.2 17c0 .7-.6 1.2-1.2 1.2H7c-.7 0-1.2-.6-1.2-1.2V7c0-.7.6-1.2 1.2-1.2h3.2V4.2H7C5.5 4.2 4.2 5.5 4.2 7v10c0 1.5 1.2 2.8 2.8 2.8h10c1.5 0 2.8-1.2 2.8-2.8v-3.6h-1.5V17zM14.9 3v1.5h3.7l-6.4 6.4 1.1 1.1 6.4-6.4v3.7h1.5V3h-6.3z" 451 })); 452 /* harmony default export */ var library_external = (external); 453 454 ;// CONCATENATED MODULE: external ["wp","plugins"] 455 var external_wp_plugins_namespaceObject = window["wp"]["plugins"]; 456 ;// CONCATENATED MODULE: external ["wp","url"] 457 var external_wp_url_namespaceObject = window["wp"]["url"]; 458 ;// CONCATENATED MODULE: external ["wp","notices"] 459 var external_wp_notices_namespaceObject = window["wp"]["notices"]; 460 ;// CONCATENATED MODULE: external ["wp","editor"] 461 var external_wp_editor_namespaceObject = window["wp"]["editor"]; 462 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/plugins/copy-content-menu-item/index.js 463 464 465 /** 466 * WordPress dependencies 467 */ 468 469 470 471 472 473 474 function CopyContentMenuItem() { 475 const { 476 createNotice 477 } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_notices_namespaceObject.store); 478 const getText = (0,external_wp_data_namespaceObject.useSelect)(select => () => select(external_wp_editor_namespaceObject.store).getEditedPostAttribute('content'), []); 479 480 function onSuccess() { 481 createNotice('info', (0,external_wp_i18n_namespaceObject.__)('All content copied.'), { 482 isDismissible: true, 483 type: 'snackbar' 484 }); 485 } 486 487 const ref = (0,external_wp_compose_namespaceObject.useCopyToClipboard)(getText, onSuccess); 488 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, { 489 ref: ref 490 }, (0,external_wp_i18n_namespaceObject.__)('Copy all content')); 491 } 492 493 ;// CONCATENATED MODULE: external ["wp","keycodes"] 494 var external_wp_keycodes_namespaceObject = window["wp"]["keycodes"]; 495 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/store/reducer.js 496 /** 497 * External dependencies 498 */ 499 500 /** 501 * WordPress dependencies 502 */ 503 504 505 /** 506 * Reducer storing the list of all programmatically removed panels. 507 * 508 * @param {Array} state Current state. 509 * @param {Object} action Action object. 510 * 511 * @return {Array} Updated state. 512 */ 513 514 function removedPanels() { 515 let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : []; 516 let action = arguments.length > 1 ? arguments[1] : undefined; 517 518 switch (action.type) { 519 case 'REMOVE_PANEL': 520 if (!(0,external_lodash_namespaceObject.includes)(state, action.panelName)) { 521 return [...state, action.panelName]; 522 } 523 524 } 525 526 return state; 527 } 528 /** 529 * Reducer for storing the name of the open modal, or null if no modal is open. 530 * 531 * @param {Object} state Previous state. 532 * @param {Object} action Action object containing the `name` of the modal 533 * 534 * @return {Object} Updated state 535 */ 536 537 function activeModal() { 538 let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null; 539 let action = arguments.length > 1 ? arguments[1] : undefined; 540 541 switch (action.type) { 542 case 'OPEN_MODAL': 543 return action.name; 544 545 case 'CLOSE_MODAL': 546 return null; 547 } 548 549 return state; 550 } 551 function publishSidebarActive() { 552 let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false; 553 let action = arguments.length > 1 ? arguments[1] : undefined; 554 555 switch (action.type) { 556 case 'OPEN_PUBLISH_SIDEBAR': 557 return true; 558 559 case 'CLOSE_PUBLISH_SIDEBAR': 560 return false; 561 562 case 'TOGGLE_PUBLISH_SIDEBAR': 563 return !state; 564 } 565 566 return state; 567 } 568 /** 569 * Reducer keeping track of the meta boxes isSaving state. 570 * A "true" value means the meta boxes saving request is in-flight. 571 * 572 * 573 * @param {boolean} state Previous state. 574 * @param {Object} action Action Object. 575 * 576 * @return {Object} Updated state. 577 */ 578 579 function isSavingMetaBoxes() { 580 let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false; 581 let action = arguments.length > 1 ? arguments[1] : undefined; 582 583 switch (action.type) { 584 case 'REQUEST_META_BOX_UPDATES': 585 return true; 586 587 case 'META_BOX_UPDATES_SUCCESS': 588 case 'META_BOX_UPDATES_FAILURE': 589 return false; 590 591 default: 592 return state; 593 } 594 } 595 /** 596 * Reducer keeping track of the meta boxes per location. 597 * 598 * @param {boolean} state Previous state. 599 * @param {Object} action Action Object. 600 * 601 * @return {Object} Updated state. 602 */ 603 604 function metaBoxLocations() { 605 let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; 606 let action = arguments.length > 1 ? arguments[1] : undefined; 607 608 switch (action.type) { 609 case 'SET_META_BOXES_PER_LOCATIONS': 610 return action.metaBoxesPerLocation; 611 } 612 613 return state; 614 } 615 /** 616 * Reducer returning the editing canvas device type. 617 * 618 * @param {Object} state Current state. 619 * @param {Object} action Dispatched action. 620 * 621 * @return {Object} Updated state. 622 */ 623 624 function deviceType() { 625 let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'Desktop'; 626 let action = arguments.length > 1 ? arguments[1] : undefined; 627 628 switch (action.type) { 629 case 'SET_PREVIEW_DEVICE_TYPE': 630 return action.deviceType; 631 } 632 633 return state; 634 } 635 /** 636 * Reducer to set the block inserter panel open or closed. 637 * 638 * Note: this reducer interacts with the list view panel reducer 639 * to make sure that only one of the two panels is open at the same time. 640 * 641 * @param {Object} state Current state. 642 * @param {Object} action Dispatched action. 643 */ 644 645 function blockInserterPanel() { 646 let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false; 647 let action = arguments.length > 1 ? arguments[1] : undefined; 648 649 switch (action.type) { 650 case 'SET_IS_LIST_VIEW_OPENED': 651 return action.isOpen ? false : state; 652 653 case 'SET_IS_INSERTER_OPENED': 654 return action.value; 655 } 656 657 return state; 658 } 659 /** 660 * Reducer to set the list view panel open or closed. 661 * 662 * Note: this reducer interacts with the inserter panel reducer 663 * to make sure that only one of the two panels is open at the same time. 664 * 665 * @param {Object} state Current state. 666 * @param {Object} action Dispatched action. 667 */ 668 669 function listViewPanel() { 670 let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false; 671 let action = arguments.length > 1 ? arguments[1] : undefined; 672 673 switch (action.type) { 674 case 'SET_IS_INSERTER_OPENED': 675 return action.value ? false : state; 676 677 case 'SET_IS_LIST_VIEW_OPENED': 678 return action.isOpen; 679 } 680 681 return state; 682 } 683 /** 684 * Reducer tracking whether the inserter is open. 685 * 686 * @param {boolean} state 687 * @param {Object} action 688 */ 689 690 function isEditingTemplate() { 691 let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false; 692 let action = arguments.length > 1 ? arguments[1] : undefined; 693 694 switch (action.type) { 695 case 'SET_IS_EDITING_TEMPLATE': 696 return action.value; 697 } 698 699 return state; 700 } 701 /** 702 * Reducer tracking whether meta boxes are initialized. 703 * 704 * @param {boolean} state 705 * @param {Object} action 706 * 707 * @return {boolean} Updated state. 708 */ 709 710 711 function metaBoxesInitialized() { 712 let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false; 713 let action = arguments.length > 1 ? arguments[1] : undefined; 714 715 switch (action.type) { 716 case 'META_BOXES_INITIALIZED': 717 return true; 718 } 719 720 return state; 721 } 722 723 const metaBoxes = (0,external_wp_data_namespaceObject.combineReducers)({ 724 isSaving: isSavingMetaBoxes, 725 locations: metaBoxLocations, 726 initialized: metaBoxesInitialized 727 }); 728 /* harmony default export */ var reducer = ((0,external_wp_data_namespaceObject.combineReducers)({ 729 activeModal, 730 metaBoxes, 731 publishSidebarActive, 732 removedPanels, 733 deviceType, 734 blockInserterPanel, 735 listViewPanel, 736 isEditingTemplate 737 })); 738 739 ;// CONCATENATED MODULE: external ["wp","apiFetch"] 740 var external_wp_apiFetch_namespaceObject = window["wp"]["apiFetch"]; 741 var external_wp_apiFetch_default = /*#__PURE__*/__webpack_require__.n(external_wp_apiFetch_namespaceObject); 742 // EXTERNAL MODULE: ./node_modules/classnames/index.js 743 var classnames = __webpack_require__(4403); 744 var classnames_default = /*#__PURE__*/__webpack_require__.n(classnames); 745 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/check.js 746 747 748 /** 749 * WordPress dependencies 750 */ 751 752 const check = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 753 xmlns: "http://www.w3.org/2000/svg", 754 viewBox: "0 0 24 24" 755 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 756 d: "M16.7 7.1l-6.3 8.5-3.3-2.5-.9 1.2 4.5 3.4L17.9 8z" 757 })); 758 /* harmony default export */ var library_check = (check); 759 760 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/star-filled.js 761 762 763 /** 764 * WordPress dependencies 765 */ 766 767 const starFilled = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 768 xmlns: "http://www.w3.org/2000/svg", 769 viewBox: "0 0 24 24" 770 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 771 d: "M11.776 4.454a.25.25 0 01.448 0l2.069 4.192a.25.25 0 00.188.137l4.626.672a.25.25 0 01.139.426l-3.348 3.263a.25.25 0 00-.072.222l.79 4.607a.25.25 0 01-.362.263l-4.138-2.175a.25.25 0 00-.232 0l-4.138 2.175a.25.25 0 01-.363-.263l.79-4.607a.25.25 0 00-.071-.222L4.754 9.881a.25.25 0 01.139-.426l4.626-.672a.25.25 0 00.188-.137l2.069-4.192z" 772 })); 773 /* harmony default export */ var star_filled = (starFilled); 774 775 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/star-empty.js 776 777 778 /** 779 * WordPress dependencies 780 */ 781 782 const starEmpty = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 783 xmlns: "http://www.w3.org/2000/svg", 784 viewBox: "0 0 24 24" 785 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 786 fillRule: "evenodd", 787 d: "M9.706 8.646a.25.25 0 01-.188.137l-4.626.672a.25.25 0 00-.139.427l3.348 3.262a.25.25 0 01.072.222l-.79 4.607a.25.25 0 00.362.264l4.138-2.176a.25.25 0 01.233 0l4.137 2.175a.25.25 0 00.363-.263l-.79-4.607a.25.25 0 01.072-.222l3.347-3.262a.25.25 0 00-.139-.427l-4.626-.672a.25.25 0 01-.188-.137l-2.069-4.192a.25.25 0 00-.448 0L9.706 8.646zM12 7.39l-.948 1.921a1.75 1.75 0 01-1.317.957l-2.12.308 1.534 1.495c.412.402.6.982.503 1.55l-.362 2.11 1.896-.997a1.75 1.75 0 011.629 0l1.895.997-.362-2.11a1.75 1.75 0 01.504-1.55l1.533-1.495-2.12-.308a1.75 1.75 0 01-1.317-.957L12 7.39z", 788 clipRule: "evenodd" 789 })); 790 /* harmony default export */ var star_empty = (starEmpty); 791 792 ;// CONCATENATED MODULE: external ["wp","viewport"] 793 var external_wp_viewport_namespaceObject = window["wp"]["viewport"]; 794 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/close-small.js 795 796 797 /** 798 * WordPress dependencies 799 */ 800 801 const closeSmall = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 802 xmlns: "http://www.w3.org/2000/svg", 803 viewBox: "0 0 24 24" 804 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 805 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" 806 })); 807 /* harmony default export */ var close_small = (closeSmall); 808 809 ;// CONCATENATED MODULE: external ["wp","deprecated"] 810 var external_wp_deprecated_namespaceObject = window["wp"]["deprecated"]; 811 var external_wp_deprecated_default = /*#__PURE__*/__webpack_require__.n(external_wp_deprecated_namespaceObject); 812 ;// CONCATENATED MODULE: ./node_modules/@wordpress/interface/build-module/store/actions.js 813 /** 814 * WordPress dependencies 815 */ 816 817 818 /** 819 * Enable the complementary area. 820 * 821 * @param {string} scope Complementary area scope. 822 * @param {string} area Area identifier. 823 */ 824 825 const enableComplementaryArea = (scope, area) => _ref => { 826 let { 827 registry 828 } = _ref; 829 830 // Return early if there's no area. 831 if (!area) { 832 return; 833 } 834 835 registry.dispatch(external_wp_preferences_namespaceObject.store).set(scope, 'complementaryArea', area); 836 }; 837 /** 838 * Disable the complementary area. 839 * 840 * @param {string} scope Complementary area scope. 841 */ 842 843 const disableComplementaryArea = scope => _ref2 => { 844 let { 845 registry 846 } = _ref2; 847 registry.dispatch(external_wp_preferences_namespaceObject.store).set(scope, 'complementaryArea', null); 848 }; 849 /** 850 * Pins an item. 851 * 852 * @param {string} scope Item scope. 853 * @param {string} item Item identifier. 854 * 855 * @return {Object} Action object. 856 */ 857 858 const pinItem = (scope, item) => _ref3 => { 859 let { 860 registry 861 } = _ref3; 862 863 // Return early if there's no item. 864 if (!item) { 865 return; 866 } 867 868 const pinnedItems = registry.select(external_wp_preferences_namespaceObject.store).get(scope, 'pinnedItems'); // The item is already pinned, there's nothing to do. 869 870 if ((pinnedItems === null || pinnedItems === void 0 ? void 0 : pinnedItems[item]) === true) { 871 return; 872 } 873 874 registry.dispatch(external_wp_preferences_namespaceObject.store).set(scope, 'pinnedItems', { ...pinnedItems, 875 [item]: true 876 }); 877 }; 878 /** 879 * Unpins an item. 880 * 881 * @param {string} scope Item scope. 882 * @param {string} item Item identifier. 883 */ 884 885 const unpinItem = (scope, item) => _ref4 => { 886 let { 887 registry 888 } = _ref4; 889 890 // Return early if there's no item. 891 if (!item) { 892 return; 893 } 894 895 const pinnedItems = registry.select(external_wp_preferences_namespaceObject.store).get(scope, 'pinnedItems'); 896 registry.dispatch(external_wp_preferences_namespaceObject.store).set(scope, 'pinnedItems', { ...pinnedItems, 897 [item]: false 898 }); 899 }; 900 /** 901 * Returns an action object used in signalling that a feature should be toggled. 902 * 903 * @param {string} scope The feature scope (e.g. core/edit-post). 904 * @param {string} featureName The feature name. 905 */ 906 907 function toggleFeature(scope, featureName) { 908 return function (_ref5) { 909 let { 910 registry 911 } = _ref5; 912 external_wp_deprecated_default()(`wp.dispatch( 'core/interface' ).toggleFeature`, { 913 since: '6.0', 914 alternative: `wp.dispatch( 'core/preferences' ).toggle` 915 }); 916 registry.dispatch(external_wp_preferences_namespaceObject.store).toggle(scope, featureName); 917 }; 918 } 919 /** 920 * Returns an action object used in signalling that a feature should be set to 921 * a true or false value 922 * 923 * @param {string} scope The feature scope (e.g. core/edit-post). 924 * @param {string} featureName The feature name. 925 * @param {boolean} value The value to set. 926 * 927 * @return {Object} Action object. 928 */ 929 930 function setFeatureValue(scope, featureName, value) { 931 return function (_ref6) { 932 let { 933 registry 934 } = _ref6; 935 external_wp_deprecated_default()(`wp.dispatch( 'core/interface' ).setFeatureValue`, { 936 since: '6.0', 937 alternative: `wp.dispatch( 'core/preferences' ).set` 938 }); 939 registry.dispatch(external_wp_preferences_namespaceObject.store).set(scope, featureName, !!value); 940 }; 941 } 942 /** 943 * Returns an action object used in signalling that defaults should be set for features. 944 * 945 * @param {string} scope The feature scope (e.g. core/edit-post). 946 * @param {Object<string, boolean>} defaults A key/value map of feature names to values. 947 * 948 * @return {Object} Action object. 949 */ 950 951 function setFeatureDefaults(scope, defaults) { 952 return function (_ref7) { 953 let { 954 registry 955 } = _ref7; 956 external_wp_deprecated_default()(`wp.dispatch( 'core/interface' ).setFeatureDefaults`, { 957 since: '6.0', 958 alternative: `wp.dispatch( 'core/preferences' ).setDefaults` 959 }); 960 registry.dispatch(external_wp_preferences_namespaceObject.store).setDefaults(scope, defaults); 961 }; 962 } 963 964 ;// CONCATENATED MODULE: ./node_modules/@wordpress/interface/build-module/store/selectors.js 965 /** 966 * WordPress dependencies 967 */ 968 969 970 971 /** 972 * Returns the complementary area that is active in a given scope. 973 * 974 * @param {Object} state Global application state. 975 * @param {string} scope Item scope. 976 * 977 * @return {string} The complementary area that is active in the given scope. 978 */ 979 980 const getActiveComplementaryArea = (0,external_wp_data_namespaceObject.createRegistrySelector)(select => (state, scope) => { 981 return select(external_wp_preferences_namespaceObject.store).get(scope, 'complementaryArea'); 982 }); 983 /** 984 * Returns a boolean indicating if an item is pinned or not. 985 * 986 * @param {Object} state Global application state. 987 * @param {string} scope Scope. 988 * @param {string} item Item to check. 989 * 990 * @return {boolean} True if the item is pinned and false otherwise. 991 */ 992 993 const isItemPinned = (0,external_wp_data_namespaceObject.createRegistrySelector)(select => (state, scope, item) => { 994 var _pinnedItems$item; 995 996 const pinnedItems = select(external_wp_preferences_namespaceObject.store).get(scope, 'pinnedItems'); 997 return (_pinnedItems$item = pinnedItems === null || pinnedItems === void 0 ? void 0 : pinnedItems[item]) !== null && _pinnedItems$item !== void 0 ? _pinnedItems$item : true; 998 }); 999 /** 1000 * Returns a boolean indicating whether a feature is active for a particular 1001 * scope. 1002 * 1003 * @param {Object} state The store state. 1004 * @param {string} scope The scope of the feature (e.g. core/edit-post). 1005 * @param {string} featureName The name of the feature. 1006 * 1007 * @return {boolean} Is the feature enabled? 1008 */ 1009 1010 const isFeatureActive = (0,external_wp_data_namespaceObject.createRegistrySelector)(select => (state, scope, featureName) => { 1011 external_wp_deprecated_default()(`wp.select( 'core/interface' ).isFeatureActive( scope, featureName )`, { 1012 since: '6.0', 1013 alternative: `!! wp.select( 'core/preferences' ).isFeatureActive( scope, featureName )` 1014 }); 1015 return !!select(external_wp_preferences_namespaceObject.store).get(scope, featureName); 1016 }); 1017 1018 ;// CONCATENATED MODULE: ./node_modules/@wordpress/interface/build-module/store/constants.js 1019 /** 1020 * The identifier for the data store. 1021 * 1022 * @type {string} 1023 */ 1024 const STORE_NAME = 'core/interface'; 1025 1026 ;// CONCATENATED MODULE: ./node_modules/@wordpress/interface/build-module/store/index.js 1027 /** 1028 * WordPress dependencies 1029 */ 1030 1031 /** 1032 * Internal dependencies 1033 */ 1034 1035 1036 1037 1038 /** 1039 * Store definition for the interface namespace. 1040 * 1041 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/data/README.md#createReduxStore 1042 * 1043 * @type {Object} 1044 */ 1045 1046 const store = (0,external_wp_data_namespaceObject.createReduxStore)(STORE_NAME, { 1047 reducer: () => {}, 1048 actions: actions_namespaceObject, 1049 selectors: selectors_namespaceObject 1050 }); // Once we build a more generic persistence plugin that works across types of stores 1051 // we'd be able to replace this with a register call. 1052 1053 (0,external_wp_data_namespaceObject.register)(store); 1054 1055 ;// CONCATENATED MODULE: ./node_modules/@wordpress/interface/build-module/components/complementary-area-context/index.js 1056 /** 1057 * WordPress dependencies 1058 */ 1059 1060 /* harmony default export */ var complementary_area_context = ((0,external_wp_plugins_namespaceObject.withPluginContext)((context, ownProps) => { 1061 return { 1062 icon: ownProps.icon || context.icon, 1063 identifier: ownProps.identifier || `$context.name}/$ownProps.name}` 1064 }; 1065 })); 1066 1067 ;// CONCATENATED MODULE: ./node_modules/@wordpress/interface/build-module/components/complementary-area-toggle/index.js 1068 1069 1070 1071 /** 1072 * External dependencies 1073 */ 1074 1075 /** 1076 * WordPress dependencies 1077 */ 1078 1079 1080 1081 /** 1082 * Internal dependencies 1083 */ 1084 1085 1086 1087 1088 function ComplementaryAreaToggle(_ref) { 1089 let { 1090 as = external_wp_components_namespaceObject.Button, 1091 scope, 1092 identifier, 1093 icon, 1094 selectedIcon, 1095 ...props 1096 } = _ref; 1097 const ComponentToUse = as; 1098 const isSelected = (0,external_wp_data_namespaceObject.useSelect)(select => select(store).getActiveComplementaryArea(scope) === identifier, [identifier]); 1099 const { 1100 enableComplementaryArea, 1101 disableComplementaryArea 1102 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 1103 return (0,external_wp_element_namespaceObject.createElement)(ComponentToUse, _extends({ 1104 icon: selectedIcon && isSelected ? selectedIcon : icon, 1105 onClick: () => { 1106 if (isSelected) { 1107 disableComplementaryArea(scope); 1108 } else { 1109 enableComplementaryArea(scope, identifier); 1110 } 1111 } 1112 }, (0,external_lodash_namespaceObject.omit)(props, ['name']))); 1113 } 1114 1115 /* harmony default export */ var complementary_area_toggle = (complementary_area_context(ComplementaryAreaToggle)); 1116 1117 ;// CONCATENATED MODULE: ./node_modules/@wordpress/interface/build-module/components/complementary-area-header/index.js 1118 1119 1120 1121 /** 1122 * External dependencies 1123 */ 1124 1125 /** 1126 * WordPress dependencies 1127 */ 1128 1129 1130 /** 1131 * Internal dependencies 1132 */ 1133 1134 1135 1136 const ComplementaryAreaHeader = _ref => { 1137 let { 1138 smallScreenTitle, 1139 children, 1140 className, 1141 toggleButtonProps 1142 } = _ref; 1143 const toggleButton = (0,external_wp_element_namespaceObject.createElement)(complementary_area_toggle, _extends({ 1144 icon: close_small 1145 }, toggleButtonProps)); 1146 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("div", { 1147 className: "components-panel__header interface-complementary-area-header__small" 1148 }, smallScreenTitle && (0,external_wp_element_namespaceObject.createElement)("span", { 1149 className: "interface-complementary-area-header__small-title" 1150 }, smallScreenTitle), toggleButton), (0,external_wp_element_namespaceObject.createElement)("div", { 1151 className: classnames_default()('components-panel__header', 'interface-complementary-area-header', className), 1152 tabIndex: -1 1153 }, children, toggleButton)); 1154 }; 1155 1156 /* harmony default export */ var complementary_area_header = (ComplementaryAreaHeader); 1157 1158 ;// CONCATENATED MODULE: ./node_modules/@wordpress/interface/build-module/components/action-item/index.js 1159 1160 1161 1162 /** 1163 * External dependencies 1164 */ 1165 1166 /** 1167 * WordPress dependencies 1168 */ 1169 1170 1171 1172 1173 function ActionItemSlot(_ref) { 1174 let { 1175 name, 1176 as: Component = external_wp_components_namespaceObject.ButtonGroup, 1177 fillProps = {}, 1178 bubblesVirtually, 1179 ...props 1180 } = _ref; 1181 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Slot, { 1182 name: name, 1183 bubblesVirtually: bubblesVirtually, 1184 fillProps: fillProps 1185 }, fills => { 1186 if ((0,external_lodash_namespaceObject.isEmpty)(external_wp_element_namespaceObject.Children.toArray(fills))) { 1187 return null; 1188 } // Special handling exists for backward compatibility. 1189 // It ensures that menu items created by plugin authors aren't 1190 // duplicated with automatically injected menu items coming 1191 // from pinnable plugin sidebars. 1192 // @see https://github.com/WordPress/gutenberg/issues/14457 1193 1194 1195 const initializedByPlugins = []; 1196 external_wp_element_namespaceObject.Children.forEach(fills, _ref2 => { 1197 let { 1198 props: { 1199 __unstableExplicitMenuItem, 1200 __unstableTarget 1201 } 1202 } = _ref2; 1203 1204 if (__unstableTarget && __unstableExplicitMenuItem) { 1205 initializedByPlugins.push(__unstableTarget); 1206 } 1207 }); 1208 const children = external_wp_element_namespaceObject.Children.map(fills, child => { 1209 if (!child.props.__unstableExplicitMenuItem && initializedByPlugins.includes(child.props.__unstableTarget)) { 1210 return null; 1211 } 1212 1213 return child; 1214 }); 1215 return (0,external_wp_element_namespaceObject.createElement)(Component, props, children); 1216 }); 1217 } 1218 1219 function ActionItem(_ref3) { 1220 let { 1221 name, 1222 as: Component = external_wp_components_namespaceObject.Button, 1223 onClick, 1224 ...props 1225 } = _ref3; 1226 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Fill, { 1227 name: name 1228 }, _ref4 => { 1229 let { 1230 onClick: fpOnClick 1231 } = _ref4; 1232 return (0,external_wp_element_namespaceObject.createElement)(Component, _extends({ 1233 onClick: onClick || fpOnClick ? function () { 1234 (onClick || external_lodash_namespaceObject.noop)(...arguments); 1235 (fpOnClick || external_lodash_namespaceObject.noop)(...arguments); 1236 } : undefined 1237 }, props)); 1238 }); 1239 } 1240 1241 ActionItem.Slot = ActionItemSlot; 1242 /* harmony default export */ var action_item = (ActionItem); 1243 1244 ;// CONCATENATED MODULE: ./node_modules/@wordpress/interface/build-module/components/complementary-area-more-menu-item/index.js 1245 1246 1247 1248 /** 1249 * External dependencies 1250 */ 1251 1252 /** 1253 * WordPress dependencies 1254 */ 1255 1256 1257 1258 /** 1259 * Internal dependencies 1260 */ 1261 1262 1263 1264 1265 const PluginsMenuItem = props => // Menu item is marked with unstable prop for backward compatibility. 1266 // They are removed so they don't leak to DOM elements. 1267 // @see https://github.com/WordPress/gutenberg/issues/14457 1268 (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, (0,external_lodash_namespaceObject.omit)(props, ['__unstableExplicitMenuItem', '__unstableTarget'])); 1269 1270 function ComplementaryAreaMoreMenuItem(_ref) { 1271 let { 1272 scope, 1273 target, 1274 __unstableExplicitMenuItem, 1275 ...props 1276 } = _ref; 1277 return (0,external_wp_element_namespaceObject.createElement)(complementary_area_toggle, _extends({ 1278 as: toggleProps => { 1279 return (0,external_wp_element_namespaceObject.createElement)(action_item, _extends({ 1280 __unstableExplicitMenuItem: __unstableExplicitMenuItem, 1281 __unstableTarget: `$scope}/$target}`, 1282 as: PluginsMenuItem, 1283 name: `$scope}/plugin-more-menu` 1284 }, toggleProps)); 1285 }, 1286 role: "menuitemcheckbox", 1287 selectedIcon: library_check, 1288 name: target, 1289 scope: scope 1290 }, props)); 1291 } 1292 1293 ;// CONCATENATED MODULE: ./node_modules/@wordpress/interface/build-module/components/pinned-items/index.js 1294 1295 1296 1297 /** 1298 * External dependencies 1299 */ 1300 1301 1302 /** 1303 * WordPress dependencies 1304 */ 1305 1306 1307 1308 function PinnedItems(_ref) { 1309 let { 1310 scope, 1311 ...props 1312 } = _ref; 1313 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Fill, _extends({ 1314 name: `PinnedItems/$scope}` 1315 }, props)); 1316 } 1317 1318 function PinnedItemsSlot(_ref2) { 1319 let { 1320 scope, 1321 className, 1322 ...props 1323 } = _ref2; 1324 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Slot, _extends({ 1325 name: `PinnedItems/$scope}` 1326 }, props), fills => !(0,external_lodash_namespaceObject.isEmpty)(fills) && (0,external_wp_element_namespaceObject.createElement)("div", { 1327 className: classnames_default()(className, 'interface-pinned-items') 1328 }, fills)); 1329 } 1330 1331 PinnedItems.Slot = PinnedItemsSlot; 1332 /* harmony default export */ var pinned_items = (PinnedItems); 1333 1334 ;// CONCATENATED MODULE: ./node_modules/@wordpress/interface/build-module/components/complementary-area/index.js 1335 1336 1337 1338 /** 1339 * External dependencies 1340 */ 1341 1342 /** 1343 * WordPress dependencies 1344 */ 1345 1346 1347 1348 1349 1350 1351 1352 /** 1353 * Internal dependencies 1354 */ 1355 1356 1357 1358 1359 1360 1361 1362 1363 function ComplementaryAreaSlot(_ref) { 1364 let { 1365 scope, 1366 ...props 1367 } = _ref; 1368 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Slot, _extends({ 1369 name: `ComplementaryArea/$scope}` 1370 }, props)); 1371 } 1372 1373 function ComplementaryAreaFill(_ref2) { 1374 let { 1375 scope, 1376 children, 1377 className 1378 } = _ref2; 1379 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Fill, { 1380 name: `ComplementaryArea/$scope}` 1381 }, (0,external_wp_element_namespaceObject.createElement)("div", { 1382 className: className 1383 }, children)); 1384 } 1385 1386 function useAdjustComplementaryListener(scope, identifier, activeArea, isActive, isSmall) { 1387 const previousIsSmall = (0,external_wp_element_namespaceObject.useRef)(false); 1388 const shouldOpenWhenNotSmall = (0,external_wp_element_namespaceObject.useRef)(false); 1389 const { 1390 enableComplementaryArea, 1391 disableComplementaryArea 1392 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 1393 (0,external_wp_element_namespaceObject.useEffect)(() => { 1394 // If the complementary area is active and the editor is switching from a big to a small window size. 1395 if (isActive && isSmall && !previousIsSmall.current) { 1396 // Disable the complementary area. 1397 disableComplementaryArea(scope); // Flag the complementary area to be reopened when the window size goes from small to big. 1398 1399 shouldOpenWhenNotSmall.current = true; 1400 } else if ( // If there is a flag indicating the complementary area should be enabled when we go from small to big window size 1401 // and we are going from a small to big window size. 1402 shouldOpenWhenNotSmall.current && !isSmall && previousIsSmall.current) { 1403 // Remove the flag indicating the complementary area should be enabled. 1404 shouldOpenWhenNotSmall.current = false; // Enable the complementary area. 1405 1406 enableComplementaryArea(scope, identifier); 1407 } else if ( // If the flag is indicating the current complementary should be reopened but another complementary area becomes active, 1408 // remove the flag. 1409 shouldOpenWhenNotSmall.current && activeArea && activeArea !== identifier) { 1410 shouldOpenWhenNotSmall.current = false; 1411 } 1412 1413 if (isSmall !== previousIsSmall.current) { 1414 previousIsSmall.current = isSmall; 1415 } 1416 }, [isActive, isSmall, scope, identifier, activeArea]); 1417 } 1418 1419 function ComplementaryArea(_ref3) { 1420 let { 1421 children, 1422 className, 1423 closeLabel = (0,external_wp_i18n_namespaceObject.__)('Close plugin'), 1424 identifier, 1425 header, 1426 headerClassName, 1427 icon, 1428 isPinnable = true, 1429 panelClassName, 1430 scope, 1431 name, 1432 smallScreenTitle, 1433 title, 1434 toggleShortcut, 1435 isActiveByDefault, 1436 showIconLabels = false 1437 } = _ref3; 1438 const { 1439 isActive, 1440 isPinned, 1441 activeArea, 1442 isSmall, 1443 isLarge 1444 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 1445 const { 1446 getActiveComplementaryArea, 1447 isItemPinned 1448 } = select(store); 1449 1450 const _activeArea = getActiveComplementaryArea(scope); 1451 1452 return { 1453 isActive: _activeArea === identifier, 1454 isPinned: isItemPinned(scope, identifier), 1455 activeArea: _activeArea, 1456 isSmall: select(external_wp_viewport_namespaceObject.store).isViewportMatch('< medium'), 1457 isLarge: select(external_wp_viewport_namespaceObject.store).isViewportMatch('large') 1458 }; 1459 }, [identifier, scope]); 1460 useAdjustComplementaryListener(scope, identifier, activeArea, isActive, isSmall); 1461 const { 1462 enableComplementaryArea, 1463 disableComplementaryArea, 1464 pinItem, 1465 unpinItem 1466 } = (0,external_wp_data_namespaceObject.useDispatch)(store); 1467 (0,external_wp_element_namespaceObject.useEffect)(() => { 1468 if (isActiveByDefault && activeArea === undefined && !isSmall) { 1469 enableComplementaryArea(scope, identifier); 1470 } 1471 }, [activeArea, isActiveByDefault, scope, identifier, isSmall]); 1472 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, isPinnable && (0,external_wp_element_namespaceObject.createElement)(pinned_items, { 1473 scope: scope 1474 }, isPinned && (0,external_wp_element_namespaceObject.createElement)(complementary_area_toggle, { 1475 scope: scope, 1476 identifier: identifier, 1477 isPressed: isActive && (!showIconLabels || isLarge), 1478 "aria-expanded": isActive, 1479 label: title, 1480 icon: showIconLabels ? library_check : icon, 1481 showTooltip: !showIconLabels, 1482 variant: showIconLabels ? 'tertiary' : undefined 1483 })), name && isPinnable && (0,external_wp_element_namespaceObject.createElement)(ComplementaryAreaMoreMenuItem, { 1484 target: name, 1485 scope: scope, 1486 icon: icon 1487 }, title), isActive && (0,external_wp_element_namespaceObject.createElement)(ComplementaryAreaFill, { 1488 className: classnames_default()('interface-complementary-area', className), 1489 scope: scope 1490 }, (0,external_wp_element_namespaceObject.createElement)(complementary_area_header, { 1491 className: headerClassName, 1492 closeLabel: closeLabel, 1493 onClose: () => disableComplementaryArea(scope), 1494 smallScreenTitle: smallScreenTitle, 1495 toggleButtonProps: { 1496 label: closeLabel, 1497 shortcut: toggleShortcut, 1498 scope, 1499 identifier 1500 } 1501 }, header || (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("strong", null, title), isPinnable && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 1502 className: "interface-complementary-area__pin-unpin-item", 1503 icon: isPinned ? star_filled : star_empty, 1504 label: isPinned ? (0,external_wp_i18n_namespaceObject.__)('Unpin from toolbar') : (0,external_wp_i18n_namespaceObject.__)('Pin to toolbar'), 1505 onClick: () => (isPinned ? unpinItem : pinItem)(scope, identifier), 1506 isPressed: isPinned, 1507 "aria-expanded": isPinned 1508 }))), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Panel, { 1509 className: panelClassName 1510 }, children))); 1511 } 1512 1513 const ComplementaryAreaWrapped = complementary_area_context(ComplementaryArea); 1514 ComplementaryAreaWrapped.Slot = ComplementaryAreaSlot; 1515 /* harmony default export */ var complementary_area = (ComplementaryAreaWrapped); 1516 1517 ;// CONCATENATED MODULE: ./node_modules/@wordpress/interface/build-module/components/fullscreen-mode/index.js 1518 /** 1519 * WordPress dependencies 1520 */ 1521 1522 1523 const FullscreenMode = _ref => { 1524 let { 1525 isActive 1526 } = _ref; 1527 (0,external_wp_element_namespaceObject.useEffect)(() => { 1528 let isSticky = false; // `is-fullscreen-mode` is set in PHP as a body class by Gutenberg, and this causes 1529 // `sticky-menu` to be applied by WordPress and prevents the admin menu being scrolled 1530 // even if `is-fullscreen-mode` is then removed. Let's remove `sticky-menu` here as 1531 // a consequence of the FullscreenMode setup. 1532 1533 if (document.body.classList.contains('sticky-menu')) { 1534 isSticky = true; 1535 document.body.classList.remove('sticky-menu'); 1536 } 1537 1538 return () => { 1539 if (isSticky) { 1540 document.body.classList.add('sticky-menu'); 1541 } 1542 }; 1543 }, []); 1544 (0,external_wp_element_namespaceObject.useEffect)(() => { 1545 if (isActive) { 1546 document.body.classList.add('is-fullscreen-mode'); 1547 } else { 1548 document.body.classList.remove('is-fullscreen-mode'); 1549 } 1550 1551 return () => { 1552 if (isActive) { 1553 document.body.classList.remove('is-fullscreen-mode'); 1554 } 1555 }; 1556 }, [isActive]); 1557 return null; 1558 }; 1559 1560 /* harmony default export */ var fullscreen_mode = (FullscreenMode); 1561 1562 ;// CONCATENATED MODULE: ./node_modules/@wordpress/interface/build-module/components/interface-skeleton/index.js 1563 1564 1565 1566 /** 1567 * External dependencies 1568 */ 1569 1570 /** 1571 * WordPress dependencies 1572 */ 1573 1574 /** 1575 * WordPress dependencies 1576 */ 1577 1578 1579 1580 1581 1582 1583 function useHTMLClass(className) { 1584 (0,external_wp_element_namespaceObject.useEffect)(() => { 1585 const element = document && document.querySelector(`html:not(.$className})`); 1586 1587 if (!element) { 1588 return; 1589 } 1590 1591 element.classList.toggle(className); 1592 return () => { 1593 element.classList.toggle(className); 1594 }; 1595 }, [className]); 1596 } 1597 1598 function InterfaceSkeleton(_ref, ref) { 1599 let { 1600 footer, 1601 header, 1602 sidebar, 1603 secondarySidebar, 1604 notices, 1605 content, 1606 drawer, 1607 actions, 1608 labels, 1609 className, 1610 shortcuts 1611 } = _ref; 1612 const navigateRegionsProps = (0,external_wp_components_namespaceObject.__unstableUseNavigateRegions)(shortcuts); 1613 useHTMLClass('interface-interface-skeleton__html-container'); 1614 const defaultLabels = { 1615 /* translators: accessibility text for the nav bar landmark region. */ 1616 drawer: (0,external_wp_i18n_namespaceObject.__)('Drawer'), 1617 1618 /* translators: accessibility text for the top bar landmark region. */ 1619 header: (0,external_wp_i18n_namespaceObject.__)('Header'), 1620 1621 /* translators: accessibility text for the content landmark region. */ 1622 body: (0,external_wp_i18n_namespaceObject.__)('Content'), 1623 1624 /* translators: accessibility text for the secondary sidebar landmark region. */ 1625 secondarySidebar: (0,external_wp_i18n_namespaceObject.__)('Block Library'), 1626 1627 /* translators: accessibility text for the settings landmark region. */ 1628 sidebar: (0,external_wp_i18n_namespaceObject.__)('Settings'), 1629 1630 /* translators: accessibility text for the publish landmark region. */ 1631 actions: (0,external_wp_i18n_namespaceObject.__)('Publish'), 1632 1633 /* translators: accessibility text for the footer landmark region. */ 1634 footer: (0,external_wp_i18n_namespaceObject.__)('Footer') 1635 }; 1636 const mergedLabels = { ...defaultLabels, 1637 ...labels 1638 }; 1639 return (0,external_wp_element_namespaceObject.createElement)("div", _extends({}, navigateRegionsProps, { 1640 ref: (0,external_wp_compose_namespaceObject.useMergeRefs)([ref, navigateRegionsProps.ref]), 1641 className: classnames_default()(className, 'interface-interface-skeleton', navigateRegionsProps.className, !!footer && 'has-footer') 1642 }), !!drawer && (0,external_wp_element_namespaceObject.createElement)("div", { 1643 className: "interface-interface-skeleton__drawer", 1644 role: "region", 1645 "aria-label": mergedLabels.drawer, 1646 tabIndex: "-1" 1647 }, drawer), (0,external_wp_element_namespaceObject.createElement)("div", { 1648 className: "interface-interface-skeleton__editor" 1649 }, !!header && (0,external_wp_element_namespaceObject.createElement)("div", { 1650 className: "interface-interface-skeleton__header", 1651 role: "region", 1652 "aria-label": mergedLabels.header, 1653 tabIndex: "-1" 1654 }, header), (0,external_wp_element_namespaceObject.createElement)("div", { 1655 className: "interface-interface-skeleton__body" 1656 }, !!secondarySidebar && (0,external_wp_element_namespaceObject.createElement)("div", { 1657 className: "interface-interface-skeleton__secondary-sidebar", 1658 role: "region", 1659 "aria-label": mergedLabels.secondarySidebar, 1660 tabIndex: "-1" 1661 }, secondarySidebar), !!notices && (0,external_wp_element_namespaceObject.createElement)("div", { 1662 className: "interface-interface-skeleton__notices" 1663 }, notices), (0,external_wp_element_namespaceObject.createElement)("div", { 1664 className: "interface-interface-skeleton__content", 1665 role: "region", 1666 "aria-label": mergedLabels.body, 1667 tabIndex: "-1" 1668 }, content), !!sidebar && (0,external_wp_element_namespaceObject.createElement)("div", { 1669 className: "interface-interface-skeleton__sidebar", 1670 role: "region", 1671 "aria-label": mergedLabels.sidebar, 1672 tabIndex: "-1" 1673 }, sidebar), !!actions && (0,external_wp_element_namespaceObject.createElement)("div", { 1674 className: "interface-interface-skeleton__actions", 1675 role: "region", 1676 "aria-label": mergedLabels.actions, 1677 tabIndex: "-1" 1678 }, actions))), !!footer && (0,external_wp_element_namespaceObject.createElement)("div", { 1679 className: "interface-interface-skeleton__footer", 1680 role: "region", 1681 "aria-label": mergedLabels.footer, 1682 tabIndex: "-1" 1683 }, footer)); 1684 } 1685 1686 /* harmony default export */ var interface_skeleton = ((0,external_wp_element_namespaceObject.forwardRef)(InterfaceSkeleton)); 1687 1688 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/more-vertical.js 1689 1690 1691 /** 1692 * WordPress dependencies 1693 */ 1694 1695 const moreVertical = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 1696 xmlns: "http://www.w3.org/2000/svg", 1697 viewBox: "0 0 24 24" 1698 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 1699 d: "M13 19h-2v-2h2v2zm0-6h-2v-2h2v2zm0-6h-2V5h2v2z" 1700 })); 1701 /* harmony default export */ var more_vertical = (moreVertical); 1702 1703 ;// CONCATENATED MODULE: ./node_modules/@wordpress/interface/build-module/components/more-menu-dropdown/index.js 1704 1705 1706 /** 1707 * External dependencies 1708 */ 1709 1710 /** 1711 * WordPress dependencies 1712 */ 1713 1714 1715 1716 1717 function MoreMenuDropdown(_ref) { 1718 let { 1719 as: DropdownComponent = external_wp_components_namespaceObject.DropdownMenu, 1720 className, 1721 1722 /* translators: button label text should, if possible, be under 16 characters. */ 1723 label = (0,external_wp_i18n_namespaceObject.__)('Options'), 1724 popoverProps, 1725 toggleProps, 1726 children 1727 } = _ref; 1728 return (0,external_wp_element_namespaceObject.createElement)(DropdownComponent, { 1729 className: classnames_default()('interface-more-menu-dropdown', className), 1730 icon: more_vertical, 1731 label: label, 1732 popoverProps: { 1733 position: 'bottom left', 1734 ...popoverProps, 1735 className: classnames_default()('interface-more-menu-dropdown__content', popoverProps === null || popoverProps === void 0 ? void 0 : popoverProps.className) 1736 }, 1737 toggleProps: { 1738 tooltipPosition: 'bottom', 1739 ...toggleProps 1740 } 1741 }, onClose => children(onClose)); 1742 } 1743 1744 ;// CONCATENATED MODULE: ./node_modules/@wordpress/interface/build-module/components/preferences-modal/index.js 1745 1746 1747 /** 1748 * WordPress dependencies 1749 */ 1750 1751 1752 function PreferencesModal(_ref) { 1753 let { 1754 closeModal, 1755 children 1756 } = _ref; 1757 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Modal, { 1758 className: "interface-preferences-modal", 1759 title: (0,external_wp_i18n_namespaceObject.__)('Preferences'), 1760 closeLabel: (0,external_wp_i18n_namespaceObject.__)('Close'), 1761 onRequestClose: closeModal 1762 }, children); 1763 } 1764 1765 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/icon/index.js 1766 /** 1767 * WordPress dependencies 1768 */ 1769 1770 /** @typedef {{icon: JSX.Element, size?: number} & import('@wordpress/primitives').SVGProps} IconProps */ 1771 1772 /** 1773 * Return an SVG icon. 1774 * 1775 * @param {IconProps} props icon is the SVG component to render 1776 * size is a number specifiying the icon size in pixels 1777 * Other props will be passed to wrapped SVG component 1778 * 1779 * @return {JSX.Element} Icon component 1780 */ 1781 1782 function Icon(_ref) { 1783 let { 1784 icon, 1785 size = 24, 1786 ...props 1787 } = _ref; 1788 return (0,external_wp_element_namespaceObject.cloneElement)(icon, { 1789 width: size, 1790 height: size, 1791 ...props 1792 }); 1793 } 1794 1795 /* harmony default export */ var icon = (Icon); 1796 1797 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/chevron-left.js 1798 1799 1800 /** 1801 * WordPress dependencies 1802 */ 1803 1804 const chevronLeft = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 1805 xmlns: "http://www.w3.org/2000/svg", 1806 viewBox: "0 0 24 24" 1807 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 1808 d: "M14.6 7l-1.2-1L8 12l5.4 6 1.2-1-4.6-5z" 1809 })); 1810 /* harmony default export */ var chevron_left = (chevronLeft); 1811 1812 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/chevron-right.js 1813 1814 1815 /** 1816 * WordPress dependencies 1817 */ 1818 1819 const chevronRight = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 1820 xmlns: "http://www.w3.org/2000/svg", 1821 viewBox: "0 0 24 24" 1822 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 1823 d: "M10.6 6L9.4 7l4.6 5-4.6 5 1.2 1 5.4-6z" 1824 })); 1825 /* harmony default export */ var chevron_right = (chevronRight); 1826 1827 ;// CONCATENATED MODULE: ./node_modules/@wordpress/interface/build-module/components/preferences-modal-tabs/index.js 1828 1829 1830 /** 1831 * WordPress dependencies 1832 */ 1833 1834 1835 1836 1837 1838 const PREFERENCES_MENU = 'preferences-menu'; 1839 function PreferencesModalTabs(_ref) { 1840 let { 1841 sections 1842 } = _ref; 1843 const isLargeViewport = (0,external_wp_compose_namespaceObject.useViewportMatch)('medium'); // This is also used to sync the two different rendered components 1844 // between small and large viewports. 1845 1846 const [activeMenu, setActiveMenu] = (0,external_wp_element_namespaceObject.useState)(PREFERENCES_MENU); 1847 /** 1848 * Create helper objects from `sections` for easier data handling. 1849 * `tabs` is used for creating the `TabPanel` and `sectionsContentMap` 1850 * is used for easier access to active tab's content. 1851 */ 1852 1853 const { 1854 tabs, 1855 sectionsContentMap 1856 } = (0,external_wp_element_namespaceObject.useMemo)(() => { 1857 let mappedTabs = { 1858 tabs: [], 1859 sectionsContentMap: {} 1860 }; 1861 1862 if (sections.length) { 1863 mappedTabs = sections.reduce((accumulator, _ref2) => { 1864 let { 1865 name, 1866 tabLabel: title, 1867 content 1868 } = _ref2; 1869 accumulator.tabs.push({ 1870 name, 1871 title 1872 }); 1873 accumulator.sectionsContentMap[name] = content; 1874 return accumulator; 1875 }, { 1876 tabs: [], 1877 sectionsContentMap: {} 1878 }); 1879 } 1880 1881 return mappedTabs; 1882 }, [sections]); 1883 const getCurrentTab = (0,external_wp_element_namespaceObject.useCallback)(tab => sectionsContentMap[tab.name] || null, [sectionsContentMap]); 1884 let modalContent; // We render different components based on the viewport size. 1885 1886 if (isLargeViewport) { 1887 modalContent = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TabPanel, { 1888 className: "interface-preferences__tabs", 1889 tabs: tabs, 1890 initialTabName: activeMenu !== PREFERENCES_MENU ? activeMenu : undefined, 1891 onSelect: setActiveMenu, 1892 orientation: "vertical" 1893 }, getCurrentTab); 1894 } else { 1895 modalContent = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalNavigatorProvider, { 1896 initialPath: "/", 1897 className: "interface-preferences__provider" 1898 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalNavigatorScreen, { 1899 path: "/" 1900 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Card, { 1901 isBorderless: true, 1902 size: "small" 1903 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.CardBody, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalItemGroup, null, tabs.map(tab => { 1904 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalNavigatorButton, { 1905 key: tab.name, 1906 path: tab.name, 1907 as: external_wp_components_namespaceObject.__experimentalItem, 1908 isAction: true 1909 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalHStack, { 1910 justify: "space-between" 1911 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FlexItem, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalTruncate, null, tab.title)), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FlexItem, null, (0,external_wp_element_namespaceObject.createElement)(icon, { 1912 icon: (0,external_wp_i18n_namespaceObject.isRTL)() ? chevron_left : chevron_right 1913 })))); 1914 }))))), sections.length && sections.map(section => { 1915 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalNavigatorScreen, { 1916 key: `$section.name}-menu`, 1917 path: section.name 1918 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Card, { 1919 isBorderless: true, 1920 size: "large" 1921 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.CardHeader, { 1922 isBorderless: false, 1923 justify: "left", 1924 size: "small", 1925 gap: "6" 1926 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalNavigatorBackButton, { 1927 icon: (0,external_wp_i18n_namespaceObject.isRTL)() ? chevron_right : chevron_left, 1928 "aria-label": (0,external_wp_i18n_namespaceObject.__)('Navigate to the previous view') 1929 }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalText, { 1930 size: "16" 1931 }, section.tabLabel)), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.CardBody, null, section.content))); 1932 })); 1933 } 1934 1935 return modalContent; 1936 } 1937 1938 ;// CONCATENATED MODULE: ./node_modules/@wordpress/interface/build-module/components/preferences-modal-section/index.js 1939 1940 1941 const Section = _ref => { 1942 let { 1943 description, 1944 title, 1945 children 1946 } = _ref; 1947 return (0,external_wp_element_namespaceObject.createElement)("fieldset", { 1948 className: "interface-preferences-modal__section" 1949 }, (0,external_wp_element_namespaceObject.createElement)("legend", null, (0,external_wp_element_namespaceObject.createElement)("h2", { 1950 className: "interface-preferences-modal__section-title" 1951 }, title), description && (0,external_wp_element_namespaceObject.createElement)("p", { 1952 className: "interface-preferences-modal__section-description" 1953 }, description)), children); 1954 }; 1955 1956 /* harmony default export */ var preferences_modal_section = (Section); 1957 1958 ;// CONCATENATED MODULE: ./node_modules/@wordpress/interface/build-module/components/preferences-modal-base-option/index.js 1959 1960 1961 /** 1962 * WordPress dependencies 1963 */ 1964 1965 1966 function BaseOption(_ref) { 1967 let { 1968 help, 1969 label, 1970 isChecked, 1971 onChange, 1972 children 1973 } = _ref; 1974 return (0,external_wp_element_namespaceObject.createElement)("div", { 1975 className: "interface-preferences-modal__option" 1976 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, { 1977 help: help, 1978 label: label, 1979 checked: isChecked, 1980 onChange: onChange 1981 }), children); 1982 } 1983 1984 /* harmony default export */ var preferences_modal_base_option = (BaseOption); 1985 1986 ;// CONCATENATED MODULE: ./node_modules/@wordpress/interface/build-module/components/index.js 1987 1988 1989 1990 1991 1992 1993 1994 1995 1996 1997 1998 1999 2000 ;// CONCATENATED MODULE: ./node_modules/@wordpress/interface/build-module/index.js 2001 2002 2003 2004 ;// CONCATENATED MODULE: external ["wp","a11y"] 2005 var external_wp_a11y_namespaceObject = window["wp"]["a11y"]; 2006 ;// CONCATENATED MODULE: external ["wp","coreData"] 2007 var external_wp_coreData_namespaceObject = window["wp"]["coreData"]; 2008 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/utils/meta-boxes.js 2009 /** 2010 * Function returning the current Meta Boxes DOM Node in the editor 2011 * whether the meta box area is opened or not. 2012 * If the MetaBox Area is visible returns it, and returns the original container instead. 2013 * 2014 * @param {string} location Meta Box location. 2015 * 2016 * @return {string} HTML content. 2017 */ 2018 const getMetaBoxContainer = location => { 2019 const area = document.querySelector(`.edit-post-meta-boxes-area.is-$location} .metabox-location-$location}`); 2020 2021 if (area) { 2022 return area; 2023 } 2024 2025 return document.querySelector('#metaboxes .metabox-location-' + location); 2026 }; 2027 2028 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/store/actions.js 2029 /** 2030 * External dependencies 2031 */ 2032 2033 /** 2034 * WordPress dependencies 2035 */ 2036 2037 2038 2039 2040 2041 2042 2043 2044 2045 2046 /** 2047 * Internal dependencies 2048 */ 2049 2050 2051 2052 /** 2053 * Returns an action object used in signalling that the user opened an editor sidebar. 2054 * 2055 * @param {?string} name Sidebar name to be opened. 2056 */ 2057 2058 const openGeneralSidebar = name => _ref => { 2059 let { 2060 registry 2061 } = _ref; 2062 return registry.dispatch(store).enableComplementaryArea(store_store.name, name); 2063 }; 2064 /** 2065 * Returns an action object signalling that the user closed the sidebar. 2066 */ 2067 2068 const closeGeneralSidebar = () => _ref2 => { 2069 let { 2070 registry 2071 } = _ref2; 2072 return registry.dispatch(store).disableComplementaryArea(store_store.name); 2073 }; 2074 /** 2075 * Returns an action object used in signalling that the user opened a modal. 2076 * 2077 * @param {string} name A string that uniquely identifies the modal. 2078 * 2079 * @return {Object} Action object. 2080 */ 2081 2082 function openModal(name) { 2083 return { 2084 type: 'OPEN_MODAL', 2085 name 2086 }; 2087 } 2088 /** 2089 * Returns an action object signalling that the user closed a modal. 2090 * 2091 * @return {Object} Action object. 2092 */ 2093 2094 function closeModal() { 2095 return { 2096 type: 'CLOSE_MODAL' 2097 }; 2098 } 2099 /** 2100 * Returns an action object used in signalling that the user opened the publish 2101 * sidebar. 2102 * 2103 * @return {Object} Action object 2104 */ 2105 2106 function openPublishSidebar() { 2107 return { 2108 type: 'OPEN_PUBLISH_SIDEBAR' 2109 }; 2110 } 2111 /** 2112 * Returns an action object used in signalling that the user closed the 2113 * publish sidebar. 2114 * 2115 * @return {Object} Action object. 2116 */ 2117 2118 function closePublishSidebar() { 2119 return { 2120 type: 'CLOSE_PUBLISH_SIDEBAR' 2121 }; 2122 } 2123 /** 2124 * Returns an action object used in signalling that the user toggles the publish sidebar. 2125 * 2126 * @return {Object} Action object 2127 */ 2128 2129 function togglePublishSidebar() { 2130 return { 2131 type: 'TOGGLE_PUBLISH_SIDEBAR' 2132 }; 2133 } 2134 /** 2135 * Returns an action object used to enable or disable a panel in the editor. 2136 * 2137 * @param {string} panelName A string that identifies the panel to enable or disable. 2138 * 2139 * @return {Object} Action object. 2140 */ 2141 2142 const toggleEditorPanelEnabled = panelName => _ref3 => { 2143 var _registry$select$get; 2144 2145 let { 2146 registry 2147 } = _ref3; 2148 const inactivePanels = (_registry$select$get = registry.select(external_wp_preferences_namespaceObject.store).get('core/edit-post', 'inactivePanels')) !== null && _registry$select$get !== void 0 ? _registry$select$get : []; 2149 const isPanelInactive = !!(inactivePanels !== null && inactivePanels !== void 0 && inactivePanels.includes(panelName)); // If the panel is inactive, remove it to enable it, else add it to 2150 // make it inactive. 2151 2152 let updatedInactivePanels; 2153 2154 if (isPanelInactive) { 2155 updatedInactivePanels = inactivePanels.filter(invactivePanelName => invactivePanelName !== panelName); 2156 } else { 2157 updatedInactivePanels = [...inactivePanels, panelName]; 2158 } 2159 2160 registry.dispatch(external_wp_preferences_namespaceObject.store).set('core/edit-post', 'inactivePanels', updatedInactivePanels); 2161 }; 2162 /** 2163 * Opens a closed panel and closes an open panel. 2164 * 2165 * @param {string} panelName A string that identifies the panel to open or close. 2166 */ 2167 2168 const toggleEditorPanelOpened = panelName => _ref4 => { 2169 var _registry$select$get2; 2170 2171 let { 2172 registry 2173 } = _ref4; 2174 const openPanels = (_registry$select$get2 = registry.select(external_wp_preferences_namespaceObject.store).get('core/edit-post', 'openPanels')) !== null && _registry$select$get2 !== void 0 ? _registry$select$get2 : []; 2175 const isPanelOpen = !!(openPanels !== null && openPanels !== void 0 && openPanels.includes(panelName)); // If the panel is open, remove it to close it, else add it to 2176 // make it open. 2177 2178 let updatedOpenPanels; 2179 2180 if (isPanelOpen) { 2181 updatedOpenPanels = openPanels.filter(openPanelName => openPanelName !== panelName); 2182 } else { 2183 updatedOpenPanels = [...openPanels, panelName]; 2184 } 2185 2186 registry.dispatch(external_wp_preferences_namespaceObject.store).set('core/edit-post', 'openPanels', updatedOpenPanels); 2187 }; 2188 /** 2189 * Returns an action object used to remove a panel from the editor. 2190 * 2191 * @param {string} panelName A string that identifies the panel to remove. 2192 * 2193 * @return {Object} Action object. 2194 */ 2195 2196 function removeEditorPanel(panelName) { 2197 return { 2198 type: 'REMOVE_PANEL', 2199 panelName 2200 }; 2201 } 2202 /** 2203 * Triggers an action used to toggle a feature flag. 2204 * 2205 * @param {string} feature Feature name. 2206 */ 2207 2208 const actions_toggleFeature = feature => _ref5 => { 2209 let { 2210 registry 2211 } = _ref5; 2212 return registry.dispatch(external_wp_preferences_namespaceObject.store).toggle('core/edit-post', feature); 2213 }; 2214 /** 2215 * Triggers an action used to switch editor mode. 2216 * 2217 * @param {string} mode The editor mode. 2218 */ 2219 2220 const switchEditorMode = mode => _ref6 => { 2221 let { 2222 registry 2223 } = _ref6; 2224 registry.dispatch(external_wp_preferences_namespaceObject.store).set('core/edit-post', 'editorMode', mode); // Unselect blocks when we switch to the code editor. 2225 2226 if (mode !== 'visual') { 2227 registry.dispatch(external_wp_blockEditor_namespaceObject.store).clearSelectedBlock(); 2228 } 2229 2230 const message = mode === 'visual' ? (0,external_wp_i18n_namespaceObject.__)('Visual editor selected') : (0,external_wp_i18n_namespaceObject.__)('Code editor selected'); 2231 (0,external_wp_a11y_namespaceObject.speak)(message, 'assertive'); 2232 }; 2233 /** 2234 * Triggers an action object used to toggle a plugin name flag. 2235 * 2236 * @param {string} pluginName Plugin name. 2237 */ 2238 2239 const togglePinnedPluginItem = pluginName => _ref7 => { 2240 let { 2241 registry 2242 } = _ref7; 2243 const isPinned = registry.select(store).isItemPinned('core/edit-post', pluginName); 2244 registry.dispatch(store)[isPinned ? 'unpinItem' : 'pinItem']('core/edit-post', pluginName); 2245 }; 2246 /** 2247 * Returns an action object used in signaling that a style should be auto-applied when a block is created. 2248 * 2249 * @param {string} blockName Name of the block. 2250 * @param {?string} blockStyle Name of the style that should be auto applied. If undefined, the "auto apply" setting of the block is removed. 2251 */ 2252 2253 const updatePreferredStyleVariations = (blockName, blockStyle) => _ref8 => { 2254 var _registry$select$get3; 2255 2256 let { 2257 registry 2258 } = _ref8; 2259 2260 if (!blockName) { 2261 return; 2262 } 2263 2264 const existingVariations = (_registry$select$get3 = registry.select(external_wp_preferences_namespaceObject.store).get('core/edit-post', 'preferredStyleVariations')) !== null && _registry$select$get3 !== void 0 ? _registry$select$get3 : {}; // When the blockStyle is omitted, remove the block's preferred variation. 2265 2266 if (!blockStyle) { 2267 const updatedVariations = { ...existingVariations 2268 }; 2269 delete updatedVariations[blockName]; 2270 registry.dispatch(external_wp_preferences_namespaceObject.store).set('core/edit-post', 'preferredStyleVariations', updatedVariations); 2271 } else { 2272 // Else add the variation. 2273 registry.dispatch(external_wp_preferences_namespaceObject.store).set('core/edit-post', 'preferredStyleVariations', { ...existingVariations, 2274 [blockName]: blockStyle 2275 }); 2276 } 2277 }; 2278 /** 2279 * Update the provided block types to be visible. 2280 * 2281 * @param {string[]} blockNames Names of block types to show. 2282 */ 2283 2284 const showBlockTypes = blockNames => _ref9 => { 2285 var _registry$select$get4; 2286 2287 let { 2288 registry 2289 } = _ref9; 2290 const existingBlockNames = (_registry$select$get4 = registry.select(external_wp_preferences_namespaceObject.store).get('core/edit-post', 'hiddenBlockTypes')) !== null && _registry$select$get4 !== void 0 ? _registry$select$get4 : []; 2291 const newBlockNames = (0,external_lodash_namespaceObject.without)(existingBlockNames, ...(0,external_lodash_namespaceObject.castArray)(blockNames)); 2292 registry.dispatch(external_wp_preferences_namespaceObject.store).set('core/edit-post', 'hiddenBlockTypes', newBlockNames); 2293 }; 2294 /** 2295 * Update the provided block types to be hidden. 2296 * 2297 * @param {string[]} blockNames Names of block types to hide. 2298 */ 2299 2300 const hideBlockTypes = blockNames => _ref10 => { 2301 var _registry$select$get5; 2302 2303 let { 2304 registry 2305 } = _ref10; 2306 const existingBlockNames = (_registry$select$get5 = registry.select(external_wp_preferences_namespaceObject.store).get('core/edit-post', 'hiddenBlockTypes')) !== null && _registry$select$get5 !== void 0 ? _registry$select$get5 : []; 2307 const mergedBlockNames = new Set([...existingBlockNames, ...(0,external_lodash_namespaceObject.castArray)(blockNames)]); 2308 registry.dispatch(external_wp_preferences_namespaceObject.store).set('core/edit-post', 'hiddenBlockTypes', [...mergedBlockNames]); 2309 }; 2310 /** 2311 * Returns an action object used in signaling 2312 * what Meta boxes are available in which location. 2313 * 2314 * @param {Object} metaBoxesPerLocation Meta boxes per location. 2315 */ 2316 2317 const setAvailableMetaBoxesPerLocation = metaBoxesPerLocation => _ref11 => { 2318 let { 2319 dispatch 2320 } = _ref11; 2321 return dispatch({ 2322 type: 'SET_META_BOXES_PER_LOCATIONS', 2323 metaBoxesPerLocation 2324 }); 2325 }; 2326 /** 2327 * Update a metabox. 2328 */ 2329 2330 const requestMetaBoxUpdates = () => async _ref12 => { 2331 let { 2332 registry, 2333 select, 2334 dispatch 2335 } = _ref12; 2336 dispatch({ 2337 type: 'REQUEST_META_BOX_UPDATES' 2338 }); // Saves the wp_editor fields. 2339 2340 if (window.tinyMCE) { 2341 window.tinyMCE.triggerSave(); 2342 } // Additional data needed for backward compatibility. 2343 // If we do not provide this data, the post will be overridden with the default values. 2344 2345 2346 const post = registry.select(external_wp_editor_namespaceObject.store).getCurrentPost(); 2347 const additionalData = [post.comment_status ? ['comment_status', post.comment_status] : false, post.ping_status ? ['ping_status', post.ping_status] : false, post.sticky ? ['sticky', post.sticky] : false, post.author ? ['post_author', post.author] : false].filter(Boolean); // We gather all the metaboxes locations data and the base form data. 2348 2349 const baseFormData = new window.FormData(document.querySelector('.metabox-base-form')); 2350 const activeMetaBoxLocations = select.getActiveMetaBoxLocations(); 2351 const formDataToMerge = [baseFormData, ...activeMetaBoxLocations.map(location => new window.FormData(getMetaBoxContainer(location)))]; // Merge all form data objects into a single one. 2352 2353 const formData = (0,external_lodash_namespaceObject.reduce)(formDataToMerge, (memo, currentFormData) => { 2354 for (const [key, value] of currentFormData) { 2355 memo.append(key, value); 2356 } 2357 2358 return memo; 2359 }, new window.FormData()); 2360 additionalData.forEach(_ref13 => { 2361 let [key, value] = _ref13; 2362 return formData.append(key, value); 2363 }); 2364 2365 try { 2366 // Save the metaboxes. 2367 await external_wp_apiFetch_default()({ 2368 url: window._wpMetaBoxUrl, 2369 method: 'POST', 2370 body: formData, 2371 parse: false 2372 }); 2373 dispatch.metaBoxUpdatesSuccess(); 2374 } catch { 2375 dispatch.metaBoxUpdatesFailure(); 2376 } 2377 }; 2378 /** 2379 * Returns an action object used to signal a successful meta box update. 2380 * 2381 * @return {Object} Action object. 2382 */ 2383 2384 function metaBoxUpdatesSuccess() { 2385 return { 2386 type: 'META_BOX_UPDATES_SUCCESS' 2387 }; 2388 } 2389 /** 2390 * Returns an action object used to signal a failed meta box update. 2391 * 2392 * @return {Object} Action object. 2393 */ 2394 2395 function metaBoxUpdatesFailure() { 2396 return { 2397 type: 'META_BOX_UPDATES_FAILURE' 2398 }; 2399 } 2400 /** 2401 * Returns an action object used to toggle the width of the editing canvas. 2402 * 2403 * @param {string} deviceType 2404 * 2405 * @return {Object} Action object. 2406 */ 2407 2408 function __experimentalSetPreviewDeviceType(deviceType) { 2409 return { 2410 type: 'SET_PREVIEW_DEVICE_TYPE', 2411 deviceType 2412 }; 2413 } 2414 /** 2415 * Returns an action object used to open/close the inserter. 2416 * 2417 * @param {boolean|Object} value Whether the inserter should be 2418 * opened (true) or closed (false). 2419 * To specify an insertion point, 2420 * use an object. 2421 * @param {string} value.rootClientId The root client ID to insert at. 2422 * @param {number} value.insertionIndex The index to insert at. 2423 * 2424 * @return {Object} Action object. 2425 */ 2426 2427 function setIsInserterOpened(value) { 2428 return { 2429 type: 'SET_IS_INSERTER_OPENED', 2430 value 2431 }; 2432 } 2433 /** 2434 * Returns an action object used to open/close the list view. 2435 * 2436 * @param {boolean} isOpen A boolean representing whether the list view should be opened or closed. 2437 * @return {Object} Action object. 2438 */ 2439 2440 function setIsListViewOpened(isOpen) { 2441 return { 2442 type: 'SET_IS_LIST_VIEW_OPENED', 2443 isOpen 2444 }; 2445 } 2446 /** 2447 * Returns an action object used to switch to template editing. 2448 * 2449 * @param {boolean} value Is editing template. 2450 * @return {Object} Action object. 2451 */ 2452 2453 function setIsEditingTemplate(value) { 2454 return { 2455 type: 'SET_IS_EDITING_TEMPLATE', 2456 value 2457 }; 2458 } 2459 /** 2460 * Switches to the template mode. 2461 * 2462 * @param {boolean} newTemplate Is new template. 2463 */ 2464 2465 const __unstableSwitchToTemplateMode = function () { 2466 let newTemplate = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false; 2467 return _ref14 => { 2468 let { 2469 registry, 2470 select, 2471 dispatch 2472 } = _ref14; 2473 dispatch(setIsEditingTemplate(true)); 2474 const isWelcomeGuideActive = select.isFeatureActive('welcomeGuideTemplate'); 2475 2476 if (!isWelcomeGuideActive) { 2477 const message = newTemplate ? (0,external_wp_i18n_namespaceObject.__)("Custom template created. You're in template mode now.") : (0,external_wp_i18n_namespaceObject.__)('Editing template. Changes made here affect all posts and pages that use the template.'); 2478 registry.dispatch(external_wp_notices_namespaceObject.store).createSuccessNotice(message, { 2479 type: 'snackbar' 2480 }); 2481 } 2482 }; 2483 }; 2484 /** 2485 * Create a block based template. 2486 * 2487 * @param {Object?} template Template to create and assign. 2488 */ 2489 2490 const __unstableCreateTemplate = template => async _ref15 => { 2491 let { 2492 registry 2493 } = _ref15; 2494 const savedTemplate = await registry.dispatch(external_wp_coreData_namespaceObject.store).saveEntityRecord('postType', 'wp_template', template); 2495 const post = registry.select(external_wp_editor_namespaceObject.store).getCurrentPost(); 2496 registry.dispatch(external_wp_coreData_namespaceObject.store).editEntityRecord('postType', post.type, post.id, { 2497 template: savedTemplate.slug 2498 }); 2499 }; 2500 let actions_metaBoxesInitialized = false; 2501 /** 2502 * Initializes WordPress `postboxes` script and the logic for saving meta boxes. 2503 */ 2504 2505 const initializeMetaBoxes = () => _ref16 => { 2506 let { 2507 registry, 2508 select, 2509 dispatch 2510 } = _ref16; 2511 2512 const isEditorReady = registry.select(external_wp_editor_namespaceObject.store).__unstableIsEditorReady(); 2513 2514 if (!isEditorReady) { 2515 return; 2516 } // Only initialize once. 2517 2518 2519 if (actions_metaBoxesInitialized) { 2520 return; 2521 } 2522 2523 const postType = registry.select(external_wp_editor_namespaceObject.store).getCurrentPostType(); 2524 2525 if (window.postboxes.page !== postType) { 2526 window.postboxes.add_postbox_toggles(postType); 2527 } 2528 2529 actions_metaBoxesInitialized = true; 2530 let wasSavingPost = registry.select(external_wp_editor_namespaceObject.store).isSavingPost(); 2531 let wasAutosavingPost = registry.select(external_wp_editor_namespaceObject.store).isAutosavingPost(); 2532 const hasMetaBoxes = select.hasMetaBoxes(); // Save metaboxes when performing a full save on the post. 2533 2534 registry.subscribe(async () => { 2535 const isSavingPost = registry.select(external_wp_editor_namespaceObject.store).isSavingPost(); 2536 const isAutosavingPost = registry.select(external_wp_editor_namespaceObject.store).isAutosavingPost(); // Save metaboxes on save completion, except for autosaves that are not a post preview. 2537 // 2538 // Meta boxes are initialized once at page load. It is not necessary to 2539 // account for updates on each state change. 2540 // 2541 // See: https://github.com/WordPress/WordPress/blob/5.1.1/wp-admin/includes/post.php#L2307-L2309. 2542 2543 const shouldTriggerMetaboxesSave = hasMetaBoxes && wasSavingPost && !isSavingPost && !wasAutosavingPost; // Save current state for next inspection. 2544 2545 wasSavingPost = isSavingPost; 2546 wasAutosavingPost = isAutosavingPost; 2547 2548 if (shouldTriggerMetaboxesSave) { 2549 await dispatch.requestMetaBoxUpdates(); 2550 } 2551 }); 2552 dispatch({ 2553 type: 'META_BOXES_INITIALIZED' 2554 }); 2555 }; 2556 2557 ;// CONCATENATED MODULE: ./node_modules/rememo/es/rememo.js 2558 2559 2560 var LEAF_KEY, hasWeakMap; 2561 2562 /** 2563 * Arbitrary value used as key for referencing cache object in WeakMap tree. 2564 * 2565 * @type {Object} 2566 */ 2567 LEAF_KEY = {}; 2568 2569 /** 2570 * Whether environment supports WeakMap. 2571 * 2572 * @type {boolean} 2573 */ 2574 hasWeakMap = typeof WeakMap !== 'undefined'; 2575 2576 /** 2577 * Returns the first argument as the sole entry in an array. 2578 * 2579 * @param {*} value Value to return. 2580 * 2581 * @return {Array} Value returned as entry in array. 2582 */ 2583 function arrayOf( value ) { 2584 return [ value ]; 2585 } 2586 2587 /** 2588 * Returns true if the value passed is object-like, or false otherwise. A value 2589 * is object-like if it can support property assignment, e.g. object or array. 2590 * 2591 * @param {*} value Value to test. 2592 * 2593 * @return {boolean} Whether value is object-like. 2594 */ 2595 function isObjectLike( value ) { 2596 return !! value && 'object' === typeof value; 2597 } 2598 2599 /** 2600 * Creates and returns a new cache object. 2601 * 2602 * @return {Object} Cache object. 2603 */ 2604 function createCache() { 2605 var cache = { 2606 clear: function() { 2607 cache.head = null; 2608 }, 2609 }; 2610 2611 return cache; 2612 } 2613 2614 /** 2615 * Returns true if entries within the two arrays are strictly equal by 2616 * reference from a starting index. 2617 * 2618 * @param {Array} a First array. 2619 * @param {Array} b Second array. 2620 * @param {number} fromIndex Index from which to start comparison. 2621 * 2622 * @return {boolean} Whether arrays are shallowly equal. 2623 */ 2624 function isShallowEqual( a, b, fromIndex ) { 2625 var i; 2626 2627 if ( a.length !== b.length ) { 2628 return false; 2629 } 2630 2631 for ( i = fromIndex; i < a.length; i++ ) { 2632 if ( a[ i ] !== b[ i ] ) { 2633 return false; 2634 } 2635 } 2636 2637 return true; 2638 } 2639 2640 /** 2641 * Returns a memoized selector function. The getDependants function argument is 2642 * called before the memoized selector and is expected to return an immutable 2643 * reference or array of references on which the selector depends for computing 2644 * its own return value. The memoize cache is preserved only as long as those 2645 * dependant references remain the same. If getDependants returns a different 2646 * reference(s), the cache is cleared and the selector value regenerated. 2647 * 2648 * @param {Function} selector Selector function. 2649 * @param {Function} getDependants Dependant getter returning an immutable 2650 * reference or array of reference used in 2651 * cache bust consideration. 2652 * 2653 * @return {Function} Memoized selector. 2654 */ 2655 /* harmony default export */ function rememo(selector, getDependants ) { 2656 var rootCache, getCache; 2657 2658 // Use object source as dependant if getter not provided 2659 if ( ! getDependants ) { 2660 getDependants = arrayOf; 2661 } 2662 2663 /** 2664 * Returns the root cache. If WeakMap is supported, this is assigned to the 2665 * root WeakMap cache set, otherwise it is a shared instance of the default 2666 * cache object. 2667 * 2668 * @return {(WeakMap|Object)} Root cache object. 2669 */ 2670 function getRootCache() { 2671 return rootCache; 2672 } 2673 2674 /** 2675 * Returns the cache for a given dependants array. When possible, a WeakMap 2676 * will be used to create a unique cache for each set of dependants. This 2677 * is feasible due to the nature of WeakMap in allowing garbage collection 2678 * to occur on entries where the key object is no longer referenced. Since 2679 * WeakMap requires the key to be an object, this is only possible when the 2680 * dependant is object-like. The root cache is created as a hierarchy where 2681 * each top-level key is the first entry in a dependants set, the value a 2682 * WeakMap where each key is the next dependant, and so on. This continues 2683 * so long as the dependants are object-like. If no dependants are object- 2684 * like, then the cache is shared across all invocations. 2685 * 2686 * @see isObjectLike 2687 * 2688 * @param {Array} dependants Selector dependants. 2689 * 2690 * @return {Object} Cache object. 2691 */ 2692 function getWeakMapCache( dependants ) { 2693 var caches = rootCache, 2694 isUniqueByDependants = true, 2695 i, dependant, map, cache; 2696 2697 for ( i = 0; i < dependants.length; i++ ) { 2698 dependant = dependants[ i ]; 2699 2700 // Can only compose WeakMap from object-like key. 2701 if ( ! isObjectLike( dependant ) ) { 2702 isUniqueByDependants = false; 2703 break; 2704 } 2705 2706 // Does current segment of cache already have a WeakMap? 2707 if ( caches.has( dependant ) ) { 2708 // Traverse into nested WeakMap. 2709 caches = caches.get( dependant ); 2710 } else { 2711 // Create, set, and traverse into a new one. 2712 map = new WeakMap(); 2713 caches.set( dependant, map ); 2714 caches = map; 2715 } 2716 } 2717 2718 // We use an arbitrary (but consistent) object as key for the last item 2719 // in the WeakMap to serve as our running cache. 2720 if ( ! caches.has( LEAF_KEY ) ) { 2721 cache = createCache(); 2722 cache.isUniqueByDependants = isUniqueByDependants; 2723 caches.set( LEAF_KEY, cache ); 2724 } 2725 2726 return caches.get( LEAF_KEY ); 2727 } 2728 2729 // Assign cache handler by availability of WeakMap 2730 getCache = hasWeakMap ? getWeakMapCache : getRootCache; 2731 2732 /** 2733 * Resets root memoization cache. 2734 */ 2735 function clear() { 2736 rootCache = hasWeakMap ? new WeakMap() : createCache(); 2737 } 2738 2739 // eslint-disable-next-line jsdoc/check-param-names 2740 /** 2741 * The augmented selector call, considering first whether dependants have 2742 * changed before passing it to underlying memoize function. 2743 * 2744 * @param {Object} source Source object for derivation. 2745 * @param {...*} extraArgs Additional arguments to pass to selector. 2746 * 2747 * @return {*} Selector result. 2748 */ 2749 function callSelector( /* source, ...extraArgs */ ) { 2750 var len = arguments.length, 2751 cache, node, i, args, dependants; 2752 2753 // Create copy of arguments (avoid leaking deoptimization). 2754 args = new Array( len ); 2755 for ( i = 0; i < len; i++ ) { 2756 args[ i ] = arguments[ i ]; 2757 } 2758 2759 dependants = getDependants.apply( null, args ); 2760 cache = getCache( dependants ); 2761 2762 // If not guaranteed uniqueness by dependants (primitive type or lack 2763 // of WeakMap support), shallow compare against last dependants and, if 2764 // references have changed, destroy cache to recalculate result. 2765 if ( ! cache.isUniqueByDependants ) { 2766 if ( cache.lastDependants && ! isShallowEqual( dependants, cache.lastDependants, 0 ) ) { 2767 cache.clear(); 2768 } 2769 2770 cache.lastDependants = dependants; 2771 } 2772 2773 node = cache.head; 2774 while ( node ) { 2775 // Check whether node arguments match arguments 2776 if ( ! isShallowEqual( node.args, args, 1 ) ) { 2777 node = node.next; 2778 continue; 2779 } 2780 2781 // At this point we can assume we've found a match 2782 2783 // Surface matched node to head if not already 2784 if ( node !== cache.head ) { 2785 // Adjust siblings to point to each other. 2786 node.prev.next = node.next; 2787 if ( node.next ) { 2788 node.next.prev = node.prev; 2789 } 2790 2791 node.next = cache.head; 2792 node.prev = null; 2793 cache.head.prev = node; 2794 cache.head = node; 2795 } 2796 2797 // Return immediately 2798 return node.val; 2799 } 2800 2801 // No cached value found. Continue to insertion phase: 2802 2803 node = { 2804 // Generate the result from original function 2805 val: selector.apply( null, args ), 2806 }; 2807 2808 // Avoid including the source object in the cache. 2809 args[ 0 ] = null; 2810 node.args = args; 2811 2812 // Don't need to check whether node is already head, since it would 2813 // have been returned above already if it was 2814 2815 // Shift existing head down list 2816 if ( cache.head ) { 2817 cache.head.prev = node; 2818 node.next = cache.head; 2819 } 2820 2821 cache.head = node; 2822 2823 return node.val; 2824 } 2825 2826 callSelector.getDependants = getDependants; 2827 callSelector.clear = clear; 2828 clear(); 2829 2830 return callSelector; 2831 } 2832 2833 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/store/selectors.js 2834 /** 2835 * External dependencies 2836 */ 2837 2838 2839 /** 2840 * WordPress dependencies 2841 */ 2842 2843 2844 2845 2846 2847 2848 2849 const EMPTY_ARRAY = []; 2850 const EMPTY_OBJECT = {}; 2851 /** 2852 * Returns the current editing mode. 2853 * 2854 * @param {Object} state Global application state. 2855 * 2856 * @return {string} Editing mode. 2857 */ 2858 2859 const getEditorMode = (0,external_wp_data_namespaceObject.createRegistrySelector)(select => () => { 2860 var _select$get; 2861 2862 return (_select$get = select(external_wp_preferences_namespaceObject.store).get('core/edit-post', 'editorMode')) !== null && _select$get !== void 0 ? _select$get : 'visual'; 2863 }); 2864 /** 2865 * Returns true if the editor sidebar is opened. 2866 * 2867 * @param {Object} state Global application state 2868 * 2869 * @return {boolean} Whether the editor sidebar is opened. 2870 */ 2871 2872 const isEditorSidebarOpened = (0,external_wp_data_namespaceObject.createRegistrySelector)(select => () => { 2873 const activeGeneralSidebar = select(store).getActiveComplementaryArea('core/edit-post'); 2874 return (0,external_lodash_namespaceObject.includes)(['edit-post/document', 'edit-post/block'], activeGeneralSidebar); 2875 }); 2876 /** 2877 * Returns true if the plugin sidebar is opened. 2878 * 2879 * @param {Object} state Global application state. 2880 * 2881 * @return {boolean} Whether the plugin sidebar is opened. 2882 */ 2883 2884 const isPluginSidebarOpened = (0,external_wp_data_namespaceObject.createRegistrySelector)(select => () => { 2885 const activeGeneralSidebar = select(store).getActiveComplementaryArea('core/edit-post'); 2886 return !!activeGeneralSidebar && !(0,external_lodash_namespaceObject.includes)(['edit-post/document', 'edit-post/block'], activeGeneralSidebar); 2887 }); 2888 /** 2889 * Returns the current active general sidebar name, or null if there is no 2890 * general sidebar active. The active general sidebar is a unique name to 2891 * identify either an editor or plugin sidebar. 2892 * 2893 * Examples: 2894 * 2895 * - `edit-post/document` 2896 * - `my-plugin/insert-image-sidebar` 2897 * 2898 * @param {Object} state Global application state. 2899 * 2900 * @return {?string} Active general sidebar name. 2901 */ 2902 2903 const getActiveGeneralSidebarName = (0,external_wp_data_namespaceObject.createRegistrySelector)(select => () => { 2904 return select(store).getActiveComplementaryArea('core/edit-post'); 2905 }); 2906 /** 2907 * Converts panels from the new preferences store format to the old format 2908 * that the post editor previously used. 2909 * 2910 * The resultant converted data should look like this: 2911 * { 2912 * panelName: { 2913 * enabled: false, 2914 * opened: true, 2915 * }, 2916 * anotherPanelName: { 2917 * opened: true 2918 * }, 2919 * } 2920 * 2921 * @param {string[] | undefined} inactivePanels An array of inactive panel names. 2922 * @param {string[] | undefined} openPanels An array of open panel names. 2923 * 2924 * @return {Object} The converted panel data. 2925 */ 2926 2927 function convertPanelsToOldFormat(inactivePanels, openPanels) { 2928 var _ref; 2929 2930 // First reduce the inactive panels. 2931 const panelsWithEnabledState = inactivePanels === null || inactivePanels === void 0 ? void 0 : inactivePanels.reduce((accumulatedPanels, panelName) => ({ ...accumulatedPanels, 2932 [panelName]: { 2933 enabled: false 2934 } 2935 }), {}); // Then reduce the open panels, passing in the result of the previous 2936 // reduction as the initial value so that both open and inactive 2937 // panel state is combined. 2938 2939 const panels = openPanels === null || openPanels === void 0 ? void 0 : openPanels.reduce((accumulatedPanels, panelName) => { 2940 const currentPanelState = accumulatedPanels === null || accumulatedPanels === void 0 ? void 0 : accumulatedPanels[panelName]; 2941 return { ...accumulatedPanels, 2942 [panelName]: { ...currentPanelState, 2943 opened: true 2944 } 2945 }; 2946 }, panelsWithEnabledState !== null && panelsWithEnabledState !== void 0 ? panelsWithEnabledState : {}); // The panels variable will only be set if openPanels wasn't `undefined`. 2947 // If it isn't set just return `panelsWithEnabledState`, and if that isn't 2948 // set return an empty object. 2949 2950 return (_ref = panels !== null && panels !== void 0 ? panels : panelsWithEnabledState) !== null && _ref !== void 0 ? _ref : EMPTY_OBJECT; 2951 } 2952 /** 2953 * Returns the preferences (these preferences are persisted locally). 2954 * 2955 * @param {Object} state Global application state. 2956 * 2957 * @return {Object} Preferences Object. 2958 */ 2959 2960 2961 const getPreferences = (0,external_wp_data_namespaceObject.createRegistrySelector)(select => () => { 2962 external_wp_deprecated_default()(`wp.data.select( 'core/edit-post' ).getPreferences`, { 2963 since: '6.0', 2964 alternative: `wp.data.select( 'core/preferences' ).get` 2965 }); // These preferences now exist in the preferences store. 2966 // Fetch them so that they can be merged into the post 2967 // editor preferences. 2968 2969 const preferences = ['hiddenBlockTypes', 'editorMode', 'preferredStyleVariations'].reduce((accumulatedPrefs, preferenceKey) => { 2970 const value = select(external_wp_preferences_namespaceObject.store).get('core/edit-post', preferenceKey); 2971 return { ...accumulatedPrefs, 2972 [preferenceKey]: value 2973 }; 2974 }, {}); // Panels were a preference, but the data structure changed when the state 2975 // was migrated to the preferences store. They need to be converted from 2976 // the new preferences store format to old format to ensure no breaking 2977 // changes for plugins. 2978 2979 const inactivePanels = select(external_wp_preferences_namespaceObject.store).get('core/edit-post', 'inactivePanels'); 2980 const openPanels = select(external_wp_preferences_namespaceObject.store).get('core/edit-post', 'openPanels'); 2981 const panels = convertPanelsToOldFormat(inactivePanels, openPanels); 2982 return { ...preferences, 2983 panels 2984 }; 2985 }); 2986 /** 2987 * 2988 * @param {Object} state Global application state. 2989 * @param {string} preferenceKey Preference Key. 2990 * @param {*} defaultValue Default Value. 2991 * 2992 * @return {*} Preference Value. 2993 */ 2994 2995 function getPreference(state, preferenceKey, defaultValue) { 2996 external_wp_deprecated_default()(`wp.data.select( 'core/edit-post' ).getPreference`, { 2997 since: '6.0', 2998 alternative: `wp.data.select( 'core/preferences' ).get` 2999 }); // Avoid using the `getPreferences` registry selector where possible. 3000 3001 const preferences = getPreferences(state); 3002 const value = preferences[preferenceKey]; 3003 return value === undefined ? defaultValue : value; 3004 } 3005 /** 3006 * Returns an array of blocks that are hidden. 3007 * 3008 * @return {Array} A list of the hidden block types 3009 */ 3010 3011 const getHiddenBlockTypes = (0,external_wp_data_namespaceObject.createRegistrySelector)(select => () => { 3012 var _select$get2; 3013 3014 return (_select$get2 = select(external_wp_preferences_namespaceObject.store).get('core/edit-post', 'hiddenBlockTypes')) !== null && _select$get2 !== void 0 ? _select$get2 : EMPTY_ARRAY; 3015 }); 3016 /** 3017 * Returns true if the publish sidebar is opened. 3018 * 3019 * @param {Object} state Global application state 3020 * 3021 * @return {boolean} Whether the publish sidebar is open. 3022 */ 3023 3024 function isPublishSidebarOpened(state) { 3025 return state.publishSidebarActive; 3026 } 3027 /** 3028 * Returns true if the given panel was programmatically removed, or false otherwise. 3029 * All panels are not removed by default. 3030 * 3031 * @param {Object} state Global application state. 3032 * @param {string} panelName A string that identifies the panel. 3033 * 3034 * @return {boolean} Whether or not the panel is removed. 3035 */ 3036 3037 function isEditorPanelRemoved(state, panelName) { 3038 return (0,external_lodash_namespaceObject.includes)(state.removedPanels, panelName); 3039 } 3040 /** 3041 * Returns true if the given panel is enabled, or false otherwise. Panels are 3042 * enabled by default. 3043 * 3044 * @param {Object} state Global application state. 3045 * @param {string} panelName A string that identifies the panel. 3046 * 3047 * @return {boolean} Whether or not the panel is enabled. 3048 */ 3049 3050 const isEditorPanelEnabled = (0,external_wp_data_namespaceObject.createRegistrySelector)(select => (state, panelName) => { 3051 const inactivePanels = select(external_wp_preferences_namespaceObject.store).get('core/edit-post', 'inactivePanels'); 3052 return !isEditorPanelRemoved(state, panelName) && !(inactivePanels !== null && inactivePanels !== void 0 && inactivePanels.includes(panelName)); 3053 }); 3054 /** 3055 * Returns true if the given panel is open, or false otherwise. Panels are 3056 * closed by default. 3057 * 3058 * @param {Object} state Global application state. 3059 * @param {string} panelName A string that identifies the panel. 3060 * 3061 * @return {boolean} Whether or not the panel is open. 3062 */ 3063 3064 const isEditorPanelOpened = (0,external_wp_data_namespaceObject.createRegistrySelector)(select => (state, panelName) => { 3065 const openPanels = select(external_wp_preferences_namespaceObject.store).get('core/edit-post', 'openPanels'); 3066 return !!(openPanels !== null && openPanels !== void 0 && openPanels.includes(panelName)); 3067 }); 3068 /** 3069 * Returns true if a modal is active, or false otherwise. 3070 * 3071 * @param {Object} state Global application state. 3072 * @param {string} modalName A string that uniquely identifies the modal. 3073 * 3074 * @return {boolean} Whether the modal is active. 3075 */ 3076 3077 function isModalActive(state, modalName) { 3078 return state.activeModal === modalName; 3079 } 3080 /** 3081 * Returns whether the given feature is enabled or not. 3082 * 3083 * @param {Object} state Global application state. 3084 * @param {string} feature Feature slug. 3085 * 3086 * @return {boolean} Is active. 3087 */ 3088 3089 const selectors_isFeatureActive = (0,external_wp_data_namespaceObject.createRegistrySelector)(select => (state, feature) => { 3090 return !!select(external_wp_preferences_namespaceObject.store).get('core/edit-post', feature); 3091 }); 3092 /** 3093 * Returns true if the plugin item is pinned to the header. 3094 * When the value is not set it defaults to true. 3095 * 3096 * @param {Object} state Global application state. 3097 * @param {string} pluginName Plugin item name. 3098 * 3099 * @return {boolean} Whether the plugin item is pinned. 3100 */ 3101 3102 const isPluginItemPinned = (0,external_wp_data_namespaceObject.createRegistrySelector)(select => (state, pluginName) => { 3103 return select(store).isItemPinned('core/edit-post', pluginName); 3104 }); 3105 /** 3106 * Returns an array of active meta box locations. 3107 * 3108 * @param {Object} state Post editor state. 3109 * 3110 * @return {string[]} Active meta box locations. 3111 */ 3112 3113 const getActiveMetaBoxLocations = rememo(state => { 3114 return Object.keys(state.metaBoxes.locations).filter(location => isMetaBoxLocationActive(state, location)); 3115 }, state => [state.metaBoxes.locations]); 3116 /** 3117 * Returns true if a metabox location is active and visible 3118 * 3119 * @param {Object} state Post editor state. 3120 * @param {string} location Meta box location to test. 3121 * 3122 * @return {boolean} Whether the meta box location is active and visible. 3123 */ 3124 3125 function isMetaBoxLocationVisible(state, location) { 3126 return isMetaBoxLocationActive(state, location) && (0,external_lodash_namespaceObject.some)(getMetaBoxesPerLocation(state, location), _ref2 => { 3127 let { 3128 id 3129 } = _ref2; 3130 return isEditorPanelEnabled(state, `meta-box-$id}`); 3131 }); 3132 } 3133 /** 3134 * Returns true if there is an active meta box in the given location, or false 3135 * otherwise. 3136 * 3137 * @param {Object} state Post editor state. 3138 * @param {string} location Meta box location to test. 3139 * 3140 * @return {boolean} Whether the meta box location is active. 3141 */ 3142 3143 function isMetaBoxLocationActive(state, location) { 3144 const metaBoxes = getMetaBoxesPerLocation(state, location); 3145 return !!metaBoxes && metaBoxes.length !== 0; 3146 } 3147 /** 3148 * Returns the list of all the available meta boxes for a given location. 3149 * 3150 * @param {Object} state Global application state. 3151 * @param {string} location Meta box location to test. 3152 * 3153 * @return {?Array} List of meta boxes. 3154 */ 3155 3156 function getMetaBoxesPerLocation(state, location) { 3157 return state.metaBoxes.locations[location]; 3158 } 3159 /** 3160 * Returns the list of all the available meta boxes. 3161 * 3162 * @param {Object} state Global application state. 3163 * 3164 * @return {Array} List of meta boxes. 3165 */ 3166 3167 const getAllMetaBoxes = rememo(state => { 3168 return (0,external_lodash_namespaceObject.flatten)((0,external_lodash_namespaceObject.values)(state.metaBoxes.locations)); 3169 }, state => [state.metaBoxes.locations]); 3170 /** 3171 * Returns true if the post is using Meta Boxes 3172 * 3173 * @param {Object} state Global application state 3174 * 3175 * @return {boolean} Whether there are metaboxes or not. 3176 */ 3177 3178 function hasMetaBoxes(state) { 3179 return getActiveMetaBoxLocations(state).length > 0; 3180 } 3181 /** 3182 * Returns true if the Meta Boxes are being saved. 3183 * 3184 * @param {Object} state Global application state. 3185 * 3186 * @return {boolean} Whether the metaboxes are being saved. 3187 */ 3188 3189 function selectors_isSavingMetaBoxes(state) { 3190 return state.metaBoxes.isSaving; 3191 } 3192 /** 3193 * Returns the current editing canvas device type. 3194 * 3195 * @param {Object} state Global application state. 3196 * 3197 * @return {string} Device type. 3198 */ 3199 3200 function __experimentalGetPreviewDeviceType(state) { 3201 return state.deviceType; 3202 } 3203 /** 3204 * Returns true if the inserter is opened. 3205 * 3206 * @param {Object} state Global application state. 3207 * 3208 * @return {boolean} Whether the inserter is opened. 3209 */ 3210 3211 function isInserterOpened(state) { 3212 return !!state.blockInserterPanel; 3213 } 3214 /** 3215 * Get the insertion point for the inserter. 3216 * 3217 * @param {Object} state Global application state. 3218 * 3219 * @return {Object} The root client ID, index to insert at and starting filter value. 3220 */ 3221 3222 function __experimentalGetInsertionPoint(state) { 3223 const { 3224 rootClientId, 3225 insertionIndex, 3226 filterValue 3227 } = state.blockInserterPanel; 3228 return { 3229 rootClientId, 3230 insertionIndex, 3231 filterValue 3232 }; 3233 } 3234 /** 3235 * Returns true if the list view is opened. 3236 * 3237 * @param {Object} state Global application state. 3238 * 3239 * @return {boolean} Whether the list view is opened. 3240 */ 3241 3242 function isListViewOpened(state) { 3243 return state.listViewPanel; 3244 } 3245 /** 3246 * Returns true if the template editing mode is enabled. 3247 * 3248 * @param {Object} state Global application state. 3249 * 3250 * @return {boolean} Whether we're editing the template. 3251 */ 3252 3253 function selectors_isEditingTemplate(state) { 3254 return state.isEditingTemplate; 3255 } 3256 /** 3257 * Returns true if meta boxes are initialized. 3258 * 3259 * @param {Object} state Global application state. 3260 * 3261 * @return {boolean} Whether meta boxes are initialized. 3262 */ 3263 3264 function areMetaBoxesInitialized(state) { 3265 return state.metaBoxes.initialized; 3266 } 3267 /** 3268 * Retrieves the template of the currently edited post. 3269 * 3270 * @return {Object?} Post Template. 3271 */ 3272 3273 const getEditedPostTemplate = (0,external_wp_data_namespaceObject.createRegistrySelector)(select => () => { 3274 const currentTemplate = select(external_wp_editor_namespaceObject.store).getEditedPostAttribute('template'); 3275 3276 if (currentTemplate) { 3277 var _select$getEntityReco; 3278 3279 const templateWithSameSlug = (_select$getEntityReco = select(external_wp_coreData_namespaceObject.store).getEntityRecords('postType', 'wp_template', { 3280 per_page: -1 3281 })) === null || _select$getEntityReco === void 0 ? void 0 : _select$getEntityReco.find(template => template.slug === currentTemplate); 3282 3283 if (!templateWithSameSlug) { 3284 return templateWithSameSlug; 3285 } 3286 3287 return select(external_wp_coreData_namespaceObject.store).getEditedEntityRecord('postType', 'wp_template', templateWithSameSlug.id); 3288 } 3289 3290 const post = select(external_wp_editor_namespaceObject.store).getCurrentPost(); 3291 3292 if (post.link) { 3293 return select(external_wp_coreData_namespaceObject.store).__experimentalGetTemplateForLink(post.link); 3294 } 3295 3296 return null; 3297 }); 3298 3299 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/store/constants.js 3300 /** 3301 * The identifier for the data store. 3302 * 3303 * @type {string} 3304 */ 3305 const constants_STORE_NAME = 'core/edit-post'; 3306 /** 3307 * CSS selector string for the admin bar view post link anchor tag. 3308 * 3309 * @type {string} 3310 */ 3311 3312 const VIEW_AS_LINK_SELECTOR = '#wp-admin-bar-view a'; 3313 /** 3314 * CSS selector string for the admin bar preview post link anchor tag. 3315 * 3316 * @type {string} 3317 */ 3318 3319 const VIEW_AS_PREVIEW_LINK_SELECTOR = '#wp-admin-bar-preview a'; 3320 3321 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/store/index.js 3322 /** 3323 * WordPress dependencies 3324 */ 3325 3326 /** 3327 * Internal dependencies 3328 */ 3329 3330 3331 3332 3333 3334 /** 3335 * Store definition for the edit post namespace. 3336 * 3337 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/data/README.md#createReduxStore 3338 * 3339 * @type {Object} 3340 */ 3341 3342 const store_store = (0,external_wp_data_namespaceObject.createReduxStore)(constants_STORE_NAME, { 3343 reducer: reducer, 3344 actions: store_actions_namespaceObject, 3345 selectors: store_selectors_namespaceObject 3346 }); 3347 (0,external_wp_data_namespaceObject.register)(store_store); 3348 3349 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/plugins/keyboard-shortcuts-help-menu-item/index.js 3350 3351 3352 /** 3353 * WordPress dependencies 3354 */ 3355 3356 3357 3358 3359 /** 3360 * Internal dependencies 3361 */ 3362 3363 3364 function KeyboardShortcutsHelpMenuItem(_ref) { 3365 let { 3366 openModal 3367 } = _ref; 3368 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, { 3369 onClick: () => { 3370 openModal('edit-post/keyboard-shortcut-help'); 3371 }, 3372 shortcut: external_wp_keycodes_namespaceObject.displayShortcut.access('h') 3373 }, (0,external_wp_i18n_namespaceObject.__)('Keyboard shortcuts')); 3374 } 3375 /* harmony default export */ var keyboard_shortcuts_help_menu_item = ((0,external_wp_data_namespaceObject.withDispatch)(dispatch => { 3376 const { 3377 openModal 3378 } = dispatch(store_store); 3379 return { 3380 openModal 3381 }; 3382 })(KeyboardShortcutsHelpMenuItem)); 3383 3384 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/header/tools-more-menu-group/index.js 3385 3386 3387 /** 3388 * External dependencies 3389 */ 3390 3391 /** 3392 * WordPress dependencies 3393 */ 3394 3395 3396 3397 const { 3398 Fill: ToolsMoreMenuGroup, 3399 Slot 3400 } = (0,external_wp_components_namespaceObject.createSlotFill)('ToolsMoreMenuGroup'); 3401 3402 ToolsMoreMenuGroup.Slot = _ref => { 3403 let { 3404 fillProps 3405 } = _ref; 3406 return (0,external_wp_element_namespaceObject.createElement)(Slot, { 3407 fillProps: fillProps 3408 }, fills => !(0,external_lodash_namespaceObject.isEmpty)(fills) && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuGroup, { 3409 label: (0,external_wp_i18n_namespaceObject.__)('Tools') 3410 }, fills)); 3411 }; 3412 3413 /* harmony default export */ var tools_more_menu_group = (ToolsMoreMenuGroup); 3414 3415 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/plugins/welcome-guide-menu-item/index.js 3416 3417 3418 /** 3419 * WordPress dependencies 3420 */ 3421 3422 3423 3424 /** 3425 * Internal dependencies 3426 */ 3427 3428 3429 function WelcomeGuideMenuItem() { 3430 const isTemplateMode = (0,external_wp_data_namespaceObject.useSelect)(select => select(store_store).isEditingTemplate(), []); 3431 return (0,external_wp_element_namespaceObject.createElement)(external_wp_preferences_namespaceObject.PreferenceToggleMenuItem, { 3432 scope: "core/edit-post", 3433 name: isTemplateMode ? 'welcomeGuideTemplate' : 'welcomeGuide', 3434 label: (0,external_wp_i18n_namespaceObject.__)('Welcome Guide') 3435 }); 3436 } 3437 3438 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/plugins/index.js 3439 3440 3441 /** 3442 * WordPress dependencies 3443 */ 3444 3445 3446 3447 3448 3449 /** 3450 * Internal dependencies 3451 */ 3452 3453 3454 3455 3456 3457 (0,external_wp_plugins_namespaceObject.registerPlugin)('edit-post', { 3458 render() { 3459 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(tools_more_menu_group, null, _ref => { 3460 let { 3461 onClose 3462 } = _ref; 3463 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, { 3464 role: "menuitem", 3465 href: (0,external_wp_url_namespaceObject.addQueryArgs)('edit.php', { 3466 post_type: 'wp_block' 3467 }) 3468 }, (0,external_wp_i18n_namespaceObject.__)('Manage Reusable blocks')), (0,external_wp_element_namespaceObject.createElement)(keyboard_shortcuts_help_menu_item, { 3469 onSelect: onClose 3470 }), (0,external_wp_element_namespaceObject.createElement)(WelcomeGuideMenuItem, null), (0,external_wp_element_namespaceObject.createElement)(CopyContentMenuItem, null), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, { 3471 role: "menuitem", 3472 icon: library_external, 3473 href: (0,external_wp_i18n_namespaceObject.__)('https://wordpress.org/support/article/wordpress-editor/'), 3474 target: "_blank", 3475 rel: "noopener noreferrer" 3476 }, (0,external_wp_i18n_namespaceObject.__)('Help'), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.VisuallyHidden, { 3477 as: "span" 3478 }, 3479 /* translators: accessibility text */ 3480 (0,external_wp_i18n_namespaceObject.__)('(opens in a new tab)')))); 3481 })); 3482 } 3483 3484 }); 3485 3486 ;// CONCATENATED MODULE: external ["wp","keyboardShortcuts"] 3487 var external_wp_keyboardShortcuts_namespaceObject = window["wp"]["keyboardShortcuts"]; 3488 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/text-editor/index.js 3489 3490 3491 /** 3492 * WordPress dependencies 3493 */ 3494 3495 3496 3497 3498 3499 3500 /** 3501 * Internal dependencies 3502 */ 3503 3504 3505 3506 function TextEditor(_ref) { 3507 let { 3508 onExit, 3509 isRichEditingEnabled 3510 } = _ref; 3511 return (0,external_wp_element_namespaceObject.createElement)("div", { 3512 className: "edit-post-text-editor" 3513 }, isRichEditingEnabled && (0,external_wp_element_namespaceObject.createElement)("div", { 3514 className: "edit-post-text-editor__toolbar" 3515 }, (0,external_wp_element_namespaceObject.createElement)("h2", null, (0,external_wp_i18n_namespaceObject.__)('Editing code')), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 3516 variant: "tertiary", 3517 onClick: onExit, 3518 shortcut: external_wp_keycodes_namespaceObject.displayShortcut.secondary('m') 3519 }, (0,external_wp_i18n_namespaceObject.__)('Exit code editor')), (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.TextEditorGlobalKeyboardShortcuts, null)), (0,external_wp_element_namespaceObject.createElement)("div", { 3520 className: "edit-post-text-editor__body" 3521 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostTitle, null), (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostTextEditor, null))); 3522 } 3523 3524 /* harmony default export */ var text_editor = ((0,external_wp_compose_namespaceObject.compose)((0,external_wp_data_namespaceObject.withSelect)(select => ({ 3525 isRichEditingEnabled: select(external_wp_editor_namespaceObject.store).getEditorSettings().richEditingEnabled 3526 })), (0,external_wp_data_namespaceObject.withDispatch)(dispatch => { 3527 return { 3528 onExit() { 3529 dispatch(store_store).switchEditorMode('visual'); 3530 } 3531 3532 }; 3533 }))(TextEditor)); 3534 3535 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/arrow-left.js 3536 3537 3538 /** 3539 * WordPress dependencies 3540 */ 3541 3542 const arrowLeft = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 3543 xmlns: "http://www.w3.org/2000/svg", 3544 viewBox: "0 0 24 24" 3545 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 3546 d: "M20 10.8H6.7l4.1-4.5-1.1-1.1-5.8 6.3 5.8 5.8 1.1-1.1-4-3.9H20z" 3547 })); 3548 /* harmony default export */ var arrow_left = (arrowLeft); 3549 3550 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/visual-editor/block-inspector-button.js 3551 3552 3553 /** 3554 * External dependencies 3555 */ 3556 3557 /** 3558 * WordPress dependencies 3559 */ 3560 3561 3562 3563 3564 3565 3566 /** 3567 * Internal dependencies 3568 */ 3569 3570 3571 function BlockInspectorButton(_ref) { 3572 let { 3573 onClick = external_lodash_namespaceObject.noop, 3574 small = false 3575 } = _ref; 3576 const { 3577 shortcut, 3578 areAdvancedSettingsOpened 3579 } = (0,external_wp_data_namespaceObject.useSelect)(select => ({ 3580 shortcut: select(external_wp_keyboardShortcuts_namespaceObject.store).getShortcutRepresentation('core/edit-post/toggle-sidebar'), 3581 areAdvancedSettingsOpened: select(store_store).getActiveGeneralSidebarName() === 'edit-post/block' 3582 }), []); 3583 const { 3584 openGeneralSidebar, 3585 closeGeneralSidebar 3586 } = (0,external_wp_data_namespaceObject.useDispatch)(store_store); 3587 const label = areAdvancedSettingsOpened ? (0,external_wp_i18n_namespaceObject.__)('Hide more settings') : (0,external_wp_i18n_namespaceObject.__)('Show more settings'); 3588 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, { 3589 onClick: () => { 3590 if (areAdvancedSettingsOpened) { 3591 closeGeneralSidebar(); 3592 (0,external_wp_a11y_namespaceObject.speak)((0,external_wp_i18n_namespaceObject.__)('Block settings closed')); 3593 } else { 3594 openGeneralSidebar('edit-post/block'); 3595 (0,external_wp_a11y_namespaceObject.speak)((0,external_wp_i18n_namespaceObject.__)('Additional settings are now available in the Editor block settings sidebar')); 3596 } 3597 3598 onClick(); 3599 }, 3600 shortcut: shortcut 3601 }, !small && label); 3602 } 3603 /* harmony default export */ var block_inspector_button = (BlockInspectorButton); 3604 3605 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/visual-editor/index.js 3606 3607 3608 /** 3609 * External dependencies 3610 */ 3611 3612 /** 3613 * WordPress dependencies 3614 */ 3615 3616 3617 3618 3619 3620 3621 3622 3623 3624 /** 3625 * Internal dependencies 3626 */ 3627 3628 3629 3630 3631 function MaybeIframe(_ref) { 3632 let { 3633 children, 3634 contentRef, 3635 shouldIframe, 3636 styles, 3637 assets, 3638 style 3639 } = _ref; 3640 const ref = (0,external_wp_blockEditor_namespaceObject.__unstableUseMouseMoveTypingReset)(); 3641 3642 if (!shouldIframe) { 3643 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.__unstableEditorStyles, { 3644 styles: styles 3645 }), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.WritingFlow, { 3646 ref: contentRef, 3647 className: "editor-styles-wrapper", 3648 style: { 3649 flex: '1', 3650 ...style 3651 }, 3652 tabIndex: -1 3653 }, children)); 3654 } 3655 3656 return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.__unstableIframe, { 3657 head: (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.__unstableEditorStyles, { 3658 styles: styles 3659 }), 3660 assets: assets, 3661 ref: ref, 3662 contentRef: contentRef, 3663 style: { 3664 width: '100%', 3665 height: '100%', 3666 display: 'block' 3667 }, 3668 name: "editor-canvas" 3669 }, children); 3670 } 3671 3672 function VisualEditor(_ref2) { 3673 let { 3674 styles 3675 } = _ref2; 3676 const { 3677 deviceType, 3678 isTemplateMode, 3679 wrapperBlockName, 3680 wrapperUniqueId 3681 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 3682 const { 3683 isEditingTemplate, 3684 __experimentalGetPreviewDeviceType 3685 } = select(store_store); 3686 const { 3687 getCurrentPostId, 3688 getCurrentPostType 3689 } = select(external_wp_editor_namespaceObject.store); 3690 3691 const _isTemplateMode = isEditingTemplate(); 3692 3693 let _wrapperBlockName; 3694 3695 if (getCurrentPostType() === 'wp_block') { 3696 _wrapperBlockName = 'core/block'; 3697 } else if (!_isTemplateMode) { 3698 _wrapperBlockName = 'core/post-content'; 3699 } 3700 3701 return { 3702 deviceType: __experimentalGetPreviewDeviceType(), 3703 isTemplateMode: _isTemplateMode, 3704 wrapperBlockName: _wrapperBlockName, 3705 wrapperUniqueId: getCurrentPostId() 3706 }; 3707 }, []); 3708 const hasMetaBoxes = (0,external_wp_data_namespaceObject.useSelect)(select => select(store_store).hasMetaBoxes(), []); 3709 const { 3710 themeSupportsLayout, 3711 assets 3712 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 3713 const _settings = select(external_wp_blockEditor_namespaceObject.store).getSettings(); 3714 3715 return { 3716 themeSupportsLayout: _settings.supportsLayout, 3717 assets: _settings.__unstableResolvedAssets 3718 }; 3719 }, []); 3720 const { 3721 clearSelectedBlock 3722 } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_blockEditor_namespaceObject.store); 3723 const { 3724 setIsEditingTemplate 3725 } = (0,external_wp_data_namespaceObject.useDispatch)(store_store); 3726 const desktopCanvasStyles = { 3727 height: '100%', 3728 width: '100%', 3729 margin: 0, 3730 display: 'flex', 3731 flexFlow: 'column', 3732 // Default background color so that grey 3733 // .edit-post-editor-regions__content color doesn't show through. 3734 background: 'white' 3735 }; 3736 const templateModeStyles = { ...desktopCanvasStyles, 3737 borderRadius: '2px 2px 0 0', 3738 border: '1px solid #ddd', 3739 borderBottom: 0 3740 }; 3741 const resizedCanvasStyles = (0,external_wp_blockEditor_namespaceObject.__experimentalUseResizeCanvas)(deviceType, isTemplateMode); 3742 const defaultLayout = (0,external_wp_blockEditor_namespaceObject.useSetting)('layout'); 3743 const previewMode = 'is-' + deviceType.toLowerCase() + '-preview'; 3744 let animatedStyles = isTemplateMode ? templateModeStyles : desktopCanvasStyles; 3745 3746 if (resizedCanvasStyles) { 3747 animatedStyles = resizedCanvasStyles; 3748 } 3749 3750 let paddingBottom; // Add a constant padding for the typewritter effect. When typing at the 3751 // bottom, there needs to be room to scroll up. 3752 3753 if (!hasMetaBoxes && !resizedCanvasStyles && !isTemplateMode) { 3754 paddingBottom = '40vh'; 3755 } 3756 3757 const ref = (0,external_wp_element_namespaceObject.useRef)(); 3758 const contentRef = (0,external_wp_compose_namespaceObject.useMergeRefs)([ref, (0,external_wp_blockEditor_namespaceObject.__unstableUseClipboardHandler)(), (0,external_wp_blockEditor_namespaceObject.__unstableUseTypewriter)(), (0,external_wp_blockEditor_namespaceObject.__unstableUseTypingObserver)(), (0,external_wp_blockEditor_namespaceObject.__unstableUseBlockSelectionClearer)()]); 3759 const blockSelectionClearerRef = (0,external_wp_blockEditor_namespaceObject.__unstableUseBlockSelectionClearer)(); 3760 const [, RecursionProvider] = (0,external_wp_blockEditor_namespaceObject.__experimentalUseNoRecursiveRenders)(wrapperUniqueId, wrapperBlockName); 3761 const layout = (0,external_wp_element_namespaceObject.useMemo)(() => { 3762 if (isTemplateMode) { 3763 return { 3764 type: 'default' 3765 }; 3766 } 3767 3768 if (themeSupportsLayout) { 3769 return defaultLayout; 3770 } 3771 3772 return undefined; 3773 }, [isTemplateMode, themeSupportsLayout, defaultLayout]); 3774 return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockTools, { 3775 __unstableContentRef: ref, 3776 className: classnames_default()('edit-post-visual-editor', { 3777 'is-template-mode': isTemplateMode 3778 }) 3779 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.VisualEditorGlobalKeyboardShortcuts, null), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__unstableMotion.div, { 3780 className: "edit-post-visual-editor__content-area", 3781 animate: { 3782 padding: isTemplateMode ? '48px 48px 0' : '0' 3783 }, 3784 ref: blockSelectionClearerRef 3785 }, isTemplateMode && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 3786 className: "edit-post-visual-editor__exit-template-mode", 3787 icon: arrow_left, 3788 onClick: () => { 3789 clearSelectedBlock(); 3790 setIsEditingTemplate(false); 3791 } 3792 }, (0,external_wp_i18n_namespaceObject.__)('Back')), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__unstableMotion.div, { 3793 animate: animatedStyles, 3794 initial: desktopCanvasStyles, 3795 className: previewMode 3796 }, (0,external_wp_element_namespaceObject.createElement)(MaybeIframe, { 3797 shouldIframe: isTemplateMode || deviceType === 'Tablet' || deviceType === 'Mobile', 3798 contentRef: contentRef, 3799 styles: styles, 3800 assets: assets, 3801 style: { 3802 paddingBottom 3803 } 3804 }, themeSupportsLayout && !isTemplateMode && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.__experimentalLayoutStyle, { 3805 selector: ".edit-post-visual-editor__post-title-wrapper, .block-editor-block-list__layout.is-root-container", 3806 layout: defaultLayout 3807 }), !isTemplateMode && (0,external_wp_element_namespaceObject.createElement)("div", { 3808 className: "edit-post-visual-editor__post-title-wrapper", 3809 contentEditable: false 3810 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostTitle, null)), (0,external_wp_element_namespaceObject.createElement)(RecursionProvider, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockList, { 3811 className: isTemplateMode ? 'wp-site-blocks' : undefined, 3812 __experimentalLayout: layout 3813 }))))), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.__unstableBlockSettingsMenuFirstItem, null, _ref3 => { 3814 let { 3815 onClose 3816 } = _ref3; 3817 return (0,external_wp_element_namespaceObject.createElement)(block_inspector_button, { 3818 onClick: onClose 3819 }); 3820 })); 3821 } 3822 3823 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/keyboard-shortcuts/index.js 3824 /** 3825 * WordPress dependencies 3826 */ 3827 3828 3829 3830 3831 3832 3833 /** 3834 * Internal dependencies 3835 */ 3836 3837 3838 3839 function KeyboardShortcuts() { 3840 const { 3841 getBlockSelectionStart 3842 } = (0,external_wp_data_namespaceObject.useSelect)(external_wp_blockEditor_namespaceObject.store); 3843 const { 3844 getEditorMode, 3845 isEditorSidebarOpened, 3846 isListViewOpened 3847 } = (0,external_wp_data_namespaceObject.useSelect)(store_store); 3848 const isModeToggleDisabled = (0,external_wp_data_namespaceObject.useSelect)(select => { 3849 const { 3850 richEditingEnabled, 3851 codeEditingEnabled 3852 } = select(external_wp_editor_namespaceObject.store).getEditorSettings(); 3853 return !richEditingEnabled || !codeEditingEnabled; 3854 }, []); 3855 const { 3856 switchEditorMode, 3857 openGeneralSidebar, 3858 closeGeneralSidebar, 3859 toggleFeature, 3860 setIsListViewOpened 3861 } = (0,external_wp_data_namespaceObject.useDispatch)(store_store); 3862 const { 3863 registerShortcut 3864 } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_keyboardShortcuts_namespaceObject.store); 3865 (0,external_wp_element_namespaceObject.useEffect)(() => { 3866 registerShortcut({ 3867 name: 'core/edit-post/toggle-mode', 3868 category: 'global', 3869 description: (0,external_wp_i18n_namespaceObject.__)('Switch between visual editor and code editor.'), 3870 keyCombination: { 3871 modifier: 'secondary', 3872 character: 'm' 3873 } 3874 }); 3875 registerShortcut({ 3876 name: 'core/edit-post/toggle-fullscreen', 3877 category: 'global', 3878 description: (0,external_wp_i18n_namespaceObject.__)('Toggle fullscreen mode.'), 3879 keyCombination: { 3880 modifier: 'secondary', 3881 character: 'f' 3882 } 3883 }); 3884 registerShortcut({ 3885 name: 'core/edit-post/toggle-list-view', 3886 category: 'global', 3887 description: (0,external_wp_i18n_namespaceObject.__)('Open the block list view.'), 3888 keyCombination: { 3889 modifier: 'access', 3890 character: 'o' 3891 } 3892 }); 3893 registerShortcut({ 3894 name: 'core/edit-post/toggle-sidebar', 3895 category: 'global', 3896 description: (0,external_wp_i18n_namespaceObject.__)('Show or hide the settings sidebar.'), 3897 keyCombination: { 3898 modifier: 'primaryShift', 3899 character: ',' 3900 } 3901 }); 3902 registerShortcut({ 3903 name: 'core/edit-post/next-region', 3904 category: 'global', 3905 description: (0,external_wp_i18n_namespaceObject.__)('Navigate to the next part of the editor.'), 3906 keyCombination: { 3907 modifier: 'ctrl', 3908 character: '`' 3909 }, 3910 aliases: [{ 3911 modifier: 'access', 3912 character: 'n' 3913 }] 3914 }); 3915 registerShortcut({ 3916 name: 'core/edit-post/previous-region', 3917 category: 'global', 3918 description: (0,external_wp_i18n_namespaceObject.__)('Navigate to the previous part of the editor.'), 3919 keyCombination: { 3920 modifier: 'ctrlShift', 3921 character: '`' 3922 }, 3923 aliases: [{ 3924 modifier: 'access', 3925 character: 'p' 3926 }] 3927 }); 3928 registerShortcut({ 3929 name: 'core/edit-post/keyboard-shortcuts', 3930 category: 'main', 3931 description: (0,external_wp_i18n_namespaceObject.__)('Display these keyboard shortcuts.'), 3932 keyCombination: { 3933 modifier: 'access', 3934 character: 'h' 3935 } 3936 }); 3937 }, []); 3938 (0,external_wp_keyboardShortcuts_namespaceObject.useShortcut)('core/edit-post/toggle-mode', () => { 3939 switchEditorMode(getEditorMode() === 'visual' ? 'text' : 'visual'); 3940 }, { 3941 isDisabled: isModeToggleDisabled 3942 }); 3943 (0,external_wp_keyboardShortcuts_namespaceObject.useShortcut)('core/edit-post/toggle-fullscreen', () => { 3944 toggleFeature('fullscreenMode'); 3945 }); 3946 (0,external_wp_keyboardShortcuts_namespaceObject.useShortcut)('core/edit-post/toggle-sidebar', event => { 3947 // This shortcut has no known clashes, but use preventDefault to prevent any 3948 // obscure shortcuts from triggering. 3949 event.preventDefault(); 3950 3951 if (isEditorSidebarOpened()) { 3952 closeGeneralSidebar(); 3953 } else { 3954 const sidebarToOpen = getBlockSelectionStart() ? 'edit-post/block' : 'edit-post/document'; 3955 openGeneralSidebar(sidebarToOpen); 3956 } 3957 }); 3958 (0,external_wp_keyboardShortcuts_namespaceObject.useShortcut)('core/edit-post/toggle-list-view', () => setIsListViewOpened(!isListViewOpened())); 3959 return null; 3960 } 3961 3962 /* harmony default export */ var keyboard_shortcuts = (KeyboardShortcuts); 3963 3964 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/keyboard-shortcut-help-modal/config.js 3965 /** 3966 * WordPress dependencies 3967 */ 3968 3969 const textFormattingShortcuts = [{ 3970 keyCombination: { 3971 modifier: 'primary', 3972 character: 'b' 3973 }, 3974 description: (0,external_wp_i18n_namespaceObject.__)('Make the selected text bold.') 3975 }, { 3976 keyCombination: { 3977 modifier: 'primary', 3978 character: 'i' 3979 }, 3980 description: (0,external_wp_i18n_namespaceObject.__)('Make the selected text italic.') 3981 }, { 3982 keyCombination: { 3983 modifier: 'primary', 3984 character: 'k' 3985 }, 3986 description: (0,external_wp_i18n_namespaceObject.__)('Convert the selected text into a link.') 3987 }, { 3988 keyCombination: { 3989 modifier: 'primaryShift', 3990 character: 'k' 3991 }, 3992 description: (0,external_wp_i18n_namespaceObject.__)('Remove a link.') 3993 }, { 3994 keyCombination: { 3995 character: '[[' 3996 }, 3997 description: (0,external_wp_i18n_namespaceObject.__)('Insert a link to a post or page') 3998 }, { 3999 keyCombination: { 4000 modifier: 'primary', 4001 character: 'u' 4002 }, 4003 description: (0,external_wp_i18n_namespaceObject.__)('Underline the selected text.') 4004 }]; 4005 4006 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/keyboard-shortcut-help-modal/shortcut.js 4007 4008 4009 /** 4010 * External dependencies 4011 */ 4012 4013 /** 4014 * WordPress dependencies 4015 */ 4016 4017 4018 4019 4020 function KeyCombination(_ref) { 4021 let { 4022 keyCombination, 4023 forceAriaLabel 4024 } = _ref; 4025 const shortcut = keyCombination.modifier ? external_wp_keycodes_namespaceObject.displayShortcutList[keyCombination.modifier](keyCombination.character) : keyCombination.character; 4026 const ariaLabel = keyCombination.modifier ? external_wp_keycodes_namespaceObject.shortcutAriaLabel[keyCombination.modifier](keyCombination.character) : keyCombination.character; 4027 return (0,external_wp_element_namespaceObject.createElement)("kbd", { 4028 className: "edit-post-keyboard-shortcut-help-modal__shortcut-key-combination", 4029 "aria-label": forceAriaLabel || ariaLabel 4030 }, (0,external_lodash_namespaceObject.castArray)(shortcut).map((character, index) => { 4031 if (character === '+') { 4032 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, { 4033 key: index 4034 }, character); 4035 } 4036 4037 return (0,external_wp_element_namespaceObject.createElement)("kbd", { 4038 key: index, 4039 className: "edit-post-keyboard-shortcut-help-modal__shortcut-key" 4040 }, character); 4041 })); 4042 } 4043 4044 function Shortcut(_ref2) { 4045 let { 4046 description, 4047 keyCombination, 4048 aliases = [], 4049 ariaLabel 4050 } = _ref2; 4051 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("div", { 4052 className: "edit-post-keyboard-shortcut-help-modal__shortcut-description" 4053 }, description), (0,external_wp_element_namespaceObject.createElement)("div", { 4054 className: "edit-post-keyboard-shortcut-help-modal__shortcut-term" 4055 }, (0,external_wp_element_namespaceObject.createElement)(KeyCombination, { 4056 keyCombination: keyCombination, 4057 forceAriaLabel: ariaLabel 4058 }), aliases.map((alias, index) => (0,external_wp_element_namespaceObject.createElement)(KeyCombination, { 4059 keyCombination: alias, 4060 forceAriaLabel: ariaLabel, 4061 key: index 4062 })))); 4063 } 4064 4065 /* harmony default export */ var keyboard_shortcut_help_modal_shortcut = (Shortcut); 4066 4067 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/keyboard-shortcut-help-modal/dynamic-shortcut.js 4068 4069 4070 /** 4071 * WordPress dependencies 4072 */ 4073 4074 4075 /** 4076 * Internal dependencies 4077 */ 4078 4079 4080 4081 function DynamicShortcut(_ref) { 4082 let { 4083 name 4084 } = _ref; 4085 const { 4086 keyCombination, 4087 description, 4088 aliases 4089 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 4090 const { 4091 getShortcutKeyCombination, 4092 getShortcutDescription, 4093 getShortcutAliases 4094 } = select(external_wp_keyboardShortcuts_namespaceObject.store); 4095 return { 4096 keyCombination: getShortcutKeyCombination(name), 4097 aliases: getShortcutAliases(name), 4098 description: getShortcutDescription(name) 4099 }; 4100 }, [name]); 4101 4102 if (!keyCombination) { 4103 return null; 4104 } 4105 4106 return (0,external_wp_element_namespaceObject.createElement)(keyboard_shortcut_help_modal_shortcut, { 4107 keyCombination: keyCombination, 4108 description: description, 4109 aliases: aliases 4110 }); 4111 } 4112 4113 /* harmony default export */ var dynamic_shortcut = (DynamicShortcut); 4114 4115 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/keyboard-shortcut-help-modal/index.js 4116 4117 4118 /** 4119 * External dependencies 4120 */ 4121 4122 4123 /** 4124 * WordPress dependencies 4125 */ 4126 4127 4128 4129 4130 4131 4132 /** 4133 * Internal dependencies 4134 */ 4135 4136 4137 4138 4139 4140 const MODAL_NAME = 'edit-post/keyboard-shortcut-help'; 4141 4142 const ShortcutList = _ref => { 4143 let { 4144 shortcuts 4145 } = _ref; 4146 return ( 4147 /* 4148 * Disable reason: The `list` ARIA role is redundant but 4149 * Safari+VoiceOver won't announce the list otherwise. 4150 */ 4151 4152 /* eslint-disable jsx-a11y/no-redundant-roles */ 4153 (0,external_wp_element_namespaceObject.createElement)("ul", { 4154 className: "edit-post-keyboard-shortcut-help-modal__shortcut-list", 4155 role: "list" 4156 }, shortcuts.map((shortcut, index) => (0,external_wp_element_namespaceObject.createElement)("li", { 4157 className: "edit-post-keyboard-shortcut-help-modal__shortcut", 4158 key: index 4159 }, (0,external_lodash_namespaceObject.isString)(shortcut) ? (0,external_wp_element_namespaceObject.createElement)(dynamic_shortcut, { 4160 name: shortcut 4161 }) : (0,external_wp_element_namespaceObject.createElement)(keyboard_shortcut_help_modal_shortcut, shortcut)))) 4162 /* eslint-enable jsx-a11y/no-redundant-roles */ 4163 4164 ); 4165 }; 4166 4167 const ShortcutSection = _ref2 => { 4168 let { 4169 title, 4170 shortcuts, 4171 className 4172 } = _ref2; 4173 return (0,external_wp_element_namespaceObject.createElement)("section", { 4174 className: classnames_default()('edit-post-keyboard-shortcut-help-modal__section', className) 4175 }, !!title && (0,external_wp_element_namespaceObject.createElement)("h2", { 4176 className: "edit-post-keyboard-shortcut-help-modal__section-title" 4177 }, title), (0,external_wp_element_namespaceObject.createElement)(ShortcutList, { 4178 shortcuts: shortcuts 4179 })); 4180 }; 4181 4182 const ShortcutCategorySection = _ref3 => { 4183 let { 4184 title, 4185 categoryName, 4186 additionalShortcuts = [] 4187 } = _ref3; 4188 const categoryShortcuts = (0,external_wp_data_namespaceObject.useSelect)(select => { 4189 return select(external_wp_keyboardShortcuts_namespaceObject.store).getCategoryShortcuts(categoryName); 4190 }, [categoryName]); 4191 return (0,external_wp_element_namespaceObject.createElement)(ShortcutSection, { 4192 title: title, 4193 shortcuts: categoryShortcuts.concat(additionalShortcuts) 4194 }); 4195 }; 4196 4197 function KeyboardShortcutHelpModal(_ref4) { 4198 let { 4199 isModalActive, 4200 toggleModal 4201 } = _ref4; 4202 (0,external_wp_keyboardShortcuts_namespaceObject.useShortcut)('core/edit-post/keyboard-shortcuts', toggleModal); 4203 4204 if (!isModalActive) { 4205 return null; 4206 } 4207 4208 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Modal, { 4209 className: "edit-post-keyboard-shortcut-help-modal", 4210 title: (0,external_wp_i18n_namespaceObject.__)('Keyboard shortcuts'), 4211 closeLabel: (0,external_wp_i18n_namespaceObject.__)('Close'), 4212 onRequestClose: toggleModal 4213 }, (0,external_wp_element_namespaceObject.createElement)(ShortcutSection, { 4214 className: "edit-post-keyboard-shortcut-help-modal__main-shortcuts", 4215 shortcuts: ['core/edit-post/keyboard-shortcuts'] 4216 }), (0,external_wp_element_namespaceObject.createElement)(ShortcutCategorySection, { 4217 title: (0,external_wp_i18n_namespaceObject.__)('Global shortcuts'), 4218 categoryName: "global" 4219 }), (0,external_wp_element_namespaceObject.createElement)(ShortcutCategorySection, { 4220 title: (0,external_wp_i18n_namespaceObject.__)('Selection shortcuts'), 4221 categoryName: "selection" 4222 }), (0,external_wp_element_namespaceObject.createElement)(ShortcutCategorySection, { 4223 title: (0,external_wp_i18n_namespaceObject.__)('Block shortcuts'), 4224 categoryName: "block", 4225 additionalShortcuts: [{ 4226 keyCombination: { 4227 character: '/' 4228 }, 4229 description: (0,external_wp_i18n_namespaceObject.__)('Change the block type after adding a new paragraph.'), 4230 4231 /* translators: The forward-slash character. e.g. '/'. */ 4232 ariaLabel: (0,external_wp_i18n_namespaceObject.__)('Forward-slash') 4233 }] 4234 }), (0,external_wp_element_namespaceObject.createElement)(ShortcutSection, { 4235 title: (0,external_wp_i18n_namespaceObject.__)('Text formatting'), 4236 shortcuts: textFormattingShortcuts 4237 })); 4238 } 4239 /* harmony default export */ var keyboard_shortcut_help_modal = ((0,external_wp_compose_namespaceObject.compose)([(0,external_wp_data_namespaceObject.withSelect)(select => ({ 4240 isModalActive: select(store_store).isModalActive(MODAL_NAME) 4241 })), (0,external_wp_data_namespaceObject.withDispatch)((dispatch, _ref5) => { 4242 let { 4243 isModalActive 4244 } = _ref5; 4245 const { 4246 openModal, 4247 closeModal 4248 } = dispatch(store_store); 4249 return { 4250 toggleModal: () => isModalActive ? closeModal() : openModal(MODAL_NAME) 4251 }; 4252 })])(KeyboardShortcutHelpModal)); 4253 4254 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/preferences-modal/options/enable-custom-fields.js 4255 4256 4257 /** 4258 * WordPress dependencies 4259 */ 4260 4261 4262 4263 4264 4265 4266 function CustomFieldsConfirmation(_ref) { 4267 let { 4268 willEnable 4269 } = _ref; 4270 const [isReloading, setIsReloading] = (0,external_wp_element_namespaceObject.useState)(false); 4271 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("p", { 4272 className: "edit-post-preferences-modal__custom-fields-confirmation-message" 4273 }, (0,external_wp_i18n_namespaceObject.__)('A page reload is required for this change. Make sure your content is saved before reloading.')), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 4274 className: "edit-post-preferences-modal__custom-fields-confirmation-button", 4275 variant: "secondary", 4276 isBusy: isReloading, 4277 disabled: isReloading, 4278 onClick: () => { 4279 setIsReloading(true); 4280 document.getElementById('toggle-custom-fields-form').submit(); 4281 } 4282 }, willEnable ? (0,external_wp_i18n_namespaceObject.__)('Enable & Reload') : (0,external_wp_i18n_namespaceObject.__)('Disable & Reload'))); 4283 } 4284 function EnableCustomFieldsOption(_ref2) { 4285 let { 4286 label, 4287 areCustomFieldsEnabled 4288 } = _ref2; 4289 const [isChecked, setIsChecked] = (0,external_wp_element_namespaceObject.useState)(areCustomFieldsEnabled); 4290 return (0,external_wp_element_namespaceObject.createElement)(preferences_modal_base_option, { 4291 label: label, 4292 isChecked: isChecked, 4293 onChange: setIsChecked 4294 }, isChecked !== areCustomFieldsEnabled && (0,external_wp_element_namespaceObject.createElement)(CustomFieldsConfirmation, { 4295 willEnable: isChecked 4296 })); 4297 } 4298 /* harmony default export */ var enable_custom_fields = ((0,external_wp_data_namespaceObject.withSelect)(select => ({ 4299 areCustomFieldsEnabled: !!select(external_wp_editor_namespaceObject.store).getEditorSettings().enableCustomFields 4300 }))(EnableCustomFieldsOption)); 4301 4302 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/preferences-modal/options/enable-panel.js 4303 /** 4304 * WordPress dependencies 4305 */ 4306 4307 4308 4309 /** 4310 * Internal dependencies 4311 */ 4312 4313 4314 /* harmony default export */ var enable_panel = ((0,external_wp_compose_namespaceObject.compose)((0,external_wp_data_namespaceObject.withSelect)((select, _ref) => { 4315 let { 4316 panelName 4317 } = _ref; 4318 const { 4319 isEditorPanelEnabled, 4320 isEditorPanelRemoved 4321 } = select(store_store); 4322 return { 4323 isRemoved: isEditorPanelRemoved(panelName), 4324 isChecked: isEditorPanelEnabled(panelName) 4325 }; 4326 }), (0,external_wp_compose_namespaceObject.ifCondition)(_ref2 => { 4327 let { 4328 isRemoved 4329 } = _ref2; 4330 return !isRemoved; 4331 }), (0,external_wp_data_namespaceObject.withDispatch)((dispatch, _ref3) => { 4332 let { 4333 panelName 4334 } = _ref3; 4335 return { 4336 onChange: () => dispatch(store_store).toggleEditorPanelEnabled(panelName) 4337 }; 4338 }))(preferences_modal_base_option)); 4339 4340 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/preferences-modal/options/enable-plugin-document-setting-panel.js 4341 4342 4343 /** 4344 * WordPress dependencies 4345 */ 4346 4347 /** 4348 * Internal dependencies 4349 */ 4350 4351 4352 const { 4353 Fill, 4354 Slot: enable_plugin_document_setting_panel_Slot 4355 } = (0,external_wp_components_namespaceObject.createSlotFill)('EnablePluginDocumentSettingPanelOption'); 4356 4357 const EnablePluginDocumentSettingPanelOption = _ref => { 4358 let { 4359 label, 4360 panelName 4361 } = _ref; 4362 return (0,external_wp_element_namespaceObject.createElement)(Fill, null, (0,external_wp_element_namespaceObject.createElement)(enable_panel, { 4363 label: label, 4364 panelName: panelName 4365 })); 4366 }; 4367 4368 EnablePluginDocumentSettingPanelOption.Slot = enable_plugin_document_setting_panel_Slot; 4369 /* harmony default export */ var enable_plugin_document_setting_panel = (EnablePluginDocumentSettingPanelOption); 4370 4371 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/preferences-modal/options/enable-publish-sidebar.js 4372 /** 4373 * WordPress dependencies 4374 */ 4375 4376 4377 4378 4379 4380 /* harmony default export */ var enable_publish_sidebar = ((0,external_wp_compose_namespaceObject.compose)((0,external_wp_data_namespaceObject.withSelect)(select => ({ 4381 isChecked: select(external_wp_editor_namespaceObject.store).isPublishSidebarEnabled() 4382 })), (0,external_wp_data_namespaceObject.withDispatch)(dispatch => { 4383 const { 4384 enablePublishSidebar, 4385 disablePublishSidebar 4386 } = dispatch(external_wp_editor_namespaceObject.store); 4387 return { 4388 onChange: isEnabled => isEnabled ? enablePublishSidebar() : disablePublishSidebar() 4389 }; 4390 }), // In < medium viewports we override this option and always show the publish sidebar. 4391 // See the edit-post's header component for the specific logic. 4392 (0,external_wp_viewport_namespaceObject.ifViewportMatches)('medium'))(preferences_modal_base_option)); 4393 4394 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/preferences-modal/options/enable-feature.js 4395 /** 4396 * WordPress dependencies 4397 */ 4398 4399 4400 4401 /** 4402 * Internal dependencies 4403 */ 4404 4405 4406 /* harmony default export */ var enable_feature = ((0,external_wp_compose_namespaceObject.compose)((0,external_wp_data_namespaceObject.withSelect)((select, _ref) => { 4407 let { 4408 featureName 4409 } = _ref; 4410 const { 4411 isFeatureActive 4412 } = select(store_store); 4413 return { 4414 isChecked: isFeatureActive(featureName) 4415 }; 4416 }), (0,external_wp_data_namespaceObject.withDispatch)((dispatch, _ref2) => { 4417 let { 4418 featureName 4419 } = _ref2; 4420 return { 4421 onChange: () => dispatch(store_store).toggleFeature(featureName) 4422 }; 4423 }))(preferences_modal_base_option)); 4424 4425 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/preferences-modal/options/index.js 4426 4427 4428 4429 4430 4431 4432 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/preferences-modal/meta-boxes-section.js 4433 4434 4435 /** 4436 * External dependencies 4437 */ 4438 4439 /** 4440 * WordPress dependencies 4441 */ 4442 4443 4444 4445 4446 4447 /** 4448 * Internal dependencies 4449 */ 4450 4451 4452 4453 function MetaBoxesSection(_ref) { 4454 let { 4455 areCustomFieldsRegistered, 4456 metaBoxes, 4457 ...sectionProps 4458 } = _ref; 4459 // The 'Custom Fields' meta box is a special case that we handle separately. 4460 const thirdPartyMetaBoxes = (0,external_lodash_namespaceObject.filter)(metaBoxes, _ref2 => { 4461 let { 4462 id 4463 } = _ref2; 4464 return id !== 'postcustom'; 4465 }); 4466 4467 if (!areCustomFieldsRegistered && thirdPartyMetaBoxes.length === 0) { 4468 return null; 4469 } 4470 4471 return (0,external_wp_element_namespaceObject.createElement)(preferences_modal_section, sectionProps, areCustomFieldsRegistered && (0,external_wp_element_namespaceObject.createElement)(enable_custom_fields, { 4472 label: (0,external_wp_i18n_namespaceObject.__)('Custom fields') 4473 }), (0,external_lodash_namespaceObject.map)(thirdPartyMetaBoxes, _ref3 => { 4474 let { 4475 id, 4476 title 4477 } = _ref3; 4478 return (0,external_wp_element_namespaceObject.createElement)(enable_panel, { 4479 key: id, 4480 label: title, 4481 panelName: `meta-box-$id}` 4482 }); 4483 })); 4484 } 4485 /* harmony default export */ var meta_boxes_section = ((0,external_wp_data_namespaceObject.withSelect)(select => { 4486 const { 4487 getEditorSettings 4488 } = select(external_wp_editor_namespaceObject.store); 4489 const { 4490 getAllMetaBoxes 4491 } = select(store_store); 4492 return { 4493 // This setting should not live in the block editor's store. 4494 areCustomFieldsRegistered: getEditorSettings().enableCustomFields !== undefined, 4495 metaBoxes: getAllMetaBoxes() 4496 }; 4497 })(MetaBoxesSection)); 4498 4499 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/block-manager/checklist.js 4500 4501 4502 /** 4503 * External dependencies 4504 */ 4505 4506 /** 4507 * WordPress dependencies 4508 */ 4509 4510 4511 4512 4513 function BlockTypesChecklist(_ref) { 4514 let { 4515 blockTypes, 4516 value, 4517 onItemChange 4518 } = _ref; 4519 return (0,external_wp_element_namespaceObject.createElement)("ul", { 4520 className: "edit-post-block-manager__checklist" 4521 }, blockTypes.map(blockType => (0,external_wp_element_namespaceObject.createElement)("li", { 4522 key: blockType.name, 4523 className: "edit-post-block-manager__checklist-item" 4524 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.CheckboxControl, { 4525 label: (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, blockType.title, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockIcon, { 4526 icon: blockType.icon 4527 })), 4528 checked: value.includes(blockType.name), 4529 onChange: (0,external_lodash_namespaceObject.partial)(onItemChange, blockType.name) 4530 })))); 4531 } 4532 4533 /* harmony default export */ var checklist = (BlockTypesChecklist); 4534 4535 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/block-manager/category.js 4536 4537 4538 /** 4539 * External dependencies 4540 */ 4541 4542 /** 4543 * WordPress dependencies 4544 */ 4545 4546 4547 4548 4549 4550 4551 /** 4552 * Internal dependencies 4553 */ 4554 4555 4556 4557 4558 function BlockManagerCategory(_ref) { 4559 let { 4560 title, 4561 blockTypes 4562 } = _ref; 4563 const instanceId = (0,external_wp_compose_namespaceObject.useInstanceId)(BlockManagerCategory); 4564 const { 4565 defaultAllowedBlockTypes, 4566 hiddenBlockTypes 4567 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 4568 const { 4569 getEditorSettings 4570 } = select(external_wp_editor_namespaceObject.store); 4571 const { 4572 getHiddenBlockTypes 4573 } = select(store_store); 4574 return { 4575 defaultAllowedBlockTypes: getEditorSettings().defaultAllowedBlockTypes, 4576 hiddenBlockTypes: getHiddenBlockTypes() 4577 }; 4578 }, []); 4579 const filteredBlockTypes = (0,external_wp_element_namespaceObject.useMemo)(() => { 4580 if (defaultAllowedBlockTypes === true) { 4581 return blockTypes; 4582 } 4583 4584 return blockTypes.filter(_ref2 => { 4585 let { 4586 name 4587 } = _ref2; 4588 return (0,external_lodash_namespaceObject.includes)(defaultAllowedBlockTypes || [], name); 4589 }); 4590 }, [defaultAllowedBlockTypes, blockTypes]); 4591 const { 4592 showBlockTypes, 4593 hideBlockTypes 4594 } = (0,external_wp_data_namespaceObject.useDispatch)(store_store); 4595 const toggleVisible = (0,external_wp_element_namespaceObject.useCallback)((blockName, nextIsChecked) => { 4596 if (nextIsChecked) { 4597 showBlockTypes(blockName); 4598 } else { 4599 hideBlockTypes(blockName); 4600 } 4601 }, []); 4602 const toggleAllVisible = (0,external_wp_element_namespaceObject.useCallback)(nextIsChecked => { 4603 const blockNames = (0,external_lodash_namespaceObject.map)(blockTypes, 'name'); 4604 4605 if (nextIsChecked) { 4606 showBlockTypes(blockNames); 4607 } else { 4608 hideBlockTypes(blockNames); 4609 } 4610 }, [blockTypes]); 4611 4612 if (!filteredBlockTypes.length) { 4613 return null; 4614 } 4615 4616 const checkedBlockNames = (0,external_lodash_namespaceObject.without)((0,external_lodash_namespaceObject.map)(filteredBlockTypes, 'name'), ...hiddenBlockTypes); 4617 const titleId = 'edit-post-block-manager__category-title-' + instanceId; 4618 const isAllChecked = checkedBlockNames.length === filteredBlockTypes.length; 4619 let ariaChecked; 4620 4621 if (isAllChecked) { 4622 ariaChecked = 'true'; 4623 } else if (checkedBlockNames.length > 0) { 4624 ariaChecked = 'mixed'; 4625 } else { 4626 ariaChecked = 'false'; 4627 } 4628 4629 return (0,external_wp_element_namespaceObject.createElement)("div", { 4630 role: "group", 4631 "aria-labelledby": titleId, 4632 className: "edit-post-block-manager__category" 4633 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.CheckboxControl, { 4634 checked: isAllChecked, 4635 onChange: toggleAllVisible, 4636 className: "edit-post-block-manager__category-title", 4637 "aria-checked": ariaChecked, 4638 label: (0,external_wp_element_namespaceObject.createElement)("span", { 4639 id: titleId 4640 }, title) 4641 }), (0,external_wp_element_namespaceObject.createElement)(checklist, { 4642 blockTypes: filteredBlockTypes, 4643 value: checkedBlockNames, 4644 onItemChange: toggleVisible 4645 })); 4646 } 4647 4648 /* harmony default export */ var block_manager_category = (BlockManagerCategory); 4649 4650 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/block-manager/index.js 4651 4652 4653 /** 4654 * External dependencies 4655 */ 4656 4657 /** 4658 * WordPress dependencies 4659 */ 4660 4661 4662 4663 4664 4665 4666 4667 4668 /** 4669 * Internal dependencies 4670 */ 4671 4672 4673 4674 4675 function BlockManager(_ref) { 4676 let { 4677 blockTypes, 4678 categories, 4679 hasBlockSupport, 4680 isMatchingSearchTerm, 4681 numberOfHiddenBlocks 4682 } = _ref; 4683 const debouncedSpeak = (0,external_wp_compose_namespaceObject.useDebounce)(external_wp_a11y_namespaceObject.speak, 500); 4684 const [search, setSearch] = (0,external_wp_element_namespaceObject.useState)(''); // Filtering occurs here (as opposed to `withSelect`) to avoid 4685 // wasted renders by consequence of `Array#filter` producing 4686 // a new value reference on each call. 4687 4688 blockTypes = blockTypes.filter(blockType => hasBlockSupport(blockType, 'inserter', true) && (!search || isMatchingSearchTerm(blockType, search)) && (!blockType.parent || (0,external_lodash_namespaceObject.includes)(blockType.parent, 'core/post-content'))); // Announce search results on change 4689 4690 (0,external_wp_element_namespaceObject.useEffect)(() => { 4691 if (!search) { 4692 return; 4693 } 4694 4695 const count = blockTypes.length; 4696 const resultsFoundMessage = (0,external_wp_i18n_namespaceObject.sprintf)( 4697 /* translators: %d: number of results. */ 4698 (0,external_wp_i18n_namespaceObject._n)('%d result found.', '%d results found.', count), count); 4699 debouncedSpeak(resultsFoundMessage); 4700 }, [blockTypes.length, search, debouncedSpeak]); 4701 return (0,external_wp_element_namespaceObject.createElement)("div", { 4702 className: "edit-post-block-manager__content" 4703 }, !!numberOfHiddenBlocks && (0,external_wp_element_namespaceObject.createElement)("div", { 4704 className: "edit-post-block-manager__disabled-blocks-count" 4705 }, (0,external_wp_i18n_namespaceObject.sprintf)( 4706 /* translators: %d: number of blocks. */ 4707 (0,external_wp_i18n_namespaceObject._n)('%d block is hidden.', '%d blocks are hidden.', numberOfHiddenBlocks), numberOfHiddenBlocks)), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SearchControl, { 4708 label: (0,external_wp_i18n_namespaceObject.__)('Search for a block'), 4709 placeholder: (0,external_wp_i18n_namespaceObject.__)('Search for a block'), 4710 value: search, 4711 onChange: nextSearch => setSearch(nextSearch), 4712 className: "edit-post-block-manager__search" 4713 }), (0,external_wp_element_namespaceObject.createElement)("div", { 4714 tabIndex: "0", 4715 role: "region", 4716 "aria-label": (0,external_wp_i18n_namespaceObject.__)('Available block types'), 4717 className: "edit-post-block-manager__results" 4718 }, blockTypes.length === 0 && (0,external_wp_element_namespaceObject.createElement)("p", { 4719 className: "edit-post-block-manager__no-results" 4720 }, (0,external_wp_i18n_namespaceObject.__)('No blocks found.')), categories.map(category => (0,external_wp_element_namespaceObject.createElement)(block_manager_category, { 4721 key: category.slug, 4722 title: category.title, 4723 blockTypes: (0,external_lodash_namespaceObject.filter)(blockTypes, { 4724 category: category.slug 4725 }) 4726 })), (0,external_wp_element_namespaceObject.createElement)(block_manager_category, { 4727 title: (0,external_wp_i18n_namespaceObject.__)('Uncategorized'), 4728 blockTypes: (0,external_lodash_namespaceObject.filter)(blockTypes, _ref2 => { 4729 let { 4730 category 4731 } = _ref2; 4732 return !category; 4733 }) 4734 }))); 4735 } 4736 4737 /* harmony default export */ var block_manager = ((0,external_wp_data_namespaceObject.withSelect)(select => { 4738 const { 4739 getBlockTypes, 4740 getCategories, 4741 hasBlockSupport, 4742 isMatchingSearchTerm 4743 } = select(external_wp_blocks_namespaceObject.store); 4744 const { 4745 getHiddenBlockTypes 4746 } = select(store_store); 4747 const hiddenBlockTypes = getHiddenBlockTypes(); 4748 const numberOfHiddenBlocks = (0,external_lodash_namespaceObject.isArray)(hiddenBlockTypes) && hiddenBlockTypes.length; 4749 return { 4750 blockTypes: getBlockTypes(), 4751 categories: getCategories(), 4752 hasBlockSupport, 4753 isMatchingSearchTerm, 4754 numberOfHiddenBlocks 4755 }; 4756 })(BlockManager)); 4757 4758 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/preferences-modal/index.js 4759 4760 4761 /** 4762 * External dependencies 4763 */ 4764 4765 /** 4766 * WordPress dependencies 4767 */ 4768 4769 4770 4771 4772 4773 4774 4775 4776 /** 4777 * Internal dependencies 4778 */ 4779 4780 4781 4782 4783 4784 const preferences_modal_MODAL_NAME = 'edit-post/preferences'; 4785 function EditPostPreferencesModal() { 4786 const isLargeViewport = (0,external_wp_compose_namespaceObject.useViewportMatch)('medium'); 4787 const { 4788 closeModal 4789 } = (0,external_wp_data_namespaceObject.useDispatch)(store_store); 4790 const { 4791 isModalActive, 4792 isViewable 4793 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 4794 const { 4795 getEditedPostAttribute 4796 } = select(external_wp_editor_namespaceObject.store); 4797 const { 4798 getPostType 4799 } = select(external_wp_coreData_namespaceObject.store); 4800 const postType = getPostType(getEditedPostAttribute('type')); 4801 return { 4802 isModalActive: select(store_store).isModalActive(preferences_modal_MODAL_NAME), 4803 isViewable: (0,external_lodash_namespaceObject.get)(postType, ['viewable'], false) 4804 }; 4805 }, []); 4806 const showBlockBreadcrumbsOption = (0,external_wp_data_namespaceObject.useSelect)(select => { 4807 const { 4808 getEditorSettings 4809 } = select(external_wp_editor_namespaceObject.store); 4810 const { 4811 getEditorMode, 4812 isFeatureActive 4813 } = select(store_store); 4814 const mode = getEditorMode(); 4815 const isRichEditingEnabled = getEditorSettings().richEditingEnabled; 4816 const hasReducedUI = isFeatureActive('reducedUI'); 4817 return !hasReducedUI && isLargeViewport && isRichEditingEnabled && mode === 'visual'; 4818 }, [isLargeViewport]); 4819 const sections = (0,external_wp_element_namespaceObject.useMemo)(() => [{ 4820 name: 'general', 4821 tabLabel: (0,external_wp_i18n_namespaceObject.__)('General'), 4822 content: (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, isLargeViewport && (0,external_wp_element_namespaceObject.createElement)(preferences_modal_section, { 4823 title: (0,external_wp_i18n_namespaceObject.__)('Publishing'), 4824 description: (0,external_wp_i18n_namespaceObject.__)('Change options related to publishing.') 4825 }, (0,external_wp_element_namespaceObject.createElement)(enable_publish_sidebar, { 4826 help: (0,external_wp_i18n_namespaceObject.__)('Review settings, such as visibility and tags.'), 4827 label: (0,external_wp_i18n_namespaceObject.__)('Include pre-publish checklist') 4828 })), (0,external_wp_element_namespaceObject.createElement)(preferences_modal_section, { 4829 title: (0,external_wp_i18n_namespaceObject.__)('Appearance'), 4830 description: (0,external_wp_i18n_namespaceObject.__)('Customize options related to the block editor interface and editing flow.') 4831 }, (0,external_wp_element_namespaceObject.createElement)(enable_feature, { 4832 featureName: "reducedUI", 4833 help: (0,external_wp_i18n_namespaceObject.__)('Compacts options and outlines in the toolbar.'), 4834 label: (0,external_wp_i18n_namespaceObject.__)('Reduce the interface') 4835 }), (0,external_wp_element_namespaceObject.createElement)(enable_feature, { 4836 featureName: "focusMode", 4837 help: (0,external_wp_i18n_namespaceObject.__)('Highlights the current block and fades other content.'), 4838 label: (0,external_wp_i18n_namespaceObject.__)('Spotlight mode') 4839 }), (0,external_wp_element_namespaceObject.createElement)(enable_feature, { 4840 featureName: "showIconLabels", 4841 help: (0,external_wp_i18n_namespaceObject.__)('Shows text instead of icons.'), 4842 label: (0,external_wp_i18n_namespaceObject.__)('Display button labels') 4843 }), (0,external_wp_element_namespaceObject.createElement)(enable_feature, { 4844 featureName: "themeStyles", 4845 help: (0,external_wp_i18n_namespaceObject.__)('Make the editor look like your theme.'), 4846 label: (0,external_wp_i18n_namespaceObject.__)('Use theme styles') 4847 }), showBlockBreadcrumbsOption && (0,external_wp_element_namespaceObject.createElement)(enable_feature, { 4848 featureName: "showBlockBreadcrumbs", 4849 help: (0,external_wp_i18n_namespaceObject.__)('Shows block breadcrumbs at the bottom of the editor.'), 4850 label: (0,external_wp_i18n_namespaceObject.__)('Display block breadcrumbs') 4851 }))) 4852 }, { 4853 name: 'blocks', 4854 tabLabel: (0,external_wp_i18n_namespaceObject.__)('Blocks'), 4855 content: (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(preferences_modal_section, { 4856 title: (0,external_wp_i18n_namespaceObject.__)('Block interactions'), 4857 description: (0,external_wp_i18n_namespaceObject.__)('Customize how you interact with blocks in the block library and editing canvas.') 4858 }, (0,external_wp_element_namespaceObject.createElement)(enable_feature, { 4859 featureName: "mostUsedBlocks", 4860 help: (0,external_wp_i18n_namespaceObject.__)('Places the most frequent blocks in the block library.'), 4861 label: (0,external_wp_i18n_namespaceObject.__)('Show most used blocks') 4862 }), (0,external_wp_element_namespaceObject.createElement)(enable_feature, { 4863 featureName: "keepCaretInsideBlock", 4864 help: (0,external_wp_i18n_namespaceObject.__)('Aids screen readers by stopping text caret from leaving blocks.'), 4865 label: (0,external_wp_i18n_namespaceObject.__)('Contain text cursor inside block') 4866 })), (0,external_wp_element_namespaceObject.createElement)(preferences_modal_section, { 4867 title: (0,external_wp_i18n_namespaceObject.__)('Visible blocks'), 4868 description: (0,external_wp_i18n_namespaceObject.__)("Disable blocks that you don't want to appear in the inserter. They can always be toggled back on later.") 4869 }, (0,external_wp_element_namespaceObject.createElement)(block_manager, null))) 4870 }, { 4871 name: 'panels', 4872 tabLabel: (0,external_wp_i18n_namespaceObject.__)('Panels'), 4873 content: (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(preferences_modal_section, { 4874 title: (0,external_wp_i18n_namespaceObject.__)('Document settings'), 4875 description: (0,external_wp_i18n_namespaceObject.__)('Choose what displays in the panel.') 4876 }, (0,external_wp_element_namespaceObject.createElement)(enable_plugin_document_setting_panel.Slot, null), isViewable && (0,external_wp_element_namespaceObject.createElement)(enable_panel, { 4877 label: (0,external_wp_i18n_namespaceObject.__)('Permalink'), 4878 panelName: "post-link" 4879 }), isViewable && (0,external_wp_element_namespaceObject.createElement)(enable_panel, { 4880 label: (0,external_wp_i18n_namespaceObject.__)('Template'), 4881 panelName: "template" 4882 }), (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostTaxonomies, { 4883 taxonomyWrapper: (content, taxonomy) => (0,external_wp_element_namespaceObject.createElement)(enable_panel, { 4884 label: (0,external_lodash_namespaceObject.get)(taxonomy, ['labels', 'menu_name']), 4885 panelName: `taxonomy-panel-$taxonomy.slug}` 4886 }) 4887 }), (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostFeaturedImageCheck, null, (0,external_wp_element_namespaceObject.createElement)(enable_panel, { 4888 label: (0,external_wp_i18n_namespaceObject.__)('Featured image'), 4889 panelName: "featured-image" 4890 })), (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostExcerptCheck, null, (0,external_wp_element_namespaceObject.createElement)(enable_panel, { 4891 label: (0,external_wp_i18n_namespaceObject.__)('Excerpt'), 4892 panelName: "post-excerpt" 4893 })), (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostTypeSupportCheck, { 4894 supportKeys: ['comments', 'trackbacks'] 4895 }, (0,external_wp_element_namespaceObject.createElement)(enable_panel, { 4896 label: (0,external_wp_i18n_namespaceObject.__)('Discussion'), 4897 panelName: "discussion-panel" 4898 })), (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PageAttributesCheck, null, (0,external_wp_element_namespaceObject.createElement)(enable_panel, { 4899 label: (0,external_wp_i18n_namespaceObject.__)('Page attributes'), 4900 panelName: "page-attributes" 4901 }))), (0,external_wp_element_namespaceObject.createElement)(meta_boxes_section, { 4902 title: (0,external_wp_i18n_namespaceObject.__)('Additional'), 4903 description: (0,external_wp_i18n_namespaceObject.__)('Add extra areas to the editor.') 4904 })) 4905 }], [isViewable, isLargeViewport, showBlockBreadcrumbsOption]); 4906 4907 if (!isModalActive) { 4908 return null; 4909 } 4910 4911 return (0,external_wp_element_namespaceObject.createElement)(PreferencesModal, { 4912 closeModal: closeModal 4913 }, (0,external_wp_element_namespaceObject.createElement)(PreferencesModalTabs, { 4914 sections: sections 4915 })); 4916 } 4917 4918 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/browser-url/index.js 4919 /** 4920 * WordPress dependencies 4921 */ 4922 4923 4924 4925 4926 /** 4927 * Returns the Post's Edit URL. 4928 * 4929 * @param {number} postId Post ID. 4930 * 4931 * @return {string} Post edit URL. 4932 */ 4933 4934 function getPostEditURL(postId) { 4935 return (0,external_wp_url_namespaceObject.addQueryArgs)('post.php', { 4936 post: postId, 4937 action: 'edit' 4938 }); 4939 } 4940 /** 4941 * Returns the Post's Trashed URL. 4942 * 4943 * @param {number} postId Post ID. 4944 * @param {string} postType Post Type. 4945 * 4946 * @return {string} Post trashed URL. 4947 */ 4948 4949 function getPostTrashedURL(postId, postType) { 4950 return (0,external_wp_url_namespaceObject.addQueryArgs)('edit.php', { 4951 trashed: 1, 4952 post_type: postType, 4953 ids: postId 4954 }); 4955 } 4956 class BrowserURL extends external_wp_element_namespaceObject.Component { 4957 constructor() { 4958 super(...arguments); 4959 this.state = { 4960 historyId: null 4961 }; 4962 } 4963 4964 componentDidUpdate(prevProps) { 4965 const { 4966 postId, 4967 postStatus, 4968 postType, 4969 isSavingPost 4970 } = this.props; 4971 const { 4972 historyId 4973 } = this.state; // Posts are still dirty while saving so wait for saving to finish 4974 // to avoid the unsaved changes warning when trashing posts. 4975 4976 if (postStatus === 'trash' && !isSavingPost) { 4977 this.setTrashURL(postId, postType); 4978 return; 4979 } 4980 4981 if ((postId !== prevProps.postId || postId !== historyId) && postStatus !== 'auto-draft' && postId) { 4982 this.setBrowserURL(postId); 4983 } 4984 } 4985 /** 4986 * Navigates the browser to the post trashed URL to show a notice about the trashed post. 4987 * 4988 * @param {number} postId Post ID. 4989 * @param {string} postType Post Type. 4990 */ 4991 4992 4993 setTrashURL(postId, postType) { 4994 window.location.href = getPostTrashedURL(postId, postType); 4995 } 4996 /** 4997 * Replaces the browser URL with a post editor link for the given post ID. 4998 * 4999 * Note it is important that, since this function may be called when the 5000 * editor first loads, the result generated `getPostEditURL` matches that 5001 * produced by the server. Otherwise, the URL will change unexpectedly. 5002 * 5003 * @param {number} postId Post ID for which to generate post editor URL. 5004 */ 5005 5006 5007 setBrowserURL(postId) { 5008 window.history.replaceState({ 5009 id: postId 5010 }, 'Post ' + postId, getPostEditURL(postId)); 5011 this.setState(() => ({ 5012 historyId: postId 5013 })); 5014 } 5015 5016 render() { 5017 return null; 5018 } 5019 5020 } 5021 /* harmony default export */ var browser_url = ((0,external_wp_data_namespaceObject.withSelect)(select => { 5022 const { 5023 getCurrentPost, 5024 isSavingPost 5025 } = select(external_wp_editor_namespaceObject.store); 5026 const post = getCurrentPost(); 5027 let { 5028 id, 5029 status, 5030 type 5031 } = post; 5032 const isTemplate = ['wp_template', 'wp_template_part'].includes(type); 5033 5034 if (isTemplate) { 5035 id = post.wp_id; 5036 } 5037 5038 return { 5039 postId: id, 5040 postStatus: status, 5041 postType: type, 5042 isSavingPost: isSavingPost() 5043 }; 5044 })(BrowserURL)); 5045 5046 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/wordpress.js 5047 5048 5049 /** 5050 * WordPress dependencies 5051 */ 5052 5053 const wordpress = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 5054 xmlns: "http://www.w3.org/2000/svg", 5055 viewBox: "-2 -2 24 24" 5056 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 5057 d: "M20 10c0-5.51-4.49-10-10-10C4.48 0 0 4.49 0 10c0 5.52 4.48 10 10 10 5.51 0 10-4.48 10-10zM7.78 15.37L4.37 6.22c.55-.02 1.17-.08 1.17-.08.5-.06.44-1.13-.06-1.11 0 0-1.45.11-2.37.11-.18 0-.37 0-.58-.01C4.12 2.69 6.87 1.11 10 1.11c2.33 0 4.45.87 6.05 2.34-.68-.11-1.65.39-1.65 1.58 0 .74.45 1.36.9 2.1.35.61.55 1.36.55 2.46 0 1.49-1.4 5-1.4 5l-3.03-8.37c.54-.02.82-.17.82-.17.5-.05.44-1.25-.06-1.22 0 0-1.44.12-2.38.12-.87 0-2.33-.12-2.33-.12-.5-.03-.56 1.2-.06 1.22l.92.08 1.26 3.41zM17.41 10c.24-.64.74-1.87.43-4.25.7 1.29 1.05 2.71 1.05 4.25 0 3.29-1.73 6.24-4.4 7.78.97-2.59 1.94-5.2 2.92-7.78zM6.1 18.09C3.12 16.65 1.11 13.53 1.11 10c0-1.3.23-2.48.72-3.59C3.25 10.3 4.67 14.2 6.1 18.09zm4.03-6.63l2.58 6.98c-.86.29-1.76.45-2.71.45-.79 0-1.57-.11-2.29-.33.81-2.38 1.62-4.74 2.42-7.1z" 5058 })); 5059 /* harmony default export */ var library_wordpress = (wordpress); 5060 5061 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/header/fullscreen-mode-close/index.js 5062 5063 5064 /** 5065 * External dependencies 5066 */ 5067 5068 5069 /** 5070 * WordPress dependencies 5071 */ 5072 5073 5074 5075 5076 5077 5078 5079 5080 5081 /** 5082 * Internal dependencies 5083 */ 5084 5085 5086 5087 function FullscreenModeClose(_ref) { 5088 let { 5089 showTooltip, 5090 icon, 5091 href 5092 } = _ref; 5093 const { 5094 isActive, 5095 isRequestingSiteIcon, 5096 postType, 5097 siteIconUrl 5098 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 5099 const { 5100 getCurrentPostType 5101 } = select(external_wp_editor_namespaceObject.store); 5102 const { 5103 isFeatureActive 5104 } = select(store_store); 5105 const { 5106 getEntityRecord, 5107 getPostType, 5108 isResolving 5109 } = select(external_wp_coreData_namespaceObject.store); 5110 const siteData = getEntityRecord('root', '__unstableBase', undefined) || {}; 5111 return { 5112 isActive: isFeatureActive('fullscreenMode'), 5113 isRequestingSiteIcon: isResolving('getEntityRecord', ['root', '__unstableBase', undefined]), 5114 postType: getPostType(getCurrentPostType()), 5115 siteIconUrl: siteData.site_icon_url 5116 }; 5117 }, []); 5118 const disableMotion = (0,external_wp_compose_namespaceObject.useReducedMotion)(); 5119 5120 if (!isActive || !postType) { 5121 return null; 5122 } 5123 5124 let buttonIcon = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Icon, { 5125 size: "36px", 5126 icon: library_wordpress 5127 }); 5128 const effect = { 5129 expand: { 5130 scale: 1.25, 5131 transition: { 5132 type: 'tween', 5133 duration: '0.3' 5134 } 5135 } 5136 }; 5137 5138 if (siteIconUrl) { 5139 buttonIcon = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__unstableMotion.img, { 5140 variants: !disableMotion && effect, 5141 alt: (0,external_wp_i18n_namespaceObject.__)('Site Icon'), 5142 className: "edit-post-fullscreen-mode-close_site-icon", 5143 src: siteIconUrl 5144 }); 5145 } 5146 5147 if (isRequestingSiteIcon) { 5148 buttonIcon = null; 5149 } // Override default icon if custom icon is provided via props. 5150 5151 5152 if (icon) { 5153 buttonIcon = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Icon, { 5154 size: "36px", 5155 icon: icon 5156 }); 5157 } 5158 5159 const classes = classnames_default()({ 5160 'edit-post-fullscreen-mode-close': true, 5161 'has-icon': siteIconUrl 5162 }); 5163 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__unstableMotion.div, { 5164 whileHover: "expand" 5165 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 5166 className: classes, 5167 href: href !== null && href !== void 0 ? href : (0,external_wp_url_namespaceObject.addQueryArgs)('edit.php', { 5168 post_type: postType.slug 5169 }), 5170 label: (0,external_lodash_namespaceObject.get)(postType, ['labels', 'view_items'], (0,external_wp_i18n_namespaceObject.__)('Back')), 5171 showTooltip: showTooltip 5172 }, buttonIcon)); 5173 } 5174 5175 /* harmony default export */ var fullscreen_mode_close = (FullscreenModeClose); 5176 5177 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/list-view.js 5178 5179 5180 /** 5181 * WordPress dependencies 5182 */ 5183 5184 const listView = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 5185 viewBox: "0 0 24 24", 5186 xmlns: "http://www.w3.org/2000/svg" 5187 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 5188 d: "M13.8 5.2H3v1.5h10.8V5.2zm-3.6 12v1.5H21v-1.5H10.2zm7.2-6H6.6v1.5h10.8v-1.5z" 5189 })); 5190 /* harmony default export */ var list_view = (listView); 5191 5192 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/plus.js 5193 5194 5195 /** 5196 * WordPress dependencies 5197 */ 5198 5199 const plus = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 5200 xmlns: "http://www.w3.org/2000/svg", 5201 viewBox: "0 0 24 24" 5202 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 5203 d: "M18 11.2h-5.2V6h-1.6v5.2H6v1.6h5.2V18h1.6v-5.2H18z" 5204 })); 5205 /* harmony default export */ var library_plus = (plus); 5206 5207 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/header/header-toolbar/index.js 5208 5209 5210 /** 5211 * WordPress dependencies 5212 */ 5213 5214 5215 5216 5217 5218 5219 5220 5221 5222 /** 5223 * Internal dependencies 5224 */ 5225 5226 5227 5228 const preventDefault = event => { 5229 event.preventDefault(); 5230 }; 5231 5232 function HeaderToolbar() { 5233 const inserterButton = (0,external_wp_element_namespaceObject.useRef)(); 5234 const { 5235 setIsInserterOpened, 5236 setIsListViewOpened 5237 } = (0,external_wp_data_namespaceObject.useDispatch)(store_store); 5238 const { 5239 isInserterEnabled, 5240 isInserterOpened, 5241 isTextModeEnabled, 5242 showIconLabels, 5243 isListViewOpen, 5244 listViewShortcut 5245 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 5246 const { 5247 hasInserterItems, 5248 getBlockRootClientId, 5249 getBlockSelectionEnd 5250 } = select(external_wp_blockEditor_namespaceObject.store); 5251 const { 5252 getEditorSettings 5253 } = select(external_wp_editor_namespaceObject.store); 5254 const { 5255 getEditorMode, 5256 isFeatureActive, 5257 isListViewOpened 5258 } = select(store_store); 5259 const { 5260 getShortcutRepresentation 5261 } = select(external_wp_keyboardShortcuts_namespaceObject.store); 5262 return { 5263 // This setting (richEditingEnabled) should not live in the block editor's setting. 5264 isInserterEnabled: getEditorMode() === 'visual' && getEditorSettings().richEditingEnabled && hasInserterItems(getBlockRootClientId(getBlockSelectionEnd())), 5265 isInserterOpened: select(store_store).isInserterOpened(), 5266 isTextModeEnabled: getEditorMode() === 'text', 5267 showIconLabels: isFeatureActive('showIconLabels'), 5268 isListViewOpen: isListViewOpened(), 5269 listViewShortcut: getShortcutRepresentation('core/edit-post/toggle-list-view') 5270 }; 5271 }, []); 5272 const isLargeViewport = (0,external_wp_compose_namespaceObject.useViewportMatch)('medium'); 5273 const isWideViewport = (0,external_wp_compose_namespaceObject.useViewportMatch)('wide'); 5274 /* translators: accessibility text for the editor toolbar */ 5275 5276 const toolbarAriaLabel = (0,external_wp_i18n_namespaceObject.__)('Document tools'); 5277 5278 const toggleListView = (0,external_wp_element_namespaceObject.useCallback)(() => setIsListViewOpened(!isListViewOpen), [setIsListViewOpened, isListViewOpen]); 5279 const overflowItems = (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarItem, { 5280 as: external_wp_editor_namespaceObject.TableOfContents, 5281 hasOutlineItemsDisabled: isTextModeEnabled, 5282 repositionDropdown: showIconLabels && !isWideViewport, 5283 showTooltip: !showIconLabels, 5284 variant: showIconLabels ? 'tertiary' : undefined 5285 }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarItem, { 5286 as: external_wp_components_namespaceObject.Button, 5287 className: "edit-post-header-toolbar__list-view-toggle", 5288 icon: list_view, 5289 disabled: isTextModeEnabled, 5290 isPressed: isListViewOpen 5291 /* translators: button label text should, if possible, be under 16 characters. */ 5292 , 5293 label: (0,external_wp_i18n_namespaceObject.__)('List View'), 5294 onClick: toggleListView, 5295 shortcut: listViewShortcut, 5296 showTooltip: !showIconLabels 5297 })); 5298 const openInserter = (0,external_wp_element_namespaceObject.useCallback)(() => { 5299 if (isInserterOpened) { 5300 // Focusing the inserter button closes the inserter popover. 5301 inserterButton.current.focus(); 5302 } else { 5303 setIsInserterOpened(true); 5304 } 5305 }, [isInserterOpened, setIsInserterOpened]); 5306 return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.NavigableToolbar, { 5307 className: "edit-post-header-toolbar", 5308 "aria-label": toolbarAriaLabel 5309 }, (0,external_wp_element_namespaceObject.createElement)("div", { 5310 className: "edit-post-header-toolbar__left" 5311 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarItem, { 5312 ref: inserterButton, 5313 as: external_wp_components_namespaceObject.Button, 5314 className: "edit-post-header-toolbar__inserter-toggle", 5315 variant: "primary", 5316 isPressed: isInserterOpened, 5317 onMouseDown: preventDefault, 5318 onClick: openInserter, 5319 disabled: !isInserterEnabled, 5320 icon: library_plus 5321 /* translators: button label text should, if possible, be under 16 5322 characters. */ 5323 , 5324 label: (0,external_wp_i18n_namespaceObject._x)('Toggle block inserter', 'Generic label for block inserter button'), 5325 showTooltip: !showIconLabels 5326 }, showIconLabels && (!isInserterOpened ? (0,external_wp_i18n_namespaceObject.__)('Add') : (0,external_wp_i18n_namespaceObject.__)('Close'))), (isWideViewport || !showIconLabels) && (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, isLargeViewport && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarItem, { 5327 as: external_wp_blockEditor_namespaceObject.ToolSelector, 5328 showTooltip: !showIconLabels, 5329 variant: showIconLabels ? 'tertiary' : undefined, 5330 disabled: isTextModeEnabled 5331 }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarItem, { 5332 as: external_wp_editor_namespaceObject.EditorHistoryUndo, 5333 showTooltip: !showIconLabels, 5334 variant: showIconLabels ? 'tertiary' : undefined 5335 }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarItem, { 5336 as: external_wp_editor_namespaceObject.EditorHistoryRedo, 5337 showTooltip: !showIconLabels, 5338 variant: showIconLabels ? 'tertiary' : undefined 5339 }), overflowItems))); 5340 } 5341 5342 /* harmony default export */ var header_toolbar = (HeaderToolbar); 5343 5344 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/header/mode-switcher/index.js 5345 5346 5347 /** 5348 * WordPress dependencies 5349 */ 5350 5351 5352 5353 5354 5355 /** 5356 * Internal dependencies 5357 */ 5358 5359 5360 /** 5361 * Set of available mode options. 5362 * 5363 * @type {Array} 5364 */ 5365 5366 const MODES = [{ 5367 value: 'visual', 5368 label: (0,external_wp_i18n_namespaceObject.__)('Visual editor') 5369 }, { 5370 value: 'text', 5371 label: (0,external_wp_i18n_namespaceObject.__)('Code editor') 5372 }]; 5373 5374 function ModeSwitcher() { 5375 const { 5376 shortcut, 5377 isRichEditingEnabled, 5378 isCodeEditingEnabled, 5379 isEditingTemplate, 5380 mode 5381 } = (0,external_wp_data_namespaceObject.useSelect)(select => ({ 5382 shortcut: select(external_wp_keyboardShortcuts_namespaceObject.store).getShortcutRepresentation('core/edit-post/toggle-mode'), 5383 isRichEditingEnabled: select(external_wp_editor_namespaceObject.store).getEditorSettings().richEditingEnabled, 5384 isCodeEditingEnabled: select(external_wp_editor_namespaceObject.store).getEditorSettings().codeEditingEnabled, 5385 isEditingTemplate: select(store_store).isEditingTemplate(), 5386 mode: select(store_store).getEditorMode() 5387 }), []); 5388 const { 5389 switchEditorMode 5390 } = (0,external_wp_data_namespaceObject.useDispatch)(store_store); 5391 5392 if (isEditingTemplate) { 5393 return null; 5394 } 5395 5396 if (!isRichEditingEnabled || !isCodeEditingEnabled) { 5397 return null; 5398 } 5399 5400 const choices = MODES.map(choice => { 5401 if (choice.value !== mode) { 5402 return { ...choice, 5403 shortcut 5404 }; 5405 } 5406 5407 return choice; 5408 }); 5409 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuGroup, { 5410 label: (0,external_wp_i18n_namespaceObject.__)('Editor') 5411 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItemsChoice, { 5412 choices: choices, 5413 value: mode, 5414 onSelect: switchEditorMode 5415 })); 5416 } 5417 5418 /* harmony default export */ var mode_switcher = (ModeSwitcher); 5419 5420 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/header/preferences-menu-item/index.js 5421 5422 5423 /** 5424 * WordPress dependencies 5425 */ 5426 5427 5428 5429 /** 5430 * Internal dependencies 5431 */ 5432 5433 5434 function PreferencesMenuItem() { 5435 const { 5436 openModal 5437 } = (0,external_wp_data_namespaceObject.useDispatch)(store_store); 5438 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, { 5439 onClick: () => { 5440 openModal('edit-post/preferences'); 5441 } 5442 }, (0,external_wp_i18n_namespaceObject.__)('Preferences')); 5443 } 5444 5445 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/header/writing-menu/index.js 5446 5447 5448 /** 5449 * WordPress dependencies 5450 */ 5451 5452 5453 5454 5455 5456 5457 function WritingMenu() { 5458 const isLargeViewport = (0,external_wp_compose_namespaceObject.useViewportMatch)('medium'); 5459 5460 if (!isLargeViewport) { 5461 return null; 5462 } 5463 5464 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuGroup, { 5465 label: (0,external_wp_i18n_namespaceObject._x)('View', 'noun') 5466 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_preferences_namespaceObject.PreferenceToggleMenuItem, { 5467 scope: "core/edit-post", 5468 name: "fixedToolbar", 5469 label: (0,external_wp_i18n_namespaceObject.__)('Top toolbar'), 5470 info: (0,external_wp_i18n_namespaceObject.__)('Access all block and document tools in a single place'), 5471 messageActivated: (0,external_wp_i18n_namespaceObject.__)('Top toolbar activated'), 5472 messageDeactivated: (0,external_wp_i18n_namespaceObject.__)('Top toolbar deactivated') 5473 }), (0,external_wp_element_namespaceObject.createElement)(external_wp_preferences_namespaceObject.PreferenceToggleMenuItem, { 5474 scope: "core/edit-post", 5475 name: "focusMode", 5476 label: (0,external_wp_i18n_namespaceObject.__)('Spotlight mode'), 5477 info: (0,external_wp_i18n_namespaceObject.__)('Focus on one block at a time'), 5478 messageActivated: (0,external_wp_i18n_namespaceObject.__)('Spotlight mode activated'), 5479 messageDeactivated: (0,external_wp_i18n_namespaceObject.__)('Spotlight mode deactivated') 5480 }), (0,external_wp_element_namespaceObject.createElement)(external_wp_preferences_namespaceObject.PreferenceToggleMenuItem, { 5481 scope: "core/edit-post", 5482 name: "fullscreenMode", 5483 label: (0,external_wp_i18n_namespaceObject.__)('Fullscreen mode'), 5484 info: (0,external_wp_i18n_namespaceObject.__)('Work without distraction'), 5485 messageActivated: (0,external_wp_i18n_namespaceObject.__)('Fullscreen mode activated'), 5486 messageDeactivated: (0,external_wp_i18n_namespaceObject.__)('Fullscreen mode deactivated'), 5487 shortcut: external_wp_keycodes_namespaceObject.displayShortcut.secondary('f') 5488 })); 5489 } 5490 5491 /* harmony default export */ var writing_menu = (WritingMenu); 5492 5493 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/header/more-menu/index.js 5494 5495 5496 /** 5497 * WordPress dependencies 5498 */ 5499 5500 5501 5502 5503 /** 5504 * Internal dependencies 5505 */ 5506 5507 5508 5509 5510 5511 5512 const MoreMenu = _ref => { 5513 let { 5514 showIconLabels 5515 } = _ref; 5516 const isLargeViewport = (0,external_wp_compose_namespaceObject.useViewportMatch)('large'); 5517 return (0,external_wp_element_namespaceObject.createElement)(MoreMenuDropdown, { 5518 toggleProps: { 5519 showTooltip: !showIconLabels, 5520 ...(showIconLabels && { 5521 variant: 'tertiary' 5522 }) 5523 } 5524 }, _ref2 => { 5525 let { 5526 onClose 5527 } = _ref2; 5528 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, showIconLabels && !isLargeViewport && (0,external_wp_element_namespaceObject.createElement)(pinned_items.Slot, { 5529 className: showIconLabels && 'show-icon-labels', 5530 scope: "core/edit-post" 5531 }), (0,external_wp_element_namespaceObject.createElement)(writing_menu, null), (0,external_wp_element_namespaceObject.createElement)(mode_switcher, null), (0,external_wp_element_namespaceObject.createElement)(action_item.Slot, { 5532 name: "core/edit-post/plugin-more-menu", 5533 label: (0,external_wp_i18n_namespaceObject.__)('Plugins'), 5534 as: external_wp_components_namespaceObject.MenuGroup, 5535 fillProps: { 5536 onClick: onClose 5537 } 5538 }), (0,external_wp_element_namespaceObject.createElement)(tools_more_menu_group.Slot, { 5539 fillProps: { 5540 onClose 5541 } 5542 }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuGroup, null, (0,external_wp_element_namespaceObject.createElement)(PreferencesMenuItem, null))); 5543 }); 5544 }; 5545 5546 /* harmony default export */ var more_menu = (MoreMenu); 5547 5548 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/header/post-publish-button-or-toggle.js 5549 5550 5551 /** 5552 * External dependencies 5553 */ 5554 5555 /** 5556 * WordPress dependencies 5557 */ 5558 5559 5560 5561 5562 /** 5563 * Internal dependencies 5564 */ 5565 5566 5567 function PostPublishButtonOrToggle(_ref) { 5568 let { 5569 forceIsDirty, 5570 forceIsSaving, 5571 hasPublishAction, 5572 isBeingScheduled, 5573 isPending, 5574 isPublished, 5575 isPublishSidebarEnabled, 5576 isPublishSidebarOpened, 5577 isScheduled, 5578 togglePublishSidebar, 5579 setEntitiesSavedStatesCallback 5580 } = _ref; 5581 const IS_TOGGLE = 'toggle'; 5582 const IS_BUTTON = 'button'; 5583 const isSmallerThanMediumViewport = (0,external_wp_compose_namespaceObject.useViewportMatch)('medium', '<'); 5584 let component; 5585 /** 5586 * Conditions to show a BUTTON (publish directly) or a TOGGLE (open publish sidebar): 5587 * 5588 * 1) We want to show a BUTTON when the post status is at the _final stage_ 5589 * for a particular role (see https://wordpress.org/support/article/post-status/): 5590 * 5591 * - is published 5592 * - is scheduled to be published 5593 * - is pending and can't be published (but only for viewports >= medium). 5594 * Originally, we considered showing a button for pending posts that couldn't be published 5595 * (for example, for an author with the contributor role). Some languages can have 5596 * long translations for "Submit for review", so given the lack of UI real estate available 5597 * we decided to take into account the viewport in that case. 5598 * See: https://github.com/WordPress/gutenberg/issues/10475 5599 * 5600 * 2) Then, in small viewports, we'll show a TOGGLE. 5601 * 5602 * 3) Finally, we'll use the publish sidebar status to decide: 5603 * 5604 * - if it is enabled, we show a TOGGLE 5605 * - if it is disabled, we show a BUTTON 5606 */ 5607 5608 if (isPublished || isScheduled && isBeingScheduled || isPending && !hasPublishAction && !isSmallerThanMediumViewport) { 5609 component = IS_BUTTON; 5610 } else if (isSmallerThanMediumViewport) { 5611 component = IS_TOGGLE; 5612 } else if (isPublishSidebarEnabled) { 5613 component = IS_TOGGLE; 5614 } else { 5615 component = IS_BUTTON; 5616 } 5617 5618 return (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostPublishButton, { 5619 forceIsDirty: forceIsDirty, 5620 forceIsSaving: forceIsSaving, 5621 isOpen: isPublishSidebarOpened, 5622 isToggle: component === IS_TOGGLE, 5623 onToggle: togglePublishSidebar, 5624 setEntitiesSavedStatesCallback: setEntitiesSavedStatesCallback 5625 }); 5626 } 5627 /* harmony default export */ var post_publish_button_or_toggle = ((0,external_wp_compose_namespaceObject.compose)((0,external_wp_data_namespaceObject.withSelect)(select => ({ 5628 hasPublishAction: (0,external_lodash_namespaceObject.get)(select(external_wp_editor_namespaceObject.store).getCurrentPost(), ['_links', 'wp:action-publish'], false), 5629 isBeingScheduled: select(external_wp_editor_namespaceObject.store).isEditedPostBeingScheduled(), 5630 isPending: select(external_wp_editor_namespaceObject.store).isCurrentPostPending(), 5631 isPublished: select(external_wp_editor_namespaceObject.store).isCurrentPostPublished(), 5632 isPublishSidebarEnabled: select(external_wp_editor_namespaceObject.store).isPublishSidebarEnabled(), 5633 isPublishSidebarOpened: select(store_store).isPublishSidebarOpened(), 5634 isScheduled: select(external_wp_editor_namespaceObject.store).isCurrentPostScheduled() 5635 })), (0,external_wp_data_namespaceObject.withDispatch)(dispatch => { 5636 const { 5637 togglePublishSidebar 5638 } = dispatch(store_store); 5639 return { 5640 togglePublishSidebar 5641 }; 5642 }))(PostPublishButtonOrToggle)); 5643 5644 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/device-preview/index.js 5645 5646 5647 /** 5648 * WordPress dependencies 5649 */ 5650 5651 5652 5653 5654 5655 5656 /** 5657 * Internal dependencies 5658 */ 5659 5660 5661 function DevicePreview() { 5662 const { 5663 hasActiveMetaboxes, 5664 isPostSaveable, 5665 isSaving, 5666 deviceType 5667 } = (0,external_wp_data_namespaceObject.useSelect)(select => ({ 5668 hasActiveMetaboxes: select(store_store).hasMetaBoxes(), 5669 isSaving: select(store_store).isSavingMetaBoxes(), 5670 isPostSaveable: select(external_wp_editor_namespaceObject.store).isEditedPostSaveable(), 5671 deviceType: select(store_store).__experimentalGetPreviewDeviceType() 5672 }), []); 5673 const { 5674 __experimentalSetPreviewDeviceType: setPreviewDeviceType 5675 } = (0,external_wp_data_namespaceObject.useDispatch)(store_store); 5676 return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.__experimentalPreviewOptions, { 5677 isEnabled: isPostSaveable, 5678 className: "edit-post-post-preview-dropdown", 5679 deviceType: deviceType, 5680 setDeviceType: setPreviewDeviceType 5681 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuGroup, null, (0,external_wp_element_namespaceObject.createElement)("div", { 5682 className: "edit-post-header-preview__grouping-external" 5683 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostPreviewButton, { 5684 className: 'edit-post-header-preview__button-external', 5685 role: "menuitem", 5686 forceIsAutosaveable: hasActiveMetaboxes, 5687 forcePreviewLink: isSaving ? null : undefined, 5688 textContent: (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_i18n_namespaceObject.__)('Preview in new tab'), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Icon, { 5689 icon: library_external 5690 })) 5691 })))); 5692 } 5693 5694 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/header/main-dashboard-button/index.js 5695 5696 5697 /** 5698 * WordPress dependencies 5699 */ 5700 5701 const slotName = '__experimentalMainDashboardButton'; 5702 const { 5703 Fill: main_dashboard_button_Fill, 5704 Slot: MainDashboardButtonSlot 5705 } = (0,external_wp_components_namespaceObject.createSlotFill)(slotName); 5706 const MainDashboardButton = main_dashboard_button_Fill; 5707 5708 const main_dashboard_button_Slot = _ref => { 5709 let { 5710 children 5711 } = _ref; 5712 const slot = (0,external_wp_components_namespaceObject.__experimentalUseSlot)(slotName); 5713 const hasFills = Boolean(slot.fills && slot.fills.length); 5714 5715 if (!hasFills) { 5716 return children; 5717 } 5718 5719 return (0,external_wp_element_namespaceObject.createElement)(MainDashboardButtonSlot, { 5720 bubblesVirtually: true 5721 }); 5722 }; 5723 5724 MainDashboardButton.Slot = main_dashboard_button_Slot; 5725 /* harmony default export */ var main_dashboard_button = (MainDashboardButton); 5726 5727 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/chevron-down.js 5728 5729 5730 /** 5731 * WordPress dependencies 5732 */ 5733 5734 const chevronDown = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 5735 viewBox: "0 0 24 24", 5736 xmlns: "http://www.w3.org/2000/svg" 5737 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 5738 d: "M17.5 11.6L12 16l-5.5-4.4.9-1.2L12 14l4.5-3.6 1 1.2z" 5739 })); 5740 /* harmony default export */ var chevron_down = (chevronDown); 5741 5742 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/header/template-title/delete-template.js 5743 5744 5745 /** 5746 * External dependencies 5747 */ 5748 5749 /** 5750 * WordPress dependencies 5751 */ 5752 5753 5754 5755 5756 5757 5758 5759 5760 /** 5761 * Internal dependencies 5762 */ 5763 5764 5765 function DeleteTemplate() { 5766 const { 5767 clearSelectedBlock 5768 } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_blockEditor_namespaceObject.store); 5769 const { 5770 setIsEditingTemplate 5771 } = (0,external_wp_data_namespaceObject.useDispatch)(store_store); 5772 const { 5773 getEditorSettings 5774 } = (0,external_wp_data_namespaceObject.useSelect)(external_wp_editor_namespaceObject.store); 5775 const { 5776 updateEditorSettings, 5777 editPost 5778 } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_editor_namespaceObject.store); 5779 const { 5780 deleteEntityRecord 5781 } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_coreData_namespaceObject.store); 5782 const { 5783 template 5784 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 5785 const { 5786 isEditingTemplate, 5787 getEditedPostTemplate 5788 } = select(store_store); 5789 5790 const _isEditing = isEditingTemplate(); 5791 5792 return { 5793 template: _isEditing ? getEditedPostTemplate() : null 5794 }; 5795 }, []); 5796 const [showConfirmDialog, setShowConfirmDialog] = (0,external_wp_element_namespaceObject.useState)(false); 5797 5798 if (!template || !template.wp_id) { 5799 return null; 5800 } 5801 5802 let templateTitle = template.slug; 5803 5804 if (template !== null && template !== void 0 && template.title) { 5805 templateTitle = template.title; 5806 } 5807 5808 const onDelete = () => { 5809 clearSelectedBlock(); 5810 setIsEditingTemplate(false); 5811 setShowConfirmDialog(false); 5812 editPost({ 5813 template: '' 5814 }); 5815 const settings = getEditorSettings(); 5816 const newAvailableTemplates = (0,external_lodash_namespaceObject.pickBy)(settings.availableTemplates, (_title, id) => { 5817 return id !== template.slug; 5818 }); 5819 updateEditorSettings({ ...settings, 5820 availableTemplates: newAvailableTemplates 5821 }); 5822 deleteEntityRecord('postType', 'wp_template', template.id, { 5823 throwOnError: true 5824 }); 5825 }; 5826 5827 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuGroup, { 5828 className: "edit-post-template-top-area__second-menu-group" 5829 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, { 5830 className: "edit-post-template-top-area__delete-template-button", 5831 isDestructive: true, 5832 variant: "secondary", 5833 "aria-label": (0,external_wp_i18n_namespaceObject.__)('Delete template'), 5834 onClick: () => { 5835 setShowConfirmDialog(true); 5836 } 5837 }, (0,external_wp_i18n_namespaceObject.__)('Delete template')), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalConfirmDialog, { 5838 isOpen: showConfirmDialog, 5839 onConfirm: onDelete, 5840 onCancel: () => { 5841 setShowConfirmDialog(false); 5842 } 5843 }, (0,external_wp_i18n_namespaceObject.sprintf)( 5844 /* translators: %s: template name */ 5845 (0,external_wp_i18n_namespaceObject.__)('Are you sure you want to delete the %s template? It may be used by other pages or posts.'), templateTitle)))); 5846 } 5847 5848 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/header/template-title/edit-template-title.js 5849 5850 5851 /** 5852 * External dependencies 5853 */ 5854 5855 /** 5856 * WordPress dependencies 5857 */ 5858 5859 5860 5861 5862 5863 5864 /** 5865 * Internal dependencies 5866 */ 5867 5868 5869 function EditTemplateTitle() { 5870 const { 5871 template 5872 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 5873 const { 5874 getEditedPostTemplate 5875 } = select(store_store); 5876 return { 5877 template: getEditedPostTemplate() 5878 }; 5879 }, []); 5880 const { 5881 editEntityRecord 5882 } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_coreData_namespaceObject.store); 5883 const { 5884 getEditorSettings 5885 } = (0,external_wp_data_namespaceObject.useSelect)(external_wp_editor_namespaceObject.store); 5886 const { 5887 updateEditorSettings 5888 } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_editor_namespaceObject.store); 5889 5890 if (template.has_theme_file) { 5891 return null; 5892 } 5893 5894 let templateTitle = (0,external_wp_i18n_namespaceObject.__)('Default'); 5895 5896 if (template !== null && template !== void 0 && template.title) { 5897 templateTitle = template.title; 5898 } else if (!!template) { 5899 templateTitle = template.slug; 5900 } 5901 5902 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, { 5903 label: (0,external_wp_i18n_namespaceObject.__)('Title'), 5904 value: templateTitle, 5905 help: (0,external_wp_i18n_namespaceObject.__)('Give the template a title that indicates its purpose, e.g. "Full Width".'), 5906 onChange: newTitle => { 5907 const settings = getEditorSettings(); 5908 const newAvailableTemplates = (0,external_lodash_namespaceObject.mapValues)(settings.availableTemplates, (existingTitle, id) => { 5909 if (id !== template.slug) { 5910 return existingTitle; 5911 } 5912 5913 return newTitle; 5914 }); 5915 updateEditorSettings({ ...settings, 5916 availableTemplates: newAvailableTemplates 5917 }); 5918 editEntityRecord('postType', 'wp_template', template.id, { 5919 title: newTitle 5920 }); 5921 } 5922 }); 5923 } 5924 5925 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/header/template-title/template-description.js 5926 5927 5928 /** 5929 * WordPress dependencies 5930 */ 5931 5932 5933 /** 5934 * Internal dependencies 5935 */ 5936 5937 5938 function TemplateDescription() { 5939 const { 5940 description, 5941 title 5942 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 5943 const { 5944 getEditedPostTemplate 5945 } = select(store_store); 5946 return { 5947 title: getEditedPostTemplate().title, 5948 description: getEditedPostTemplate().description 5949 }; 5950 }, []); 5951 5952 if (!description) { 5953 return null; 5954 } 5955 5956 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalHeading, { 5957 level: 4, 5958 weight: 600 5959 }, title), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalText, { 5960 className: "edit-post-template-details__description", 5961 size: "body", 5962 as: "p", 5963 style: { 5964 marginTop: '12px' 5965 } 5966 }, description)); 5967 } 5968 5969 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/header/template-title/index.js 5970 5971 5972 /** 5973 * WordPress dependencies 5974 */ 5975 5976 5977 5978 5979 /** 5980 * Internal dependencies 5981 */ 5982 5983 5984 5985 5986 5987 5988 5989 5990 function TemplateTitle() { 5991 const { 5992 template, 5993 isEditing, 5994 title 5995 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 5996 const { 5997 isEditingTemplate, 5998 getEditedPostTemplate 5999 } = select(store_store); 6000 const { 6001 getEditedPostAttribute 6002 } = select(external_wp_editor_namespaceObject.store); 6003 6004 const _isEditing = isEditingTemplate(); 6005 6006 return { 6007 template: _isEditing ? getEditedPostTemplate() : null, 6008 isEditing: _isEditing, 6009 title: getEditedPostAttribute('title') ? getEditedPostAttribute('title') : (0,external_wp_i18n_namespaceObject.__)('Untitled') 6010 }; 6011 }, []); 6012 const { 6013 clearSelectedBlock 6014 } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_blockEditor_namespaceObject.store); 6015 const { 6016 setIsEditingTemplate 6017 } = (0,external_wp_data_namespaceObject.useDispatch)(store_store); 6018 6019 if (!isEditing || !template) { 6020 return null; 6021 } 6022 6023 let templateTitle = (0,external_wp_i18n_namespaceObject.__)('Default'); 6024 6025 if (template !== null && template !== void 0 && template.title) { 6026 templateTitle = template.title; 6027 } else if (!!template) { 6028 templateTitle = template.slug; 6029 } 6030 6031 const hasOptions = !!(template.custom || template.wp_id || template.description); 6032 return (0,external_wp_element_namespaceObject.createElement)("div", { 6033 className: "edit-post-template-top-area" 6034 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 6035 className: "edit-post-template-post-title", 6036 isLink: true, 6037 showTooltip: true, 6038 label: (0,external_wp_i18n_namespaceObject.sprintf)( 6039 /* translators: %s: Title of the referring post, e.g: "Hello World!" */ 6040 (0,external_wp_i18n_namespaceObject.__)('Edit %s'), title), 6041 onClick: () => { 6042 clearSelectedBlock(); 6043 setIsEditingTemplate(false); 6044 } 6045 }, title), hasOptions ? (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Dropdown, { 6046 position: "bottom center", 6047 contentClassName: "edit-post-template-top-area__popover", 6048 renderToggle: _ref => { 6049 let { 6050 onToggle 6051 } = _ref; 6052 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 6053 className: "edit-post-template-title", 6054 isLink: true, 6055 icon: chevron_down, 6056 showTooltip: true, 6057 onClick: onToggle, 6058 label: (0,external_wp_i18n_namespaceObject.__)('Template Options') 6059 }, templateTitle); 6060 }, 6061 renderContent: () => (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(EditTemplateTitle, null), (0,external_wp_element_namespaceObject.createElement)(TemplateDescription, null), (0,external_wp_element_namespaceObject.createElement)(DeleteTemplate, null)) 6062 }) : (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalText, { 6063 className: "edit-post-template-title", 6064 size: "body", 6065 style: { 6066 lineHeight: '24px' 6067 } 6068 }, templateTitle)); 6069 } 6070 6071 /* harmony default export */ var template_title = (TemplateTitle); 6072 6073 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/header/index.js 6074 6075 6076 /** 6077 * External dependencies 6078 */ 6079 6080 /** 6081 * WordPress dependencies 6082 */ 6083 6084 6085 6086 6087 6088 /** 6089 * Internal dependencies 6090 */ 6091 6092 6093 6094 6095 6096 6097 6098 6099 6100 6101 function Header(_ref) { 6102 let { 6103 setEntitiesSavedStatesCallback 6104 } = _ref; 6105 const { 6106 hasActiveMetaboxes, 6107 isPublishSidebarOpened, 6108 isSaving, 6109 showIconLabels, 6110 hasReducedUI 6111 } = (0,external_wp_data_namespaceObject.useSelect)(select => ({ 6112 hasActiveMetaboxes: select(store_store).hasMetaBoxes(), 6113 isPublishSidebarOpened: select(store_store).isPublishSidebarOpened(), 6114 isSaving: select(store_store).isSavingMetaBoxes(), 6115 showIconLabels: select(store_store).isFeatureActive('showIconLabels'), 6116 hasReducedUI: select(store_store).isFeatureActive('reducedUI') 6117 }), []); 6118 const isLargeViewport = (0,external_wp_compose_namespaceObject.useViewportMatch)('large'); 6119 const classes = classnames_default()('edit-post-header', { 6120 'has-reduced-ui': hasReducedUI 6121 }); 6122 return (0,external_wp_element_namespaceObject.createElement)("div", { 6123 className: classes 6124 }, (0,external_wp_element_namespaceObject.createElement)(main_dashboard_button.Slot, null, (0,external_wp_element_namespaceObject.createElement)(fullscreen_mode_close, { 6125 showTooltip: true 6126 })), (0,external_wp_element_namespaceObject.createElement)("div", { 6127 className: "edit-post-header__toolbar" 6128 }, (0,external_wp_element_namespaceObject.createElement)(header_toolbar, null), (0,external_wp_element_namespaceObject.createElement)(template_title, null)), (0,external_wp_element_namespaceObject.createElement)("div", { 6129 className: "edit-post-header__settings" 6130 }, !isPublishSidebarOpened && // This button isn't completely hidden by the publish sidebar. 6131 // We can't hide the whole toolbar when the publish sidebar is open because 6132 // we want to prevent mounting/unmounting the PostPublishButtonOrToggle DOM node. 6133 // We track that DOM node to return focus to the PostPublishButtonOrToggle 6134 // when the publish sidebar has been closed. 6135 (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostSavedState, { 6136 forceIsDirty: hasActiveMetaboxes, 6137 forceIsSaving: isSaving, 6138 showIconLabels: showIconLabels 6139 }), (0,external_wp_element_namespaceObject.createElement)(DevicePreview, null), (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostPreviewButton, { 6140 forceIsAutosaveable: hasActiveMetaboxes, 6141 forcePreviewLink: isSaving ? null : undefined 6142 }), (0,external_wp_element_namespaceObject.createElement)(post_publish_button_or_toggle, { 6143 forceIsDirty: hasActiveMetaboxes, 6144 forceIsSaving: isSaving, 6145 setEntitiesSavedStatesCallback: setEntitiesSavedStatesCallback 6146 }), (isLargeViewport || !showIconLabels) && (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(pinned_items.Slot, { 6147 scope: "core/edit-post" 6148 }), (0,external_wp_element_namespaceObject.createElement)(more_menu, { 6149 showIconLabels: showIconLabels 6150 })), showIconLabels && !isLargeViewport && (0,external_wp_element_namespaceObject.createElement)(more_menu, { 6151 showIconLabels: showIconLabels 6152 }))); 6153 } 6154 6155 /* harmony default export */ var header = (Header); 6156 6157 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/close.js 6158 6159 6160 /** 6161 * WordPress dependencies 6162 */ 6163 6164 const close_close = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 6165 xmlns: "http://www.w3.org/2000/svg", 6166 viewBox: "0 0 24 24" 6167 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 6168 d: "M13 11.8l6.1-6.3-1-1-6.1 6.2-6.1-6.2-1 1 6.1 6.3-6.5 6.7 1 1 6.5-6.6 6.5 6.6 1-1z" 6169 })); 6170 /* harmony default export */ var library_close = (close_close); 6171 6172 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/secondary-sidebar/inserter-sidebar.js 6173 6174 6175 6176 /** 6177 * WordPress dependencies 6178 */ 6179 6180 6181 6182 6183 6184 6185 6186 /** 6187 * Internal dependencies 6188 */ 6189 6190 6191 function InserterSidebar() { 6192 const { 6193 insertionPoint, 6194 showMostUsedBlocks 6195 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 6196 const { 6197 isFeatureActive, 6198 __experimentalGetInsertionPoint 6199 } = select(store_store); 6200 return { 6201 insertionPoint: __experimentalGetInsertionPoint(), 6202 showMostUsedBlocks: isFeatureActive('mostUsedBlocks') 6203 }; 6204 }, []); 6205 const { 6206 setIsInserterOpened 6207 } = (0,external_wp_data_namespaceObject.useDispatch)(store_store); 6208 const isMobileViewport = (0,external_wp_compose_namespaceObject.useViewportMatch)('medium', '<'); 6209 const TagName = !isMobileViewport ? external_wp_components_namespaceObject.VisuallyHidden : 'div'; 6210 const [inserterDialogRef, inserterDialogProps] = (0,external_wp_compose_namespaceObject.__experimentalUseDialog)({ 6211 onClose: () => setIsInserterOpened(false), 6212 focusOnMount: null 6213 }); 6214 const libraryRef = (0,external_wp_element_namespaceObject.useRef)(); 6215 (0,external_wp_element_namespaceObject.useEffect)(() => { 6216 libraryRef.current.focusSearch(); 6217 }, []); 6218 return (0,external_wp_element_namespaceObject.createElement)("div", _extends({ 6219 ref: inserterDialogRef 6220 }, inserterDialogProps, { 6221 className: "edit-post-editor__inserter-panel" 6222 }), (0,external_wp_element_namespaceObject.createElement)(TagName, { 6223 className: "edit-post-editor__inserter-panel-header" 6224 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 6225 icon: library_close, 6226 label: (0,external_wp_i18n_namespaceObject.__)('Close block inserter'), 6227 onClick: () => setIsInserterOpened(false) 6228 })), (0,external_wp_element_namespaceObject.createElement)("div", { 6229 className: "edit-post-editor__inserter-panel-content" 6230 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.__experimentalLibrary, { 6231 showMostUsedBlocks: showMostUsedBlocks, 6232 showInserterHelpPanel: true, 6233 shouldFocusBlock: isMobileViewport, 6234 rootClientId: insertionPoint.rootClientId, 6235 __experimentalInsertionIndex: insertionPoint.insertionIndex, 6236 __experimentalFilterValue: insertionPoint.filterValue, 6237 ref: libraryRef 6238 }))); 6239 } 6240 6241 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/secondary-sidebar/list-view-sidebar.js 6242 6243 6244 /** 6245 * WordPress dependencies 6246 */ 6247 6248 6249 6250 6251 6252 6253 6254 /** 6255 * Internal dependencies 6256 */ 6257 6258 6259 function ListViewSidebar() { 6260 const { 6261 setIsListViewOpened 6262 } = (0,external_wp_data_namespaceObject.useDispatch)(store_store); 6263 const focusOnMountRef = (0,external_wp_compose_namespaceObject.useFocusOnMount)('firstElement'); 6264 const headerFocusReturnRef = (0,external_wp_compose_namespaceObject.useFocusReturn)(); 6265 const contentFocusReturnRef = (0,external_wp_compose_namespaceObject.useFocusReturn)(); 6266 6267 function closeOnEscape(event) { 6268 if (event.keyCode === external_wp_keycodes_namespaceObject.ESCAPE && !event.defaultPrevented) { 6269 event.preventDefault(); 6270 setIsListViewOpened(false); 6271 } 6272 } 6273 6274 const instanceId = (0,external_wp_compose_namespaceObject.useInstanceId)(ListViewSidebar); 6275 const labelId = `edit-post-editor__list-view-panel-label-$instanceId}`; 6276 return (// eslint-disable-next-line jsx-a11y/no-static-element-interactions 6277 (0,external_wp_element_namespaceObject.createElement)("div", { 6278 "aria-labelledby": labelId, 6279 className: "edit-post-editor__list-view-panel", 6280 onKeyDown: closeOnEscape 6281 }, (0,external_wp_element_namespaceObject.createElement)("div", { 6282 className: "edit-post-editor__list-view-panel-header", 6283 ref: headerFocusReturnRef 6284 }, (0,external_wp_element_namespaceObject.createElement)("strong", { 6285 id: labelId 6286 }, (0,external_wp_i18n_namespaceObject.__)('List View')), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 6287 icon: close_small, 6288 label: (0,external_wp_i18n_namespaceObject.__)('Close List View Sidebar'), 6289 onClick: () => setIsListViewOpened(false) 6290 })), (0,external_wp_element_namespaceObject.createElement)("div", { 6291 className: "edit-post-editor__list-view-panel-content", 6292 ref: (0,external_wp_compose_namespaceObject.useMergeRefs)([contentFocusReturnRef, focusOnMountRef]) 6293 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.__experimentalListView, { 6294 showNestedBlocks: true, 6295 __experimentalFeatures: true, 6296 __experimentalPersistentListViewFeatures: true 6297 }))) 6298 ); 6299 } 6300 6301 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/cog.js 6302 6303 6304 /** 6305 * WordPress dependencies 6306 */ 6307 6308 const cog = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 6309 xmlns: "http://www.w3.org/2000/svg", 6310 viewBox: "0 0 24 24" 6311 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 6312 fillRule: "evenodd", 6313 d: "M10.289 4.836A1 1 0 0111.275 4h1.306a1 1 0 01.987.836l.244 1.466c.787.26 1.503.679 2.108 1.218l1.393-.522a1 1 0 011.216.437l.653 1.13a1 1 0 01-.23 1.273l-1.148.944a6.025 6.025 0 010 2.435l1.149.946a1 1 0 01.23 1.272l-.653 1.13a1 1 0 01-1.216.437l-1.394-.522c-.605.54-1.32.958-2.108 1.218l-.244 1.466a1 1 0 01-.987.836h-1.306a1 1 0 01-.986-.836l-.244-1.466a5.995 5.995 0 01-2.108-1.218l-1.394.522a1 1 0 01-1.217-.436l-.653-1.131a1 1 0 01.23-1.272l1.149-.946a6.026 6.026 0 010-2.435l-1.148-.944a1 1 0 01-.23-1.272l.653-1.131a1 1 0 011.217-.437l1.393.522a5.994 5.994 0 012.108-1.218l.244-1.466zM14.929 12a3 3 0 11-6 0 3 3 0 016 0z", 6314 clipRule: "evenodd" 6315 })); 6316 /* harmony default export */ var library_cog = (cog); 6317 6318 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/sidebar/settings-header/index.js 6319 6320 6321 /** 6322 * WordPress dependencies 6323 */ 6324 6325 6326 6327 6328 /** 6329 * Internal dependencies 6330 */ 6331 6332 6333 6334 const SettingsHeader = _ref => { 6335 let { 6336 sidebarName 6337 } = _ref; 6338 const { 6339 openGeneralSidebar 6340 } = (0,external_wp_data_namespaceObject.useDispatch)(store_store); 6341 6342 const openDocumentSettings = () => openGeneralSidebar('edit-post/document'); 6343 6344 const openBlockSettings = () => openGeneralSidebar('edit-post/block'); 6345 6346 const { 6347 documentLabel, 6348 isTemplateMode 6349 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 6350 const postTypeLabel = select(external_wp_editor_namespaceObject.store).getPostTypeLabel(); 6351 return { 6352 // translators: Default label for the Document sidebar tab, not selected. 6353 documentLabel: postTypeLabel || (0,external_wp_i18n_namespaceObject._x)('Document', 'noun'), 6354 isTemplateMode: select(store_store).isEditingTemplate() 6355 }; 6356 }, []); 6357 const [documentAriaLabel, documentActiveClass] = sidebarName === 'edit-post/document' ? // translators: ARIA label for the Document sidebar tab, selected. %s: Document label. 6358 [(0,external_wp_i18n_namespaceObject.sprintf)((0,external_wp_i18n_namespaceObject.__)('%s (selected)'), documentLabel), 'is-active'] : [documentLabel, '']; 6359 const [blockAriaLabel, blockActiveClass] = sidebarName === 'edit-post/block' ? // translators: ARIA label for the Block Settings Sidebar tab, selected. 6360 [(0,external_wp_i18n_namespaceObject.__)('Block (selected)'), 'is-active'] : // translators: ARIA label for the Block Settings Sidebar tab, not selected. 6361 [(0,external_wp_i18n_namespaceObject.__)('Block'), '']; 6362 const [templateAriaLabel, templateActiveClass] = sidebarName === 'edit-post/document' ? [(0,external_wp_i18n_namespaceObject.__)('Template (selected)'), 'is-active'] : [(0,external_wp_i18n_namespaceObject.__)('Template'), '']; 6363 /* Use a list so screen readers will announce how many tabs there are. */ 6364 6365 return (0,external_wp_element_namespaceObject.createElement)("ul", null, !isTemplateMode && (0,external_wp_element_namespaceObject.createElement)("li", null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 6366 onClick: openDocumentSettings, 6367 className: `edit-post-sidebar__panel-tab $documentActiveClass}`, 6368 "aria-label": documentAriaLabel, 6369 "data-label": documentLabel 6370 }, documentLabel)), isTemplateMode && (0,external_wp_element_namespaceObject.createElement)("li", null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 6371 onClick: openDocumentSettings, 6372 className: `edit-post-sidebar__panel-tab $templateActiveClass}`, 6373 "aria-label": templateAriaLabel, 6374 "data-label": (0,external_wp_i18n_namespaceObject.__)('Template') 6375 }, (0,external_wp_i18n_namespaceObject.__)('Template'))), (0,external_wp_element_namespaceObject.createElement)("li", null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 6376 onClick: openBlockSettings, 6377 className: `edit-post-sidebar__panel-tab $blockActiveClass}`, 6378 "aria-label": blockAriaLabel // translators: Data label for the Block Settings Sidebar tab. 6379 , 6380 "data-label": (0,external_wp_i18n_namespaceObject.__)('Block') 6381 }, // translators: Text label for the Block Settings Sidebar tab. 6382 (0,external_wp_i18n_namespaceObject.__)('Block')))); 6383 }; 6384 6385 /* harmony default export */ var settings_header = (SettingsHeader); 6386 6387 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/sidebar/post-visibility/index.js 6388 6389 6390 /** 6391 * WordPress dependencies 6392 */ 6393 6394 6395 6396 function PostVisibility() { 6397 return (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostVisibilityCheck, { 6398 render: _ref => { 6399 let { 6400 canEdit 6401 } = _ref; 6402 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelRow, { 6403 className: "edit-post-post-visibility" 6404 }, (0,external_wp_element_namespaceObject.createElement)("span", null, (0,external_wp_i18n_namespaceObject.__)('Visibility')), !canEdit && (0,external_wp_element_namespaceObject.createElement)("span", null, (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostVisibilityLabel, null)), canEdit && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Dropdown, { 6405 position: "bottom left", 6406 contentClassName: "edit-post-post-visibility__dialog", 6407 renderToggle: _ref2 => { 6408 let { 6409 isOpen, 6410 onToggle 6411 } = _ref2; 6412 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 6413 "aria-expanded": isOpen, 6414 className: "edit-post-post-visibility__toggle", 6415 onClick: onToggle, 6416 variant: "tertiary" 6417 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostVisibilityLabel, null)); 6418 }, 6419 renderContent: () => (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostVisibility, null) 6420 })); 6421 } 6422 }); 6423 } 6424 /* harmony default export */ var post_visibility = (PostVisibility); 6425 6426 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/sidebar/post-trash/index.js 6427 6428 6429 /** 6430 * WordPress dependencies 6431 */ 6432 6433 6434 function PostTrash() { 6435 return (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostTrashCheck, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelRow, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostTrash, null))); 6436 } 6437 6438 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/sidebar/post-schedule/index.js 6439 6440 6441 /** 6442 * WordPress dependencies 6443 */ 6444 6445 6446 6447 6448 function PostSchedule() { 6449 const anchorRef = (0,external_wp_element_namespaceObject.useRef)(); 6450 return (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostScheduleCheck, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelRow, { 6451 className: "edit-post-post-schedule", 6452 ref: anchorRef 6453 }, (0,external_wp_element_namespaceObject.createElement)("span", null, (0,external_wp_i18n_namespaceObject.__)('Publish')), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Dropdown, { 6454 popoverProps: { 6455 anchorRef: anchorRef.current 6456 }, 6457 position: "bottom left", 6458 contentClassName: "edit-post-post-schedule__dialog", 6459 renderToggle: _ref => { 6460 let { 6461 onToggle, 6462 isOpen 6463 } = _ref; 6464 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 6465 className: "edit-post-post-schedule__toggle", 6466 onClick: onToggle, 6467 "aria-expanded": isOpen, 6468 variant: "tertiary" 6469 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostScheduleLabel, null))); 6470 }, 6471 renderContent: () => (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostSchedule, null) 6472 }))); 6473 } 6474 /* harmony default export */ var post_schedule = (PostSchedule); 6475 6476 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/sidebar/post-sticky/index.js 6477 6478 6479 /** 6480 * WordPress dependencies 6481 */ 6482 6483 6484 function PostSticky() { 6485 return (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostStickyCheck, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelRow, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostSticky, null))); 6486 } 6487 /* harmony default export */ var post_sticky = (PostSticky); 6488 6489 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/sidebar/post-author/index.js 6490 6491 6492 /** 6493 * WordPress dependencies 6494 */ 6495 6496 6497 function PostAuthor() { 6498 return (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostAuthorCheck, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelRow, { 6499 className: "edit-post-post-author" 6500 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostAuthor, null))); 6501 } 6502 /* harmony default export */ var post_author = (PostAuthor); 6503 6504 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/sidebar/post-slug/index.js 6505 6506 6507 /** 6508 * WordPress dependencies 6509 */ 6510 6511 6512 function PostSlug() { 6513 return (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostSlugCheck, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelRow, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostSlug, null))); 6514 } 6515 /* harmony default export */ var post_slug = (PostSlug); 6516 6517 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/sidebar/post-format/index.js 6518 6519 6520 /** 6521 * WordPress dependencies 6522 */ 6523 6524 6525 function PostFormat() { 6526 return (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostFormatCheck, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelRow, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostFormat, null))); 6527 } 6528 /* harmony default export */ var post_format = (PostFormat); 6529 6530 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/sidebar/post-pending-status/index.js 6531 6532 6533 /** 6534 * WordPress dependencies 6535 */ 6536 6537 6538 function PostPendingStatus() { 6539 return (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostPendingStatusCheck, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelRow, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostPendingStatus, null))); 6540 } 6541 /* harmony default export */ var post_pending_status = (PostPendingStatus); 6542 6543 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/sidebar/plugin-post-status-info/index.js 6544 6545 6546 /** 6547 * Defines as extensibility slot for the Status & visibility panel. 6548 */ 6549 6550 /** 6551 * WordPress dependencies 6552 */ 6553 6554 const { 6555 Fill: plugin_post_status_info_Fill, 6556 Slot: plugin_post_status_info_Slot 6557 } = (0,external_wp_components_namespaceObject.createSlotFill)('PluginPostStatusInfo'); 6558 /** 6559 * Renders a row in the Status & visibility panel of the Document sidebar. 6560 * It should be noted that this is named and implemented around the function it serves 6561 * and not its location, which may change in future iterations. 6562 * 6563 * @param {Object} props Component properties. 6564 * @param {string} [props.className] An optional class name added to the row. 6565 * @param {WPElement} props.children Children to be rendered. 6566 * 6567 * @example 6568 * ```js 6569 * // Using ES5 syntax 6570 * var __ = wp.i18n.__; 6571 * var PluginPostStatusInfo = wp.editPost.PluginPostStatusInfo; 6572 * 6573 * function MyPluginPostStatusInfo() { 6574 * return wp.element.createElement( 6575 * PluginPostStatusInfo, 6576 * { 6577 * className: 'my-plugin-post-status-info', 6578 * }, 6579 * __( 'My post status info' ) 6580 * ) 6581 * } 6582 * ``` 6583 * 6584 * @example 6585 * ```jsx 6586 * // Using ESNext syntax 6587 * import { __ } from '@wordpress/i18n'; 6588 * import { PluginPostStatusInfo } from '@wordpress/edit-post'; 6589 * 6590 * const MyPluginPostStatusInfo = () => ( 6591 * <PluginPostStatusInfo 6592 * className="my-plugin-post-status-info" 6593 * > 6594 * { __( 'My post status info' ) } 6595 * </PluginPostStatusInfo> 6596 * ); 6597 * ``` 6598 * 6599 * @return {WPComponent} The component to be rendered. 6600 */ 6601 6602 const PluginPostStatusInfo = _ref => { 6603 let { 6604 children, 6605 className 6606 } = _ref; 6607 return (0,external_wp_element_namespaceObject.createElement)(plugin_post_status_info_Fill, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelRow, { 6608 className: className 6609 }, children)); 6610 }; 6611 6612 PluginPostStatusInfo.Slot = plugin_post_status_info_Slot; 6613 /* harmony default export */ var plugin_post_status_info = (PluginPostStatusInfo); 6614 6615 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/sidebar/post-status/index.js 6616 6617 6618 /** 6619 * WordPress dependencies 6620 */ 6621 6622 6623 6624 6625 /** 6626 * Internal dependencies 6627 */ 6628 6629 6630 6631 6632 6633 6634 6635 6636 6637 6638 6639 /** 6640 * Module Constants 6641 */ 6642 6643 const PANEL_NAME = 'post-status'; 6644 6645 function PostStatus(_ref) { 6646 let { 6647 isOpened, 6648 onTogglePanel 6649 } = _ref; 6650 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, { 6651 className: "edit-post-post-status", 6652 title: (0,external_wp_i18n_namespaceObject.__)('Status & visibility'), 6653 opened: isOpened, 6654 onToggle: onTogglePanel 6655 }, (0,external_wp_element_namespaceObject.createElement)(plugin_post_status_info.Slot, null, fills => (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(post_visibility, null), (0,external_wp_element_namespaceObject.createElement)(post_schedule, null), (0,external_wp_element_namespaceObject.createElement)(post_format, null), (0,external_wp_element_namespaceObject.createElement)(post_sticky, null), (0,external_wp_element_namespaceObject.createElement)(post_pending_status, null), (0,external_wp_element_namespaceObject.createElement)(post_slug, null), (0,external_wp_element_namespaceObject.createElement)(post_author, null), fills, (0,external_wp_element_namespaceObject.createElement)(PostTrash, null)))); 6656 } 6657 6658 /* harmony default export */ var post_status = ((0,external_wp_compose_namespaceObject.compose)([(0,external_wp_data_namespaceObject.withSelect)(select => { 6659 // We use isEditorPanelRemoved to hide the panel if it was programatically removed. We do 6660 // not use isEditorPanelEnabled since this panel should not be disabled through the UI. 6661 const { 6662 isEditorPanelRemoved, 6663 isEditorPanelOpened 6664 } = select(store_store); 6665 return { 6666 isRemoved: isEditorPanelRemoved(PANEL_NAME), 6667 isOpened: isEditorPanelOpened(PANEL_NAME) 6668 }; 6669 }), (0,external_wp_compose_namespaceObject.ifCondition)(_ref2 => { 6670 let { 6671 isRemoved 6672 } = _ref2; 6673 return !isRemoved; 6674 }), (0,external_wp_data_namespaceObject.withDispatch)(dispatch => ({ 6675 onTogglePanel() { 6676 return dispatch(store_store).toggleEditorPanelOpened(PANEL_NAME); 6677 } 6678 6679 }))])(PostStatus)); 6680 6681 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/sidebar/last-revision/index.js 6682 6683 6684 /** 6685 * WordPress dependencies 6686 */ 6687 6688 6689 6690 function LastRevision() { 6691 return (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostLastRevisionCheck, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, { 6692 className: "edit-post-last-revision__panel" 6693 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostLastRevision, null))); 6694 } 6695 6696 /* harmony default export */ var last_revision = (LastRevision); 6697 6698 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/sidebar/post-taxonomies/taxonomy-panel.js 6699 6700 6701 /** 6702 * External dependencies 6703 */ 6704 6705 /** 6706 * WordPress dependencies 6707 */ 6708 6709 6710 6711 6712 /** 6713 * Internal dependencies 6714 */ 6715 6716 6717 6718 function TaxonomyPanel(_ref) { 6719 let { 6720 isEnabled, 6721 taxonomy, 6722 isOpened, 6723 onTogglePanel, 6724 children 6725 } = _ref; 6726 6727 if (!isEnabled) { 6728 return null; 6729 } 6730 6731 const taxonomyMenuName = (0,external_lodash_namespaceObject.get)(taxonomy, ['labels', 'menu_name']); 6732 6733 if (!taxonomyMenuName) { 6734 return null; 6735 } 6736 6737 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, { 6738 title: taxonomyMenuName, 6739 opened: isOpened, 6740 onToggle: onTogglePanel 6741 }, children); 6742 } 6743 6744 /* harmony default export */ var taxonomy_panel = ((0,external_wp_compose_namespaceObject.compose)((0,external_wp_data_namespaceObject.withSelect)((select, ownProps) => { 6745 const slug = (0,external_lodash_namespaceObject.get)(ownProps.taxonomy, ['slug']); 6746 const panelName = slug ? `taxonomy-panel-$slug}` : ''; 6747 return { 6748 panelName, 6749 isEnabled: slug ? select(store_store).isEditorPanelEnabled(panelName) : false, 6750 isOpened: slug ? select(store_store).isEditorPanelOpened(panelName) : false 6751 }; 6752 }), (0,external_wp_data_namespaceObject.withDispatch)((dispatch, ownProps) => ({ 6753 onTogglePanel: () => { 6754 dispatch(store_store).toggleEditorPanelOpened(ownProps.panelName); 6755 } 6756 })))(TaxonomyPanel)); 6757 6758 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/sidebar/post-taxonomies/index.js 6759 6760 6761 /** 6762 * WordPress dependencies 6763 */ 6764 6765 /** 6766 * Internal dependencies 6767 */ 6768 6769 6770 6771 function PostTaxonomies() { 6772 return (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostTaxonomiesCheck, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostTaxonomies, { 6773 taxonomyWrapper: (content, taxonomy) => { 6774 return (0,external_wp_element_namespaceObject.createElement)(taxonomy_panel, { 6775 taxonomy: taxonomy 6776 }, content); 6777 } 6778 })); 6779 } 6780 6781 /* harmony default export */ var post_taxonomies = (PostTaxonomies); 6782 6783 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/sidebar/featured-image/index.js 6784 6785 6786 /** 6787 * External dependencies 6788 */ 6789 6790 /** 6791 * WordPress dependencies 6792 */ 6793 6794 6795 6796 6797 6798 6799 6800 /** 6801 * Internal dependencies 6802 */ 6803 6804 6805 /** 6806 * Module Constants 6807 */ 6808 6809 const featured_image_PANEL_NAME = 'featured-image'; 6810 6811 function FeaturedImage(_ref) { 6812 let { 6813 isEnabled, 6814 isOpened, 6815 postType, 6816 onTogglePanel 6817 } = _ref; 6818 6819 if (!isEnabled) { 6820 return null; 6821 } 6822 6823 return (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostFeaturedImageCheck, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, { 6824 title: (0,external_lodash_namespaceObject.get)(postType, ['labels', 'featured_image'], (0,external_wp_i18n_namespaceObject.__)('Featured image')), 6825 opened: isOpened, 6826 onToggle: onTogglePanel 6827 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostFeaturedImage, null))); 6828 } 6829 6830 const applyWithSelect = (0,external_wp_data_namespaceObject.withSelect)(select => { 6831 const { 6832 getEditedPostAttribute 6833 } = select(external_wp_editor_namespaceObject.store); 6834 const { 6835 getPostType 6836 } = select(external_wp_coreData_namespaceObject.store); 6837 const { 6838 isEditorPanelEnabled, 6839 isEditorPanelOpened 6840 } = select(store_store); 6841 return { 6842 postType: getPostType(getEditedPostAttribute('type')), 6843 isEnabled: isEditorPanelEnabled(featured_image_PANEL_NAME), 6844 isOpened: isEditorPanelOpened(featured_image_PANEL_NAME) 6845 }; 6846 }); 6847 const applyWithDispatch = (0,external_wp_data_namespaceObject.withDispatch)(dispatch => { 6848 const { 6849 toggleEditorPanelOpened 6850 } = dispatch(store_store); 6851 return { 6852 onTogglePanel: (0,external_lodash_namespaceObject.partial)(toggleEditorPanelOpened, featured_image_PANEL_NAME) 6853 }; 6854 }); 6855 /* harmony default export */ var featured_image = ((0,external_wp_compose_namespaceObject.compose)(applyWithSelect, applyWithDispatch)(FeaturedImage)); 6856 6857 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/sidebar/post-excerpt/index.js 6858 6859 6860 /** 6861 * WordPress dependencies 6862 */ 6863 6864 6865 6866 6867 6868 /** 6869 * Internal dependencies 6870 */ 6871 6872 6873 /** 6874 * Module Constants 6875 */ 6876 6877 const post_excerpt_PANEL_NAME = 'post-excerpt'; 6878 6879 function PostExcerpt(_ref) { 6880 let { 6881 isEnabled, 6882 isOpened, 6883 onTogglePanel 6884 } = _ref; 6885 6886 if (!isEnabled) { 6887 return null; 6888 } 6889 6890 return (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostExcerptCheck, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, { 6891 title: (0,external_wp_i18n_namespaceObject.__)('Excerpt'), 6892 opened: isOpened, 6893 onToggle: onTogglePanel 6894 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostExcerpt, null))); 6895 } 6896 6897 /* harmony default export */ var post_excerpt = ((0,external_wp_compose_namespaceObject.compose)([(0,external_wp_data_namespaceObject.withSelect)(select => { 6898 return { 6899 isEnabled: select(store_store).isEditorPanelEnabled(post_excerpt_PANEL_NAME), 6900 isOpened: select(store_store).isEditorPanelOpened(post_excerpt_PANEL_NAME) 6901 }; 6902 }), (0,external_wp_data_namespaceObject.withDispatch)(dispatch => ({ 6903 onTogglePanel() { 6904 return dispatch(store_store).toggleEditorPanelOpened(post_excerpt_PANEL_NAME); 6905 } 6906 6907 }))])(PostExcerpt)); 6908 6909 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/sidebar/post-link/index.js 6910 6911 6912 /** 6913 * External dependencies 6914 */ 6915 6916 /** 6917 * WordPress dependencies 6918 */ 6919 6920 6921 6922 6923 6924 6925 6926 6927 6928 /** 6929 * Internal dependencies 6930 */ 6931 6932 6933 /** 6934 * Module Constants 6935 */ 6936 6937 const post_link_PANEL_NAME = 'post-link'; 6938 6939 function PostLink(_ref) { 6940 let { 6941 isOpened, 6942 onTogglePanel, 6943 isEditable, 6944 postLink, 6945 permalinkPrefix, 6946 permalinkSuffix, 6947 editPermalink, 6948 postSlug, 6949 postTypeLabel 6950 } = _ref; 6951 const [forceEmptyField, setForceEmptyField] = (0,external_wp_element_namespaceObject.useState)(false); 6952 let prefixElement, postNameElement, suffixElement; 6953 6954 if (isEditable) { 6955 prefixElement = permalinkPrefix && (0,external_wp_element_namespaceObject.createElement)("span", { 6956 className: "edit-post-post-link__link-prefix" 6957 }, permalinkPrefix); 6958 postNameElement = postSlug && (0,external_wp_element_namespaceObject.createElement)("span", { 6959 className: "edit-post-post-link__link-post-name" 6960 }, postSlug); 6961 suffixElement = permalinkSuffix && (0,external_wp_element_namespaceObject.createElement)("span", { 6962 className: "edit-post-post-link__link-suffix" 6963 }, permalinkSuffix); 6964 } 6965 6966 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, { 6967 title: (0,external_wp_i18n_namespaceObject.__)('Permalink'), 6968 opened: isOpened, 6969 onToggle: onTogglePanel 6970 }, isEditable && (0,external_wp_element_namespaceObject.createElement)("div", { 6971 className: "editor-post-link" 6972 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, { 6973 label: (0,external_wp_i18n_namespaceObject.__)('URL Slug'), 6974 value: forceEmptyField ? '' : postSlug, 6975 autoComplete: "off", 6976 spellCheck: "false", 6977 onChange: newValue => { 6978 editPermalink(newValue); // When we delete the field the permalink gets 6979 // reverted to the original value. 6980 // The forceEmptyField logic allows the user to have 6981 // the field temporarily empty while typing. 6982 6983 if (!newValue) { 6984 if (!forceEmptyField) { 6985 setForceEmptyField(true); 6986 } 6987 6988 return; 6989 } 6990 6991 if (forceEmptyField) { 6992 setForceEmptyField(false); 6993 } 6994 }, 6995 onBlur: event => { 6996 editPermalink((0,external_wp_url_namespaceObject.cleanForSlug)(event.target.value)); 6997 6998 if (forceEmptyField) { 6999 setForceEmptyField(false); 7000 } 7001 } 7002 }), (0,external_wp_element_namespaceObject.createElement)("p", null, (0,external_wp_i18n_namespaceObject.__)('The last part of the URL.'), ' ', (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ExternalLink, { 7003 href: (0,external_wp_i18n_namespaceObject.__)('https://wordpress.org/support/article/settings-sidebar/#permalink') 7004 }, (0,external_wp_i18n_namespaceObject.__)('Read about permalinks')))), (0,external_wp_element_namespaceObject.createElement)("h3", { 7005 className: "edit-post-post-link__preview-label" 7006 }, postTypeLabel || (0,external_wp_i18n_namespaceObject.__)('View post')), (0,external_wp_element_namespaceObject.createElement)("div", { 7007 className: "edit-post-post-link__preview-link-container" 7008 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ExternalLink, { 7009 className: "edit-post-post-link__link", 7010 href: postLink, 7011 target: "_blank" 7012 }, isEditable ? (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, prefixElement, postNameElement, suffixElement) : postLink))); 7013 } 7014 7015 /* harmony default export */ var post_link = ((0,external_wp_compose_namespaceObject.compose)([(0,external_wp_data_namespaceObject.withSelect)(select => { 7016 const { 7017 isPermalinkEditable, 7018 getCurrentPost, 7019 isCurrentPostPublished, 7020 getPermalinkParts, 7021 getEditedPostAttribute, 7022 getEditedPostSlug 7023 } = select(external_wp_editor_namespaceObject.store); 7024 const { 7025 isEditorPanelEnabled, 7026 isEditorPanelOpened 7027 } = select(store_store); 7028 const { 7029 getPostType 7030 } = select(external_wp_coreData_namespaceObject.store); 7031 const { 7032 link 7033 } = getCurrentPost(); 7034 const postTypeName = getEditedPostAttribute('type'); 7035 const postType = getPostType(postTypeName); 7036 const permalinkParts = getPermalinkParts(); 7037 return { 7038 postLink: link, 7039 isEditable: isPermalinkEditable(), 7040 isPublished: isCurrentPostPublished(), 7041 isOpened: isEditorPanelOpened(post_link_PANEL_NAME), 7042 isEnabled: isEditorPanelEnabled(post_link_PANEL_NAME), 7043 isViewable: (0,external_lodash_namespaceObject.get)(postType, ['viewable'], false), 7044 postSlug: (0,external_wp_url_namespaceObject.safeDecodeURIComponent)(getEditedPostSlug()), 7045 postTypeLabel: (0,external_lodash_namespaceObject.get)(postType, ['labels', 'view_item']), 7046 hasPermalinkParts: !!permalinkParts, 7047 permalinkPrefix: permalinkParts === null || permalinkParts === void 0 ? void 0 : permalinkParts.prefix, 7048 permalinkSuffix: permalinkParts === null || permalinkParts === void 0 ? void 0 : permalinkParts.suffix 7049 }; 7050 }), (0,external_wp_compose_namespaceObject.ifCondition)(_ref2 => { 7051 let { 7052 isEnabled, 7053 postLink, 7054 isViewable, 7055 hasPermalinkParts 7056 } = _ref2; 7057 return isEnabled && postLink && isViewable && hasPermalinkParts; 7058 }), (0,external_wp_data_namespaceObject.withDispatch)(dispatch => { 7059 const { 7060 toggleEditorPanelOpened 7061 } = dispatch(store_store); 7062 const { 7063 editPost 7064 } = dispatch(external_wp_editor_namespaceObject.store); 7065 return { 7066 onTogglePanel: () => toggleEditorPanelOpened(post_link_PANEL_NAME), 7067 editPermalink: newSlug => { 7068 editPost({ 7069 slug: newSlug 7070 }); 7071 } 7072 }; 7073 })])(PostLink)); 7074 7075 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/sidebar/discussion-panel/index.js 7076 7077 7078 /** 7079 * WordPress dependencies 7080 */ 7081 7082 7083 7084 7085 7086 /** 7087 * Internal dependencies 7088 */ 7089 7090 7091 /** 7092 * Module Constants 7093 */ 7094 7095 const discussion_panel_PANEL_NAME = 'discussion-panel'; 7096 7097 function DiscussionPanel(_ref) { 7098 let { 7099 isEnabled, 7100 isOpened, 7101 onTogglePanel 7102 } = _ref; 7103 7104 if (!isEnabled) { 7105 return null; 7106 } 7107 7108 return (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostTypeSupportCheck, { 7109 supportKeys: ['comments', 'trackbacks'] 7110 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, { 7111 title: (0,external_wp_i18n_namespaceObject.__)('Discussion'), 7112 opened: isOpened, 7113 onToggle: onTogglePanel 7114 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostTypeSupportCheck, { 7115 supportKeys: "comments" 7116 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelRow, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostComments, null))), (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostTypeSupportCheck, { 7117 supportKeys: "trackbacks" 7118 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelRow, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostPingbacks, null))))); 7119 } 7120 7121 /* harmony default export */ var discussion_panel = ((0,external_wp_compose_namespaceObject.compose)([(0,external_wp_data_namespaceObject.withSelect)(select => { 7122 return { 7123 isEnabled: select(store_store).isEditorPanelEnabled(discussion_panel_PANEL_NAME), 7124 isOpened: select(store_store).isEditorPanelOpened(discussion_panel_PANEL_NAME) 7125 }; 7126 }), (0,external_wp_data_namespaceObject.withDispatch)(dispatch => ({ 7127 onTogglePanel() { 7128 return dispatch(store_store).toggleEditorPanelOpened(discussion_panel_PANEL_NAME); 7129 } 7130 7131 }))])(DiscussionPanel)); 7132 7133 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/sidebar/page-attributes/index.js 7134 7135 7136 /** 7137 * External dependencies 7138 */ 7139 7140 /** 7141 * WordPress dependencies 7142 */ 7143 7144 7145 7146 7147 7148 7149 /** 7150 * Internal dependencies 7151 */ 7152 7153 7154 /** 7155 * Module Constants 7156 */ 7157 7158 const page_attributes_PANEL_NAME = 'page-attributes'; 7159 function PageAttributes() { 7160 const { 7161 isEnabled, 7162 isOpened, 7163 postType 7164 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 7165 const { 7166 getEditedPostAttribute 7167 } = select(external_wp_editor_namespaceObject.store); 7168 const { 7169 isEditorPanelEnabled, 7170 isEditorPanelOpened 7171 } = select(store_store); 7172 const { 7173 getPostType 7174 } = select(external_wp_coreData_namespaceObject.store); 7175 return { 7176 isEnabled: isEditorPanelEnabled(page_attributes_PANEL_NAME), 7177 isOpened: isEditorPanelOpened(page_attributes_PANEL_NAME), 7178 postType: getPostType(getEditedPostAttribute('type')) 7179 }; 7180 }, []); 7181 const { 7182 toggleEditorPanelOpened 7183 } = (0,external_wp_data_namespaceObject.useDispatch)(store_store); 7184 7185 if (!isEnabled || !postType) { 7186 return null; 7187 } 7188 7189 const onTogglePanel = (0,external_lodash_namespaceObject.partial)(toggleEditorPanelOpened, page_attributes_PANEL_NAME); 7190 return (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PageAttributesCheck, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, { 7191 title: (0,external_lodash_namespaceObject.get)(postType, ['labels', 'attributes'], (0,external_wp_i18n_namespaceObject.__)('Page attributes')), 7192 opened: isOpened, 7193 onToggle: onTogglePanel 7194 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PageAttributesParent, null), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelRow, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PageAttributesOrder, null)))); 7195 } 7196 /* harmony default export */ var page_attributes = (PageAttributes); 7197 7198 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/meta-boxes/meta-boxes-area/index.js 7199 7200 7201 /** 7202 * External dependencies 7203 */ 7204 7205 /** 7206 * WordPress dependencies 7207 */ 7208 7209 7210 7211 7212 /** 7213 * Internal dependencies 7214 */ 7215 7216 7217 /** 7218 * Render metabox area. 7219 * 7220 * @param {Object} props Component props. 7221 * @param {string} props.location metabox location. 7222 * @return {WPComponent} The component to be rendered. 7223 */ 7224 7225 function MetaBoxesArea(_ref) { 7226 let { 7227 location 7228 } = _ref; 7229 const container = (0,external_wp_element_namespaceObject.useRef)(null); 7230 const formRef = (0,external_wp_element_namespaceObject.useRef)(null); 7231 (0,external_wp_element_namespaceObject.useEffect)(() => { 7232 formRef.current = document.querySelector('.metabox-location-' + location); 7233 7234 if (formRef.current) { 7235 container.current.appendChild(formRef.current); 7236 } 7237 7238 return () => { 7239 if (formRef.current) { 7240 document.querySelector('#metaboxes').appendChild(formRef.current); 7241 } 7242 }; 7243 }, [location]); 7244 const isSaving = (0,external_wp_data_namespaceObject.useSelect)(select => { 7245 return select(store_store).isSavingMetaBoxes(); 7246 }, []); 7247 const classes = classnames_default()('edit-post-meta-boxes-area', `is-$location}`, { 7248 'is-loading': isSaving 7249 }); 7250 return (0,external_wp_element_namespaceObject.createElement)("div", { 7251 className: classes 7252 }, isSaving && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Spinner, null), (0,external_wp_element_namespaceObject.createElement)("div", { 7253 className: "edit-post-meta-boxes-area__container", 7254 ref: container 7255 }), (0,external_wp_element_namespaceObject.createElement)("div", { 7256 className: "edit-post-meta-boxes-area__clear" 7257 })); 7258 } 7259 7260 /* harmony default export */ var meta_boxes_area = (MetaBoxesArea); 7261 7262 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/meta-boxes/meta-box-visibility.js 7263 /** 7264 * WordPress dependencies 7265 */ 7266 7267 7268 /** 7269 * Internal dependencies 7270 */ 7271 7272 7273 7274 class MetaBoxVisibility extends external_wp_element_namespaceObject.Component { 7275 componentDidMount() { 7276 this.updateDOM(); 7277 } 7278 7279 componentDidUpdate(prevProps) { 7280 if (this.props.isVisible !== prevProps.isVisible) { 7281 this.updateDOM(); 7282 } 7283 } 7284 7285 updateDOM() { 7286 const { 7287 id, 7288 isVisible 7289 } = this.props; 7290 const element = document.getElementById(id); 7291 7292 if (!element) { 7293 return; 7294 } 7295 7296 if (isVisible) { 7297 element.classList.remove('is-hidden'); 7298 } else { 7299 element.classList.add('is-hidden'); 7300 } 7301 } 7302 7303 render() { 7304 return null; 7305 } 7306 7307 } 7308 7309 /* harmony default export */ var meta_box_visibility = ((0,external_wp_data_namespaceObject.withSelect)((select, _ref) => { 7310 let { 7311 id 7312 } = _ref; 7313 return { 7314 isVisible: select(store_store).isEditorPanelEnabled(`meta-box-$id}`) 7315 }; 7316 })(MetaBoxVisibility)); 7317 7318 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/meta-boxes/index.js 7319 7320 7321 /** 7322 * External dependencies 7323 */ 7324 7325 /** 7326 * WordPress dependencies 7327 */ 7328 7329 7330 7331 7332 /** 7333 * Internal dependencies 7334 */ 7335 7336 7337 7338 7339 function MetaBoxes(_ref) { 7340 let { 7341 location 7342 } = _ref; 7343 const registry = (0,external_wp_data_namespaceObject.useRegistry)(); 7344 const { 7345 metaBoxes, 7346 areMetaBoxesInitialized, 7347 isEditorReady 7348 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 7349 const { 7350 __unstableIsEditorReady 7351 } = select(external_wp_editor_namespaceObject.store); 7352 const { 7353 getMetaBoxesPerLocation, 7354 areMetaBoxesInitialized: _areMetaBoxesInitialized 7355 } = select(store_store); 7356 return { 7357 metaBoxes: getMetaBoxesPerLocation(location), 7358 areMetaBoxesInitialized: _areMetaBoxesInitialized(), 7359 isEditorReady: __unstableIsEditorReady() 7360 }; 7361 }, [location]); // When editor is ready, initialize postboxes (wp core script) and metabox 7362 // saving. This initializes all meta box locations, not just this specific 7363 // one. 7364 7365 (0,external_wp_element_namespaceObject.useEffect)(() => { 7366 if (isEditorReady && !areMetaBoxesInitialized) { 7367 registry.dispatch(store_store).initializeMetaBoxes(); 7368 } 7369 }, [isEditorReady, areMetaBoxesInitialized]); 7370 7371 if (!areMetaBoxesInitialized) { 7372 return null; 7373 } 7374 7375 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_lodash_namespaceObject.map)(metaBoxes, _ref2 => { 7376 let { 7377 id 7378 } = _ref2; 7379 return (0,external_wp_element_namespaceObject.createElement)(meta_box_visibility, { 7380 key: id, 7381 id: id 7382 }); 7383 }), (0,external_wp_element_namespaceObject.createElement)(meta_boxes_area, { 7384 location: location 7385 })); 7386 } 7387 7388 ;// CONCATENATED MODULE: external ["wp","warning"] 7389 var external_wp_warning_namespaceObject = window["wp"]["warning"]; 7390 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/sidebar/plugin-document-setting-panel/index.js 7391 7392 7393 /** 7394 * Defines as extensibility slot for the Settings sidebar 7395 */ 7396 7397 /** 7398 * WordPress dependencies 7399 */ 7400 7401 7402 7403 7404 7405 /** 7406 * Internal dependencies 7407 */ 7408 7409 7410 7411 const { 7412 Fill: plugin_document_setting_panel_Fill, 7413 Slot: plugin_document_setting_panel_Slot 7414 } = (0,external_wp_components_namespaceObject.createSlotFill)('PluginDocumentSettingPanel'); 7415 7416 const PluginDocumentSettingFill = _ref => { 7417 let { 7418 isEnabled, 7419 panelName, 7420 opened, 7421 onToggle, 7422 className, 7423 title, 7424 icon, 7425 children 7426 } = _ref; 7427 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(enable_plugin_document_setting_panel, { 7428 label: title, 7429 panelName: panelName 7430 }), (0,external_wp_element_namespaceObject.createElement)(plugin_document_setting_panel_Fill, null, isEnabled && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, { 7431 className: className, 7432 title: title, 7433 icon: icon, 7434 opened: opened, 7435 onToggle: onToggle 7436 }, children))); 7437 }; 7438 /** 7439 * Renders items below the Status & Availability panel in the Document Sidebar. 7440 * 7441 * @param {Object} props Component properties. 7442 * @param {string} [props.name] The machine-friendly name for the panel. 7443 * @param {string} [props.className] An optional class name added to the row. 7444 * @param {string} [props.title] The title of the panel 7445 * @param {WPBlockTypeIconRender} [props.icon=inherits from the plugin] The [Dashicon](https://developer.wordpress.org/resource/dashicons/) icon slug string, or an SVG WP element, to be rendered when the sidebar is pinned to toolbar. 7446 * 7447 * @example 7448 * ```js 7449 * // Using ES5 syntax 7450 * var el = wp.element.createElement; 7451 * var __ = wp.i18n.__; 7452 * var registerPlugin = wp.plugins.registerPlugin; 7453 * var PluginDocumentSettingPanel = wp.editPost.PluginDocumentSettingPanel; 7454 * 7455 * function MyDocumentSettingPlugin() { 7456 * return el( 7457 * PluginDocumentSettingPanel, 7458 * { 7459 * className: 'my-document-setting-plugin', 7460 * title: 'My Panel', 7461 * }, 7462 * __( 'My Document Setting Panel' ) 7463 * ); 7464 * } 7465 * 7466 * registerPlugin( 'my-document-setting-plugin', { 7467 * render: MyDocumentSettingPlugin 7468 * } ); 7469 * ``` 7470 * 7471 * @example 7472 * ```jsx 7473 * // Using ESNext syntax 7474 * import { registerPlugin } from '@wordpress/plugins'; 7475 * import { PluginDocumentSettingPanel } from '@wordpress/edit-post'; 7476 * 7477 * const MyDocumentSettingTest = () => ( 7478 * <PluginDocumentSettingPanel className="my-document-setting-plugin" title="My Panel"> 7479 * <p>My Document Setting Panel</p> 7480 * </PluginDocumentSettingPanel> 7481 * ); 7482 * 7483 * registerPlugin( 'document-setting-test', { render: MyDocumentSettingTest } ); 7484 * ``` 7485 * 7486 * @return {WPComponent} The component to be rendered. 7487 */ 7488 7489 7490 const PluginDocumentSettingPanel = (0,external_wp_compose_namespaceObject.compose)((0,external_wp_plugins_namespaceObject.withPluginContext)((context, ownProps) => { 7491 if (undefined === ownProps.name) { 7492 typeof process !== "undefined" && process.env && "production" !== "production" ? 0 : void 0; 7493 } 7494 7495 return { 7496 icon: ownProps.icon || context.icon, 7497 panelName: `$context.name}/$ownProps.name}` 7498 }; 7499 }), (0,external_wp_data_namespaceObject.withSelect)((select, _ref2) => { 7500 let { 7501 panelName 7502 } = _ref2; 7503 return { 7504 opened: select(store_store).isEditorPanelOpened(panelName), 7505 isEnabled: select(store_store).isEditorPanelEnabled(panelName) 7506 }; 7507 }), (0,external_wp_data_namespaceObject.withDispatch)((dispatch, _ref3) => { 7508 let { 7509 panelName 7510 } = _ref3; 7511 return { 7512 onToggle() { 7513 return dispatch(store_store).toggleEditorPanelOpened(panelName); 7514 } 7515 7516 }; 7517 }))(PluginDocumentSettingFill); 7518 PluginDocumentSettingPanel.Slot = plugin_document_setting_panel_Slot; 7519 /* harmony default export */ var plugin_document_setting_panel = (PluginDocumentSettingPanel); 7520 7521 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/sidebar/plugin-sidebar/index.js 7522 7523 7524 7525 /** 7526 * WordPress dependencies 7527 */ 7528 7529 7530 7531 7532 7533 /** 7534 * Internal dependencies 7535 */ 7536 7537 7538 /** 7539 * Renders a sidebar when activated. The contents within the `PluginSidebar` will appear as content within the sidebar. 7540 * It also automatically renders a corresponding `PluginSidebarMenuItem` component when `isPinnable` flag is set to `true`. 7541 * If you wish to display the sidebar, you can with use the `PluginSidebarMoreMenuItem` component or the `wp.data.dispatch` API: 7542 * 7543 * ```js 7544 * wp.data.dispatch( 'core/edit-post' ).openGeneralSidebar( 'plugin-name/sidebar-name' ); 7545 * ``` 7546 * 7547 * @see PluginSidebarMoreMenuItem 7548 * 7549 * @param {Object} props Element props. 7550 * @param {string} props.name A string identifying the sidebar. Must be unique for every sidebar registered within the scope of your plugin. 7551 * @param {string} [props.className] An optional class name added to the sidebar body. 7552 * @param {string} props.title Title displayed at the top of the sidebar. 7553 * @param {boolean} [props.isPinnable=true] Whether to allow to pin sidebar to the toolbar. When set to `true` it also automatically renders a corresponding menu item. 7554 * @param {WPBlockTypeIconRender} [props.icon=inherits from the plugin] The [Dashicon](https://developer.wordpress.org/resource/dashicons/) icon slug string, or an SVG WP element, to be rendered when the sidebar is pinned to toolbar. 7555 * 7556 * @example 7557 * ```js 7558 * // Using ES5 syntax 7559 * var __ = wp.i18n.__; 7560 * var el = wp.element.createElement; 7561 * var PanelBody = wp.components.PanelBody; 7562 * var PluginSidebar = wp.editPost.PluginSidebar; 7563 * var moreIcon = wp.element.createElement( 'svg' ); //... svg element. 7564 * 7565 * function MyPluginSidebar() { 7566 * return el( 7567 * PluginSidebar, 7568 * { 7569 * name: 'my-sidebar', 7570 * title: 'My sidebar title', 7571 * icon: moreIcon, 7572 * }, 7573 * el( 7574 * PanelBody, 7575 * {}, 7576 * __( 'My sidebar content' ) 7577 * ) 7578 * ); 7579 * } 7580 * ``` 7581 * 7582 * @example 7583 * ```jsx 7584 * // Using ESNext syntax 7585 * import { __ } from '@wordpress/i18n'; 7586 * import { PanelBody } from '@wordpress/components'; 7587 * import { PluginSidebar } from '@wordpress/edit-post'; 7588 * import { more } from '@wordpress/icons'; 7589 * 7590 * const MyPluginSidebar = () => ( 7591 * <PluginSidebar 7592 * name="my-sidebar" 7593 * title="My sidebar title" 7594 * icon={ more } 7595 * > 7596 * <PanelBody> 7597 * { __( 'My sidebar content' ) } 7598 * </PanelBody> 7599 * </PluginSidebar> 7600 * ); 7601 * ``` 7602 */ 7603 7604 function PluginSidebarEditPost(_ref) { 7605 let { 7606 className, 7607 ...props 7608 } = _ref; 7609 const { 7610 postTitle, 7611 shortcut, 7612 showIconLabels 7613 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 7614 return { 7615 postTitle: select(external_wp_editor_namespaceObject.store).getEditedPostAttribute('title'), 7616 shortcut: select(external_wp_keyboardShortcuts_namespaceObject.store).getShortcutRepresentation('core/edit-post/toggle-sidebar'), 7617 showIconLabels: select(store_store).isFeatureActive('showIconLabels') 7618 }; 7619 }, []); 7620 return (0,external_wp_element_namespaceObject.createElement)(complementary_area, _extends({ 7621 panelClassName: className, 7622 className: "edit-post-sidebar", 7623 smallScreenTitle: postTitle || (0,external_wp_i18n_namespaceObject.__)('(no title)'), 7624 scope: "core/edit-post", 7625 toggleShortcut: shortcut, 7626 showIconLabels: showIconLabels 7627 }, props)); 7628 } 7629 7630 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/sidebar/template/actions.js 7631 7632 7633 /** 7634 * External dependencies 7635 */ 7636 7637 /** 7638 * WordPress dependencies 7639 */ 7640 7641 7642 7643 7644 7645 7646 7647 /** 7648 * Internal dependencies 7649 */ 7650 7651 7652 7653 7654 function PostTemplateActions(_ref) { 7655 let { 7656 isPostsPage 7657 } = _ref; 7658 const [isModalOpen, setIsModalOpen] = (0,external_wp_element_namespaceObject.useState)(false); 7659 const [isBusy, setIsBusy] = (0,external_wp_element_namespaceObject.useState)(false); 7660 const [title, setTitle] = (0,external_wp_element_namespaceObject.useState)(''); 7661 const { 7662 template, 7663 supportsTemplateMode, 7664 defaultTemplate 7665 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 7666 var _getPostType$viewable, _getPostType; 7667 7668 const { 7669 getCurrentPostType, 7670 getEditorSettings 7671 } = select(external_wp_editor_namespaceObject.store); 7672 const { 7673 getPostType 7674 } = select(external_wp_coreData_namespaceObject.store); 7675 const { 7676 getEditedPostTemplate 7677 } = select(store_store); 7678 const isViewable = (_getPostType$viewable = (_getPostType = getPostType(getCurrentPostType())) === null || _getPostType === void 0 ? void 0 : _getPostType.viewable) !== null && _getPostType$viewable !== void 0 ? _getPostType$viewable : false; 7679 7680 const _supportsTemplateMode = getEditorSettings().supportsTemplateMode && isViewable; 7681 7682 return { 7683 template: _supportsTemplateMode && getEditedPostTemplate(), 7684 supportsTemplateMode: _supportsTemplateMode, 7685 defaultTemplate: getEditorSettings().defaultBlockTemplate 7686 }; 7687 }, []); 7688 const { 7689 __unstableCreateTemplate, 7690 __unstableSwitchToTemplateMode 7691 } = (0,external_wp_data_namespaceObject.useDispatch)(store_store); 7692 7693 if (!supportsTemplateMode) { 7694 return null; 7695 } 7696 7697 const defaultTitle = (0,external_wp_i18n_namespaceObject.__)('Custom Template'); 7698 7699 async function onCreateTemplate(event) { 7700 event.preventDefault(); 7701 7702 if (isBusy) { 7703 return; 7704 } 7705 7706 setIsBusy(true); 7707 const newTemplateContent = defaultTemplate !== null && defaultTemplate !== void 0 ? defaultTemplate : (0,external_wp_blocks_namespaceObject.serialize)([(0,external_wp_blocks_namespaceObject.createBlock)('core/group', { 7708 tagName: 'header', 7709 layout: { 7710 inherit: true 7711 } 7712 }, [(0,external_wp_blocks_namespaceObject.createBlock)('core/site-title'), (0,external_wp_blocks_namespaceObject.createBlock)('core/site-tagline')]), (0,external_wp_blocks_namespaceObject.createBlock)('core/separator'), (0,external_wp_blocks_namespaceObject.createBlock)('core/group', { 7713 tagName: 'main' 7714 }, [(0,external_wp_blocks_namespaceObject.createBlock)('core/group', { 7715 layout: { 7716 inherit: true 7717 } 7718 }, [(0,external_wp_blocks_namespaceObject.createBlock)('core/post-title')]), (0,external_wp_blocks_namespaceObject.createBlock)('core/post-content', { 7719 layout: { 7720 inherit: true 7721 } 7722 })])]); 7723 await __unstableCreateTemplate({ 7724 slug: 'wp-custom-template-' + (0,external_lodash_namespaceObject.kebabCase)(title || defaultTitle), 7725 content: newTemplateContent, 7726 title: title || defaultTitle 7727 }); 7728 setIsBusy(false); 7729 setIsModalOpen(false); 7730 7731 __unstableSwitchToTemplateMode(true); 7732 } 7733 7734 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("div", { 7735 className: "edit-post-template__actions" 7736 }, !!template && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 7737 variant: "link", 7738 onClick: () => __unstableSwitchToTemplateMode() 7739 }, (0,external_wp_i18n_namespaceObject.__)('Edit')), !isPostsPage && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 7740 variant: "link", 7741 onClick: () => setIsModalOpen(true) 7742 }, 7743 /* translators: button to create a new template */ 7744 (0,external_wp_i18n_namespaceObject._x)('New', 'action'))), isModalOpen && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Modal, { 7745 title: (0,external_wp_i18n_namespaceObject.__)('Create custom template'), 7746 closeLabel: (0,external_wp_i18n_namespaceObject.__)('Close'), 7747 onRequestClose: () => { 7748 setIsModalOpen(false); 7749 setTitle(''); 7750 }, 7751 overlayClassName: "edit-post-template__modal" 7752 }, (0,external_wp_element_namespaceObject.createElement)("form", { 7753 onSubmit: onCreateTemplate 7754 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Flex, { 7755 align: "flex-start", 7756 gap: 8 7757 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FlexItem, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, { 7758 label: (0,external_wp_i18n_namespaceObject.__)('Name'), 7759 value: title, 7760 onChange: setTitle, 7761 placeholder: defaultTitle, 7762 disabled: isBusy, 7763 help: (0,external_wp_i18n_namespaceObject.__)('Describe the purpose of the template, e.g. "Full Width". Custom templates can be applied to any post or page.') 7764 }))), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Flex, { 7765 className: "edit-post-template__modal-actions", 7766 justify: "flex-end", 7767 expanded: false 7768 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FlexItem, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 7769 variant: "tertiary", 7770 onClick: () => { 7771 setIsModalOpen(false); 7772 setTitle(''); 7773 } 7774 }, (0,external_wp_i18n_namespaceObject.__)('Cancel'))), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FlexItem, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 7775 variant: "primary", 7776 type: "submit", 7777 isBusy: isBusy, 7778 "aria-disabled": isBusy 7779 }, (0,external_wp_i18n_namespaceObject.__)('Create'))))))); 7780 } 7781 7782 /* harmony default export */ var actions = (PostTemplateActions); 7783 7784 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/sidebar/template/index.js 7785 7786 7787 /** 7788 * External dependencies 7789 */ 7790 7791 /** 7792 * WordPress dependencies 7793 */ 7794 7795 7796 7797 7798 7799 7800 7801 /** 7802 * Internal dependencies 7803 */ 7804 7805 7806 7807 /** 7808 * Module Constants 7809 */ 7810 7811 const template_PANEL_NAME = 'template'; 7812 function TemplatePanel() { 7813 const { 7814 isEnabled, 7815 isOpened, 7816 isPostsPage, 7817 selectedTemplate, 7818 availableTemplates, 7819 fetchedTemplates, 7820 isViewable, 7821 template, 7822 supportsTemplateMode, 7823 canUserCreate 7824 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 7825 var _getPostType$viewable, _getPostType; 7826 7827 const { 7828 isEditorPanelEnabled, 7829 isEditorPanelOpened, 7830 getEditedPostTemplate 7831 } = select(store_store); 7832 const { 7833 getEditedPostAttribute, 7834 getEditorSettings, 7835 getCurrentPostId, 7836 getCurrentPostType 7837 } = select(external_wp_editor_namespaceObject.store); 7838 const { 7839 getPostType, 7840 getEntityRecord, 7841 getEntityRecords, 7842 canUser 7843 } = select(external_wp_coreData_namespaceObject.store); 7844 const currentPostId = getCurrentPostId(); 7845 const currentPostType = getCurrentPostType(); 7846 const settings = getEntityRecord('root', 'site'); 7847 7848 const _isViewable = (_getPostType$viewable = (_getPostType = getPostType(currentPostType)) === null || _getPostType === void 0 ? void 0 : _getPostType.viewable) !== null && _getPostType$viewable !== void 0 ? _getPostType$viewable : false; 7849 7850 const _supportsTemplateMode = select(external_wp_editor_namespaceObject.store).getEditorSettings().supportsTemplateMode && _isViewable; 7851 7852 const templateRecords = getEntityRecords('postType', 'wp_template', { 7853 post_type: currentPostType, 7854 per_page: -1 7855 }); 7856 return { 7857 isEnabled: isEditorPanelEnabled(template_PANEL_NAME), 7858 isOpened: isEditorPanelOpened(template_PANEL_NAME), 7859 isPostsPage: currentPostId === (settings === null || settings === void 0 ? void 0 : settings.page_for_posts), 7860 selectedTemplate: getEditedPostAttribute('template'), 7861 availableTemplates: getEditorSettings().availableTemplates, 7862 fetchedTemplates: templateRecords, 7863 template: _supportsTemplateMode && getEditedPostTemplate(), 7864 isViewable: _isViewable, 7865 supportsTemplateMode: _supportsTemplateMode, 7866 canUserCreate: canUser('create', 'templates') 7867 }; 7868 }, []); 7869 const templates = (0,external_wp_element_namespaceObject.useMemo)(() => { 7870 return { ...availableTemplates, 7871 ...(0,external_lodash_namespaceObject.fromPairs)((fetchedTemplates !== null && fetchedTemplates !== void 0 ? fetchedTemplates : []).map(_ref => { 7872 let { 7873 slug, 7874 title 7875 } = _ref; 7876 return [slug, title.rendered]; 7877 })) 7878 }; 7879 }, [availableTemplates, fetchedTemplates]); 7880 const { 7881 toggleEditorPanelOpened 7882 } = (0,external_wp_data_namespaceObject.useDispatch)(store_store); 7883 const { 7884 editPost 7885 } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_editor_namespaceObject.store); 7886 7887 if (!isEnabled || !isViewable || (0,external_lodash_namespaceObject.isEmpty)(availableTemplates) && (!supportsTemplateMode || !canUserCreate)) { 7888 return null; 7889 } 7890 7891 const onTogglePanel = (0,external_lodash_namespaceObject.partial)(toggleEditorPanelOpened, template_PANEL_NAME); 7892 7893 let panelTitle = (0,external_wp_i18n_namespaceObject.__)('Template'); 7894 7895 if (!!template) { 7896 var _template$title; 7897 7898 panelTitle = (0,external_wp_i18n_namespaceObject.sprintf)( 7899 /* translators: %s: template title */ 7900 (0,external_wp_i18n_namespaceObject.__)('Template: %s'), (_template$title = template === null || template === void 0 ? void 0 : template.title) !== null && _template$title !== void 0 ? _template$title : template.slug); 7901 } 7902 7903 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, { 7904 title: panelTitle, 7905 opened: isOpened, 7906 onToggle: onTogglePanel 7907 }, isPostsPage ? (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Notice, { 7908 className: "edit-post-template__notice", 7909 status: "warning", 7910 isDismissible: false 7911 }, (0,external_wp_i18n_namespaceObject.__)('The posts page template cannot be changed.')) : (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SelectControl, { 7912 hideLabelFromVision: true, 7913 label: (0,external_wp_i18n_namespaceObject.__)('Template:'), 7914 value: Object.keys(templates).includes(selectedTemplate) ? selectedTemplate : '', 7915 onChange: templateSlug => { 7916 editPost({ 7917 template: templateSlug || '' 7918 }); 7919 }, 7920 options: (0,external_lodash_namespaceObject.map)(templates, (templateName, templateSlug) => ({ 7921 value: templateSlug, 7922 label: templateName 7923 })) 7924 }), canUserCreate && (0,external_wp_element_namespaceObject.createElement)(actions, { 7925 isPostsPage: isPostsPage 7926 })); 7927 } 7928 /* harmony default export */ var template = (TemplatePanel); 7929 7930 ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/layout.js 7931 7932 7933 /** 7934 * WordPress dependencies 7935 */ 7936 7937 const layout = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { 7938 xmlns: "http://www.w3.org/2000/svg", 7939 viewBox: "0 0 24 24" 7940 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 7941 d: "M18 5.5H6a.5.5 0 00-.5.5v3h13V6a.5.5 0 00-.5-.5zm.5 5H10v8h8a.5.5 0 00.5-.5v-7.5zm-10 0h-3V18a.5.5 0 00.5.5h2.5v-8zM6 4h12a2 2 0 012 2v12a2 2 0 01-2 2H6a2 2 0 01-2-2V6a2 2 0 012-2z" 7942 })); 7943 /* harmony default export */ var library_layout = (layout); 7944 7945 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/sidebar/template-summary/index.js 7946 7947 7948 /** 7949 * WordPress dependencies 7950 */ 7951 7952 7953 7954 /** 7955 * Internal dependencies 7956 */ 7957 7958 7959 7960 function TemplateSummary() { 7961 const template = (0,external_wp_data_namespaceObject.useSelect)(select => { 7962 const { 7963 getEditedPostTemplate 7964 } = select(store_store); 7965 return getEditedPostTemplate(); 7966 }, []); 7967 7968 if (!template) { 7969 return null; 7970 } 7971 7972 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Flex, { 7973 align: "flex-start", 7974 gap: "3" 7975 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FlexItem, null, (0,external_wp_element_namespaceObject.createElement)(icon, { 7976 icon: library_layout 7977 })), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FlexBlock, null, (0,external_wp_element_namespaceObject.createElement)("h2", { 7978 className: "edit-post-template-summary__title" 7979 }, (template === null || template === void 0 ? void 0 : template.title) || (template === null || template === void 0 ? void 0 : template.slug)), (0,external_wp_element_namespaceObject.createElement)("p", null, template === null || template === void 0 ? void 0 : template.description)))); 7980 } 7981 7982 /* harmony default export */ var template_summary = (TemplateSummary); 7983 7984 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/sidebar/settings-sidebar/index.js 7985 7986 7987 /** 7988 * WordPress dependencies 7989 */ 7990 7991 7992 7993 7994 7995 /** 7996 * Internal dependencies 7997 */ 7998 7999 8000 8001 8002 8003 8004 8005 8006 8007 8008 8009 8010 8011 8012 8013 8014 8015 8016 const SIDEBAR_ACTIVE_BY_DEFAULT = external_wp_element_namespaceObject.Platform.select({ 8017 web: true, 8018 native: false 8019 }); 8020 8021 const SettingsSidebar = () => { 8022 const { 8023 sidebarName, 8024 keyboardShortcut, 8025 isTemplateMode 8026 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 8027 // The settings sidebar is used by the edit-post/document and edit-post/block sidebars. 8028 // sidebarName represents the sidebar that is active or that should be active when the SettingsSidebar toggle button is pressed. 8029 // If one of the two sidebars is active the component will contain the content of that sidebar. 8030 // When neither of the the two sidebars is active we can not simply return null, because the PluginSidebarEditPost 8031 // component, besides being used to render the sidebar, also renders the toggle button. In that case sidebarName 8032 // should contain the sidebar that will be active when the toggle button is pressed. If a block 8033 // is selected, that should be edit-post/block otherwise it's edit-post/document. 8034 let sidebar = select(store).getActiveComplementaryArea(store_store.name); 8035 8036 if (!['edit-post/document', 'edit-post/block'].includes(sidebar)) { 8037 if (select(external_wp_blockEditor_namespaceObject.store).getBlockSelectionStart()) { 8038 sidebar = 'edit-post/block'; 8039 } 8040 8041 sidebar = 'edit-post/document'; 8042 } 8043 8044 const shortcut = select(external_wp_keyboardShortcuts_namespaceObject.store).getShortcutRepresentation('core/edit-post/toggle-sidebar'); 8045 return { 8046 sidebarName: sidebar, 8047 keyboardShortcut: shortcut, 8048 isTemplateMode: select(store_store).isEditingTemplate() 8049 }; 8050 }, []); 8051 return (0,external_wp_element_namespaceObject.createElement)(PluginSidebarEditPost, { 8052 identifier: sidebarName, 8053 header: (0,external_wp_element_namespaceObject.createElement)(settings_header, { 8054 sidebarName: sidebarName 8055 }), 8056 closeLabel: (0,external_wp_i18n_namespaceObject.__)('Close settings'), 8057 headerClassName: "edit-post-sidebar__panel-tabs" 8058 /* translators: button label text should, if possible, be under 16 characters. */ 8059 , 8060 title: (0,external_wp_i18n_namespaceObject.__)('Settings'), 8061 toggleShortcut: keyboardShortcut, 8062 icon: library_cog, 8063 isActiveByDefault: SIDEBAR_ACTIVE_BY_DEFAULT 8064 }, !isTemplateMode && sidebarName === 'edit-post/document' && (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(post_status, null), (0,external_wp_element_namespaceObject.createElement)(template, null), (0,external_wp_element_namespaceObject.createElement)(plugin_document_setting_panel.Slot, null), (0,external_wp_element_namespaceObject.createElement)(last_revision, null), (0,external_wp_element_namespaceObject.createElement)(post_link, null), (0,external_wp_element_namespaceObject.createElement)(post_taxonomies, null), (0,external_wp_element_namespaceObject.createElement)(featured_image, null), (0,external_wp_element_namespaceObject.createElement)(post_excerpt, null), (0,external_wp_element_namespaceObject.createElement)(discussion_panel, null), (0,external_wp_element_namespaceObject.createElement)(page_attributes, null), (0,external_wp_element_namespaceObject.createElement)(MetaBoxes, { 8065 location: "side" 8066 })), isTemplateMode && sidebarName === 'edit-post/document' && (0,external_wp_element_namespaceObject.createElement)(template_summary, null), sidebarName === 'edit-post/block' && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockInspector, null)); 8067 }; 8068 8069 /* harmony default export */ var settings_sidebar = (SettingsSidebar); 8070 8071 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/welcome-guide/image.js 8072 8073 function WelcomeGuideImage(_ref) { 8074 let { 8075 nonAnimatedSrc, 8076 animatedSrc 8077 } = _ref; 8078 return (0,external_wp_element_namespaceObject.createElement)("picture", { 8079 className: "edit-post-welcome-guide__image" 8080 }, (0,external_wp_element_namespaceObject.createElement)("source", { 8081 srcSet: nonAnimatedSrc, 8082 media: "(prefers-reduced-motion: reduce)" 8083 }), (0,external_wp_element_namespaceObject.createElement)("img", { 8084 src: animatedSrc, 8085 width: "312", 8086 height: "240", 8087 alt: "" 8088 })); 8089 } 8090 8091 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/welcome-guide/default.js 8092 8093 8094 /** 8095 * WordPress dependencies 8096 */ 8097 8098 8099 8100 8101 /** 8102 * Internal dependencies 8103 */ 8104 8105 8106 8107 function WelcomeGuideDefault() { 8108 const { 8109 toggleFeature 8110 } = (0,external_wp_data_namespaceObject.useDispatch)(store_store); 8111 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Guide, { 8112 className: "edit-post-welcome-guide", 8113 contentLabel: (0,external_wp_i18n_namespaceObject.__)('Welcome to the block editor'), 8114 finishButtonText: (0,external_wp_i18n_namespaceObject.__)('Get started'), 8115 onFinish: () => toggleFeature('welcomeGuide'), 8116 pages: [{ 8117 image: (0,external_wp_element_namespaceObject.createElement)(WelcomeGuideImage, { 8118 nonAnimatedSrc: "https://s.w.org/images/block-editor/welcome-canvas.svg", 8119 animatedSrc: "https://s.w.org/images/block-editor/welcome-canvas.gif" 8120 }), 8121 content: (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("h1", { 8122 className: "edit-post-welcome-guide__heading" 8123 }, (0,external_wp_i18n_namespaceObject.__)('Welcome to the block editor')), (0,external_wp_element_namespaceObject.createElement)("p", { 8124 className: "edit-post-welcome-guide__text" 8125 }, (0,external_wp_i18n_namespaceObject.__)('In the WordPress editor, each paragraph, image, or video is presented as a distinct “block” of content.'))) 8126 }, { 8127 image: (0,external_wp_element_namespaceObject.createElement)(WelcomeGuideImage, { 8128 nonAnimatedSrc: "https://s.w.org/images/block-editor/welcome-editor.svg", 8129 animatedSrc: "https://s.w.org/images/block-editor/welcome-editor.gif" 8130 }), 8131 content: (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("h1", { 8132 className: "edit-post-welcome-guide__heading" 8133 }, (0,external_wp_i18n_namespaceObject.__)('Make each block your own')), (0,external_wp_element_namespaceObject.createElement)("p", { 8134 className: "edit-post-welcome-guide__text" 8135 }, (0,external_wp_i18n_namespaceObject.__)('Each block comes with its own set of controls for changing things like color, width, and alignment. These will show and hide automatically when you have a block selected.'))) 8136 }, { 8137 image: (0,external_wp_element_namespaceObject.createElement)(WelcomeGuideImage, { 8138 nonAnimatedSrc: "https://s.w.org/images/block-editor/welcome-library.svg", 8139 animatedSrc: "https://s.w.org/images/block-editor/welcome-library.gif" 8140 }), 8141 content: (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("h1", { 8142 className: "edit-post-welcome-guide__heading" 8143 }, (0,external_wp_i18n_namespaceObject.__)('Get to know the block library')), (0,external_wp_element_namespaceObject.createElement)("p", { 8144 className: "edit-post-welcome-guide__text" 8145 }, (0,external_wp_element_namespaceObject.createInterpolateElement)((0,external_wp_i18n_namespaceObject.__)('All of the blocks available to you live in the block library. You’ll find it wherever you see the <InserterIconImage /> icon.'), { 8146 InserterIconImage: (0,external_wp_element_namespaceObject.createElement)("img", { 8147 alt: (0,external_wp_i18n_namespaceObject.__)('inserter'), 8148 src: "data:image/svg+xml,%3Csvg width='18' height='18' viewBox='0 0 18 18' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Crect width='18' height='18' rx='2' fill='%231E1E1E'/%3E%3Cpath d='M9.22727 4V14M4 8.77273H14' stroke='white' stroke-width='1.5'/%3E%3C/svg%3E%0A" 8149 }) 8150 }))) 8151 }, { 8152 image: (0,external_wp_element_namespaceObject.createElement)(WelcomeGuideImage, { 8153 nonAnimatedSrc: "https://s.w.org/images/block-editor/welcome-documentation.svg", 8154 animatedSrc: "https://s.w.org/images/block-editor/welcome-documentation.gif" 8155 }), 8156 content: (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("h1", { 8157 className: "edit-post-welcome-guide__heading" 8158 }, (0,external_wp_i18n_namespaceObject.__)('Learn how to use the block editor')), (0,external_wp_element_namespaceObject.createElement)("p", { 8159 className: "edit-post-welcome-guide__text" 8160 }, (0,external_wp_i18n_namespaceObject.__)('New to the block editor? Want to learn more about using it? '), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ExternalLink, { 8161 href: (0,external_wp_i18n_namespaceObject.__)('https://wordpress.org/support/article/wordpress-editor/') 8162 }, (0,external_wp_i18n_namespaceObject.__)("Here's a detailed guide.")))) 8163 }] 8164 }); 8165 } 8166 8167 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/welcome-guide/template.js 8168 8169 8170 /** 8171 * WordPress dependencies 8172 */ 8173 8174 8175 8176 /** 8177 * Internal dependencies 8178 */ 8179 8180 8181 8182 function WelcomeGuideTemplate() { 8183 const { 8184 toggleFeature 8185 } = (0,external_wp_data_namespaceObject.useDispatch)(store_store); 8186 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Guide, { 8187 className: "edit-template-welcome-guide", 8188 contentLabel: (0,external_wp_i18n_namespaceObject.__)('Welcome to the template editor'), 8189 finishButtonText: (0,external_wp_i18n_namespaceObject.__)('Get started'), 8190 onFinish: () => toggleFeature('welcomeGuideTemplate'), 8191 pages: [{ 8192 image: (0,external_wp_element_namespaceObject.createElement)(WelcomeGuideImage, { 8193 nonAnimatedSrc: "https://s.w.org/images/block-editor/welcome-template-editor.svg", 8194 animatedSrc: "https://s.w.org/images/block-editor/welcome-template-editor.gif" 8195 }), 8196 content: (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("h1", { 8197 className: "edit-post-welcome-guide__heading" 8198 }, (0,external_wp_i18n_namespaceObject.__)('Welcome to the template editor')), (0,external_wp_element_namespaceObject.createElement)("p", { 8199 className: "edit-post-welcome-guide__text" 8200 }, (0,external_wp_i18n_namespaceObject.__)('Templates help define the layout of the site. You can customize all aspects of your posts and pages using blocks and patterns in this editor.'))) 8201 }] 8202 }); 8203 } 8204 8205 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/welcome-guide/index.js 8206 8207 8208 /** 8209 * WordPress dependencies 8210 */ 8211 8212 /** 8213 * Internal dependencies 8214 */ 8215 8216 8217 8218 8219 function WelcomeGuide() { 8220 const { 8221 isActive, 8222 isTemplateMode 8223 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 8224 const { 8225 isFeatureActive, 8226 isEditingTemplate 8227 } = select(store_store); 8228 8229 const _isTemplateMode = isEditingTemplate(); 8230 8231 const feature = _isTemplateMode ? 'welcomeGuideTemplate' : 'welcomeGuide'; 8232 return { 8233 isActive: isFeatureActive(feature), 8234 isTemplateMode: _isTemplateMode 8235 }; 8236 }, []); 8237 8238 if (!isActive) { 8239 return null; 8240 } 8241 8242 return isTemplateMode ? (0,external_wp_element_namespaceObject.createElement)(WelcomeGuideTemplate, null) : (0,external_wp_element_namespaceObject.createElement)(WelcomeGuideDefault, null); 8243 } 8244 8245 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/sidebar/plugin-post-publish-panel/index.js 8246 8247 8248 /** 8249 * WordPress dependencies 8250 */ 8251 8252 8253 8254 const { 8255 Fill: plugin_post_publish_panel_Fill, 8256 Slot: plugin_post_publish_panel_Slot 8257 } = (0,external_wp_components_namespaceObject.createSlotFill)('PluginPostPublishPanel'); 8258 8259 const PluginPostPublishPanelFill = _ref => { 8260 let { 8261 children, 8262 className, 8263 title, 8264 initialOpen = false, 8265 icon 8266 } = _ref; 8267 return (0,external_wp_element_namespaceObject.createElement)(plugin_post_publish_panel_Fill, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, { 8268 className: className, 8269 initialOpen: initialOpen || !title, 8270 title: title, 8271 icon: icon 8272 }, children)); 8273 }; 8274 /** 8275 * Renders provided content to the post-publish panel in the publish flow 8276 * (side panel that opens after a user publishes the post). 8277 * 8278 * @param {Object} props Component properties. 8279 * @param {string} [props.className] An optional class name added to the panel. 8280 * @param {string} [props.title] Title displayed at the top of the panel. 8281 * @param {boolean} [props.initialOpen=false] Whether to have the panel initially opened. When no title is provided it is always opened. 8282 * @param {WPBlockTypeIconRender} [props.icon=inherits from the plugin] The [Dashicon](https://developer.wordpress.org/resource/dashicons/) icon slug string, or an SVG WP element, to be rendered when the sidebar is pinned to toolbar. 8283 * 8284 * @example 8285 * ```js 8286 * // Using ES5 syntax 8287 * var __ = wp.i18n.__; 8288 * var PluginPostPublishPanel = wp.editPost.PluginPostPublishPanel; 8289 * 8290 * function MyPluginPostPublishPanel() { 8291 * return wp.element.createElement( 8292 * PluginPostPublishPanel, 8293 * { 8294 * className: 'my-plugin-post-publish-panel', 8295 * title: __( 'My panel title' ), 8296 * initialOpen: true, 8297 * }, 8298 * __( 'My panel content' ) 8299 * ); 8300 * } 8301 * ``` 8302 * 8303 * @example 8304 * ```jsx 8305 * // Using ESNext syntax 8306 * import { __ } from '@wordpress/i18n'; 8307 * import { PluginPostPublishPanel } from '@wordpress/edit-post'; 8308 * 8309 * const MyPluginPostPublishPanel = () => ( 8310 * <PluginPostPublishPanel 8311 * className="my-plugin-post-publish-panel" 8312 * title={ __( 'My panel title' ) } 8313 * initialOpen={ true } 8314 * > 8315 * { __( 'My panel content' ) } 8316 * </PluginPostPublishPanel> 8317 * ); 8318 * ``` 8319 * 8320 * @return {WPComponent} The component to be rendered. 8321 */ 8322 8323 8324 const PluginPostPublishPanel = (0,external_wp_compose_namespaceObject.compose)((0,external_wp_plugins_namespaceObject.withPluginContext)((context, ownProps) => { 8325 return { 8326 icon: ownProps.icon || context.icon 8327 }; 8328 }))(PluginPostPublishPanelFill); 8329 PluginPostPublishPanel.Slot = plugin_post_publish_panel_Slot; 8330 /* harmony default export */ var plugin_post_publish_panel = (PluginPostPublishPanel); 8331 8332 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/sidebar/plugin-pre-publish-panel/index.js 8333 8334 8335 /** 8336 * WordPress dependencies 8337 */ 8338 8339 8340 8341 const { 8342 Fill: plugin_pre_publish_panel_Fill, 8343 Slot: plugin_pre_publish_panel_Slot 8344 } = (0,external_wp_components_namespaceObject.createSlotFill)('PluginPrePublishPanel'); 8345 8346 const PluginPrePublishPanelFill = _ref => { 8347 let { 8348 children, 8349 className, 8350 title, 8351 initialOpen = false, 8352 icon 8353 } = _ref; 8354 return (0,external_wp_element_namespaceObject.createElement)(plugin_pre_publish_panel_Fill, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, { 8355 className: className, 8356 initialOpen: initialOpen || !title, 8357 title: title, 8358 icon: icon 8359 }, children)); 8360 }; 8361 /** 8362 * Renders provided content to the pre-publish side panel in the publish flow 8363 * (side panel that opens when a user first pushes "Publish" from the main editor). 8364 * 8365 * @param {Object} props Component props. 8366 * @param {string} [props.className] An optional class name added to the panel. 8367 * @param {string} [props.title] Title displayed at the top of the panel. 8368 * @param {boolean} [props.initialOpen=false] Whether to have the panel initially opened. 8369 * When no title is provided it is always opened. 8370 * @param {WPBlockTypeIconRender} [props.icon=inherits from the plugin] The [Dashicon](https://developer.wordpress.org/resource/dashicons/) 8371 * icon slug string, or an SVG WP element, to be rendered when 8372 * the sidebar is pinned to toolbar. 8373 * 8374 * @example 8375 * ```js 8376 * // Using ES5 syntax 8377 * var __ = wp.i18n.__; 8378 * var PluginPrePublishPanel = wp.editPost.PluginPrePublishPanel; 8379 * 8380 * function MyPluginPrePublishPanel() { 8381 * return wp.element.createElement( 8382 * PluginPrePublishPanel, 8383 * { 8384 * className: 'my-plugin-pre-publish-panel', 8385 * title: __( 'My panel title' ), 8386 * initialOpen: true, 8387 * }, 8388 * __( 'My panel content' ) 8389 * ); 8390 * } 8391 * ``` 8392 * 8393 * @example 8394 * ```jsx 8395 * // Using ESNext syntax 8396 * import { __ } from '@wordpress/i18n'; 8397 * import { PluginPrePublishPanel } from '@wordpress/edit-post'; 8398 * 8399 * const MyPluginPrePublishPanel = () => ( 8400 * <PluginPrePublishPanel 8401 * className="my-plugin-pre-publish-panel" 8402 * title={ __( 'My panel title' ) } 8403 * initialOpen={ true } 8404 * > 8405 * { __( 'My panel content' ) } 8406 * </PluginPrePublishPanel> 8407 * ); 8408 * ``` 8409 * 8410 * @return {WPComponent} The component to be rendered. 8411 */ 8412 8413 8414 const PluginPrePublishPanel = (0,external_wp_compose_namespaceObject.compose)((0,external_wp_plugins_namespaceObject.withPluginContext)((context, ownProps) => { 8415 return { 8416 icon: ownProps.icon || context.icon 8417 }; 8418 }))(PluginPrePublishPanelFill); 8419 PluginPrePublishPanel.Slot = plugin_pre_publish_panel_Slot; 8420 /* harmony default export */ var plugin_pre_publish_panel = (PluginPrePublishPanel); 8421 8422 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/layout/actions-panel.js 8423 8424 8425 /** 8426 * WordPress dependencies 8427 */ 8428 8429 8430 8431 8432 8433 /** 8434 * Internal dependencies 8435 */ 8436 8437 8438 8439 8440 const { 8441 Fill: actions_panel_Fill, 8442 Slot: actions_panel_Slot 8443 } = (0,external_wp_components_namespaceObject.createSlotFill)('ActionsPanel'); 8444 const ActionsPanelFill = (/* unused pure expression or super */ null && (actions_panel_Fill)); 8445 function ActionsPanel(_ref) { 8446 let { 8447 setEntitiesSavedStatesCallback, 8448 closeEntitiesSavedStates, 8449 isEntitiesSavedStatesOpen 8450 } = _ref; 8451 const { 8452 closePublishSidebar, 8453 togglePublishSidebar 8454 } = (0,external_wp_data_namespaceObject.useDispatch)(store_store); 8455 const { 8456 publishSidebarOpened, 8457 hasActiveMetaboxes, 8458 isSavingMetaBoxes, 8459 hasNonPostEntityChanges 8460 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 8461 return { 8462 publishSidebarOpened: select(store_store).isPublishSidebarOpened(), 8463 hasActiveMetaboxes: select(store_store).hasMetaBoxes(), 8464 isSavingMetaBoxes: select(store_store).isSavingMetaBoxes(), 8465 hasNonPostEntityChanges: select(external_wp_editor_namespaceObject.store).hasNonPostEntityChanges() 8466 }; 8467 }, []); 8468 const openEntitiesSavedStates = (0,external_wp_element_namespaceObject.useCallback)(() => setEntitiesSavedStatesCallback(true), []); // It is ok for these components to be unmounted when not in visual use. 8469 // We don't want more than one present at a time, decide which to render. 8470 8471 let unmountableContent; 8472 8473 if (publishSidebarOpened) { 8474 unmountableContent = (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostPublishPanel, { 8475 onClose: closePublishSidebar, 8476 forceIsDirty: hasActiveMetaboxes, 8477 forceIsSaving: isSavingMetaBoxes, 8478 PrePublishExtension: plugin_pre_publish_panel.Slot, 8479 PostPublishExtension: plugin_post_publish_panel.Slot 8480 }); 8481 } else if (hasNonPostEntityChanges) { 8482 unmountableContent = (0,external_wp_element_namespaceObject.createElement)("div", { 8483 className: "edit-post-layout__toggle-entities-saved-states-panel" 8484 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 8485 variant: "secondary", 8486 className: "edit-post-layout__toggle-entities-saved-states-panel-button", 8487 onClick: openEntitiesSavedStates, 8488 "aria-expanded": false 8489 }, (0,external_wp_i18n_namespaceObject.__)('Open save panel'))); 8490 } else { 8491 unmountableContent = (0,external_wp_element_namespaceObject.createElement)("div", { 8492 className: "edit-post-layout__toggle-publish-panel" 8493 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 8494 variant: "secondary", 8495 className: "edit-post-layout__toggle-publish-panel-button", 8496 onClick: togglePublishSidebar, 8497 "aria-expanded": false 8498 }, (0,external_wp_i18n_namespaceObject.__)('Open publish panel'))); 8499 } // Since EntitiesSavedStates controls its own panel, we can keep it 8500 // always mounted to retain its own component state (such as checkboxes). 8501 8502 8503 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, isEntitiesSavedStatesOpen && (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.EntitiesSavedStates, { 8504 close: closeEntitiesSavedStates 8505 }), (0,external_wp_element_namespaceObject.createElement)(actions_panel_Slot, { 8506 bubblesVirtually: true 8507 }), !isEntitiesSavedStatesOpen && unmountableContent); 8508 } 8509 8510 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/start-page-options/index.js 8511 8512 8513 /** 8514 * WordPress dependencies 8515 */ 8516 8517 8518 8519 8520 8521 8522 8523 /** 8524 * Internal dependencies 8525 */ 8526 8527 8528 8529 function PatternSelection(_ref) { 8530 let { 8531 onChoosePattern 8532 } = _ref; 8533 const { 8534 blockPatterns 8535 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 8536 const { 8537 __experimentalGetPatternsByBlockTypes 8538 } = select(external_wp_blockEditor_namespaceObject.store); 8539 return { 8540 blockPatterns: __experimentalGetPatternsByBlockTypes('core/post-content') 8541 }; 8542 }, []); 8543 const shownBlockPatterns = (0,external_wp_compose_namespaceObject.useAsyncList)(blockPatterns); 8544 const { 8545 resetEditorBlocks 8546 } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_editor_namespaceObject.store); 8547 return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.__experimentalBlockPatternsList, { 8548 blockPatterns: blockPatterns, 8549 shownPatterns: shownBlockPatterns, 8550 onClickPattern: (_pattern, blocks) => { 8551 resetEditorBlocks(blocks); 8552 onChoosePattern(); 8553 } 8554 }); 8555 } 8556 8557 const START_PAGE_MODAL_STATES = { 8558 INITIAL: 'INITIAL', 8559 PATTERN: 'PATTERN', 8560 CLOSED: 'CLOSED' 8561 }; 8562 function StartPageOptions() { 8563 const [modalState, setModalState] = (0,external_wp_element_namespaceObject.useState)(START_PAGE_MODAL_STATES.INITIAL); 8564 const shouldOpenModel = (0,external_wp_data_namespaceObject.useSelect)(select => { 8565 if (modalState !== START_PAGE_MODAL_STATES.INITIAL) { 8566 return false; 8567 } 8568 8569 const { 8570 __experimentalGetPatternsByBlockTypes 8571 } = select(external_wp_blockEditor_namespaceObject.store); 8572 const { 8573 getCurrentPostType, 8574 getEditedPostContent, 8575 isEditedPostSaveable 8576 } = select(external_wp_editor_namespaceObject.store); 8577 const { 8578 isEditingTemplate, 8579 isFeatureActive 8580 } = select(store_store); 8581 return getCurrentPostType() === 'page' && !isEditedPostSaveable() && '' === getEditedPostContent() && !isEditingTemplate() && !isFeatureActive('welcomeGuide') && __experimentalGetPatternsByBlockTypes('core/post-content').length >= 1; 8582 }, [modalState]); 8583 (0,external_wp_element_namespaceObject.useEffect)(() => { 8584 if (shouldOpenModel) { 8585 setModalState(START_PAGE_MODAL_STATES.PATTERN); 8586 } 8587 }, [shouldOpenModel]); 8588 8589 if (modalState === START_PAGE_MODAL_STATES.INITIAL || modalState === START_PAGE_MODAL_STATES.CLOSED) { 8590 return null; 8591 } 8592 8593 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Modal, { 8594 className: "edit-post-start-page-options__modal", 8595 title: (0,external_wp_i18n_namespaceObject.__)('Choose a pattern'), 8596 closeLabel: (0,external_wp_i18n_namespaceObject.__)('Cancel'), 8597 onRequestClose: () => { 8598 setModalState(START_PAGE_MODAL_STATES.CLOSED); 8599 } 8600 }, (0,external_wp_element_namespaceObject.createElement)("div", { 8601 className: "edit-post-start-page-options__modal-content" 8602 }, modalState === START_PAGE_MODAL_STATES.PATTERN && (0,external_wp_element_namespaceObject.createElement)(PatternSelection, { 8603 onChoosePattern: () => { 8604 setModalState(START_PAGE_MODAL_STATES.CLOSED); 8605 } 8606 }))); 8607 } 8608 8609 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/layout/index.js 8610 8611 8612 /** 8613 * External dependencies 8614 */ 8615 8616 /** 8617 * WordPress dependencies 8618 */ 8619 8620 8621 8622 8623 8624 8625 8626 8627 8628 8629 8630 8631 /** 8632 * Internal dependencies 8633 */ 8634 8635 8636 8637 8638 8639 8640 8641 8642 8643 8644 8645 8646 8647 8648 8649 8650 const interfaceLabels = { 8651 /* translators: accessibility text for the editor top bar landmark region. */ 8652 header: (0,external_wp_i18n_namespaceObject.__)('Editor top bar'), 8653 8654 /* translators: accessibility text for the editor content landmark region. */ 8655 body: (0,external_wp_i18n_namespaceObject.__)('Editor content'), 8656 8657 /* translators: accessibility text for the editor settings landmark region. */ 8658 sidebar: (0,external_wp_i18n_namespaceObject.__)('Editor settings'), 8659 8660 /* translators: accessibility text for the editor publish landmark region. */ 8661 actions: (0,external_wp_i18n_namespaceObject.__)('Editor publish'), 8662 8663 /* translators: accessibility text for the editor footer landmark region. */ 8664 footer: (0,external_wp_i18n_namespaceObject.__)('Editor footer') 8665 }; 8666 8667 function Layout(_ref) { 8668 let { 8669 styles 8670 } = _ref; 8671 const isMobileViewport = (0,external_wp_compose_namespaceObject.useViewportMatch)('medium', '<'); 8672 const isHugeViewport = (0,external_wp_compose_namespaceObject.useViewportMatch)('huge', '>='); 8673 const { 8674 openGeneralSidebar, 8675 closeGeneralSidebar, 8676 setIsInserterOpened 8677 } = (0,external_wp_data_namespaceObject.useDispatch)(store_store); 8678 const { 8679 createErrorNotice 8680 } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_notices_namespaceObject.store); 8681 const { 8682 mode, 8683 isFullscreenActive, 8684 isRichEditingEnabled, 8685 sidebarIsOpened, 8686 hasActiveMetaboxes, 8687 hasFixedToolbar, 8688 previousShortcut, 8689 nextShortcut, 8690 hasBlockSelected, 8691 isInserterOpened, 8692 isListViewOpened, 8693 showIconLabels, 8694 hasReducedUI, 8695 showBlockBreadcrumbs, 8696 isTemplateMode, 8697 documentLabel 8698 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 8699 const { 8700 getEditorSettings, 8701 getPostTypeLabel 8702 } = select(external_wp_editor_namespaceObject.store); 8703 const editorSettings = getEditorSettings(); 8704 const postTypeLabel = getPostTypeLabel(); 8705 return { 8706 isTemplateMode: select(store_store).isEditingTemplate(), 8707 hasFixedToolbar: select(store_store).isFeatureActive('fixedToolbar'), 8708 sidebarIsOpened: !!(select(store).getActiveComplementaryArea(store_store.name) || select(store_store).isPublishSidebarOpened()), 8709 isFullscreenActive: select(store_store).isFeatureActive('fullscreenMode'), 8710 isInserterOpened: select(store_store).isInserterOpened(), 8711 isListViewOpened: select(store_store).isListViewOpened(), 8712 mode: select(store_store).getEditorMode(), 8713 isRichEditingEnabled: editorSettings.richEditingEnabled, 8714 hasActiveMetaboxes: select(store_store).hasMetaBoxes(), 8715 previousShortcut: select(external_wp_keyboardShortcuts_namespaceObject.store).getAllShortcutKeyCombinations('core/edit-post/previous-region'), 8716 nextShortcut: select(external_wp_keyboardShortcuts_namespaceObject.store).getAllShortcutKeyCombinations('core/edit-post/next-region'), 8717 showIconLabels: select(store_store).isFeatureActive('showIconLabels'), 8718 hasReducedUI: select(store_store).isFeatureActive('reducedUI'), 8719 showBlockBreadcrumbs: select(store_store).isFeatureActive('showBlockBreadcrumbs'), 8720 // translators: Default label for the Document in the Block Breadcrumb. 8721 documentLabel: postTypeLabel || (0,external_wp_i18n_namespaceObject._x)('Document', 'noun') 8722 }; 8723 }, []); 8724 const className = classnames_default()('edit-post-layout', 'is-mode-' + mode, { 8725 'is-sidebar-opened': sidebarIsOpened, 8726 'has-fixed-toolbar': hasFixedToolbar, 8727 'has-metaboxes': hasActiveMetaboxes, 8728 'show-icon-labels': showIconLabels 8729 }); 8730 8731 const openSidebarPanel = () => openGeneralSidebar(hasBlockSelected ? 'edit-post/block' : 'edit-post/document'); // Inserter and Sidebars are mutually exclusive 8732 8733 8734 (0,external_wp_element_namespaceObject.useEffect)(() => { 8735 if (sidebarIsOpened && !isHugeViewport) { 8736 setIsInserterOpened(false); 8737 } 8738 }, [sidebarIsOpened, isHugeViewport]); 8739 (0,external_wp_element_namespaceObject.useEffect)(() => { 8740 if (isInserterOpened && !isHugeViewport) { 8741 closeGeneralSidebar(); 8742 } 8743 }, [isInserterOpened, isHugeViewport]); // Local state for save panel. 8744 // Note 'truthy' callback implies an open panel. 8745 8746 const [entitiesSavedStatesCallback, setEntitiesSavedStatesCallback] = (0,external_wp_element_namespaceObject.useState)(false); 8747 const closeEntitiesSavedStates = (0,external_wp_element_namespaceObject.useCallback)(arg => { 8748 if (typeof entitiesSavedStatesCallback === 'function') { 8749 entitiesSavedStatesCallback(arg); 8750 } 8751 8752 setEntitiesSavedStatesCallback(false); 8753 }, [entitiesSavedStatesCallback]); 8754 const secondarySidebarLabel = isListViewOpened ? (0,external_wp_i18n_namespaceObject.__)('List View') : (0,external_wp_i18n_namespaceObject.__)('Block Library'); 8755 8756 const secondarySidebar = () => { 8757 if (mode === 'visual' && isInserterOpened) { 8758 return (0,external_wp_element_namespaceObject.createElement)(InserterSidebar, null); 8759 } 8760 8761 if (mode === 'visual' && isListViewOpened) { 8762 return (0,external_wp_element_namespaceObject.createElement)(ListViewSidebar, null); 8763 } 8764 8765 return null; 8766 }; 8767 8768 function onPluginAreaError(name) { 8769 createErrorNotice((0,external_wp_i18n_namespaceObject.sprintf)( 8770 /* translators: %s: plugin name */ 8771 (0,external_wp_i18n_namespaceObject.__)('The "%s" plugin has encountered an error and cannot be rendered.'), name)); 8772 } 8773 8774 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(fullscreen_mode, { 8775 isActive: isFullscreenActive 8776 }), (0,external_wp_element_namespaceObject.createElement)(browser_url, null), (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.UnsavedChangesWarning, null), (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.AutosaveMonitor, null), (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.LocalAutosaveMonitor, null), (0,external_wp_element_namespaceObject.createElement)(keyboard_shortcuts, null), (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.EditorKeyboardShortcutsRegister, null), (0,external_wp_element_namespaceObject.createElement)(settings_sidebar, null), (0,external_wp_element_namespaceObject.createElement)(interface_skeleton, { 8777 className: className, 8778 labels: { ...interfaceLabels, 8779 secondarySidebar: secondarySidebarLabel 8780 }, 8781 header: (0,external_wp_element_namespaceObject.createElement)(header, { 8782 setEntitiesSavedStatesCallback: setEntitiesSavedStatesCallback 8783 }), 8784 secondarySidebar: secondarySidebar(), 8785 sidebar: (!isMobileViewport || sidebarIsOpened) && (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, !isMobileViewport && !sidebarIsOpened && (0,external_wp_element_namespaceObject.createElement)("div", { 8786 className: "edit-post-layout__toggle-sidebar-panel" 8787 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { 8788 variant: "secondary", 8789 className: "edit-post-layout__toggle-sidebar-panel-button", 8790 onClick: openSidebarPanel, 8791 "aria-expanded": false 8792 }, hasBlockSelected ? (0,external_wp_i18n_namespaceObject.__)('Open block settings') : (0,external_wp_i18n_namespaceObject.__)('Open document settings'))), (0,external_wp_element_namespaceObject.createElement)(complementary_area.Slot, { 8793 scope: "core/edit-post" 8794 })), 8795 notices: (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.EditorSnackbars, null), 8796 content: (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.EditorNotices, null), (mode === 'text' || !isRichEditingEnabled) && (0,external_wp_element_namespaceObject.createElement)(text_editor, null), isRichEditingEnabled && mode === 'visual' && (0,external_wp_element_namespaceObject.createElement)(VisualEditor, { 8797 styles: styles 8798 }), !isTemplateMode && (0,external_wp_element_namespaceObject.createElement)("div", { 8799 className: "edit-post-layout__metaboxes" 8800 }, (0,external_wp_element_namespaceObject.createElement)(MetaBoxes, { 8801 location: "normal" 8802 }), (0,external_wp_element_namespaceObject.createElement)(MetaBoxes, { 8803 location: "advanced" 8804 })), isMobileViewport && sidebarIsOpened && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ScrollLock, null), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockStyles.Slot, { 8805 scope: "core/block-inspector" 8806 })), 8807 footer: !hasReducedUI && showBlockBreadcrumbs && !isMobileViewport && isRichEditingEnabled && mode === 'visual' && (0,external_wp_element_namespaceObject.createElement)("div", { 8808 className: "edit-post-layout__footer" 8809 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockBreadcrumb, { 8810 rootLabelText: documentLabel 8811 })), 8812 actions: (0,external_wp_element_namespaceObject.createElement)(ActionsPanel, { 8813 closeEntitiesSavedStates: closeEntitiesSavedStates, 8814 isEntitiesSavedStatesOpen: entitiesSavedStatesCallback, 8815 setEntitiesSavedStatesCallback: setEntitiesSavedStatesCallback 8816 }), 8817 shortcuts: { 8818 previous: previousShortcut, 8819 next: nextShortcut 8820 } 8821 }), (0,external_wp_element_namespaceObject.createElement)(EditPostPreferencesModal, null), (0,external_wp_element_namespaceObject.createElement)(keyboard_shortcut_help_modal, null), (0,external_wp_element_namespaceObject.createElement)(WelcomeGuide, null), (0,external_wp_element_namespaceObject.createElement)(StartPageOptions, null), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Popover.Slot, null), (0,external_wp_element_namespaceObject.createElement)(external_wp_plugins_namespaceObject.PluginArea, { 8822 onError: onPluginAreaError 8823 })); 8824 } 8825 8826 /* harmony default export */ var components_layout = (Layout); 8827 8828 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/editor-initialization/listener-hooks.js 8829 /** 8830 * WordPress dependencies 8831 */ 8832 8833 8834 8835 8836 /** 8837 * Internal dependencies 8838 */ 8839 8840 8841 /** 8842 * This listener hook monitors for block selection and triggers the appropriate 8843 * sidebar state. 8844 * 8845 * @param {number} postId The current post id. 8846 */ 8847 8848 const useBlockSelectionListener = postId => { 8849 const { 8850 hasBlockSelection, 8851 isEditorSidebarOpened 8852 } = (0,external_wp_data_namespaceObject.useSelect)(select => ({ 8853 hasBlockSelection: !!select(external_wp_blockEditor_namespaceObject.store).getBlockSelectionStart(), 8854 isEditorSidebarOpened: select(constants_STORE_NAME).isEditorSidebarOpened() 8855 }), [postId]); 8856 const { 8857 openGeneralSidebar 8858 } = (0,external_wp_data_namespaceObject.useDispatch)(constants_STORE_NAME); 8859 (0,external_wp_element_namespaceObject.useEffect)(() => { 8860 if (!isEditorSidebarOpened) { 8861 return; 8862 } 8863 8864 if (hasBlockSelection) { 8865 openGeneralSidebar('edit-post/block'); 8866 } else { 8867 openGeneralSidebar('edit-post/document'); 8868 } 8869 }, [hasBlockSelection, isEditorSidebarOpened]); 8870 }; 8871 /** 8872 * This listener hook monitors any change in permalink and updates the view 8873 * post link in the admin bar. 8874 * 8875 * @param {number} postId 8876 */ 8877 8878 const useUpdatePostLinkListener = postId => { 8879 const { 8880 newPermalink 8881 } = (0,external_wp_data_namespaceObject.useSelect)(select => ({ 8882 newPermalink: select(external_wp_editor_namespaceObject.store).getCurrentPost().link 8883 }), [postId]); 8884 const nodeToUpdate = (0,external_wp_element_namespaceObject.useRef)(); 8885 (0,external_wp_element_namespaceObject.useEffect)(() => { 8886 nodeToUpdate.current = document.querySelector(VIEW_AS_PREVIEW_LINK_SELECTOR) || document.querySelector(VIEW_AS_LINK_SELECTOR); 8887 }, [postId]); 8888 (0,external_wp_element_namespaceObject.useEffect)(() => { 8889 if (!newPermalink || !nodeToUpdate.current) { 8890 return; 8891 } 8892 8893 nodeToUpdate.current.setAttribute('href', newPermalink); 8894 }, [newPermalink]); 8895 }; 8896 8897 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/editor-initialization/index.js 8898 /** 8899 * Internal dependencies 8900 */ 8901 8902 /** 8903 * Data component used for initializing the editor and re-initializes 8904 * when postId changes or on unmount. 8905 * 8906 * @param {number} postId The id of the post. 8907 * @return {null} This is a data component so does not render any ui. 8908 */ 8909 8910 function EditorInitialization(_ref) { 8911 let { 8912 postId 8913 } = _ref; 8914 useBlockSelectionListener(postId); 8915 useUpdatePostLinkListener(postId); 8916 return null; 8917 } 8918 8919 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/editor.js 8920 8921 8922 8923 /** 8924 * External dependencies 8925 */ 8926 8927 /** 8928 * WordPress dependencies 8929 */ 8930 8931 8932 8933 8934 8935 8936 8937 8938 8939 /** 8940 * Internal dependencies 8941 */ 8942 8943 8944 8945 8946 8947 function Editor(_ref) { 8948 let { 8949 postId, 8950 postType, 8951 settings, 8952 initialEdits, 8953 onError, 8954 ...props 8955 } = _ref; 8956 const { 8957 hasFixedToolbar, 8958 focusMode, 8959 hasReducedUI, 8960 hasThemeStyles, 8961 post, 8962 preferredStyleVariations, 8963 hiddenBlockTypes, 8964 blockTypes, 8965 keepCaretInsideBlock, 8966 isTemplateMode, 8967 template 8968 } = (0,external_wp_data_namespaceObject.useSelect)(select => { 8969 var _getPostType$viewable, _getPostType; 8970 8971 const { 8972 isFeatureActive, 8973 __experimentalGetPreviewDeviceType, 8974 isEditingTemplate, 8975 getEditedPostTemplate, 8976 getHiddenBlockTypes 8977 } = select(store_store); 8978 const { 8979 getEntityRecord, 8980 getPostType, 8981 getEntityRecords 8982 } = select(external_wp_coreData_namespaceObject.store); 8983 const { 8984 getEditorSettings 8985 } = select(external_wp_editor_namespaceObject.store); 8986 const { 8987 getBlockTypes 8988 } = select(external_wp_blocks_namespaceObject.store); 8989 const isTemplate = ['wp_template', 'wp_template_part'].includes(postType); // Ideally the initializeEditor function should be called using the ID of the REST endpoint. 8990 // to avoid the special case. 8991 8992 let postObject; 8993 8994 if (isTemplate) { 8995 const posts = getEntityRecords('postType', postType, { 8996 wp_id: postId 8997 }); 8998 postObject = posts === null || posts === void 0 ? void 0 : posts[0]; 8999 } else { 9000 postObject = getEntityRecord('postType', postType, postId); 9001 } 9002 9003 const supportsTemplateMode = getEditorSettings().supportsTemplateMode; 9004 const isViewable = (_getPostType$viewable = (_getPostType = getPostType(postType)) === null || _getPostType === void 0 ? void 0 : _getPostType.viewable) !== null && _getPostType$viewable !== void 0 ? _getPostType$viewable : false; 9005 return { 9006 hasFixedToolbar: isFeatureActive('fixedToolbar') || __experimentalGetPreviewDeviceType() !== 'Desktop', 9007 focusMode: isFeatureActive('focusMode'), 9008 hasReducedUI: isFeatureActive('reducedUI'), 9009 hasThemeStyles: isFeatureActive('themeStyles'), 9010 preferredStyleVariations: select(external_wp_preferences_namespaceObject.store).get('core/edit-post', 'preferredStyleVariations'), 9011 hiddenBlockTypes: getHiddenBlockTypes(), 9012 blockTypes: getBlockTypes(), 9013 keepCaretInsideBlock: isFeatureActive('keepCaretInsideBlock'), 9014 isTemplateMode: isEditingTemplate(), 9015 template: supportsTemplateMode && isViewable ? getEditedPostTemplate() : null, 9016 post: postObject 9017 }; 9018 }, [postType, postId]); 9019 const { 9020 updatePreferredStyleVariations, 9021 setIsInserterOpened 9022 } = (0,external_wp_data_namespaceObject.useDispatch)(store_store); 9023 const editorSettings = (0,external_wp_element_namespaceObject.useMemo)(() => { 9024 const result = { ...settings, 9025 __experimentalPreferredStyleVariations: { 9026 value: preferredStyleVariations, 9027 onChange: updatePreferredStyleVariations 9028 }, 9029 hasFixedToolbar, 9030 focusMode, 9031 hasReducedUI, 9032 // This is marked as experimental to give time for the quick inserter to mature. 9033 __experimentalSetIsInserterOpened: setIsInserterOpened, 9034 keepCaretInsideBlock, 9035 // Keep a reference of the `allowedBlockTypes` from the server to handle use cases 9036 // where we need to differentiate if a block is disabled by the user or some plugin. 9037 defaultAllowedBlockTypes: settings.allowedBlockTypes 9038 }; // Omit hidden block types if exists and non-empty. 9039 9040 if ((0,external_lodash_namespaceObject.size)(hiddenBlockTypes) > 0) { 9041 // Defer to passed setting for `allowedBlockTypes` if provided as 9042 // anything other than `true` (where `true` is equivalent to allow 9043 // all block types). 9044 const defaultAllowedBlockTypes = true === settings.allowedBlockTypes ? (0,external_lodash_namespaceObject.map)(blockTypes, 'name') : settings.allowedBlockTypes || []; 9045 result.allowedBlockTypes = (0,external_lodash_namespaceObject.without)(defaultAllowedBlockTypes, ...hiddenBlockTypes); 9046 } 9047 9048 return result; 9049 }, [settings, hasFixedToolbar, focusMode, hasReducedUI, hiddenBlockTypes, blockTypes, preferredStyleVariations, setIsInserterOpened, updatePreferredStyleVariations, keepCaretInsideBlock]); 9050 const styles = (0,external_wp_element_namespaceObject.useMemo)(() => { 9051 const themeStyles = []; 9052 const presetStyles = []; 9053 (0,external_lodash_namespaceObject.forEach)(settings.styles, style => { 9054 if (!style.__unstableType || style.__unstableType === 'theme') { 9055 themeStyles.push(style); 9056 } else { 9057 presetStyles.push(style); 9058 } 9059 }); 9060 const defaultEditorStyles = [...settings.defaultEditorStyles, ...presetStyles]; 9061 return hasThemeStyles && themeStyles.length ? settings.styles : defaultEditorStyles; 9062 }, [settings, hasThemeStyles]); 9063 9064 if (!post) { 9065 return null; 9066 } 9067 9068 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.StrictMode, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_keyboardShortcuts_namespaceObject.ShortcutProvider, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SlotFillProvider, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.EditorProvider, _extends({ 9069 settings: editorSettings, 9070 post: post, 9071 initialEdits: initialEdits, 9072 useSubRegistry: false, 9073 __unstableTemplate: isTemplateMode ? template : undefined 9074 }, props), (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.ErrorBoundary, { 9075 onError: onError 9076 }, (0,external_wp_element_namespaceObject.createElement)(EditorInitialization, { 9077 postId: postId 9078 }), (0,external_wp_element_namespaceObject.createElement)(components_layout, { 9079 styles: styles 9080 })), (0,external_wp_element_namespaceObject.createElement)(external_wp_editor_namespaceObject.PostLockedModal, null))))); 9081 } 9082 9083 /* harmony default export */ var editor = (Editor); 9084 9085 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/block-settings-menu/plugin-block-settings-menu-item.js 9086 9087 9088 /** 9089 * External dependencies 9090 */ 9091 9092 /** 9093 * WordPress dependencies 9094 */ 9095 9096 9097 9098 9099 9100 const isEverySelectedBlockAllowed = (selected, allowed) => (0,external_lodash_namespaceObject.difference)(selected, allowed).length === 0; 9101 /** 9102 * Plugins may want to add an item to the menu either for every block 9103 * or only for the specific ones provided in the `allowedBlocks` component property. 9104 * 9105 * If there are multiple blocks selected the item will be rendered if every block 9106 * is of one allowed type (not necessarily the same). 9107 * 9108 * @param {string[]} selectedBlocks Array containing the names of the blocks selected 9109 * @param {string[]} allowedBlocks Array containing the names of the blocks allowed 9110 * @return {boolean} Whether the item will be rendered or not. 9111 */ 9112 9113 9114 const shouldRenderItem = (selectedBlocks, allowedBlocks) => !Array.isArray(allowedBlocks) || isEverySelectedBlockAllowed(selectedBlocks, allowedBlocks); 9115 /** 9116 * Renders a new item in the block settings menu. 9117 * 9118 * @param {Object} props Component props. 9119 * @param {Array} [props.allowedBlocks] An array containing a list of block names for which the item should be shown. If not present, it'll be rendered for any block. If multiple blocks are selected, it'll be shown if and only if all of them are in the allowed list. 9120 * @param {WPBlockTypeIconRender} [props.icon] The [Dashicon](https://developer.wordpress.org/resource/dashicons/) icon slug string, or an SVG WP element. 9121 * @param {string} props.label The menu item text. 9122 * @param {Function} props.onClick Callback function to be executed when the user click the menu item. 9123 * @param {boolean} [props.small] Whether to render the label or not. 9124 * @param {string} [props.role] The ARIA role for the menu item. 9125 * 9126 * @example 9127 * ```js 9128 * // Using ES5 syntax 9129 * var __ = wp.i18n.__; 9130 * var PluginBlockSettingsMenuItem = wp.editPost.PluginBlockSettingsMenuItem; 9131 * 9132 * function doOnClick(){ 9133 * // To be called when the user clicks the menu item. 9134 * } 9135 * 9136 * function MyPluginBlockSettingsMenuItem() { 9137 * return wp.element.createElement( 9138 * PluginBlockSettingsMenuItem, 9139 * { 9140 * allowedBlocks: [ 'core/paragraph' ], 9141 * icon: 'dashicon-name', 9142 * label: __( 'Menu item text' ), 9143 * onClick: doOnClick, 9144 * } 9145 * ); 9146 * } 9147 * ``` 9148 * 9149 * @example 9150 * ```jsx 9151 * // Using ESNext syntax 9152 * import { __ } from '@wordpress/i18n'; 9153 * import { PluginBlockSettingsMenuItem } from '@wordpress/edit-post'; 9154 * 9155 * const doOnClick = ( ) => { 9156 * // To be called when the user clicks the menu item. 9157 * }; 9158 * 9159 * const MyPluginBlockSettingsMenuItem = () => ( 9160 * <PluginBlockSettingsMenuItem 9161 * allowedBlocks={ [ 'core/paragraph' ] } 9162 * icon='dashicon-name' 9163 * label={ __( 'Menu item text' ) } 9164 * onClick={ doOnClick } /> 9165 * ); 9166 * ``` 9167 * 9168 * @return {WPComponent} The component to be rendered. 9169 */ 9170 9171 9172 const PluginBlockSettingsMenuItem = _ref => { 9173 let { 9174 allowedBlocks, 9175 icon, 9176 label, 9177 onClick, 9178 small, 9179 role 9180 } = _ref; 9181 return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockSettingsMenuControls, null, _ref2 => { 9182 let { 9183 selectedBlocks, 9184 onClose 9185 } = _ref2; 9186 9187 if (!shouldRenderItem(selectedBlocks, allowedBlocks)) { 9188 return null; 9189 } 9190 9191 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, { 9192 onClick: (0,external_wp_compose_namespaceObject.compose)(onClick, onClose), 9193 icon: icon, 9194 label: small ? label : undefined, 9195 role: role 9196 }, !small && label); 9197 }); 9198 }; 9199 9200 /* harmony default export */ var plugin_block_settings_menu_item = (PluginBlockSettingsMenuItem); 9201 9202 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/header/plugin-more-menu-item/index.js 9203 /** 9204 * WordPress dependencies 9205 */ 9206 9207 9208 9209 9210 /** 9211 * Renders a menu item in `Plugins` group in `More Menu` drop down, and can be used to as a button or link depending on the props provided. 9212 * The text within the component appears as the menu item label. 9213 * 9214 * @param {Object} props Component properties. 9215 * @param {string} [props.href] When `href` is provided then the menu item is represented as an anchor rather than button. It corresponds to the `href` attribute of the anchor. 9216 * @param {WPBlockTypeIconRender} [props.icon=inherits from the plugin] The [Dashicon](https://developer.wordpress.org/resource/dashicons/) icon slug string, or an SVG WP element, to be rendered to the left of the menu item label. 9217 * @param {Function} [props.onClick=noop] The callback function to be executed when the user clicks the menu item. 9218 * @param {...*} [props.other] Any additional props are passed through to the underlying [MenuItem](https://github.com/WordPress/gutenberg/tree/HEAD/packages/components/src/menu-item/README.md) component. 9219 * 9220 * @example 9221 * ```js 9222 * // Using ES5 syntax 9223 * var __ = wp.i18n.__; 9224 * var PluginMoreMenuItem = wp.editPost.PluginMoreMenuItem; 9225 * var moreIcon = wp.element.createElement( 'svg' ); //... svg element. 9226 * 9227 * function onButtonClick() { 9228 * alert( 'Button clicked.' ); 9229 * } 9230 * 9231 * function MyButtonMoreMenuItem() { 9232 * return wp.element.createElement( 9233 * PluginMoreMenuItem, 9234 * { 9235 * icon: moreIcon, 9236 * onClick: onButtonClick, 9237 * }, 9238 * __( 'My button title' ) 9239 * ); 9240 * } 9241 * ``` 9242 * 9243 * @example 9244 * ```jsx 9245 * // Using ESNext syntax 9246 * import { __ } from '@wordpress/i18n'; 9247 * import { PluginMoreMenuItem } from '@wordpress/edit-post'; 9248 * import { more } from '@wordpress/icons'; 9249 * 9250 * function onButtonClick() { 9251 * alert( 'Button clicked.' ); 9252 * } 9253 * 9254 * const MyButtonMoreMenuItem = () => ( 9255 * <PluginMoreMenuItem 9256 * icon={ more } 9257 * onClick={ onButtonClick } 9258 * > 9259 * { __( 'My button title' ) } 9260 * </PluginMoreMenuItem> 9261 * ); 9262 * ``` 9263 * 9264 * @return {WPComponent} The component to be rendered. 9265 */ 9266 9267 /* harmony default export */ var plugin_more_menu_item = ((0,external_wp_compose_namespaceObject.compose)((0,external_wp_plugins_namespaceObject.withPluginContext)((context, ownProps) => { 9268 var _ownProps$as; 9269 9270 return { 9271 as: (_ownProps$as = ownProps.as) !== null && _ownProps$as !== void 0 ? _ownProps$as : external_wp_components_namespaceObject.MenuItem, 9272 icon: ownProps.icon || context.icon, 9273 name: 'core/edit-post/plugin-more-menu' 9274 }; 9275 }))(action_item)); 9276 9277 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/components/header/plugin-sidebar-more-menu-item/index.js 9278 9279 9280 9281 /** 9282 * WordPress dependencies 9283 */ 9284 9285 /** 9286 * Renders a menu item in `Plugins` group in `More Menu` drop down, 9287 * and can be used to activate the corresponding `PluginSidebar` component. 9288 * The text within the component appears as the menu item label. 9289 * 9290 * @param {Object} props Component props. 9291 * @param {string} props.target A string identifying the target sidebar you wish to be activated by this menu item. Must be the same as the `name` prop you have given to that sidebar. 9292 * @param {WPBlockTypeIconRender} [props.icon=inherits from the plugin] The [Dashicon](https://developer.wordpress.org/resource/dashicons/) icon slug string, or an SVG WP element, to be rendered to the left of the menu item label. 9293 * 9294 * @example 9295 * ```js 9296 * // Using ES5 syntax 9297 * var __ = wp.i18n.__; 9298 * var PluginSidebarMoreMenuItem = wp.editPost.PluginSidebarMoreMenuItem; 9299 * var moreIcon = wp.element.createElement( 'svg' ); //... svg element. 9300 * 9301 * function MySidebarMoreMenuItem() { 9302 * return wp.element.createElement( 9303 * PluginSidebarMoreMenuItem, 9304 * { 9305 * target: 'my-sidebar', 9306 * icon: moreIcon, 9307 * }, 9308 * __( 'My sidebar title' ) 9309 * ) 9310 * } 9311 * ``` 9312 * 9313 * @example 9314 * ```jsx 9315 * // Using ESNext syntax 9316 * import { __ } from '@wordpress/i18n'; 9317 * import { PluginSidebarMoreMenuItem } from '@wordpress/edit-post'; 9318 * import { more } from '@wordpress/icons'; 9319 * 9320 * const MySidebarMoreMenuItem = () => ( 9321 * <PluginSidebarMoreMenuItem 9322 * target="my-sidebar" 9323 * icon={ more } 9324 * > 9325 * { __( 'My sidebar title' ) } 9326 * </PluginSidebarMoreMenuItem> 9327 * ); 9328 * ``` 9329 * 9330 * @return {WPComponent} The component to be rendered. 9331 */ 9332 9333 function PluginSidebarMoreMenuItem(props) { 9334 return (0,external_wp_element_namespaceObject.createElement)(ComplementaryAreaMoreMenuItem // Menu item is marked with unstable prop for backward compatibility. 9335 // @see https://github.com/WordPress/gutenberg/issues/14457 9336 , _extends({ 9337 __unstableExplicitMenuItem: true, 9338 scope: "core/edit-post" 9339 }, props)); 9340 } 9341 9342 ;// CONCATENATED MODULE: ./node_modules/@wordpress/edit-post/build-module/index.js 9343 9344 9345 /** 9346 * WordPress dependencies 9347 */ 9348 9349 9350 9351 9352 9353 9354 /** 9355 * Internal dependencies 9356 */ 9357 9358 9359 9360 9361 9362 /** 9363 * Reinitializes the editor after the user chooses to reboot the editor after 9364 * an unhandled error occurs, replacing previously mounted editor element using 9365 * an initial state from prior to the crash. 9366 * 9367 * @param {Object} postType Post type of the post to edit. 9368 * @param {Object} postId ID of the post to edit. 9369 * @param {Element} target DOM node in which editor is rendered. 9370 * @param {?Object} settings Editor settings object. 9371 * @param {Object} initialEdits Programmatic edits to apply initially, to be 9372 * considered as non-user-initiated (bypass for 9373 * unsaved changes prompt). 9374 */ 9375 9376 function reinitializeEditor(postType, postId, target, settings, initialEdits) { 9377 (0,external_wp_element_namespaceObject.unmountComponentAtNode)(target); 9378 const reboot = reinitializeEditor.bind(null, postType, postId, target, settings, initialEdits); 9379 (0,external_wp_element_namespaceObject.render)((0,external_wp_element_namespaceObject.createElement)(editor, { 9380 settings: settings, 9381 onError: reboot, 9382 postId: postId, 9383 postType: postType, 9384 initialEdits: initialEdits, 9385 recovery: true 9386 }), target); 9387 } 9388 /** 9389 * Initializes and returns an instance of Editor. 9390 * 9391 * @param {string} id Unique identifier for editor instance. 9392 * @param {string} postType Post type of the post to edit. 9393 * @param {Object} postId ID of the post to edit. 9394 * @param {?Object} settings Editor settings object. 9395 * @param {Object} initialEdits Programmatic edits to apply initially, to be 9396 * considered as non-user-initiated (bypass for 9397 * unsaved changes prompt). 9398 */ 9399 9400 function initializeEditor(id, postType, postId, settings, initialEdits) { 9401 // Prevent adding template part in the post editor. 9402 // Only add the filter when the post editor is initialized, not imported. 9403 (0,external_wp_hooks_namespaceObject.addFilter)('blockEditor.__unstableCanInsertBlockType', 'removeTemplatePartsFromInserter', (can, blockType) => { 9404 if (!(0,external_wp_data_namespaceObject.select)(store_store).isEditingTemplate() && blockType.name === 'core/template-part') { 9405 return false; 9406 } 9407 9408 return can; 9409 }); 9410 const target = document.getElementById(id); 9411 const reboot = reinitializeEditor.bind(null, postType, postId, target, settings, initialEdits); 9412 (0,external_wp_data_namespaceObject.dispatch)(external_wp_preferences_namespaceObject.store).setDefaults('core/edit-post', { 9413 editorMode: 'visual', 9414 fixedToolbar: false, 9415 fullscreenMode: true, 9416 hiddenBlockTypes: [], 9417 inactivePanels: [], 9418 isPublishSidebarEnabled: true, 9419 openPanels: ['post-status'], 9420 preferredStyleVariations: {}, 9421 showBlockBreadcrumbs: true, 9422 showIconLabels: false, 9423 themeStyles: true, 9424 welcomeGuide: true, 9425 welcomeGuideTemplate: true 9426 }); 9427 9428 (0,external_wp_data_namespaceObject.dispatch)(external_wp_blocks_namespaceObject.store).__experimentalReapplyBlockTypeFilters(); 9429 9430 (0,external_wp_blockLibrary_namespaceObject.registerCoreBlocks)(); 9431 9432 if (false) {} // Show a console log warning if the browser is not in Standards rendering mode. 9433 9434 9435 const documentMode = document.compatMode === 'CSS1Compat' ? 'Standards' : 'Quirks'; 9436 9437 if (documentMode !== 'Standards') { 9438 // eslint-disable-next-line no-console 9439 console.warn("Your browser is using Quirks Mode. \nThis can cause rendering issues such as blocks overlaying meta boxes in the editor. Quirks Mode can be triggered by PHP errors or HTML code appearing before the opening <!DOCTYPE html>. Try checking the raw page source or your site's PHP error log and resolving errors there, removing any HTML before the doctype, or disabling plugins."); 9440 } // This is a temporary fix for a couple of issues specific to Webkit on iOS. 9441 // Without this hack the browser scrolls the mobile toolbar off-screen. 9442 // Once supported in Safari we can replace this in favor of preventScroll. 9443 // For details see issue #18632 and PR #18686 9444 // Specifically, we scroll `interface-interface-skeleton__body` to enable a fixed top toolbar. 9445 // But Mobile Safari forces the `html` element to scroll upwards, hiding the toolbar. 9446 9447 9448 const isIphone = window.navigator.userAgent.indexOf('iPhone') !== -1; 9449 9450 if (isIphone) { 9451 window.addEventListener('scroll', event => { 9452 const editorScrollContainer = document.getElementsByClassName('interface-interface-skeleton__body')[0]; 9453 9454 if (event.target === document) { 9455 // Scroll element into view by scrolling the editor container by the same amount 9456 // that Mobile Safari tried to scroll the html element upwards. 9457 if (window.scrollY > 100) { 9458 editorScrollContainer.scrollTop = editorScrollContainer.scrollTop + window.scrollY; 9459 } // Undo unwanted scroll on html element, but only in the visual editor. 9460 9461 9462 if (document.getElementsByClassName('is-mode-visual')[0]) { 9463 window.scrollTo(0, 0); 9464 } 9465 } 9466 }); 9467 } 9468 9469 (0,external_wp_element_namespaceObject.render)((0,external_wp_element_namespaceObject.createElement)(editor, { 9470 settings: settings, 9471 onError: reboot, 9472 postId: postId, 9473 postType: postType, 9474 initialEdits: initialEdits 9475 }), target); 9476 } 9477 9478 9479 9480 9481 9482 9483 9484 9485 9486 9487 9488 9489 }(); 9490 (window.wp = window.wp || {}).editPost = __webpack_exports__; 9491 /******/ })() 9492 ;
title
Description
Body
title
Description
Body
title
Description
Body
title
Body
Generated: Fri Jan 24 01:00:03 2025 | Cross-referenced by PHPXref 0.7.1 |