-
Notifications
You must be signed in to change notification settings - Fork 4.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Navigation Editor: Allow menu renaming #29012
Merged
Merged
Changes from 8 commits
Commits
Show all changes
23 commits
Select commit
Hold shift + click to select a range
3ebd509
feature to change navigation menu name
b5ee729
name editor component added
d3ce125
add missing styles|
2295c5a
remove doubled hooks
19ea70c
remove ;
2f0531f
navigation post variable updated
2b55320
use-menu-locations hook moved to hooks directory
416f946
console error fixed
e6b0992
name edition moved to the sidebar. In toolbar manu name changed to bu…
e724897
move NameEditor to InspectorControls in InspectorAdditions in order t…
bec25b5
use TextControl component in name-editor
1c8a9a2
changes according to CR
0a90dda
add missing file
bbfbff1
changes according to CR: removed aria-label from name-display/index.j…
4073eda
Dispatch save requests sequentially instead of in parallel
talldan fcdab0a
explicitly set () => setIsMenuNameEditFocused( true )
e6415be
add translation to the file
2dfb3ad
resolved conflicts with trunk
d3cb3df
resolved conflicts with trunk 2
cd98168
Merge branch 'trunk' into add/navigation-menu-name-editor
grzim 00561eb
sprintf added
98dc6a0
Merge branch 'add/navigation-menu-name-editor' of github.com:WordPres…
2f53f2f
Update unit test to take into account the call to saveEditedEntityRecord
talldan File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
35 changes: 35 additions & 0 deletions
35
packages/edit-navigation/src/components/name-editor/index.js
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,35 @@ | ||
/** | ||
* WordPress dependencies | ||
*/ | ||
import { __ } from '@wordpress/i18n'; | ||
import { useEffect, useState } from '@wordpress/element'; | ||
/** | ||
* Internal dependencies | ||
*/ | ||
import { BlockControls } from '@wordpress/block-editor'; | ||
import { ToolbarGroup, ToolbarItem } from '@wordpress/components'; | ||
import { useMenuEntity, useNavigationEditorMenu } from '../../hooks'; | ||
|
||
export function NameEditor() { | ||
const { menuName, menuId } = useNavigationEditorMenu(); | ||
const { editMenuName } = useMenuEntity( menuId ); | ||
talldan marked this conversation as resolved.
Show resolved
Hide resolved
|
||
const [ tmpMenuName, setTmpMenuName ] = useState( menuName ); | ||
grzim marked this conversation as resolved.
Show resolved
Hide resolved
|
||
useEffect( () => setTmpMenuName( menuName ), [ menuName ] ); | ||
return ( | ||
<> | ||
<BlockControls> | ||
draganescu marked this conversation as resolved.
Show resolved
Hide resolved
|
||
<ToolbarGroup> | ||
<ToolbarItem | ||
as="input" | ||
value={ tmpMenuName } | ||
onChange={ ( { target: { value } } ) => { | ||
setTmpMenuName( value ); | ||
editMenuName( value ); | ||
} } | ||
aria-label={ __( 'Edit menu name' ) } | ||
/> | ||
</ToolbarGroup> | ||
</BlockControls> | ||
</> | ||
); | ||
} |
33 changes: 33 additions & 0 deletions
33
packages/edit-navigation/src/filters/add-menu-name-editor.js
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,33 @@ | ||
/** | ||
* WordPress dependencies | ||
*/ | ||
/** | ||
* Internal dependencies | ||
*/ | ||
import { NameEditor } from '../components/name-editor'; | ||
import { addFilter } from '@wordpress/hooks'; | ||
import { createHigherOrderComponent } from '@wordpress/compose'; | ||
import { useNavigationEditor } from '../hooks'; | ||
|
||
const addMenuNameEditor = createHigherOrderComponent( | ||
( BlockEdit ) => ( props ) => { | ||
if ( props.name !== 'core/navigation' ) { | ||
return <BlockEdit { ...props } />; | ||
} | ||
const { menuName } = useNavigationEditor(); | ||
return ( | ||
<> | ||
<BlockEdit { ...props } menuName={ menuName } /> | ||
<NameEditor { ...props } /> | ||
</> | ||
); | ||
}, | ||
'withMenuName' | ||
); | ||
|
||
export default () => | ||
addFilter( | ||
'editor.BlockEdit', | ||
'core/edit-navigation/with-menu-name', | ||
addMenuNameEditor | ||
); |
22 changes: 22 additions & 0 deletions
22
packages/edit-navigation/src/filters/disable-inserting-non-navigation-blocks.js
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
/** | ||
* WordPress dependencies | ||
*/ | ||
import { addFilter } from '@wordpress/hooks'; | ||
/** | ||
* External dependencies | ||
*/ | ||
import { set } from 'lodash'; | ||
|
||
function disableInsertingNonNavigationBlocks( settings, name ) { | ||
if ( ! [ 'core/navigation', 'core/navigation-link' ].includes( name ) ) { | ||
set( settings, [ 'supports', 'inserter' ], false ); | ||
} | ||
return settings; | ||
} | ||
|
||
export default () => | ||
addFilter( | ||
'blocks.registerBlockType', | ||
'core/edit-navigation/disable-inserting-non-navigation-blocks', | ||
disableInsertingNonNavigationBlocks | ||
); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
/** | ||
* Internal dependencies | ||
*/ | ||
import addMenuNameEditor from './add-menu-name-editor'; | ||
import disableInsertingNonNavigationBlocks from './disable-inserting-non-navigation-blocks'; | ||
import removeEditUnsupportedFeatures from './remove-edit-unsupported-features'; | ||
import removeSettingsUnsupportedFeatures from './remove-settings-unsupported-features'; | ||
|
||
export const addFilters = ( | ||
shouldAddDisableInsertingNonNavigationBlocksFilter | ||
) => { | ||
addMenuNameEditor(); | ||
if ( shouldAddDisableInsertingNonNavigationBlocksFilter ) { | ||
disableInsertingNonNavigationBlocks(); | ||
} | ||
removeEditUnsupportedFeatures(); | ||
removeSettingsUnsupportedFeatures(); | ||
}; |
30 changes: 30 additions & 0 deletions
30
packages/edit-navigation/src/filters/remove-edit-unsupported-features.js
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
/** | ||
* WordPress dependencies | ||
*/ | ||
import { addFilter } from '@wordpress/hooks'; | ||
import { createHigherOrderComponent } from '@wordpress/compose'; | ||
|
||
const removeNavigationBlockEditUnsupportedFeatures = createHigherOrderComponent( | ||
( BlockEdit ) => ( props ) => { | ||
if ( props.name !== 'core/navigation' ) { | ||
return <BlockEdit { ...props } />; | ||
} | ||
|
||
return ( | ||
<BlockEdit | ||
{ ...props } | ||
hasSubmenuIndicatorSetting={ false } | ||
hasItemJustificationControls={ false } | ||
hasListViewModal={ false } | ||
/> | ||
); | ||
}, | ||
'removeNavigationBlockEditUnsupportedFeatures' | ||
); | ||
|
||
export default () => | ||
addFilter( | ||
'editor.BlockEdit', | ||
'core/edit-navigation/remove-navigation-block-edit-unsupported-features', | ||
removeNavigationBlockEditUnsupportedFeatures | ||
); |
28 changes: 28 additions & 0 deletions
28
packages/edit-navigation/src/filters/remove-settings-unsupported-features.js
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,28 @@ | ||
/** | ||
* WordPress dependencies | ||
*/ | ||
import { addFilter } from '@wordpress/hooks'; | ||
|
||
function removeNavigationBlockSettingsUnsupportedFeatures( settings, name ) { | ||
if ( name !== 'core/navigation' ) { | ||
return settings; | ||
} | ||
|
||
return { | ||
...settings, | ||
supports: { | ||
customClassName: false, | ||
html: false, | ||
inserter: true, | ||
}, | ||
// Remove any block variations. | ||
variations: undefined, | ||
}; | ||
} | ||
|
||
export default () => | ||
addFilter( | ||
'blocks.registerBlockType', | ||
'core/edit-navigation/remove-navigation-block-settings-unsupported-features', | ||
removeNavigationBlockSettingsUnsupportedFeatures | ||
); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
/** | ||
* WordPress dependencies | ||
*/ | ||
import { __ } from '@wordpress/i18n'; | ||
import { createContext } from '@wordpress/element'; | ||
|
||
export const untitledMenu = __( '(untitled menu)' ); | ||
export const MenuIdContext = createContext(); | ||
|
||
export { default as useMenuEntity } from './use-menu-entity'; | ||
export { default as useNavigationEditor } from './use-navigation-editor'; | ||
export { default as useNavigationBlockEditor } from './use-navigation-block-editor'; | ||
export { default as useMenuNotifications } from './use-menu-notifications'; | ||
export { default as useNavigationEditorMenu } from './use-navigation-editor-menu'; | ||
export { default as useMenuLocations } from './use-menu-locations'; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,35 @@ | ||
/** | ||
* WordPress dependencies | ||
*/ | ||
import { useSelect, useDispatch } from '@wordpress/data'; | ||
/** | ||
* Internal dependencies | ||
*/ | ||
import { MENU_KIND, MENU_POST_TYPE } from '../utils/constants'; | ||
|
||
import { untitledMenu } from './index'; | ||
|
||
export default function useMenuEntity( menuId ) { | ||
const { editEntityRecord, saveEditedEntityRecord } = useDispatch( 'core' ); | ||
|
||
const menuEntityData = [ MENU_KIND, MENU_POST_TYPE, menuId ]; | ||
const editedMenu = useSelect( | ||
( select ) => | ||
menuId && | ||
select( 'core' ).getEditedEntityRecord( ...menuEntityData ), | ||
[ menuId ] | ||
); | ||
|
||
const editedMenuName = menuId && editedMenu.name; | ||
|
||
const saveMenuName = () => | ||
editedMenuName && saveEditedEntityRecord( ...menuEntityData ); | ||
|
||
const editMenuName = ( name = untitledMenu ) => | ||
editEntityRecord( ...menuEntityData, { name } ); | ||
|
||
return { | ||
saveMenuName, | ||
editMenuName, | ||
}; | ||
} |
File renamed without changes.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I didn't anticipate this, but both these lines result in the menu being saved.
saveNavigationPost
saves the menu via the customizer API (because the REST API doesn't quite work yet for saving menu items).I'd be worried about race conditions here.
This is some technical debt, so not really something caused by your PR.
I don't have a solution available right now, will have to have a think about it.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
what is the edge case when the race condition could really happen?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm worried that one request might overwrite the other, since both API requests can modify the same database record.
I think the easiest solution right now would be to make sure the requests happen sequentially. This could be done by moving the
saveEditedEntityRecord
dispatch to be inside thesaveNavigationPost
action. Should be able to dispatch it with code like this, where theyield
will wait for the request to complete before triggering the second request (the call tobatchSave
):This makes sense actually, as it means the on-screen notices that are implemented in
saveNavigationPost
can be made so that the visible notices associated with saving are displayed at the right time.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Some further background. The way saving menus currently works is a temporary thing. Currently the
batchSave
function has been patched to use an endpoint that is currently used by the Customize > Menus screen. But that isn't part of the REST API, and not something we want to support long into the future for the navigation editor.Ideally the whole system would use the WordPress REST APIs and the core-data package's entities. There are two things that need to happen: