You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
The overlay kit provider seems to behave differently than other libraries. Is this intended behavior?
Detail
I realized that the following actions were needed in the test code to test the operation of overlay-kit.
afterEach(()=>{overlay.unmountAll();});
The reason this is necessary is because the OverlayProvider is separate from the elements mounted in the actual DOM.
Therefore, in most cases providing different OverlayProviders for individual tests does not make sense from the perspective of making the tests independent.
constwrapper=({ children }: PropsWithChildren)=><OverlayProvider>{children}</OverlayProvider>;
However, libraries such as jotai can guarantee test independence by providing different providers.
import{ProviderasJotaiProvider}from'jotai'constwrapper=({ children }: PropsWithChildren)=><JotaiProvider>{children}</JotaiProvider>;
Personally, I think jotai's approach is closer to the provider role that users expect.
My Opinion
If this is the intended design, it would be good to provide documentation on how to test with overlay-kit.
If this wasn't intended, I think we need to think about how to do it.
I'm curious about your opinion,
Thank you for making a great library thanks! 🙂
The text was updated successfully, but these errors were encountered:
Hello, and thank you for your interest and questions regarding overlay-kit.
You’re correct in noting that OverlayProviders are not intended to operate independently. The primary purpose of this component is to store state in a ContextAPI Provider and to render overlays alongside children.
This design choice was made with the intent for OverlayProviders to function as a singleton, under the assumption that there wouldn’t be a scenario where OverlayProviders would need to unmount in a service context. However, this overlooks scenarios involving mocking during testing, where OverlayProviders might indeed unmount.
To address this, we will make changes so that overlay.unmountAll() is called automatically when OverlayProviders unmount.
Summery
The overlay kit provider seems to behave differently than other libraries. Is this intended behavior?
Detail
I realized that the following actions were needed in the test code to test the operation of overlay-kit.
The reason this is necessary is because the OverlayProvider is separate from the elements mounted in the actual DOM.
Therefore, in most cases providing different OverlayProviders for individual tests does not make sense from the perspective of making the tests independent.
However, libraries such as jotai can guarantee test independence by providing different providers.
Personally, I think jotai's approach is closer to the provider role that users expect.
My Opinion
If this is the intended design, it would be good to provide documentation on how to test with overlay-kit.
If this wasn't intended, I think we need to think about how to do it.
I'm curious about your opinion,
Thank you for making a great library thanks! 🙂
The text was updated successfully, but these errors were encountered: