@wordpress/edit-post 8.44.0 → 8.45.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (37) hide show
  1. package/CHANGELOG.md +6 -0
  2. package/build/components/back-button/fullscreen-mode-close.cjs +1 -1
  3. package/build/components/back-button/fullscreen-mode-close.cjs.map +1 -1
  4. package/build/components/layout/index.cjs +2 -1
  5. package/build/components/layout/index.cjs.map +2 -2
  6. package/build/components/meta-boxes/use-meta-box-initialization.cjs +5 -16
  7. package/build/components/meta-boxes/use-meta-box-initialization.cjs.map +2 -2
  8. package/build/store/actions.cjs +0 -8
  9. package/build/store/actions.cjs.map +2 -2
  10. package/build/store/reducer.cjs +7 -14
  11. package/build/store/reducer.cjs.map +2 -2
  12. package/build/store/selectors.cjs +0 -5
  13. package/build/store/selectors.cjs.map +2 -2
  14. package/build-module/components/back-button/fullscreen-mode-close.mjs +1 -1
  15. package/build-module/components/back-button/fullscreen-mode-close.mjs.map +1 -1
  16. package/build-module/components/layout/index.mjs +1 -1
  17. package/build-module/components/layout/index.mjs.map +2 -2
  18. package/build-module/components/meta-boxes/use-meta-box-initialization.mjs +5 -16
  19. package/build-module/components/meta-boxes/use-meta-box-initialization.mjs.map +2 -2
  20. package/build-module/store/actions.mjs +0 -7
  21. package/build-module/store/actions.mjs.map +2 -2
  22. package/build-module/store/reducer.mjs +6 -12
  23. package/build-module/store/reducer.mjs.map +2 -2
  24. package/build-module/store/selectors.mjs +0 -4
  25. package/build-module/store/selectors.mjs.map +2 -2
  26. package/build-style/style-rtl.css +1 -136
  27. package/build-style/style.css +1 -136
  28. package/package.json +34 -33
  29. package/src/components/back-button/fullscreen-mode-close.js +1 -1
  30. package/src/components/layout/index.js +1 -1
  31. package/src/components/layout/style.scss +1 -1
  32. package/src/components/meta-boxes/test/use-meta-box-initialization.js +22 -9
  33. package/src/components/meta-boxes/use-meta-box-initialization.js +9 -24
  34. package/src/store/actions.js +0 -13
  35. package/src/store/reducer.js +4 -19
  36. package/src/store/selectors.js +0 -12
  37. package/src/style.scss +0 -1
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../src/store/reducer.js"],
4
- "sourcesContent": ["/**\n * WordPress dependencies\n */\nimport { combineReducers } from '@wordpress/data';\n\n/**\n * Reducer keeping track of the meta boxes isSaving state.\n * A \"true\" value means the meta boxes saving request is in-flight.\n *\n *\n * @param {boolean} state Previous state.\n * @param {Object} action Action Object.\n *\n * @return {Object} Updated state.\n */\nexport function isSavingMetaBoxes( state = false, action ) {\n\tswitch ( action.type ) {\n\t\tcase 'REQUEST_META_BOX_UPDATES':\n\t\t\treturn true;\n\t\tcase 'META_BOX_UPDATES_SUCCESS':\n\t\tcase 'META_BOX_UPDATES_FAILURE':\n\t\t\treturn false;\n\t\tdefault:\n\t\t\treturn state;\n\t}\n}\n\nfunction mergeMetaboxes( metaboxes = [], newMetaboxes ) {\n\tconst mergedMetaboxes = [ ...metaboxes ];\n\tfor ( const metabox of newMetaboxes ) {\n\t\tconst existing = mergedMetaboxes.findIndex(\n\t\t\t( box ) => box.id === metabox.id\n\t\t);\n\t\tif ( existing !== -1 ) {\n\t\t\tmergedMetaboxes[ existing ] = metabox;\n\t\t} else {\n\t\t\tmergedMetaboxes.push( metabox );\n\t\t}\n\t}\n\treturn mergedMetaboxes;\n}\n\n/**\n * Reducer keeping track of the meta boxes per location.\n *\n * @param {boolean} state Previous state.\n * @param {Object} action Action Object.\n *\n * @return {Object} Updated state.\n */\nexport function metaBoxLocations( state = {}, action ) {\n\tswitch ( action.type ) {\n\t\tcase 'SET_META_BOXES_PER_LOCATIONS': {\n\t\t\tconst newState = { ...state };\n\t\t\tfor ( const [ location, metaboxes ] of Object.entries(\n\t\t\t\taction.metaBoxesPerLocation\n\t\t\t) ) {\n\t\t\t\tnewState[ location ] = mergeMetaboxes(\n\t\t\t\t\tnewState[ location ],\n\t\t\t\t\tmetaboxes\n\t\t\t\t);\n\t\t\t}\n\t\t\treturn newState;\n\t\t}\n\t}\n\n\treturn state;\n}\n\n/**\n * Reducer tracking whether meta boxes are initialized.\n *\n * @param {boolean} state\n * @param {Object} action\n *\n * @return {boolean} Updated state.\n */\nfunction metaBoxesInitialized( state = false, action ) {\n\tswitch ( action.type ) {\n\t\tcase 'META_BOXES_INITIALIZED':\n\t\t\treturn true;\n\t}\n\treturn state;\n}\n\n/**\n * Reducer tracking meta box IDs marked as compatible with real-time collaboration\n * via the add_meta_box() __rtc_compatible_meta_box compatibility flag.\n *\n * @param {string[]} state Previous state.\n * @param {Object} action Action Object.\n *\n * @return {string[]} Updated state.\n */\nexport function rtcCompatibleMetaBoxIds( state = [], action ) {\n\tswitch ( action.type ) {\n\t\tcase 'SET_RTC_COMPATIBLE_META_BOX_IDS':\n\t\t\treturn action.ids;\n\t}\n\treturn state;\n}\n\nconst metaBoxes = combineReducers( {\n\tisSaving: isSavingMetaBoxes,\n\tlocations: metaBoxLocations,\n\tinitialized: metaBoxesInitialized,\n\trtcCompatibleIds: rtcCompatibleMetaBoxIds,\n} );\n\nexport default combineReducers( {\n\tmetaBoxes,\n} );\n"],
5
- "mappings": ";AAGA,SAAS,uBAAuB;AAYzB,SAAS,kBAAmB,QAAQ,OAAO,QAAS;AAC1D,UAAS,OAAO,MAAO;AAAA,IACtB,KAAK;AACJ,aAAO;AAAA,IACR,KAAK;AAAA,IACL,KAAK;AACJ,aAAO;AAAA,IACR;AACC,aAAO;AAAA,EACT;AACD;AAEA,SAAS,eAAgB,YAAY,CAAC,GAAG,cAAe;AACvD,QAAM,kBAAkB,CAAE,GAAG,SAAU;AACvC,aAAY,WAAW,cAAe;AACrC,UAAM,WAAW,gBAAgB;AAAA,MAChC,CAAE,QAAS,IAAI,OAAO,QAAQ;AAAA,IAC/B;AACA,QAAK,aAAa,IAAK;AACtB,sBAAiB,QAAS,IAAI;AAAA,IAC/B,OAAO;AACN,sBAAgB,KAAM,OAAQ;AAAA,IAC/B;AAAA,EACD;AACA,SAAO;AACR;AAUO,SAAS,iBAAkB,QAAQ,CAAC,GAAG,QAAS;AACtD,UAAS,OAAO,MAAO;AAAA,IACtB,KAAK,gCAAgC;AACpC,YAAM,WAAW,EAAE,GAAG,MAAM;AAC5B,iBAAY,CAAE,UAAU,SAAU,KAAK,OAAO;AAAA,QAC7C,OAAO;AAAA,MACR,GAAI;AACH,iBAAU,QAAS,IAAI;AAAA,UACtB,SAAU,QAAS;AAAA,UACnB;AAAA,QACD;AAAA,MACD;AACA,aAAO;AAAA,IACR;AAAA,EACD;AAEA,SAAO;AACR;AAUA,SAAS,qBAAsB,QAAQ,OAAO,QAAS;AACtD,UAAS,OAAO,MAAO;AAAA,IACtB,KAAK;AACJ,aAAO;AAAA,EACT;AACA,SAAO;AACR;AAWO,SAAS,wBAAyB,QAAQ,CAAC,GAAG,QAAS;AAC7D,UAAS,OAAO,MAAO;AAAA,IACtB,KAAK;AACJ,aAAO,OAAO;AAAA,EAChB;AACA,SAAO;AACR;AAEA,IAAM,YAAY,gBAAiB;AAAA,EAClC,UAAU;AAAA,EACV,WAAW;AAAA,EACX,aAAa;AAAA,EACb,kBAAkB;AACnB,CAAE;AAEF,IAAO,kBAAQ,gBAAiB;AAAA,EAC/B;AACD,CAAE;",
4
+ "sourcesContent": ["/**\n * WordPress dependencies\n */\nimport { combineReducers } from '@wordpress/data';\n\n/**\n * Reducer keeping track of the meta boxes isSaving state.\n * A \"true\" value means the meta boxes saving request is in-flight.\n *\n *\n * @param {boolean} state Previous state.\n * @param {Object} action Action Object.\n *\n * @return {Object} Updated state.\n */\nexport function isSavingMetaBoxes( state = false, action ) {\n\tswitch ( action.type ) {\n\t\tcase 'REQUEST_META_BOX_UPDATES':\n\t\t\treturn true;\n\t\tcase 'META_BOX_UPDATES_SUCCESS':\n\t\tcase 'META_BOX_UPDATES_FAILURE':\n\t\t\treturn false;\n\t\tdefault:\n\t\t\treturn state;\n\t}\n}\n\nfunction mergeMetaboxes( metaboxes = [], newMetaboxes ) {\n\tconst mergedMetaboxes = [ ...metaboxes ];\n\tfor ( const metabox of newMetaboxes ) {\n\t\tconst existing = mergedMetaboxes.findIndex(\n\t\t\t( box ) => box.id === metabox.id\n\t\t);\n\t\tif ( existing !== -1 ) {\n\t\t\tmergedMetaboxes[ existing ] = {\n\t\t\t\t...mergedMetaboxes[ existing ],\n\t\t\t\t...metabox,\n\t\t\t};\n\t\t} else {\n\t\t\tmergedMetaboxes.push( metabox );\n\t\t}\n\t}\n\treturn mergedMetaboxes;\n}\n\n/**\n * Reducer keeping track of the meta boxes per location.\n *\n * @param {boolean} state Previous state.\n * @param {Object} action Action Object.\n *\n * @return {Object} Updated state.\n */\nexport function metaBoxLocations( state = {}, action ) {\n\tswitch ( action.type ) {\n\t\tcase 'SET_META_BOXES_PER_LOCATIONS': {\n\t\t\tconst newState = { ...state };\n\t\t\tfor ( const [ location, metaboxes ] of Object.entries(\n\t\t\t\taction.metaBoxesPerLocation\n\t\t\t) ) {\n\t\t\t\tnewState[ location ] = mergeMetaboxes(\n\t\t\t\t\tnewState[ location ],\n\t\t\t\t\tmetaboxes\n\t\t\t\t);\n\t\t\t}\n\t\t\treturn newState;\n\t\t}\n\t}\n\n\treturn state;\n}\n\n/**\n * Reducer tracking whether meta boxes are initialized.\n *\n * @param {boolean} state\n * @param {Object} action\n *\n * @return {boolean} Updated state.\n */\nfunction metaBoxesInitialized( state = false, action ) {\n\tswitch ( action.type ) {\n\t\tcase 'META_BOXES_INITIALIZED':\n\t\t\treturn true;\n\t}\n\treturn state;\n}\n\nconst metaBoxes = combineReducers( {\n\tisSaving: isSavingMetaBoxes,\n\tlocations: metaBoxLocations,\n\tinitialized: metaBoxesInitialized,\n} );\n\nexport default combineReducers( {\n\tmetaBoxes,\n} );\n"],
5
+ "mappings": ";AAGA,SAAS,uBAAuB;AAYzB,SAAS,kBAAmB,QAAQ,OAAO,QAAS;AAC1D,UAAS,OAAO,MAAO;AAAA,IACtB,KAAK;AACJ,aAAO;AAAA,IACR,KAAK;AAAA,IACL,KAAK;AACJ,aAAO;AAAA,IACR;AACC,aAAO;AAAA,EACT;AACD;AAEA,SAAS,eAAgB,YAAY,CAAC,GAAG,cAAe;AACvD,QAAM,kBAAkB,CAAE,GAAG,SAAU;AACvC,aAAY,WAAW,cAAe;AACrC,UAAM,WAAW,gBAAgB;AAAA,MAChC,CAAE,QAAS,IAAI,OAAO,QAAQ;AAAA,IAC/B;AACA,QAAK,aAAa,IAAK;AACtB,sBAAiB,QAAS,IAAI;AAAA,QAC7B,GAAG,gBAAiB,QAAS;AAAA,QAC7B,GAAG;AAAA,MACJ;AAAA,IACD,OAAO;AACN,sBAAgB,KAAM,OAAQ;AAAA,IAC/B;AAAA,EACD;AACA,SAAO;AACR;AAUO,SAAS,iBAAkB,QAAQ,CAAC,GAAG,QAAS;AACtD,UAAS,OAAO,MAAO;AAAA,IACtB,KAAK,gCAAgC;AACpC,YAAM,WAAW,EAAE,GAAG,MAAM;AAC5B,iBAAY,CAAE,UAAU,SAAU,KAAK,OAAO;AAAA,QAC7C,OAAO;AAAA,MACR,GAAI;AACH,iBAAU,QAAS,IAAI;AAAA,UACtB,SAAU,QAAS;AAAA,UACnB;AAAA,QACD;AAAA,MACD;AACA,aAAO;AAAA,IACR;AAAA,EACD;AAEA,SAAO;AACR;AAUA,SAAS,qBAAsB,QAAQ,OAAO,QAAS;AACtD,UAAS,OAAO,MAAO;AAAA,IACtB,KAAK;AACJ,aAAO;AAAA,EACT;AACA,SAAO;AACR;AAEA,IAAM,YAAY,gBAAiB;AAAA,EAClC,UAAU;AAAA,EACV,WAAW;AAAA,EACX,aAAa;AACd,CAAE;AAEF,IAAO,kBAAQ,gBAAiB;AAAA,EAC/B;AACD,CAAE;",
6
6
  "names": []
7
7
  }
@@ -183,9 +183,6 @@ var getAllMetaBoxes = createSelector(
183
183
  },
184
184
  (state) => [state.metaBoxes.locations]
185
185
  );
186
- function getRtcCompatibleMetaBoxIds(state) {
187
- return state.metaBoxes.rtcCompatibleIds;
188
- }
189
186
  function hasMetaBoxes(state) {
190
187
  return getActiveMetaBoxLocations(state).length > 0;
191
188
  }
@@ -271,7 +268,6 @@ export {
271
268
  getMetaBoxesPerLocation,
272
269
  getPreference,
273
270
  getPreferences,
274
- getRtcCompatibleMetaBoxIds,
275
271
  hasMetaBoxes,
276
272
  isEditingTemplate,
277
273
  isEditorPanelEnabled,
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../src/store/selectors.js"],
4
- "sourcesContent": ["/**\n * WordPress dependencies\n */\nimport { createSelector, createRegistrySelector } from '@wordpress/data';\nimport { store as preferencesStore } from '@wordpress/preferences';\nimport { store as coreStore } from '@wordpress/core-data';\nimport {\n\tstore as editorStore,\n\tprivateApis as editorPrivateApis,\n} from '@wordpress/editor';\nimport deprecated from '@wordpress/deprecated';\n\n/**\n * Internal dependencies\n */\nimport { unlock } from '../lock-unlock';\nconst { interfaceStore } = unlock( editorPrivateApis );\nconst EMPTY_ARRAY = [];\nconst EMPTY_OBJECT = {};\n\n/**\n * Returns the current editing mode.\n *\n * @param {Object} state Global application state.\n *\n * @return {string} Editing mode.\n */\nexport const getEditorMode = createRegistrySelector(\n\t( select ) => () =>\n\t\tselect( preferencesStore ).get( 'core', 'editorMode' ) ?? 'visual'\n);\n\n/**\n * Returns true if the editor sidebar is opened.\n *\n * @param {Object} state Global application state\n *\n * @return {boolean} Whether the editor sidebar is opened.\n */\nexport const isEditorSidebarOpened = createRegistrySelector(\n\t( select ) => () => {\n\t\tconst activeGeneralSidebar =\n\t\t\tselect( interfaceStore ).getActiveComplementaryArea( 'core' );\n\t\treturn [ 'edit-post/document', 'edit-post/block' ].includes(\n\t\t\tactiveGeneralSidebar\n\t\t);\n\t}\n);\n\n/**\n * Returns true if the plugin sidebar is opened.\n *\n * @param {Object} state Global application state.\n *\n * @return {boolean} Whether the plugin sidebar is opened.\n */\nexport const isPluginSidebarOpened = createRegistrySelector(\n\t( select ) => () => {\n\t\tconst activeGeneralSidebar =\n\t\t\tselect( interfaceStore ).getActiveComplementaryArea( 'core' );\n\t\treturn (\n\t\t\t!! activeGeneralSidebar &&\n\t\t\t! [ 'edit-post/document', 'edit-post/block' ].includes(\n\t\t\t\tactiveGeneralSidebar\n\t\t\t)\n\t\t);\n\t}\n);\n\n/**\n * Returns the current active general sidebar name, or null if there is no\n * general sidebar active. The active general sidebar is a unique name to\n * identify either an editor or plugin sidebar.\n *\n * Examples:\n *\n * - `edit-post/document`\n * - `my-plugin/insert-image-sidebar`\n *\n * @param {Object} state Global application state.\n *\n * @return {?string} Active general sidebar name.\n */\nexport const getActiveGeneralSidebarName = createRegistrySelector(\n\t( select ) => () => {\n\t\treturn select( interfaceStore ).getActiveComplementaryArea( 'core' );\n\t}\n);\n\n/**\n * Converts panels from the new preferences store format to the old format\n * that the post editor previously used.\n *\n * The resultant converted data should look like this:\n * {\n * panelName: {\n * enabled: false,\n * opened: true,\n * },\n * anotherPanelName: {\n * opened: true\n * },\n * }\n *\n * @param {string[] | undefined} inactivePanels An array of inactive panel names.\n * @param {string[] | undefined} openPanels An array of open panel names.\n *\n * @return {Object} The converted panel data.\n */\nfunction convertPanelsToOldFormat( inactivePanels, openPanels ) {\n\t// First reduce the inactive panels.\n\tconst panelsWithEnabledState = inactivePanels?.reduce(\n\t\t( accumulatedPanels, panelName ) => ( {\n\t\t\t...accumulatedPanels,\n\t\t\t[ panelName ]: {\n\t\t\t\tenabled: false,\n\t\t\t},\n\t\t} ),\n\t\t{}\n\t);\n\n\t// Then reduce the open panels, passing in the result of the previous\n\t// reduction as the initial value so that both open and inactive\n\t// panel state is combined.\n\tconst panels = openPanels?.reduce( ( accumulatedPanels, panelName ) => {\n\t\tconst currentPanelState = accumulatedPanels?.[ panelName ];\n\t\treturn {\n\t\t\t...accumulatedPanels,\n\t\t\t[ panelName ]: {\n\t\t\t\t...currentPanelState,\n\t\t\t\topened: true,\n\t\t\t},\n\t\t};\n\t}, panelsWithEnabledState ?? {} );\n\n\t// The panels variable will only be set if openPanels wasn't `undefined`.\n\t// If it isn't set just return `panelsWithEnabledState`, and if that isn't\n\t// set return an empty object.\n\treturn panels ?? panelsWithEnabledState ?? EMPTY_OBJECT;\n}\n\n/**\n * Returns the preferences (these preferences are persisted locally).\n *\n * @param {Object} state Global application state.\n *\n * @return {Object} Preferences Object.\n */\nexport const getPreferences = createRegistrySelector( ( select ) => () => {\n\tdeprecated( `select( 'core/edit-post' ).getPreferences`, {\n\t\tsince: '6.0',\n\t\talternative: `select( 'core/preferences' ).get`,\n\t} );\n\n\tconst corePreferences = [ 'editorMode', 'hiddenBlockTypes' ].reduce(\n\t\t( accumulatedPrefs, preferenceKey ) => {\n\t\t\tconst value = select( preferencesStore ).get(\n\t\t\t\t'core',\n\t\t\t\tpreferenceKey\n\t\t\t);\n\n\t\t\treturn {\n\t\t\t\t...accumulatedPrefs,\n\t\t\t\t[ preferenceKey ]: value,\n\t\t\t};\n\t\t},\n\t\t{}\n\t);\n\n\t// Panels were a preference, but the data structure changed when the state\n\t// was migrated to the preferences store. They need to be converted from\n\t// the new preferences store format to old format to ensure no breaking\n\t// changes for plugins.\n\tconst inactivePanels = select( preferencesStore ).get(\n\t\t'core',\n\t\t'inactivePanels'\n\t);\n\tconst openPanels = select( preferencesStore ).get( 'core', 'openPanels' );\n\tconst panels = convertPanelsToOldFormat( inactivePanels, openPanels );\n\n\treturn {\n\t\t...corePreferences,\n\t\tpanels,\n\t};\n} );\n\n/**\n *\n * @param {Object} state Global application state.\n * @param {string} preferenceKey Preference Key.\n * @param {*} defaultValue Default Value.\n *\n * @return {*} Preference Value.\n */\nexport function getPreference( state, preferenceKey, defaultValue ) {\n\tdeprecated( `select( 'core/edit-post' ).getPreference`, {\n\t\tsince: '6.0',\n\t\talternative: `select( 'core/preferences' ).get`,\n\t} );\n\n\t// Avoid using the `getPreferences` registry selector where possible.\n\tconst preferences = getPreferences( state );\n\tconst value = preferences[ preferenceKey ];\n\treturn value === undefined ? defaultValue : value;\n}\n\n/**\n * Returns an array of blocks that are hidden.\n *\n * @return {Array} A list of the hidden block types\n */\nexport const getHiddenBlockTypes = createRegistrySelector( ( select ) => () => {\n\treturn (\n\t\tselect( preferencesStore ).get( 'core', 'hiddenBlockTypes' ) ??\n\t\tEMPTY_ARRAY\n\t);\n} );\n\n/**\n * Returns true if the publish sidebar is opened.\n *\n * @deprecated\n *\n * @param {Object} state Global application state\n *\n * @return {boolean} Whether the publish sidebar is open.\n */\nexport const isPublishSidebarOpened = createRegistrySelector(\n\t( select ) => () => {\n\t\tdeprecated( `select( 'core/edit-post' ).isPublishSidebarOpened`, {\n\t\t\tsince: '6.6',\n\t\t\talternative: `select( 'core/editor' ).isPublishSidebarOpened`,\n\t\t} );\n\t\treturn select( editorStore ).isPublishSidebarOpened();\n\t}\n);\n\n/**\n * Returns true if the given panel was programmatically removed, or false otherwise.\n * All panels are not removed by default.\n *\n * @deprecated\n *\n * @param {Object} state Global application state.\n * @param {string} panelName A string that identifies the panel.\n *\n * @return {boolean} Whether or not the panel is removed.\n */\nexport const isEditorPanelRemoved = createRegistrySelector(\n\t( select ) => ( state, panelName ) => {\n\t\tdeprecated( `select( 'core/edit-post' ).isEditorPanelRemoved`, {\n\t\t\tsince: '6.5',\n\t\t\talternative: `select( 'core/editor' ).isEditorPanelRemoved`,\n\t\t} );\n\t\treturn select( editorStore ).isEditorPanelRemoved( panelName );\n\t}\n);\n\n/**\n * Returns true if the given panel is enabled, or false otherwise. Panels are\n * enabled by default.\n *\n * @deprecated\n *\n * @param {Object} state Global application state.\n * @param {string} panelName A string that identifies the panel.\n *\n * @return {boolean} Whether or not the panel is enabled.\n */\nexport const isEditorPanelEnabled = createRegistrySelector(\n\t( select ) => ( state, panelName ) => {\n\t\tdeprecated( `select( 'core/edit-post' ).isEditorPanelEnabled`, {\n\t\t\tsince: '6.5',\n\t\t\talternative: `select( 'core/editor' ).isEditorPanelEnabled`,\n\t\t} );\n\t\treturn select( editorStore ).isEditorPanelEnabled( panelName );\n\t}\n);\n\n/**\n * Returns true if the given panel is open, or false otherwise. Panels are\n * closed by default.\n *\n * @deprecated\n *\n * @param {Object} state Global application state.\n * @param {string} panelName A string that identifies the panel.\n *\n * @return {boolean} Whether or not the panel is open.\n */\nexport const isEditorPanelOpened = createRegistrySelector(\n\t( select ) => ( state, panelName ) => {\n\t\tdeprecated( `select( 'core/edit-post' ).isEditorPanelOpened`, {\n\t\t\tsince: '6.5',\n\t\t\talternative: `select( 'core/editor' ).isEditorPanelOpened`,\n\t\t} );\n\t\treturn select( editorStore ).isEditorPanelOpened( panelName );\n\t}\n);\n\n/**\n * Returns true if a modal is active, or false otherwise.\n *\n * @deprecated since WP 6.3 use `core/interface` store's selector with the same name instead.\n *\n * @param {Object} state Global application state.\n * @param {string} modalName A string that uniquely identifies the modal.\n *\n * @return {boolean} Whether the modal is active.\n */\nexport const isModalActive = createRegistrySelector(\n\t( select ) => ( state, modalName ) => {\n\t\tdeprecated( `select( 'core/edit-post' ).isModalActive`, {\n\t\t\tsince: '6.3',\n\t\t\talternative: `select( 'core/interface' ).isModalActive`,\n\t\t} );\n\t\treturn !! select( interfaceStore ).isModalActive( modalName );\n\t}\n);\n\n/**\n * Returns whether the given feature is enabled or not.\n *\n * @param {Object} state Global application state.\n * @param {string} feature Feature slug.\n *\n * @return {boolean} Is active.\n */\nexport const isFeatureActive = createRegistrySelector(\n\t( select ) => ( state, feature ) => {\n\t\treturn !! select( preferencesStore ).get( 'core/edit-post', feature );\n\t}\n);\n\n/**\n * Returns true if the plugin item is pinned to the header.\n * When the value is not set it defaults to true.\n *\n * @param {Object} state Global application state.\n * @param {string} pluginName Plugin item name.\n *\n * @return {boolean} Whether the plugin item is pinned.\n */\nexport const isPluginItemPinned = createRegistrySelector(\n\t( select ) => ( state, pluginName ) => {\n\t\treturn select( interfaceStore ).isItemPinned( 'core', pluginName );\n\t}\n);\n\n/**\n * Returns an array of active meta box locations.\n *\n * @param {Object} state Post editor state.\n *\n * @return {string[]} Active meta box locations.\n */\nexport const getActiveMetaBoxLocations = createSelector(\n\t( state ) => {\n\t\treturn Object.keys( state.metaBoxes.locations ).filter( ( location ) =>\n\t\t\tisMetaBoxLocationActive( state, location )\n\t\t);\n\t},\n\t( state ) => [ state.metaBoxes.locations ]\n);\n\n/**\n * Returns true if a metabox location is active and visible\n *\n * @param {Object} state Post editor state.\n * @param {string} location Meta box location to test.\n *\n * @return {boolean} Whether the meta box location is active and visible.\n */\nexport const isMetaBoxLocationVisible = createRegistrySelector(\n\t( select ) => ( state, location ) => {\n\t\treturn (\n\t\t\tisMetaBoxLocationActive( state, location ) &&\n\t\t\tgetMetaBoxesPerLocation( state, location )?.some( ( { id } ) => {\n\t\t\t\treturn select( editorStore ).isEditorPanelEnabled(\n\t\t\t\t\t`meta-box-${ id }`\n\t\t\t\t);\n\t\t\t} )\n\t\t);\n\t}\n);\n\n/**\n * Returns true if there is an active meta box in the given location, or false\n * otherwise.\n *\n * @param {Object} state Post editor state.\n * @param {string} location Meta box location to test.\n *\n * @return {boolean} Whether the meta box location is active.\n */\nexport function isMetaBoxLocationActive( state, location ) {\n\tconst metaBoxes = getMetaBoxesPerLocation( state, location );\n\treturn !! metaBoxes && metaBoxes.length !== 0;\n}\n\n/**\n * Returns the list of all the available meta boxes for a given location.\n *\n * @param {Object} state Global application state.\n * @param {string} location Meta box location to test.\n *\n * @return {?Array} List of meta boxes.\n */\nexport function getMetaBoxesPerLocation( state, location ) {\n\treturn state.metaBoxes.locations[ location ];\n}\n\n/**\n * Returns the list of all the available meta boxes.\n *\n * @param {Object} state Global application state.\n *\n * @return {Array} List of meta boxes.\n */\nexport const getAllMetaBoxes = createSelector(\n\t( state ) => {\n\t\treturn Object.values( state.metaBoxes.locations ).flat();\n\t},\n\t( state ) => [ state.metaBoxes.locations ]\n);\n\n/**\n * Returns the list of meta box IDs marked as compatible with real-time\n * collaboration via the add_meta_box() __rtc_compatible_meta_box compatibility flag.\n *\n * @param {Object} state Global application state.\n *\n * @return {string[]} List of RTC-compatible meta box IDs.\n */\nexport function getRtcCompatibleMetaBoxIds( state ) {\n\treturn state.metaBoxes.rtcCompatibleIds;\n}\n\n/**\n * Returns true if the post is using Meta Boxes\n *\n * @param {Object} state Global application state\n *\n * @return {boolean} Whether there are metaboxes or not.\n */\nexport function hasMetaBoxes( state ) {\n\treturn getActiveMetaBoxLocations( state ).length > 0;\n}\n\n/**\n * Returns true if the Meta Boxes are being saved.\n *\n * @param {Object} state Global application state.\n *\n * @return {boolean} Whether the metaboxes are being saved.\n */\nexport function isSavingMetaBoxes( state ) {\n\treturn state.metaBoxes.isSaving;\n}\n\n/**\n * Returns the current editing canvas device type.\n *\n * @deprecated\n *\n * @param {Object} state Global application state.\n *\n * @return {string} Device type.\n */\nexport const __experimentalGetPreviewDeviceType = createRegistrySelector(\n\t( select ) => () => {\n\t\tdeprecated(\n\t\t\t`select( 'core/edit-site' ).__experimentalGetPreviewDeviceType`,\n\t\t\t{\n\t\t\t\tsince: '6.5',\n\t\t\t\tversion: '6.7',\n\t\t\t\talternative: `select( 'core/editor' ).getDeviceType`,\n\t\t\t}\n\t\t);\n\t\treturn select( editorStore ).getDeviceType();\n\t}\n);\n\n/**\n * Returns true if the inserter is opened.\n *\n * @deprecated\n *\n * @param {Object} state Global application state.\n *\n * @return {boolean} Whether the inserter is opened.\n */\nexport const isInserterOpened = createRegistrySelector( ( select ) => () => {\n\tdeprecated( `select( 'core/edit-post' ).isInserterOpened`, {\n\t\tsince: '6.5',\n\t\talternative: `select( 'core/editor' ).isInserterOpened`,\n\t} );\n\treturn select( editorStore ).isInserterOpened();\n} );\n\n/**\n * Get the insertion point for the inserter.\n *\n * @deprecated\n *\n * @param {Object} state Global application state.\n *\n * @return {Object} The root client ID, index to insert at and starting filter value.\n */\nexport const __experimentalGetInsertionPoint = createRegistrySelector(\n\t( select ) => () => {\n\t\tdeprecated(\n\t\t\t`select( 'core/edit-post' ).__experimentalGetInsertionPoint`,\n\t\t\t{\n\t\t\t\tsince: '6.5',\n\t\t\t\tversion: '6.7',\n\t\t\t}\n\t\t);\n\t\treturn unlock( select( editorStore ) ).getInserter();\n\t}\n);\n\n/**\n * Returns true if the list view is opened.\n *\n * @param {Object} state Global application state.\n *\n * @return {boolean} Whether the list view is opened.\n */\nexport const isListViewOpened = createRegistrySelector( ( select ) => () => {\n\tdeprecated( `select( 'core/edit-post' ).isListViewOpened`, {\n\t\tsince: '6.5',\n\t\talternative: `select( 'core/editor' ).isListViewOpened`,\n\t} );\n\treturn select( editorStore ).isListViewOpened();\n} );\n\n/**\n * Returns true if the template editing mode is enabled.\n *\n * @deprecated\n */\nexport const isEditingTemplate = createRegistrySelector( ( select ) => () => {\n\tdeprecated( `select( 'core/edit-post' ).isEditingTemplate`, {\n\t\tsince: '6.5',\n\t\talternative: `select( 'core/editor' ).getRenderingMode`,\n\t} );\n\treturn select( editorStore ).getCurrentPostType() === 'wp_template';\n} );\n\n/**\n * Returns true if meta boxes are initialized.\n *\n * @param {Object} state Global application state.\n *\n * @return {boolean} Whether meta boxes are initialized.\n */\nexport function areMetaBoxesInitialized( state ) {\n\treturn state.metaBoxes.initialized;\n}\n\n/**\n * Retrieves the template of the currently edited post.\n *\n * @return {?Object} Post Template.\n */\nexport const getEditedPostTemplate = createRegistrySelector(\n\t( select ) => () => {\n\t\tconst { id: postId, type: postType } =\n\t\t\tselect( editorStore ).getCurrentPost();\n\t\tconst templateId = unlock( select( coreStore ) ).getTemplateId(\n\t\t\tpostType,\n\t\t\tpostId\n\t\t);\n\t\tif ( ! templateId ) {\n\t\t\treturn undefined;\n\t\t}\n\t\treturn select( coreStore ).getEditedEntityRecord(\n\t\t\t'postType',\n\t\t\t'wp_template',\n\t\t\ttemplateId\n\t\t);\n\t}\n);\n"],
5
- "mappings": "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",
4
+ "sourcesContent": ["/**\n * WordPress dependencies\n */\nimport { createSelector, createRegistrySelector } from '@wordpress/data';\nimport { store as preferencesStore } from '@wordpress/preferences';\nimport { store as coreStore } from '@wordpress/core-data';\nimport {\n\tstore as editorStore,\n\tprivateApis as editorPrivateApis,\n} from '@wordpress/editor';\nimport deprecated from '@wordpress/deprecated';\n\n/**\n * Internal dependencies\n */\nimport { unlock } from '../lock-unlock';\nconst { interfaceStore } = unlock( editorPrivateApis );\nconst EMPTY_ARRAY = [];\nconst EMPTY_OBJECT = {};\n\n/**\n * Returns the current editing mode.\n *\n * @param {Object} state Global application state.\n *\n * @return {string} Editing mode.\n */\nexport const getEditorMode = createRegistrySelector(\n\t( select ) => () =>\n\t\tselect( preferencesStore ).get( 'core', 'editorMode' ) ?? 'visual'\n);\n\n/**\n * Returns true if the editor sidebar is opened.\n *\n * @param {Object} state Global application state\n *\n * @return {boolean} Whether the editor sidebar is opened.\n */\nexport const isEditorSidebarOpened = createRegistrySelector(\n\t( select ) => () => {\n\t\tconst activeGeneralSidebar =\n\t\t\tselect( interfaceStore ).getActiveComplementaryArea( 'core' );\n\t\treturn [ 'edit-post/document', 'edit-post/block' ].includes(\n\t\t\tactiveGeneralSidebar\n\t\t);\n\t}\n);\n\n/**\n * Returns true if the plugin sidebar is opened.\n *\n * @param {Object} state Global application state.\n *\n * @return {boolean} Whether the plugin sidebar is opened.\n */\nexport const isPluginSidebarOpened = createRegistrySelector(\n\t( select ) => () => {\n\t\tconst activeGeneralSidebar =\n\t\t\tselect( interfaceStore ).getActiveComplementaryArea( 'core' );\n\t\treturn (\n\t\t\t!! activeGeneralSidebar &&\n\t\t\t! [ 'edit-post/document', 'edit-post/block' ].includes(\n\t\t\t\tactiveGeneralSidebar\n\t\t\t)\n\t\t);\n\t}\n);\n\n/**\n * Returns the current active general sidebar name, or null if there is no\n * general sidebar active. The active general sidebar is a unique name to\n * identify either an editor or plugin sidebar.\n *\n * Examples:\n *\n * - `edit-post/document`\n * - `my-plugin/insert-image-sidebar`\n *\n * @param {Object} state Global application state.\n *\n * @return {?string} Active general sidebar name.\n */\nexport const getActiveGeneralSidebarName = createRegistrySelector(\n\t( select ) => () => {\n\t\treturn select( interfaceStore ).getActiveComplementaryArea( 'core' );\n\t}\n);\n\n/**\n * Converts panels from the new preferences store format to the old format\n * that the post editor previously used.\n *\n * The resultant converted data should look like this:\n * {\n * panelName: {\n * enabled: false,\n * opened: true,\n * },\n * anotherPanelName: {\n * opened: true\n * },\n * }\n *\n * @param {string[] | undefined} inactivePanels An array of inactive panel names.\n * @param {string[] | undefined} openPanels An array of open panel names.\n *\n * @return {Object} The converted panel data.\n */\nfunction convertPanelsToOldFormat( inactivePanels, openPanels ) {\n\t// First reduce the inactive panels.\n\tconst panelsWithEnabledState = inactivePanels?.reduce(\n\t\t( accumulatedPanels, panelName ) => ( {\n\t\t\t...accumulatedPanels,\n\t\t\t[ panelName ]: {\n\t\t\t\tenabled: false,\n\t\t\t},\n\t\t} ),\n\t\t{}\n\t);\n\n\t// Then reduce the open panels, passing in the result of the previous\n\t// reduction as the initial value so that both open and inactive\n\t// panel state is combined.\n\tconst panels = openPanels?.reduce( ( accumulatedPanels, panelName ) => {\n\t\tconst currentPanelState = accumulatedPanels?.[ panelName ];\n\t\treturn {\n\t\t\t...accumulatedPanels,\n\t\t\t[ panelName ]: {\n\t\t\t\t...currentPanelState,\n\t\t\t\topened: true,\n\t\t\t},\n\t\t};\n\t}, panelsWithEnabledState ?? {} );\n\n\t// The panels variable will only be set if openPanels wasn't `undefined`.\n\t// If it isn't set just return `panelsWithEnabledState`, and if that isn't\n\t// set return an empty object.\n\treturn panels ?? panelsWithEnabledState ?? EMPTY_OBJECT;\n}\n\n/**\n * Returns the preferences (these preferences are persisted locally).\n *\n * @param {Object} state Global application state.\n *\n * @return {Object} Preferences Object.\n */\nexport const getPreferences = createRegistrySelector( ( select ) => () => {\n\tdeprecated( `select( 'core/edit-post' ).getPreferences`, {\n\t\tsince: '6.0',\n\t\talternative: `select( 'core/preferences' ).get`,\n\t} );\n\n\tconst corePreferences = [ 'editorMode', 'hiddenBlockTypes' ].reduce(\n\t\t( accumulatedPrefs, preferenceKey ) => {\n\t\t\tconst value = select( preferencesStore ).get(\n\t\t\t\t'core',\n\t\t\t\tpreferenceKey\n\t\t\t);\n\n\t\t\treturn {\n\t\t\t\t...accumulatedPrefs,\n\t\t\t\t[ preferenceKey ]: value,\n\t\t\t};\n\t\t},\n\t\t{}\n\t);\n\n\t// Panels were a preference, but the data structure changed when the state\n\t// was migrated to the preferences store. They need to be converted from\n\t// the new preferences store format to old format to ensure no breaking\n\t// changes for plugins.\n\tconst inactivePanels = select( preferencesStore ).get(\n\t\t'core',\n\t\t'inactivePanels'\n\t);\n\tconst openPanels = select( preferencesStore ).get( 'core', 'openPanels' );\n\tconst panels = convertPanelsToOldFormat( inactivePanels, openPanels );\n\n\treturn {\n\t\t...corePreferences,\n\t\tpanels,\n\t};\n} );\n\n/**\n *\n * @param {Object} state Global application state.\n * @param {string} preferenceKey Preference Key.\n * @param {*} defaultValue Default Value.\n *\n * @return {*} Preference Value.\n */\nexport function getPreference( state, preferenceKey, defaultValue ) {\n\tdeprecated( `select( 'core/edit-post' ).getPreference`, {\n\t\tsince: '6.0',\n\t\talternative: `select( 'core/preferences' ).get`,\n\t} );\n\n\t// Avoid using the `getPreferences` registry selector where possible.\n\tconst preferences = getPreferences( state );\n\tconst value = preferences[ preferenceKey ];\n\treturn value === undefined ? defaultValue : value;\n}\n\n/**\n * Returns an array of blocks that are hidden.\n *\n * @return {Array} A list of the hidden block types\n */\nexport const getHiddenBlockTypes = createRegistrySelector( ( select ) => () => {\n\treturn (\n\t\tselect( preferencesStore ).get( 'core', 'hiddenBlockTypes' ) ??\n\t\tEMPTY_ARRAY\n\t);\n} );\n\n/**\n * Returns true if the publish sidebar is opened.\n *\n * @deprecated\n *\n * @param {Object} state Global application state\n *\n * @return {boolean} Whether the publish sidebar is open.\n */\nexport const isPublishSidebarOpened = createRegistrySelector(\n\t( select ) => () => {\n\t\tdeprecated( `select( 'core/edit-post' ).isPublishSidebarOpened`, {\n\t\t\tsince: '6.6',\n\t\t\talternative: `select( 'core/editor' ).isPublishSidebarOpened`,\n\t\t} );\n\t\treturn select( editorStore ).isPublishSidebarOpened();\n\t}\n);\n\n/**\n * Returns true if the given panel was programmatically removed, or false otherwise.\n * All panels are not removed by default.\n *\n * @deprecated\n *\n * @param {Object} state Global application state.\n * @param {string} panelName A string that identifies the panel.\n *\n * @return {boolean} Whether or not the panel is removed.\n */\nexport const isEditorPanelRemoved = createRegistrySelector(\n\t( select ) => ( state, panelName ) => {\n\t\tdeprecated( `select( 'core/edit-post' ).isEditorPanelRemoved`, {\n\t\t\tsince: '6.5',\n\t\t\talternative: `select( 'core/editor' ).isEditorPanelRemoved`,\n\t\t} );\n\t\treturn select( editorStore ).isEditorPanelRemoved( panelName );\n\t}\n);\n\n/**\n * Returns true if the given panel is enabled, or false otherwise. Panels are\n * enabled by default.\n *\n * @deprecated\n *\n * @param {Object} state Global application state.\n * @param {string} panelName A string that identifies the panel.\n *\n * @return {boolean} Whether or not the panel is enabled.\n */\nexport const isEditorPanelEnabled = createRegistrySelector(\n\t( select ) => ( state, panelName ) => {\n\t\tdeprecated( `select( 'core/edit-post' ).isEditorPanelEnabled`, {\n\t\t\tsince: '6.5',\n\t\t\talternative: `select( 'core/editor' ).isEditorPanelEnabled`,\n\t\t} );\n\t\treturn select( editorStore ).isEditorPanelEnabled( panelName );\n\t}\n);\n\n/**\n * Returns true if the given panel is open, or false otherwise. Panels are\n * closed by default.\n *\n * @deprecated\n *\n * @param {Object} state Global application state.\n * @param {string} panelName A string that identifies the panel.\n *\n * @return {boolean} Whether or not the panel is open.\n */\nexport const isEditorPanelOpened = createRegistrySelector(\n\t( select ) => ( state, panelName ) => {\n\t\tdeprecated( `select( 'core/edit-post' ).isEditorPanelOpened`, {\n\t\t\tsince: '6.5',\n\t\t\talternative: `select( 'core/editor' ).isEditorPanelOpened`,\n\t\t} );\n\t\treturn select( editorStore ).isEditorPanelOpened( panelName );\n\t}\n);\n\n/**\n * Returns true if a modal is active, or false otherwise.\n *\n * @deprecated since WP 6.3 use `core/interface` store's selector with the same name instead.\n *\n * @param {Object} state Global application state.\n * @param {string} modalName A string that uniquely identifies the modal.\n *\n * @return {boolean} Whether the modal is active.\n */\nexport const isModalActive = createRegistrySelector(\n\t( select ) => ( state, modalName ) => {\n\t\tdeprecated( `select( 'core/edit-post' ).isModalActive`, {\n\t\t\tsince: '6.3',\n\t\t\talternative: `select( 'core/interface' ).isModalActive`,\n\t\t} );\n\t\treturn !! select( interfaceStore ).isModalActive( modalName );\n\t}\n);\n\n/**\n * Returns whether the given feature is enabled or not.\n *\n * @param {Object} state Global application state.\n * @param {string} feature Feature slug.\n *\n * @return {boolean} Is active.\n */\nexport const isFeatureActive = createRegistrySelector(\n\t( select ) => ( state, feature ) => {\n\t\treturn !! select( preferencesStore ).get( 'core/edit-post', feature );\n\t}\n);\n\n/**\n * Returns true if the plugin item is pinned to the header.\n * When the value is not set it defaults to true.\n *\n * @param {Object} state Global application state.\n * @param {string} pluginName Plugin item name.\n *\n * @return {boolean} Whether the plugin item is pinned.\n */\nexport const isPluginItemPinned = createRegistrySelector(\n\t( select ) => ( state, pluginName ) => {\n\t\treturn select( interfaceStore ).isItemPinned( 'core', pluginName );\n\t}\n);\n\n/**\n * Returns an array of active meta box locations.\n *\n * @param {Object} state Post editor state.\n *\n * @return {string[]} Active meta box locations.\n */\nexport const getActiveMetaBoxLocations = createSelector(\n\t( state ) => {\n\t\treturn Object.keys( state.metaBoxes.locations ).filter( ( location ) =>\n\t\t\tisMetaBoxLocationActive( state, location )\n\t\t);\n\t},\n\t( state ) => [ state.metaBoxes.locations ]\n);\n\n/**\n * Returns true if a metabox location is active and visible\n *\n * @param {Object} state Post editor state.\n * @param {string} location Meta box location to test.\n *\n * @return {boolean} Whether the meta box location is active and visible.\n */\nexport const isMetaBoxLocationVisible = createRegistrySelector(\n\t( select ) => ( state, location ) => {\n\t\treturn (\n\t\t\tisMetaBoxLocationActive( state, location ) &&\n\t\t\tgetMetaBoxesPerLocation( state, location )?.some( ( { id } ) => {\n\t\t\t\treturn select( editorStore ).isEditorPanelEnabled(\n\t\t\t\t\t`meta-box-${ id }`\n\t\t\t\t);\n\t\t\t} )\n\t\t);\n\t}\n);\n\n/**\n * Returns true if there is an active meta box in the given location, or false\n * otherwise.\n *\n * @param {Object} state Post editor state.\n * @param {string} location Meta box location to test.\n *\n * @return {boolean} Whether the meta box location is active.\n */\nexport function isMetaBoxLocationActive( state, location ) {\n\tconst metaBoxes = getMetaBoxesPerLocation( state, location );\n\treturn !! metaBoxes && metaBoxes.length !== 0;\n}\n\n/**\n * Returns the list of all the available meta boxes for a given location.\n *\n * @param {Object} state Global application state.\n * @param {string} location Meta box location to test.\n *\n * @return {?Array} List of meta boxes.\n */\nexport function getMetaBoxesPerLocation( state, location ) {\n\treturn state.metaBoxes.locations[ location ];\n}\n\n/**\n * Returns the list of all the available meta boxes.\n *\n * @param {Object} state Global application state.\n *\n * @return {Array} List of meta boxes.\n */\nexport const getAllMetaBoxes = createSelector(\n\t( state ) => {\n\t\treturn Object.values( state.metaBoxes.locations ).flat();\n\t},\n\t( state ) => [ state.metaBoxes.locations ]\n);\n\n/**\n * Returns true if the post is using Meta Boxes\n *\n * @param {Object} state Global application state\n *\n * @return {boolean} Whether there are metaboxes or not.\n */\nexport function hasMetaBoxes( state ) {\n\treturn getActiveMetaBoxLocations( state ).length > 0;\n}\n\n/**\n * Returns true if the Meta Boxes are being saved.\n *\n * @param {Object} state Global application state.\n *\n * @return {boolean} Whether the metaboxes are being saved.\n */\nexport function isSavingMetaBoxes( state ) {\n\treturn state.metaBoxes.isSaving;\n}\n\n/**\n * Returns the current editing canvas device type.\n *\n * @deprecated\n *\n * @param {Object} state Global application state.\n *\n * @return {string} Device type.\n */\nexport const __experimentalGetPreviewDeviceType = createRegistrySelector(\n\t( select ) => () => {\n\t\tdeprecated(\n\t\t\t`select( 'core/edit-site' ).__experimentalGetPreviewDeviceType`,\n\t\t\t{\n\t\t\t\tsince: '6.5',\n\t\t\t\tversion: '6.7',\n\t\t\t\talternative: `select( 'core/editor' ).getDeviceType`,\n\t\t\t}\n\t\t);\n\t\treturn select( editorStore ).getDeviceType();\n\t}\n);\n\n/**\n * Returns true if the inserter is opened.\n *\n * @deprecated\n *\n * @param {Object} state Global application state.\n *\n * @return {boolean} Whether the inserter is opened.\n */\nexport const isInserterOpened = createRegistrySelector( ( select ) => () => {\n\tdeprecated( `select( 'core/edit-post' ).isInserterOpened`, {\n\t\tsince: '6.5',\n\t\talternative: `select( 'core/editor' ).isInserterOpened`,\n\t} );\n\treturn select( editorStore ).isInserterOpened();\n} );\n\n/**\n * Get the insertion point for the inserter.\n *\n * @deprecated\n *\n * @param {Object} state Global application state.\n *\n * @return {Object} The root client ID, index to insert at and starting filter value.\n */\nexport const __experimentalGetInsertionPoint = createRegistrySelector(\n\t( select ) => () => {\n\t\tdeprecated(\n\t\t\t`select( 'core/edit-post' ).__experimentalGetInsertionPoint`,\n\t\t\t{\n\t\t\t\tsince: '6.5',\n\t\t\t\tversion: '6.7',\n\t\t\t}\n\t\t);\n\t\treturn unlock( select( editorStore ) ).getInserter();\n\t}\n);\n\n/**\n * Returns true if the list view is opened.\n *\n * @param {Object} state Global application state.\n *\n * @return {boolean} Whether the list view is opened.\n */\nexport const isListViewOpened = createRegistrySelector( ( select ) => () => {\n\tdeprecated( `select( 'core/edit-post' ).isListViewOpened`, {\n\t\tsince: '6.5',\n\t\talternative: `select( 'core/editor' ).isListViewOpened`,\n\t} );\n\treturn select( editorStore ).isListViewOpened();\n} );\n\n/**\n * Returns true if the template editing mode is enabled.\n *\n * @deprecated\n */\nexport const isEditingTemplate = createRegistrySelector( ( select ) => () => {\n\tdeprecated( `select( 'core/edit-post' ).isEditingTemplate`, {\n\t\tsince: '6.5',\n\t\talternative: `select( 'core/editor' ).getRenderingMode`,\n\t} );\n\treturn select( editorStore ).getCurrentPostType() === 'wp_template';\n} );\n\n/**\n * Returns true if meta boxes are initialized.\n *\n * @param {Object} state Global application state.\n *\n * @return {boolean} Whether meta boxes are initialized.\n */\nexport function areMetaBoxesInitialized( state ) {\n\treturn state.metaBoxes.initialized;\n}\n\n/**\n * Retrieves the template of the currently edited post.\n *\n * @return {?Object} Post Template.\n */\nexport const getEditedPostTemplate = createRegistrySelector(\n\t( select ) => () => {\n\t\tconst { id: postId, type: postType } =\n\t\t\tselect( editorStore ).getCurrentPost();\n\t\tconst templateId = unlock( select( coreStore ) ).getTemplateId(\n\t\t\tpostType,\n\t\t\tpostId\n\t\t);\n\t\tif ( ! templateId ) {\n\t\t\treturn undefined;\n\t\t}\n\t\treturn select( coreStore ).getEditedEntityRecord(\n\t\t\t'postType',\n\t\t\t'wp_template',\n\t\t\ttemplateId\n\t\t);\n\t}\n);\n"],
5
+ "mappings": "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",
6
6
  "names": []
7
7
  }
@@ -106,141 +106,6 @@
106
106
  }
107
107
  }
108
108
 
109
- .admin-ui-page {
110
- display: flex;
111
- height: 100%;
112
- background-color: var(--wpds-color-bg-surface-neutral, #fcfcfc);
113
- color: var(--wpds-color-fg-content-neutral, #1e1e1e);
114
- position: relative;
115
- z-index: 1;
116
- flex-flow: column;
117
- text-wrap: pretty;
118
- }
119
-
120
- .admin-ui-page__header {
121
- padding: var(--wpds-dimension-padding-lg, 16px) var(--wpds-dimension-padding-2xl, 24px);
122
- border-bottom: var(--wpds-border-width-xs, 1px) solid var(--wpds-color-stroke-surface-neutral-weak, #e4e4e4);
123
- background: var(--wpds-color-bg-surface-neutral-strong, #ffffff);
124
- position: sticky;
125
- top: 0;
126
- z-index: 1;
127
- }
128
-
129
- .admin-ui-page__header-title {
130
- font-family: var(--wpds-typography-font-family-heading, -apple-system, system-ui, "Segoe UI", "Roboto", "Oxygen-Sans", "Ubuntu", "Cantarell", "Helvetica Neue", sans-serif);
131
- font-size: var(--wpds-typography-font-size-lg, 15px);
132
- font-weight: var(--wpds-typography-font-weight-medium, 499);
133
- line-height: var(--wpds-typography-line-height-lg, 28px);
134
- margin: 0;
135
- overflow: hidden;
136
- text-overflow: ellipsis;
137
- white-space: nowrap;
138
- }
139
-
140
- .admin-ui-page__sidebar-toggle-slot:empty {
141
- display: none;
142
- }
143
-
144
- .admin-ui-page__header-subtitle {
145
- padding-block-end: var(--wpds-dimension-padding-xs, 4px);
146
- color: var(--wpds-color-fg-content-neutral-weak, #707070);
147
- font-size: var(--wpds-typography-font-size-md, 13px);
148
- line-height: var(--wpds-typography-line-height-md, 24px);
149
- margin: 0;
150
- }
151
-
152
- .admin-ui-page__content {
153
- flex-grow: 1;
154
- overflow: auto;
155
- display: flex;
156
- flex-direction: column;
157
- }
158
-
159
- .admin-ui-page__content.has-padding {
160
- padding: var(--wpds-dimension-padding-lg, 16px) var(--wpds-dimension-padding-2xl, 24px);
161
- }
162
-
163
- .show-icon-labels .admin-ui-page__header-actions .components-button.has-icon {
164
- width: auto;
165
- padding: 0 var(--wpds-dimension-padding-xs, 4px);
166
- }
167
-
168
- .show-icon-labels .admin-ui-page__header-actions .components-button.has-icon svg {
169
- display: none;
170
- }
171
-
172
- .show-icon-labels .admin-ui-page__header-actions .components-button.has-icon::after {
173
- content: attr(aria-label);
174
- font-size: var(--wpds-typography-font-size-sm, 12px);
175
- }
176
-
177
- /**
178
- * SCSS Variables.
179
- *
180
- * Please use variables from this sheet to ensure consistency across the UI.
181
- * Don't add to this sheet unless you're pretty sure the value will be reused in many places.
182
- * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.
183
- */
184
- /**
185
- * Colors
186
- */
187
- /**
188
- * Fonts & basic variables.
189
- */
190
- /**
191
- * Typography
192
- */
193
- /**
194
- * Grid System.
195
- * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/
196
- */
197
- /**
198
- * Radius scale.
199
- */
200
- /**
201
- * Elevation scale.
202
- */
203
- /**
204
- * Dimensions.
205
- */
206
- /**
207
- * Mobile specific styles
208
- */
209
- /**
210
- * Editor styles.
211
- */
212
- /**
213
- * Block & Editor UI.
214
- */
215
- /**
216
- * Block paddings.
217
- */
218
- /**
219
- * React Native specific.
220
- * These variables do not appear to be used anywhere else.
221
- */
222
- .admin-ui-breadcrumbs__list {
223
- font-family: var(--wpds-typography-font-family-heading, -apple-system, system-ui, "Segoe UI", "Roboto", "Oxygen-Sans", "Ubuntu", "Cantarell", "Helvetica Neue", sans-serif);
224
- font-size: var(--wpds-typography-font-size-lg, 15px);
225
- font-weight: var(--wpds-typography-font-weight-medium, 499);
226
- line-height: var(--wpds-typography-line-height-lg, 28px);
227
- list-style: none;
228
- padding: 0;
229
- margin: 0;
230
- gap: 0;
231
- min-height: 32px;
232
- }
233
-
234
- .admin-ui-breadcrumbs__list li:not(:last-child)::after {
235
- content: "/";
236
- margin: 0 8px;
237
- }
238
-
239
- .admin-ui-breadcrumbs__list h1 {
240
- font-size: inherit;
241
- line-height: inherit;
242
- }
243
-
244
109
  .edit-post-fullscreen-mode-close__view-mode-toggle {
245
110
  top: 0;
246
111
  right: 0;
@@ -367,7 +232,7 @@
367
232
  touch-action: none;
368
233
  }
369
234
  .edit-post-meta-boxes-main__presenter > button[aria-expanded] {
370
- cursor: pointer;
235
+ cursor: var(--wpds-cursor-control, pointer);
371
236
  width: 100%;
372
237
  display: flex;
373
238
  justify-content: space-between;
@@ -106,141 +106,6 @@
106
106
  }
107
107
  }
108
108
 
109
- .admin-ui-page {
110
- display: flex;
111
- height: 100%;
112
- background-color: var(--wpds-color-bg-surface-neutral, #fcfcfc);
113
- color: var(--wpds-color-fg-content-neutral, #1e1e1e);
114
- position: relative;
115
- z-index: 1;
116
- flex-flow: column;
117
- text-wrap: pretty;
118
- }
119
-
120
- .admin-ui-page__header {
121
- padding: var(--wpds-dimension-padding-lg, 16px) var(--wpds-dimension-padding-2xl, 24px);
122
- border-bottom: var(--wpds-border-width-xs, 1px) solid var(--wpds-color-stroke-surface-neutral-weak, #e4e4e4);
123
- background: var(--wpds-color-bg-surface-neutral-strong, #ffffff);
124
- position: sticky;
125
- top: 0;
126
- z-index: 1;
127
- }
128
-
129
- .admin-ui-page__header-title {
130
- font-family: var(--wpds-typography-font-family-heading, -apple-system, system-ui, "Segoe UI", "Roboto", "Oxygen-Sans", "Ubuntu", "Cantarell", "Helvetica Neue", sans-serif);
131
- font-size: var(--wpds-typography-font-size-lg, 15px);
132
- font-weight: var(--wpds-typography-font-weight-medium, 499);
133
- line-height: var(--wpds-typography-line-height-lg, 28px);
134
- margin: 0;
135
- overflow: hidden;
136
- text-overflow: ellipsis;
137
- white-space: nowrap;
138
- }
139
-
140
- .admin-ui-page__sidebar-toggle-slot:empty {
141
- display: none;
142
- }
143
-
144
- .admin-ui-page__header-subtitle {
145
- padding-block-end: var(--wpds-dimension-padding-xs, 4px);
146
- color: var(--wpds-color-fg-content-neutral-weak, #707070);
147
- font-size: var(--wpds-typography-font-size-md, 13px);
148
- line-height: var(--wpds-typography-line-height-md, 24px);
149
- margin: 0;
150
- }
151
-
152
- .admin-ui-page__content {
153
- flex-grow: 1;
154
- overflow: auto;
155
- display: flex;
156
- flex-direction: column;
157
- }
158
-
159
- .admin-ui-page__content.has-padding {
160
- padding: var(--wpds-dimension-padding-lg, 16px) var(--wpds-dimension-padding-2xl, 24px);
161
- }
162
-
163
- .show-icon-labels .admin-ui-page__header-actions .components-button.has-icon {
164
- width: auto;
165
- padding: 0 var(--wpds-dimension-padding-xs, 4px);
166
- }
167
-
168
- .show-icon-labels .admin-ui-page__header-actions .components-button.has-icon svg {
169
- display: none;
170
- }
171
-
172
- .show-icon-labels .admin-ui-page__header-actions .components-button.has-icon::after {
173
- content: attr(aria-label);
174
- font-size: var(--wpds-typography-font-size-sm, 12px);
175
- }
176
-
177
- /**
178
- * SCSS Variables.
179
- *
180
- * Please use variables from this sheet to ensure consistency across the UI.
181
- * Don't add to this sheet unless you're pretty sure the value will be reused in many places.
182
- * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.
183
- */
184
- /**
185
- * Colors
186
- */
187
- /**
188
- * Fonts & basic variables.
189
- */
190
- /**
191
- * Typography
192
- */
193
- /**
194
- * Grid System.
195
- * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/
196
- */
197
- /**
198
- * Radius scale.
199
- */
200
- /**
201
- * Elevation scale.
202
- */
203
- /**
204
- * Dimensions.
205
- */
206
- /**
207
- * Mobile specific styles
208
- */
209
- /**
210
- * Editor styles.
211
- */
212
- /**
213
- * Block & Editor UI.
214
- */
215
- /**
216
- * Block paddings.
217
- */
218
- /**
219
- * React Native specific.
220
- * These variables do not appear to be used anywhere else.
221
- */
222
- .admin-ui-breadcrumbs__list {
223
- font-family: var(--wpds-typography-font-family-heading, -apple-system, system-ui, "Segoe UI", "Roboto", "Oxygen-Sans", "Ubuntu", "Cantarell", "Helvetica Neue", sans-serif);
224
- font-size: var(--wpds-typography-font-size-lg, 15px);
225
- font-weight: var(--wpds-typography-font-weight-medium, 499);
226
- line-height: var(--wpds-typography-line-height-lg, 28px);
227
- list-style: none;
228
- padding: 0;
229
- margin: 0;
230
- gap: 0;
231
- min-height: 32px;
232
- }
233
-
234
- .admin-ui-breadcrumbs__list li:not(:last-child)::after {
235
- content: "/";
236
- margin: 0 8px;
237
- }
238
-
239
- .admin-ui-breadcrumbs__list h1 {
240
- font-size: inherit;
241
- line-height: inherit;
242
- }
243
-
244
109
  .edit-post-fullscreen-mode-close__view-mode-toggle {
245
110
  top: 0;
246
111
  left: 0;
@@ -367,7 +232,7 @@
367
232
  touch-action: none;
368
233
  }
369
234
  .edit-post-meta-boxes-main__presenter > button[aria-expanded] {
370
- cursor: pointer;
235
+ cursor: var(--wpds-cursor-control, pointer);
371
236
  width: 100%;
372
237
  display: flex;
373
238
  justify-content: space-between;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@wordpress/edit-post",
3
- "version": "8.44.0",
3
+ "version": "8.45.0",
4
4
  "description": "Edit Post module for WordPress.",
5
5
  "author": "The WordPress Contributors",
6
6
  "license": "GPL-2.0-or-later",
@@ -48,37 +48,38 @@
48
48
  "postbox"
49
49
  ],
50
50
  "dependencies": {
51
- "@wordpress/a11y": "^4.44.0",
52
- "@wordpress/admin-ui": "^1.12.0",
53
- "@wordpress/api-fetch": "^7.44.0",
54
- "@wordpress/base-styles": "^6.20.0",
55
- "@wordpress/block-editor": "^15.17.0",
56
- "@wordpress/block-library": "^9.44.0",
57
- "@wordpress/blocks": "^15.17.0",
58
- "@wordpress/commands": "^1.44.0",
59
- "@wordpress/components": "^32.6.0",
60
- "@wordpress/compose": "^7.44.0",
61
- "@wordpress/core-data": "^7.44.0",
62
- "@wordpress/data": "^10.44.0",
63
- "@wordpress/deprecated": "^4.44.0",
64
- "@wordpress/dom": "^4.44.0",
65
- "@wordpress/editor": "^14.44.0",
66
- "@wordpress/element": "^6.44.0",
67
- "@wordpress/global-styles-engine": "^1.11.0",
68
- "@wordpress/hooks": "^4.44.0",
69
- "@wordpress/html-entities": "^4.44.0",
70
- "@wordpress/i18n": "^6.17.0",
71
- "@wordpress/icons": "^12.2.0",
72
- "@wordpress/keyboard-shortcuts": "^5.44.0",
73
- "@wordpress/keycodes": "^4.44.0",
74
- "@wordpress/notices": "^5.44.0",
75
- "@wordpress/plugins": "^7.44.0",
76
- "@wordpress/preferences": "^4.44.0",
77
- "@wordpress/private-apis": "^1.44.0",
78
- "@wordpress/url": "^4.44.0",
79
- "@wordpress/viewport": "^6.44.0",
80
- "@wordpress/warning": "^3.44.0",
81
- "@wordpress/widgets": "^4.44.0",
51
+ "@wordpress/a11y": "^4.45.0",
52
+ "@wordpress/admin-ui": "^2.0.0",
53
+ "@wordpress/api-fetch": "^7.45.0",
54
+ "@wordpress/base-styles": "^7.0.0",
55
+ "@wordpress/block-editor": "^15.18.0",
56
+ "@wordpress/block-library": "^9.45.0",
57
+ "@wordpress/blocks": "^15.18.0",
58
+ "@wordpress/commands": "^1.45.0",
59
+ "@wordpress/components": "^33.0.0",
60
+ "@wordpress/compose": "^7.45.0",
61
+ "@wordpress/core-data": "^7.45.0",
62
+ "@wordpress/data": "^10.45.0",
63
+ "@wordpress/deprecated": "^4.45.0",
64
+ "@wordpress/dom": "^4.45.0",
65
+ "@wordpress/editor": "^14.45.0",
66
+ "@wordpress/element": "^6.45.0",
67
+ "@wordpress/global-styles-engine": "^1.12.0",
68
+ "@wordpress/hooks": "^4.45.0",
69
+ "@wordpress/html-entities": "^4.45.0",
70
+ "@wordpress/i18n": "^6.18.0",
71
+ "@wordpress/icons": "^13.0.0",
72
+ "@wordpress/keyboard-shortcuts": "^5.45.0",
73
+ "@wordpress/keycodes": "^4.45.0",
74
+ "@wordpress/notices": "^5.45.0",
75
+ "@wordpress/plugins": "^7.45.0",
76
+ "@wordpress/preferences": "^4.45.0",
77
+ "@wordpress/private-apis": "^1.45.0",
78
+ "@wordpress/ui": "^0.12.0",
79
+ "@wordpress/url": "^4.45.0",
80
+ "@wordpress/viewport": "^6.45.0",
81
+ "@wordpress/warning": "^3.45.0",
82
+ "@wordpress/widgets": "^4.45.0",
82
83
  "clsx": "^2.1.1",
83
84
  "memize": "^2.1.0"
84
85
  },
@@ -89,5 +90,5 @@
89
90
  "publishConfig": {
90
91
  "access": "public"
91
92
  },
92
- "gitHead": "b862d8c84121a47bbeff882f6c87e61681ce2e0d"
93
+ "gitHead": "8c229eaed0e88c9827e2da3d73a78f9ddd77714b"
93
94
  }
@@ -134,7 +134,7 @@ function FullscreenModeClose( { showTooltip, icon, href, initialPost } ) {
134
134
  href={ buttonHref }
135
135
  label={ buttonLabel }
136
136
  showTooltip={ showTooltip }
137
- tooltipPosition="middle right"
137
+ tooltipPosition="bottom"
138
138
  >
139
139
  <motion.div variants={ ! disableMotion && siteIconVariants }>
140
140
  <div className="edit-post-fullscreen-mode-close__view-mode-toggle-icon">
@@ -41,7 +41,6 @@ import {
41
41
  Icon,
42
42
  SlotFillProvider,
43
43
  Tooltip,
44
- VisuallyHidden,
45
44
  __unstableUseNavigateRegions as useNavigateRegions,
46
45
  privateApis as componentsPrivateApis,
47
46
  } from '@wordpress/components';
@@ -51,6 +50,7 @@ import {
51
50
  useRefEffect,
52
51
  useViewportMatch,
53
52
  } from '@wordpress/compose';
53
+ import { VisuallyHidden } from '@wordpress/ui';
54
54
 
55
55
  /**
56
56
  * Internal dependencies
@@ -39,7 +39,7 @@
39
39
  }
40
40
 
41
41
  > button[aria-expanded] {
42
- cursor: pointer;
42
+ cursor: var(--wpds-cursor-control);
43
43
  width: 100%;
44
44
  display: flex;
45
45
  justify-content: space-between;
@@ -39,7 +39,6 @@ function createMockStores( {
39
39
  isEditorReady = true,
40
40
  isCollaborationEnabled = true,
41
41
  metaBoxes = [],
42
- rtcCompatibleIds = [],
43
42
  } = {} ) {
44
43
  return {
45
44
  'core/editor': {
@@ -66,7 +65,6 @@ function createMockStores( {
66
65
  },
67
66
  selectors: {
68
67
  getAllMetaBoxes: jest.fn( () => metaBoxes ),
69
- getRtcCompatibleMetaBoxIds: jest.fn( () => rtcCompatibleIds ),
70
68
  hasMetaBoxes: jest.fn( () => metaBoxes.length > 0 ),
71
69
  getActiveMetaBoxLocations: jest.fn( () =>
72
70
  metaBoxes.length > 0 ? [ 'normal' ] : []
@@ -113,10 +111,17 @@ describe( 'useMetaBoxInitialization', () => {
113
111
  it( 'does not disable collaboration when all metaboxes are rtcCompatible', () => {
114
112
  const mockStores = createMockStores( {
115
113
  metaBoxes: [
116
- { id: 'my-metabox', title: 'My Meta Box' },
117
- { id: 'another-metabox', title: 'Another' },
114
+ {
115
+ id: 'my-metabox',
116
+ title: 'My Meta Box',
117
+ __rtc_compatible: true,
118
+ },
119
+ {
120
+ id: 'another-metabox',
121
+ title: 'Another',
122
+ __rtc_compatible: true,
123
+ },
118
124
  ],
119
- rtcCompatibleIds: [ 'my-metabox', 'another-metabox' ],
120
125
  } );
121
126
  const registry = createRegistry( mockStores );
122
127
 
@@ -129,10 +134,13 @@ describe( 'useMetaBoxInitialization', () => {
129
134
  it( 'disables collaboration when some metaboxes lack rtcCompatible', () => {
130
135
  const mockStores = createMockStores( {
131
136
  metaBoxes: [
132
- { id: 'compatible-metabox', title: 'Compatible' },
137
+ {
138
+ id: 'compatible-metabox',
139
+ title: 'Compatible',
140
+ __rtc_compatible: true,
141
+ },
133
142
  { id: 'incompatible-metabox', title: 'Incompatible' },
134
143
  ],
135
- rtcCompatibleIds: [ 'compatible-metabox' ],
136
144
  } );
137
145
  const registry = createRegistry( mockStores );
138
146
 
@@ -143,8 +151,13 @@ describe( 'useMetaBoxInitialization', () => {
143
151
 
144
152
  it( 'does not disable collaboration when the only metabox is rtcCompatible', () => {
145
153
  const mockStores = createMockStores( {
146
- metaBoxes: [ { id: 'compatible-metabox', title: 'Compatible' } ],
147
- rtcCompatibleIds: [ 'compatible-metabox' ],
154
+ metaBoxes: [
155
+ {
156
+ id: 'compatible-metabox',
157
+ title: 'Compatible',
158
+ __rtc_compatible: true,
159
+ },
160
+ ],
148
161
  } );
149
162
  const registry = createRegistry( mockStores );
150
163