reusable-blocks.js 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489
  1. /******/ (function() { // webpackBootstrap
  2. /******/ "use strict";
  3. /******/ // The require scope
  4. /******/ var __webpack_require__ = {};
  5. /******/
  6. /************************************************************************/
  7. /******/ /* webpack/runtime/define property getters */
  8. /******/ !function() {
  9. /******/ // define getter functions for harmony exports
  10. /******/ __webpack_require__.d = function(exports, definition) {
  11. /******/ for(var key in definition) {
  12. /******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
  13. /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
  14. /******/ }
  15. /******/ }
  16. /******/ };
  17. /******/ }();
  18. /******/
  19. /******/ /* webpack/runtime/hasOwnProperty shorthand */
  20. /******/ !function() {
  21. /******/ __webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }
  22. /******/ }();
  23. /******/
  24. /******/ /* webpack/runtime/make namespace object */
  25. /******/ !function() {
  26. /******/ // define __esModule on exports
  27. /******/ __webpack_require__.r = function(exports) {
  28. /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
  29. /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
  30. /******/ }
  31. /******/ Object.defineProperty(exports, '__esModule', { value: true });
  32. /******/ };
  33. /******/ }();
  34. /******/
  35. /************************************************************************/
  36. var __webpack_exports__ = {};
  37. // ESM COMPAT FLAG
  38. __webpack_require__.r(__webpack_exports__);
  39. // EXPORTS
  40. __webpack_require__.d(__webpack_exports__, {
  41. "ReusableBlocksMenuItems": function() { return /* reexport */ reusable_blocks_menu_items; },
  42. "store": function() { return /* reexport */ store; }
  43. });
  44. // NAMESPACE OBJECT: ./node_modules/@wordpress/reusable-blocks/build-module/store/actions.js
  45. var actions_namespaceObject = {};
  46. __webpack_require__.r(actions_namespaceObject);
  47. __webpack_require__.d(actions_namespaceObject, {
  48. "__experimentalConvertBlockToStatic": function() { return __experimentalConvertBlockToStatic; },
  49. "__experimentalConvertBlocksToReusable": function() { return __experimentalConvertBlocksToReusable; },
  50. "__experimentalDeleteReusableBlock": function() { return __experimentalDeleteReusableBlock; },
  51. "__experimentalSetEditingReusableBlock": function() { return __experimentalSetEditingReusableBlock; }
  52. });
  53. // NAMESPACE OBJECT: ./node_modules/@wordpress/reusable-blocks/build-module/store/selectors.js
  54. var selectors_namespaceObject = {};
  55. __webpack_require__.r(selectors_namespaceObject);
  56. __webpack_require__.d(selectors_namespaceObject, {
  57. "__experimentalIsEditingReusableBlock": function() { return __experimentalIsEditingReusableBlock; }
  58. });
  59. ;// CONCATENATED MODULE: external ["wp","data"]
  60. var external_wp_data_namespaceObject = window["wp"]["data"];
  61. ;// CONCATENATED MODULE: external "lodash"
  62. var external_lodash_namespaceObject = window["lodash"];
  63. ;// CONCATENATED MODULE: external ["wp","blockEditor"]
  64. var external_wp_blockEditor_namespaceObject = window["wp"]["blockEditor"];
  65. ;// CONCATENATED MODULE: external ["wp","blocks"]
  66. var external_wp_blocks_namespaceObject = window["wp"]["blocks"];
  67. ;// CONCATENATED MODULE: external ["wp","i18n"]
  68. var external_wp_i18n_namespaceObject = window["wp"]["i18n"];
  69. ;// CONCATENATED MODULE: ./node_modules/@wordpress/reusable-blocks/build-module/store/actions.js
  70. /**
  71. * External dependencies
  72. */
  73. /**
  74. * WordPress dependencies
  75. */
  76. /**
  77. * Returns a generator converting a reusable block into a static block.
  78. *
  79. * @param {string} clientId The client ID of the block to attach.
  80. */
  81. const __experimentalConvertBlockToStatic = clientId => _ref => {
  82. let {
  83. registry
  84. } = _ref;
  85. const oldBlock = registry.select(external_wp_blockEditor_namespaceObject.store).getBlock(clientId);
  86. const reusableBlock = registry.select('core').getEditedEntityRecord('postType', 'wp_block', oldBlock.attributes.ref);
  87. const newBlocks = (0,external_wp_blocks_namespaceObject.parse)((0,external_lodash_namespaceObject.isFunction)(reusableBlock.content) ? reusableBlock.content(reusableBlock) : reusableBlock.content);
  88. registry.dispatch(external_wp_blockEditor_namespaceObject.store).replaceBlocks(oldBlock.clientId, newBlocks);
  89. };
  90. /**
  91. * Returns a generator converting one or more static blocks into a reusable block.
  92. *
  93. * @param {string[]} clientIds The client IDs of the block to detach.
  94. * @param {string} title Reusable block title.
  95. */
  96. const __experimentalConvertBlocksToReusable = (clientIds, title) => async _ref2 => {
  97. let {
  98. registry,
  99. dispatch
  100. } = _ref2;
  101. const reusableBlock = {
  102. title: title || (0,external_wp_i18n_namespaceObject.__)('Untitled Reusable block'),
  103. content: (0,external_wp_blocks_namespaceObject.serialize)(registry.select(external_wp_blockEditor_namespaceObject.store).getBlocksByClientId(clientIds)),
  104. status: 'publish'
  105. };
  106. const updatedRecord = await registry.dispatch('core').saveEntityRecord('postType', 'wp_block', reusableBlock);
  107. const newBlock = (0,external_wp_blocks_namespaceObject.createBlock)('core/block', {
  108. ref: updatedRecord.id
  109. });
  110. registry.dispatch(external_wp_blockEditor_namespaceObject.store).replaceBlocks(clientIds, newBlock);
  111. dispatch.__experimentalSetEditingReusableBlock(newBlock.clientId, true);
  112. };
  113. /**
  114. * Returns a generator deleting a reusable block.
  115. *
  116. * @param {string} id The ID of the reusable block to delete.
  117. */
  118. const __experimentalDeleteReusableBlock = id => async _ref3 => {
  119. let {
  120. registry
  121. } = _ref3;
  122. const reusableBlock = registry.select('core').getEditedEntityRecord('postType', 'wp_block', id); // Don't allow a reusable block with a temporary ID to be deleted.
  123. if (!reusableBlock) {
  124. return;
  125. } // Remove any other blocks that reference this reusable block.
  126. const allBlocks = registry.select(external_wp_blockEditor_namespaceObject.store).getBlocks();
  127. const associatedBlocks = allBlocks.filter(block => (0,external_wp_blocks_namespaceObject.isReusableBlock)(block) && block.attributes.ref === id);
  128. const associatedBlockClientIds = associatedBlocks.map(block => block.clientId); // Remove the parsed block.
  129. if (associatedBlockClientIds.length) {
  130. registry.dispatch(external_wp_blockEditor_namespaceObject.store).removeBlocks(associatedBlockClientIds);
  131. }
  132. await registry.dispatch('core').deleteEntityRecord('postType', 'wp_block', id);
  133. };
  134. /**
  135. * Returns an action descriptor for SET_EDITING_REUSABLE_BLOCK action.
  136. *
  137. * @param {string} clientId The clientID of the reusable block to target.
  138. * @param {boolean} isEditing Whether the block should be in editing state.
  139. * @return {Object} Action descriptor.
  140. */
  141. function __experimentalSetEditingReusableBlock(clientId, isEditing) {
  142. return {
  143. type: 'SET_EDITING_REUSABLE_BLOCK',
  144. clientId,
  145. isEditing
  146. };
  147. }
  148. ;// CONCATENATED MODULE: ./node_modules/@wordpress/reusable-blocks/build-module/store/reducer.js
  149. /**
  150. * WordPress dependencies
  151. */
  152. function isEditingReusableBlock() {
  153. let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
  154. let action = arguments.length > 1 ? arguments[1] : undefined;
  155. if ((action === null || action === void 0 ? void 0 : action.type) === 'SET_EDITING_REUSABLE_BLOCK') {
  156. return { ...state,
  157. [action.clientId]: action.isEditing
  158. };
  159. }
  160. return state;
  161. }
  162. /* harmony default export */ var reducer = ((0,external_wp_data_namespaceObject.combineReducers)({
  163. isEditingReusableBlock
  164. }));
  165. ;// CONCATENATED MODULE: ./node_modules/@wordpress/reusable-blocks/build-module/store/selectors.js
  166. /**
  167. * Returns true if reusable block is in the editing state.
  168. *
  169. * @param {Object} state Global application state.
  170. * @param {number} clientId the clientID of the block.
  171. * @return {boolean} Whether the reusable block is in the editing state.
  172. */
  173. function __experimentalIsEditingReusableBlock(state, clientId) {
  174. return state.isEditingReusableBlock[clientId];
  175. }
  176. ;// CONCATENATED MODULE: ./node_modules/@wordpress/reusable-blocks/build-module/store/index.js
  177. /**
  178. * WordPress dependencies
  179. */
  180. /**
  181. * Internal dependencies
  182. */
  183. const STORE_NAME = 'core/reusable-blocks';
  184. /**
  185. * Store definition for the reusable blocks namespace.
  186. *
  187. * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/data/README.md#createReduxStore
  188. *
  189. * @type {Object}
  190. */
  191. const store = (0,external_wp_data_namespaceObject.createReduxStore)(STORE_NAME, {
  192. actions: actions_namespaceObject,
  193. reducer: reducer,
  194. selectors: selectors_namespaceObject
  195. });
  196. (0,external_wp_data_namespaceObject.register)(store);
  197. ;// CONCATENATED MODULE: external ["wp","element"]
  198. var external_wp_element_namespaceObject = window["wp"]["element"];
  199. ;// CONCATENATED MODULE: external ["wp","components"]
  200. var external_wp_components_namespaceObject = window["wp"]["components"];
  201. ;// CONCATENATED MODULE: external ["wp","primitives"]
  202. var external_wp_primitives_namespaceObject = window["wp"]["primitives"];
  203. ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/symbol.js
  204. /**
  205. * WordPress dependencies
  206. */
  207. const symbol = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
  208. xmlns: "http://www.w3.org/2000/svg",
  209. viewBox: "0 0 24 24"
  210. }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
  211. d: "M21.3 10.8l-5.6-5.6c-.7-.7-1.8-.7-2.5 0l-5.6 5.6c-.7.7-.7 1.8 0 2.5l5.6 5.6c.3.3.8.5 1.2.5s.9-.2 1.2-.5l5.6-5.6c.8-.7.8-1.9.1-2.5zm-1 1.4l-5.6 5.6c-.1.1-.3.1-.4 0l-5.6-5.6c-.1-.1-.1-.3 0-.4l5.6-5.6s.1-.1.2-.1.1 0 .2.1l5.6 5.6c.1.1.1.3 0 .4zm-16.6-.4L10 5.5l-1-1-6.3 6.3c-.7.7-.7 1.8 0 2.5L9 19.5l1.1-1.1-6.3-6.3c-.2 0-.2-.2-.1-.3z"
  212. }));
  213. /* harmony default export */ var library_symbol = (symbol);
  214. ;// CONCATENATED MODULE: external ["wp","notices"]
  215. var external_wp_notices_namespaceObject = window["wp"]["notices"];
  216. ;// CONCATENATED MODULE: external ["wp","coreData"]
  217. var external_wp_coreData_namespaceObject = window["wp"]["coreData"];
  218. ;// CONCATENATED MODULE: ./node_modules/@wordpress/reusable-blocks/build-module/components/reusable-blocks-menu-items/reusable-block-convert-button.js
  219. /**
  220. * WordPress dependencies
  221. */
  222. /**
  223. * Internal dependencies
  224. */
  225. /**
  226. * Menu control to convert block(s) to reusable block.
  227. *
  228. * @param {Object} props Component props.
  229. * @param {string[]} props.clientIds Client ids of selected blocks.
  230. * @param {string} props.rootClientId ID of the currently selected top-level block.
  231. * @return {import('@wordpress/element').WPComponent} The menu control or null.
  232. */
  233. function ReusableBlockConvertButton(_ref) {
  234. let {
  235. clientIds,
  236. rootClientId
  237. } = _ref;
  238. const [isModalOpen, setIsModalOpen] = (0,external_wp_element_namespaceObject.useState)(false);
  239. const [title, setTitle] = (0,external_wp_element_namespaceObject.useState)('');
  240. const canConvert = (0,external_wp_data_namespaceObject.useSelect)(select => {
  241. var _getBlocksByClientId;
  242. const {
  243. canUser
  244. } = select(external_wp_coreData_namespaceObject.store);
  245. const {
  246. getBlocksByClientId,
  247. canInsertBlockType
  248. } = select(external_wp_blockEditor_namespaceObject.store);
  249. const blocks = (_getBlocksByClientId = getBlocksByClientId(clientIds)) !== null && _getBlocksByClientId !== void 0 ? _getBlocksByClientId : [];
  250. const isReusable = blocks.length === 1 && blocks[0] && (0,external_wp_blocks_namespaceObject.isReusableBlock)(blocks[0]) && !!select(external_wp_coreData_namespaceObject.store).getEntityRecord('postType', 'wp_block', blocks[0].attributes.ref);
  251. const _canConvert = // Hide when this is already a reusable block.
  252. !isReusable && // Hide when reusable blocks are disabled.
  253. canInsertBlockType('core/block', rootClientId) && blocks.every(block => // Guard against the case where a regular block has *just* been converted.
  254. !!block && // Hide on invalid blocks.
  255. block.isValid && // Hide when block doesn't support being made reusable.
  256. (0,external_wp_blocks_namespaceObject.hasBlockSupport)(block.name, 'reusable', true)) && // Hide when current doesn't have permission to do that.
  257. !!canUser('create', 'blocks');
  258. return _canConvert;
  259. }, [clientIds]);
  260. const {
  261. __experimentalConvertBlocksToReusable: convertBlocksToReusable
  262. } = (0,external_wp_data_namespaceObject.useDispatch)(store);
  263. const {
  264. createSuccessNotice,
  265. createErrorNotice
  266. } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_notices_namespaceObject.store);
  267. const onConvert = (0,external_wp_element_namespaceObject.useCallback)(async function (reusableBlockTitle) {
  268. try {
  269. await convertBlocksToReusable(clientIds, reusableBlockTitle);
  270. createSuccessNotice((0,external_wp_i18n_namespaceObject.__)('Reusable block created.'), {
  271. type: 'snackbar'
  272. });
  273. } catch (error) {
  274. createErrorNotice(error.message, {
  275. type: 'snackbar'
  276. });
  277. }
  278. }, [clientIds]);
  279. if (!canConvert) {
  280. return null;
  281. }
  282. return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockSettingsMenuControls, null, _ref2 => {
  283. let {
  284. onClose
  285. } = _ref2;
  286. return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, {
  287. icon: library_symbol,
  288. onClick: () => {
  289. setIsModalOpen(true);
  290. }
  291. }, (0,external_wp_i18n_namespaceObject.__)('Add to Reusable blocks')), isModalOpen && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Modal, {
  292. title: (0,external_wp_i18n_namespaceObject.__)('Create Reusable block'),
  293. closeLabel: (0,external_wp_i18n_namespaceObject.__)('Close'),
  294. onRequestClose: () => {
  295. setIsModalOpen(false);
  296. setTitle('');
  297. },
  298. overlayClassName: "reusable-blocks-menu-items__convert-modal"
  299. }, (0,external_wp_element_namespaceObject.createElement)("form", {
  300. onSubmit: event => {
  301. event.preventDefault();
  302. onConvert(title);
  303. setIsModalOpen(false);
  304. setTitle('');
  305. onClose();
  306. }
  307. }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, {
  308. label: (0,external_wp_i18n_namespaceObject.__)('Name'),
  309. value: title,
  310. onChange: setTitle
  311. }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Flex, {
  312. className: "reusable-blocks-menu-items__convert-modal-actions",
  313. justify: "flex-end"
  314. }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FlexItem, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
  315. variant: "tertiary",
  316. onClick: () => {
  317. setIsModalOpen(false);
  318. setTitle('');
  319. }
  320. }, (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, {
  321. variant: "primary",
  322. type: "submit"
  323. }, (0,external_wp_i18n_namespaceObject.__)('Save')))))));
  324. });
  325. }
  326. ;// CONCATENATED MODULE: external ["wp","url"]
  327. var external_wp_url_namespaceObject = window["wp"]["url"];
  328. ;// CONCATENATED MODULE: ./node_modules/@wordpress/reusable-blocks/build-module/components/reusable-blocks-menu-items/reusable-blocks-manage-button.js
  329. /**
  330. * WordPress dependencies
  331. */
  332. /**
  333. * Internal dependencies
  334. */
  335. function ReusableBlocksManageButton(_ref) {
  336. let {
  337. clientId
  338. } = _ref;
  339. const {
  340. canRemove,
  341. isVisible
  342. } = (0,external_wp_data_namespaceObject.useSelect)(select => {
  343. const {
  344. getBlock,
  345. canRemoveBlock
  346. } = select(external_wp_blockEditor_namespaceObject.store);
  347. const {
  348. canUser
  349. } = select(external_wp_coreData_namespaceObject.store);
  350. const reusableBlock = getBlock(clientId);
  351. return {
  352. canRemove: canRemoveBlock(clientId),
  353. isVisible: !!reusableBlock && (0,external_wp_blocks_namespaceObject.isReusableBlock)(reusableBlock) && !!canUser('update', 'blocks', reusableBlock.attributes.ref)
  354. };
  355. }, [clientId]);
  356. const {
  357. __experimentalConvertBlockToStatic: convertBlockToStatic
  358. } = (0,external_wp_data_namespaceObject.useDispatch)(store);
  359. if (!isVisible) {
  360. return null;
  361. }
  362. return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockSettingsMenuControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, {
  363. href: (0,external_wp_url_namespaceObject.addQueryArgs)('edit.php', {
  364. post_type: 'wp_block'
  365. })
  366. }, (0,external_wp_i18n_namespaceObject.__)('Manage Reusable blocks')), canRemove && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, {
  367. onClick: () => convertBlockToStatic(clientId)
  368. }, (0,external_wp_i18n_namespaceObject.__)('Convert to regular blocks')));
  369. }
  370. /* harmony default export */ var reusable_blocks_manage_button = (ReusableBlocksManageButton);
  371. ;// CONCATENATED MODULE: ./node_modules/@wordpress/reusable-blocks/build-module/components/reusable-blocks-menu-items/index.js
  372. /**
  373. * WordPress dependencies
  374. */
  375. /**
  376. * Internal dependencies
  377. */
  378. function ReusableBlocksMenuItems(_ref) {
  379. let {
  380. clientIds,
  381. rootClientId
  382. } = _ref;
  383. return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(ReusableBlockConvertButton, {
  384. clientIds: clientIds,
  385. rootClientId: rootClientId
  386. }), clientIds.length === 1 && (0,external_wp_element_namespaceObject.createElement)(reusable_blocks_manage_button, {
  387. clientId: clientIds[0]
  388. }));
  389. }
  390. /* harmony default export */ var reusable_blocks_menu_items = ((0,external_wp_data_namespaceObject.withSelect)(select => {
  391. const {
  392. getSelectedBlockClientIds
  393. } = select(external_wp_blockEditor_namespaceObject.store);
  394. return {
  395. clientIds: getSelectedBlockClientIds()
  396. };
  397. })(ReusableBlocksMenuItems));
  398. ;// CONCATENATED MODULE: ./node_modules/@wordpress/reusable-blocks/build-module/components/index.js
  399. ;// CONCATENATED MODULE: ./node_modules/@wordpress/reusable-blocks/build-module/index.js
  400. (window.wp = window.wp || {}).reusableBlocks = __webpack_exports__;
  401. /******/ })()
  402. ;