this["wp"] = this["wp"] || {}; this["wp"]["reusableBlocks"] = /******/ (function(modules) { // webpackBootstrap /******/ // The module cache /******/ var installedModules = {}; /******/ /******/ // The require function /******/ function __webpack_require__(moduleId) { /******/ /******/ // Check if module is in cache /******/ if(installedModules[moduleId]) { /******/ return installedModules[moduleId].exports; /******/ } /******/ // Create a new module (and put it into the cache) /******/ var module = installedModules[moduleId] = { /******/ i: moduleId, /******/ l: false, /******/ exports: {} /******/ }; /******/ /******/ // Execute the module function /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); /******/ /******/ // Flag the module as loaded /******/ module.l = true; /******/ /******/ // Return the exports of the module /******/ return module.exports; /******/ } /******/ /******/ /******/ // expose the modules object (__webpack_modules__) /******/ __webpack_require__.m = modules; /******/ /******/ // expose the module cache /******/ __webpack_require__.c = installedModules; /******/ /******/ // define getter function for harmony exports /******/ __webpack_require__.d = function(exports, name, getter) { /******/ if(!__webpack_require__.o(exports, name)) { /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); /******/ } /******/ }; /******/ /******/ // define __esModule on exports /******/ __webpack_require__.r = function(exports) { /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); /******/ } /******/ Object.defineProperty(exports, '__esModule', { value: true }); /******/ }; /******/ /******/ // create a fake namespace object /******/ // mode & 1: value is a module id, require it /******/ // mode & 2: merge all properties of value into the ns /******/ // mode & 4: return value when already ns object /******/ // mode & 8|1: behave like require /******/ __webpack_require__.t = function(value, mode) { /******/ if(mode & 1) value = __webpack_require__(value); /******/ if(mode & 8) return value; /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; /******/ var ns = Object.create(null); /******/ __webpack_require__.r(ns); /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); /******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); /******/ return ns; /******/ }; /******/ /******/ // getDefaultExport function for compatibility with non-harmony modules /******/ __webpack_require__.n = function(module) { /******/ var getter = module && module.__esModule ? /******/ function getDefault() { return module['default']; } : /******/ function getModuleExports() { return module; }; /******/ __webpack_require__.d(getter, 'a', getter); /******/ return getter; /******/ }; /******/ /******/ // Object.prototype.hasOwnProperty.call /******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; /******/ /******/ // __webpack_public_path__ /******/ __webpack_require__.p = ""; /******/ /******/ /******/ // Load entry module and return exports /******/ return __webpack_require__(__webpack_require__.s = 569); /******/ }) /************************************************************************/ /******/ ({ /***/ 0: /***/ (function(module, exports) { (function() { module.exports = window["wp"]["element"]; }()); /***/ }), /***/ 1: /***/ (function(module, exports) { (function() { module.exports = window["wp"]["i18n"]; }()); /***/ }), /***/ 18: /***/ (function(module, exports) { (function() { module.exports = window["wp"]["coreData"]; }()); /***/ }), /***/ 2: /***/ (function(module, exports) { (function() { module.exports = window["lodash"]; }()); /***/ }), /***/ 20: /***/ (function(module, exports) { (function() { module.exports = window["wp"]["url"]; }()); /***/ }), /***/ 3: /***/ (function(module, exports) { (function() { module.exports = window["wp"]["primitives"]; }()); /***/ }), /***/ 323: /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; /* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(0); /* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var _wordpress_primitives__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3); /* harmony import */ var _wordpress_primitives__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_wordpress_primitives__WEBPACK_IMPORTED_MODULE_1__); /** * WordPress dependencies */ const reusableBlock = Object(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__["createElement"])(_wordpress_primitives__WEBPACK_IMPORTED_MODULE_1__["SVG"], { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24" }, Object(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__["createElement"])(_wordpress_primitives__WEBPACK_IMPORTED_MODULE_1__["Path"], { d: "M7 7.2h8.2L13.5 9l1.1 1.1 3.6-3.6-3.5-4-1.1 1 1.9 2.3H7c-.9 0-1.7.3-2.3.9-1.4 1.5-1.4 4.2-1.4 5.6v.2h1.5v-.3c0-1.1 0-3.5 1-4.5.3-.3.7-.5 1.2-.5zm13.8 4V11h-1.5v.3c0 1.1 0 3.5-1 4.5-.3.3-.7.5-1.3.5H8.8l1.7-1.7-1.1-1.1L5.9 17l3.5 4 1.1-1-1.9-2.3H17c.9 0 1.7-.3 2.3-.9 1.5-1.4 1.5-4.2 1.5-5.6z" })); /* harmony default export */ __webpack_exports__["a"] = (reusableBlock); /***/ }), /***/ 36: /***/ (function(module, exports) { (function() { module.exports = window["wp"]["notices"]; }()); /***/ }), /***/ 4: /***/ (function(module, exports) { (function() { module.exports = window["wp"]["components"]; }()); /***/ }), /***/ 5: /***/ (function(module, exports) { (function() { module.exports = window["wp"]["data"]; }()); /***/ }), /***/ 569: /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; // ESM COMPAT FLAG __webpack_require__.r(__webpack_exports__); // EXPORTS __webpack_require__.d(__webpack_exports__, "store", function() { return /* reexport */ store; }); __webpack_require__.d(__webpack_exports__, "ReusableBlocksMenuItems", function() { return /* reexport */ reusable_blocks_menu_items; }); // NAMESPACE OBJECT: ./node_modules/@wordpress/reusable-blocks/build-module/store/actions.js var actions_namespaceObject = {}; __webpack_require__.r(actions_namespaceObject); __webpack_require__.d(actions_namespaceObject, "__experimentalConvertBlockToStatic", function() { return __experimentalConvertBlockToStatic; }); __webpack_require__.d(actions_namespaceObject, "__experimentalConvertBlocksToReusable", function() { return __experimentalConvertBlocksToReusable; }); __webpack_require__.d(actions_namespaceObject, "__experimentalDeleteReusableBlock", function() { return __experimentalDeleteReusableBlock; }); __webpack_require__.d(actions_namespaceObject, "__experimentalSetEditingReusableBlock", function() { return __experimentalSetEditingReusableBlock; }); // NAMESPACE OBJECT: ./node_modules/@wordpress/reusable-blocks/build-module/store/selectors.js var selectors_namespaceObject = {}; __webpack_require__.r(selectors_namespaceObject); __webpack_require__.d(selectors_namespaceObject, "__experimentalIsEditingReusableBlock", function() { return __experimentalIsEditingReusableBlock; }); // EXTERNAL MODULE: external ["wp","blockEditor"] var external_wp_blockEditor_ = __webpack_require__(6); // EXTERNAL MODULE: external ["wp","coreData"] var external_wp_coreData_ = __webpack_require__(18); // EXTERNAL MODULE: external ["wp","data"] var external_wp_data_ = __webpack_require__(5); // EXTERNAL MODULE: external "lodash" var external_lodash_ = __webpack_require__(2); // EXTERNAL MODULE: external ["wp","blocks"] var external_wp_blocks_ = __webpack_require__(8); // EXTERNAL MODULE: external ["wp","i18n"] var external_wp_i18n_ = __webpack_require__(1); // CONCATENATED MODULE: ./node_modules/@wordpress/reusable-blocks/build-module/store/controls.js /** * External dependencies */ /** * WordPress dependencies */ /** * Internal dependencies */ /** * Convert a reusable block to a static block effect handler * * @param {string} clientId Block ID. * @return {Object} control descriptor. */ function convertBlockToStatic(clientId) { return { type: 'CONVERT_BLOCK_TO_STATIC', clientId }; } /** * Convert a static block to a reusable block effect handler * * @param {Array} clientIds Block IDs. * @param {string} title Reusable block title. * @return {Object} control descriptor. */ function controls_convertBlocksToReusable(clientIds, title) { return { type: 'CONVERT_BLOCKS_TO_REUSABLE', clientIds, title }; } /** * Deletes a reusable block. * * @param {string} id Reusable block ID. * @return {Object} control descriptor. */ function deleteReusableBlock(id) { return { type: 'DELETE_REUSABLE_BLOCK', id }; } const controls = { CONVERT_BLOCK_TO_STATIC: Object(external_wp_data_["createRegistryControl"])(registry => ({ clientId }) => { const oldBlock = registry.select(external_wp_blockEditor_["store"]).getBlock(clientId); const reusableBlock = registry.select('core').getEditedEntityRecord('postType', 'wp_block', oldBlock.attributes.ref); const newBlocks = Object(external_wp_blocks_["parse"])(Object(external_lodash_["isFunction"])(reusableBlock.content) ? reusableBlock.content(reusableBlock) : reusableBlock.content); registry.dispatch(external_wp_blockEditor_["store"]).replaceBlocks(oldBlock.clientId, newBlocks); }), CONVERT_BLOCKS_TO_REUSABLE: Object(external_wp_data_["createRegistryControl"])(registry => async function ({ clientIds, title }) { const reusableBlock = { title: title || Object(external_wp_i18n_["__"])('Untitled Reusable block'), content: Object(external_wp_blocks_["serialize"])(registry.select(external_wp_blockEditor_["store"]).getBlocksByClientId(clientIds)), status: 'publish' }; const updatedRecord = await registry.dispatch('core').saveEntityRecord('postType', 'wp_block', reusableBlock); const newBlock = Object(external_wp_blocks_["createBlock"])('core/block', { ref: updatedRecord.id }); registry.dispatch(external_wp_blockEditor_["store"]).replaceBlocks(clientIds, newBlock); registry.dispatch(store).__experimentalSetEditingReusableBlock(newBlock.clientId, true); }), DELETE_REUSABLE_BLOCK: Object(external_wp_data_["createRegistryControl"])(registry => async function ({ id }) { const reusableBlock = registry.select('core').getEditedEntityRecord('postType', 'wp_block', id); // Don't allow a reusable block with a temporary ID to be deleted if (!reusableBlock) { return; } // Remove any other blocks that reference this reusable block const allBlocks = registry.select(external_wp_blockEditor_["store"]).getBlocks(); const associatedBlocks = allBlocks.filter(block => Object(external_wp_blocks_["isReusableBlock"])(block) && block.attributes.ref === id); const associatedBlockClientIds = associatedBlocks.map(block => block.clientId); // Remove the parsed block. if (associatedBlockClientIds.length) { registry.dispatch(external_wp_blockEditor_["store"]).removeBlocks(associatedBlockClientIds); } await registry.dispatch('core').deleteEntityRecord('postType', 'wp_block', id); }) }; /* harmony default export */ var store_controls = (controls); // CONCATENATED MODULE: ./node_modules/@wordpress/reusable-blocks/build-module/store/actions.js /** * Internal dependencies */ /** * Returns a generator converting a reusable block into a static block. * * @param {string} clientId The client ID of the block to attach. */ function* __experimentalConvertBlockToStatic(clientId) { yield convertBlockToStatic(clientId); } /** * Returns a generator converting one or more static blocks into a reusable block. * * @param {string[]} clientIds The client IDs of the block to detach. * @param {string} title Reusable block title. */ function* __experimentalConvertBlocksToReusable(clientIds, title) { yield controls_convertBlocksToReusable(clientIds, title); } /** * Returns a generator deleting a reusable block. * * @param {string} id The ID of the reusable block to delete. */ function* __experimentalDeleteReusableBlock(id) { yield deleteReusableBlock(id); } /** * Returns an action descriptor for SET_EDITING_REUSABLE_BLOCK action. * * @param {string} clientId The clientID of the reusable block to target. * @param {boolean} isEditing Whether the block should be in editing state. * @return {Object} Action descriptor. */ function __experimentalSetEditingReusableBlock(clientId, isEditing) { return { type: 'SET_EDITING_REUSABLE_BLOCK', clientId, isEditing }; } // CONCATENATED MODULE: ./node_modules/@wordpress/reusable-blocks/build-module/store/reducer.js /** * WordPress dependencies */ function isEditingReusableBlock(state = {}, action) { if ((action === null || action === void 0 ? void 0 : action.type) === 'SET_EDITING_REUSABLE_BLOCK') { return { ...state, [action.clientId]: action.isEditing }; } return state; } /* harmony default export */ var reducer = (Object(external_wp_data_["combineReducers"])({ isEditingReusableBlock })); // CONCATENATED MODULE: ./node_modules/@wordpress/reusable-blocks/build-module/store/selectors.js /** * Returns true if reusable block is in the editing state. * * @param {Object} state Global application state. * @param {number} clientId the clientID of the block. * @return {boolean} Whether the reusable block is in the editing state. */ function __experimentalIsEditingReusableBlock(state, clientId) { return state.isEditingReusableBlock[clientId]; } // CONCATENATED MODULE: ./node_modules/@wordpress/reusable-blocks/build-module/store/index.js /** * WordPress dependencies */ /** * Internal dependencies */ const STORE_NAME = 'core/reusable-blocks'; /** * Store definition for the reusable blocks namespace. * * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/data/README.md#createReduxStore * * @type {Object} */ const store = Object(external_wp_data_["createReduxStore"])(STORE_NAME, { actions: actions_namespaceObject, controls: store_controls, reducer: reducer, selectors: selectors_namespaceObject }); Object(external_wp_data_["register"])(store); // EXTERNAL MODULE: external ["wp","element"] var external_wp_element_ = __webpack_require__(0); // EXTERNAL MODULE: external ["wp","components"] var external_wp_components_ = __webpack_require__(4); // EXTERNAL MODULE: ./node_modules/@wordpress/icons/build-module/library/reusable-block.js var reusable_block = __webpack_require__(323); // EXTERNAL MODULE: external ["wp","notices"] var external_wp_notices_ = __webpack_require__(36); // CONCATENATED MODULE: ./node_modules/@wordpress/reusable-blocks/build-module/components/reusable-blocks-menu-items/reusable-block-convert-button.js /** * WordPress dependencies */ /** * Internal dependencies */ /** * Menu control to convert block(s) to reusable block. * * @param {Object} props Component props. * @param {string[]} props.clientIds Client ids of selected blocks. * @param {string} props.rootClientId ID of the currently selected top-level block. * @return {import('@wordpress/element').WPComponent} The menu control or null. */ function ReusableBlockConvertButton({ clientIds, rootClientId }) { const [isModalOpen, setIsModalOpen] = Object(external_wp_element_["useState"])(false); const [title, setTitle] = Object(external_wp_element_["useState"])(''); const canConvert = Object(external_wp_data_["useSelect"])(select => { var _getBlocksByClientId; const { canUser } = select('core'); const { getBlocksByClientId, canInsertBlockType } = select('core/block-editor'); const blocks = (_getBlocksByClientId = getBlocksByClientId(clientIds)) !== null && _getBlocksByClientId !== void 0 ? _getBlocksByClientId : []; const isReusable = blocks.length === 1 && blocks[0] && Object(external_wp_blocks_["isReusableBlock"])(blocks[0]) && !!select('core').getEntityRecord('postType', 'wp_block', blocks[0].attributes.ref); const _canConvert = // Hide when this is already a reusable block. !isReusable && // Hide when reusable blocks are disabled. canInsertBlockType('core/block', rootClientId) && blocks.every(block => // Guard against the case where a regular block has *just* been converted. !!block && // Hide on invalid blocks. block.isValid && // Hide when block doesn't support being made reusable. Object(external_wp_blocks_["hasBlockSupport"])(block.name, 'reusable', true)) && // Hide when current doesn't have permission to do that. !!canUser('create', 'blocks'); return _canConvert; }, [clientIds]); const { __experimentalConvertBlocksToReusable: convertBlocksToReusable } = Object(external_wp_data_["useDispatch"])(store); const { createSuccessNotice, createErrorNotice } = Object(external_wp_data_["useDispatch"])(external_wp_notices_["store"]); const onConvert = Object(external_wp_element_["useCallback"])(async function (reusableBlockTitle) { try { await convertBlocksToReusable(clientIds, reusableBlockTitle); createSuccessNotice(Object(external_wp_i18n_["__"])('Reusable block created.'), { type: 'snackbar' }); } catch (error) { createErrorNotice(error.message, { type: 'snackbar' }); } }, [clientIds]); if (!canConvert) { return null; } return Object(external_wp_element_["createElement"])(external_wp_blockEditor_["BlockSettingsMenuControls"], null, ({ onClose }) => Object(external_wp_element_["createElement"])(external_wp_element_["Fragment"], null, Object(external_wp_element_["createElement"])(external_wp_components_["MenuItem"], { icon: reusable_block["a" /* default */], onClick: () => { setIsModalOpen(true); } }, Object(external_wp_i18n_["__"])('Add to Reusable blocks')), isModalOpen && Object(external_wp_element_["createElement"])(external_wp_components_["Modal"], { title: Object(external_wp_i18n_["__"])('Create Reusable block'), closeLabel: Object(external_wp_i18n_["__"])('Close'), onRequestClose: () => { setIsModalOpen(false); setTitle(''); }, overlayClassName: "reusable-blocks-menu-items__convert-modal" }, Object(external_wp_element_["createElement"])("form", { onSubmit: event => { event.preventDefault(); onConvert(title); setIsModalOpen(false); setTitle(''); onClose(); } }, Object(external_wp_element_["createElement"])(external_wp_components_["TextControl"], { label: Object(external_wp_i18n_["__"])('Name'), value: title, onChange: setTitle }), Object(external_wp_element_["createElement"])(external_wp_components_["Flex"], { className: "reusable-blocks-menu-items__convert-modal-actions", justify: "flex-end" }, Object(external_wp_element_["createElement"])(external_wp_components_["FlexItem"], null, Object(external_wp_element_["createElement"])(external_wp_components_["Button"], { isSecondary: true, onClick: () => { setIsModalOpen(false); setTitle(''); } }, Object(external_wp_i18n_["__"])('Cancel'))), Object(external_wp_element_["createElement"])(external_wp_components_["FlexItem"], null, Object(external_wp_element_["createElement"])(external_wp_components_["Button"], { isPrimary: true, type: "submit" }, Object(external_wp_i18n_["__"])('Save')))))))); } // EXTERNAL MODULE: external ["wp","url"] var external_wp_url_ = __webpack_require__(20); // CONCATENATED MODULE: ./node_modules/@wordpress/reusable-blocks/build-module/components/reusable-blocks-menu-items/reusable-blocks-manage-button.js /** * WordPress dependencies */ function ReusableBlocksManageButton({ clientId }) { const { isVisible } = Object(external_wp_data_["useSelect"])(select => { const { getBlock } = select(external_wp_blockEditor_["store"]); const { canUser } = select('core'); const reusableBlock = getBlock(clientId); return { isVisible: !!reusableBlock && Object(external_wp_blocks_["isReusableBlock"])(reusableBlock) && !!canUser('update', 'blocks', reusableBlock.attributes.ref) }; }, [clientId]); if (!isVisible) { return null; } return Object(external_wp_element_["createElement"])(external_wp_blockEditor_["BlockSettingsMenuControls"], null, Object(external_wp_element_["createElement"])(external_wp_components_["MenuItem"], { href: Object(external_wp_url_["addQueryArgs"])('edit.php', { post_type: 'wp_block' }) }, Object(external_wp_i18n_["__"])('Manage Reusable blocks'))); } /* harmony default export */ var reusable_blocks_manage_button = (ReusableBlocksManageButton); // CONCATENATED MODULE: ./node_modules/@wordpress/reusable-blocks/build-module/components/reusable-blocks-menu-items/index.js /** * WordPress dependencies */ /** * Internal dependencies */ function ReusableBlocksMenuItems({ clientIds, rootClientId }) { return Object(external_wp_element_["createElement"])(external_wp_element_["Fragment"], null, Object(external_wp_element_["createElement"])(ReusableBlockConvertButton, { clientIds: clientIds, rootClientId: rootClientId }), clientIds.length === 1 && Object(external_wp_element_["createElement"])(reusable_blocks_manage_button, { clientId: clientIds[0] })); } /* harmony default export */ var reusable_blocks_menu_items = (Object(external_wp_data_["withSelect"])(select => { const { getSelectedBlockClientIds } = select(external_wp_blockEditor_["store"]); return { clientIds: getSelectedBlockClientIds() }; })(ReusableBlocksMenuItems)); // CONCATENATED MODULE: ./node_modules/@wordpress/reusable-blocks/build-module/components/index.js // CONCATENATED MODULE: ./node_modules/@wordpress/reusable-blocks/build-module/index.js /** * WordPress dependencies */ /***/ }), /***/ 6: /***/ (function(module, exports) { (function() { module.exports = window["wp"]["blockEditor"]; }()); /***/ }), /***/ 8: /***/ (function(module, exports) { (function() { module.exports = window["wp"]["blocks"]; }()); /***/ }) /******/ });