Skip to content
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

Fixed Navigation: Create new Menu produces a warning in the console stating misuse of refs #68578

Open
wants to merge 1 commit into
base: trunk
Choose a base branch
from

Conversation

Mayank-Tripathi32
Copy link
Contributor

fixes #68572

What?

Fix console warning about ref handling when creating a new menu from Navigation block's Block Panel in site editor

Why?

When creating a new menu from the Navigation block's Block Panel, a warning appears in the developer console: "Function components cannot be given refs". This warning occurs because the Disabled component, being a function component, cannot directly handle refs. This needs to be fixed to maintain a clean developer experience and proper component behavior.

How?

Modified the UnsavedInnerBlocks component to properly handle refs by:

  • Ensuring the ref from innerBlocksProps is passed to a DOM element (div) instead of the Disabled component
  • Wrapping the div with Disabled component when isSaving is true
  • Maintaining all other props and functionality from innerBlocksProps

Related React Issue

reactjs/react.dev#2120

Testing Instructions

  1. Navigate to the Site Editor
  2. Add a Navigation block
  3. Open the Block Panel (sidebar settings)
  4. Click the three dots menu
  5. Click "Create new Menu"
  6. Verify no warnings appear in the developer console
  7. Verify the menu creation functionality works as expected
  8. Verify the block's disabled state works correctly during saving

ScreenCast

TEST.NAVIGATION.CONSOLE.mp4

Copy link

github-actions bot commented Jan 9, 2025

Warning: Type of PR label mismatch

To merge this PR, it requires exactly 1 label indicating the type of PR. Other labels are optional and not being checked here.

  • Type-related labels to choose from: [Type] Automated Testing, [Type] Breaking Change, [Type] Bug, [Type] Build Tooling, [Type] Code Quality, [Type] Copy, [Type] Developer Documentation, [Type] Enhancement, [Type] Experimental, [Type] Feature, [Type] New API, [Type] Task, [Type] Technical Prototype, [Type] Performance, [Type] Project Management, [Type] Regression, [Type] Security, [Type] WP Core Ticket, Backport from WordPress Core, Gutenberg Plugin.
  • Labels found: .

Read more about Type labels in Gutenberg. Don't worry if you don't have the required permissions to add labels; the PR reviewer should be able to help with the task.

Copy link

github-actions bot commented Jan 9, 2025

The following accounts have interacted with this PR and/or linked issues. I will continue to update these lists as activity occurs. You can also manually ask me to refresh this list by adding the props-bot label.

If you're merging code through a pull request on GitHub, copy and paste the following into the bottom of the merge commit message.

Co-authored-by: Mayank-Tripathi32 <[email protected]>
Co-authored-by: yogeshbhutkar <[email protected]>

To understand the WordPress project's expectations around crediting contributors, please review the Contributor Attribution page in the Core Handbook.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Navigation: Create new Menu produces a warning in the console stating misuse of refs
1 participant