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

DropZone context is lost between parent and child components during render #654

Closed
haidv1992 opened this issue Oct 12, 2024 · 1 comment
Closed

Comments

@haidv1992
Copy link

I'm facing an issue where the context from DropZoneProvider is not being properly passed down to the DropZoneRender component. Despite correctly wrapping the DropZone components with DropZoneProvider, the context becomes null or undefined at certain child components (specifically within Columns and Section), while it remains intact at higher levels, such as the Root component.

Steps to Reproduce:

  1. Wrap a DropZone inside a DropZoneProvider within the Root component.
  2. Use DropZone inside Columns (which is a part of the rendered content) with zones like column-0, column-1, etc.
  3. During render, the context logs correctly at the Root level but turns null or undefined inside DropZoneRender at the Columns level.

Expected Behavior:
The context from DropZoneProvider should be consistently available across all child components, especially inside DropZoneRender, without becoming null.

Actual Behavior:
The context is available at the Root component but turns null inside DropZoneRender when rendering specific columns inside Columns. The issue persists even after memoizing DropZoneProvider to reduce unnecessary re-renders.

Logs:

  1. At the Root level, the context is logged correctly:
    {
      "data": { ... },
      "config": { ... },
      "mode": "render"
    }
  2. However, inside DropZoneRender, the context becomes:
    {
      "ctx": null
    }

Things I have tried:

  • Memoizing DropZoneProvider using React.memo to prevent unnecessary re-renders.
  • Logging context values in every DropZoneProvider to check if they are being re-mounted or unmounted. (They are not.)
  • Ensuring that the key of each DropZoneProvider is stable and unique.

Code Example:

Here is a simplified version of the component structure:

<DropZoneProvider value={contextValue}>
  <Root>
    <DropZone zone={rootDroppableId} />
  </Root>
</DropZoneProvider>

<DropZoneProvider key={areaId} value={contextValue}>
  <Section>
    <DropZone zone={`column-0`} />
  </Section>
</DropZoneProvider>

Additional Info:

  • This issue occurs in one of my projects, but the same setup works fine in another project where DropZoneProvider passes context correctly.
  • I'm using React 18.3.0, and the issue persists even after updating dependencies.

Could this be related to React's context propagation or a potential conflict with useMemo/useState within DropZoneProvider? Any guidance or suggestions from the community would be greatly appreciated!


image

Environment:

  • React version: 18.3.0
  • Context API: React.createContext
  • Related Libraries: @measured/dnd, custom components (DropZone, Columns, etc.)
    i use version v0.16.1 and use demo to run

Feel free to tweak the details to better match your exact scenario!

@chrisvxd
Copy link
Member

chrisvxd commented Jan 3, 2025

Hey @haidv1992 - DropZone provider is a Puck internal and isn't part of the public API, so I'm not sure this is a bug. By the sounds of it, it seems you're trying to do this within the Puck repo, rather than in your own repo. Is that correct?

Regardless, #598 implemented a significant amount of rework of the DropZone API, and we are actively exploring a complete DropZone replacement as part of #255.

I'm going to close this as I don't expect it to be a public API issue, but please drop a comment if you'd like to discuss further!

@chrisvxd chrisvxd closed this as not planned Won't fix, can't repro, duplicate, stale Jan 3, 2025
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

No branches or pull requests

2 participants