-
Notifications
You must be signed in to change notification settings - Fork 208
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
fix(overlay): returning only the first element for slot assignedElements #4930
base: main
Are you sure you want to change the base?
Conversation
We would like to see you use case here considering this is very specific. Can you add a video or a repro to show how does this solve your issue? |
@Rajdeepc Yes, I can add a video or we can do another debug session so I can walk threw it with you or you team? |
@Rajdeepc This is a video of the component not rendering. The component container stays blank and you can see the console output going forever. It will eventually crash the browser. Sequence.low.02.mp4 |
This seems to be a condition where the entire component is re-rendering multiple times due to state or property changes. Can you do a repro of your use case by any means? |
|
@Rajdeepc Express does use Service Workers but its still very resource heavy and I think its effecting the rendering of our component. We also use a lot of OverlayTriggers that might effect render changes also. |
@Rajdeepc This only happens in Express, it does not repo in our development at or any other environment that I know of. There maybe a late state change that is happening but its not from a map or any other iterator that I could find. I think its just a normal state change or its being delayed by the slag in the process. |
Pull Request Test Coverage Report for Build 12362748808Details
💛 - Coveralls |
5bb9e8b
to
38d3f0e
Compare
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.
Can you please make sure that the PR is clean from any css related changes on radio and search!
return slot.assignedElements({ flatten: true }) as HTMLElement[]; | ||
const nodes = slot.assignedNodes({ flatten: true }); | ||
return [ | ||
nodes.find((node) => node instanceof HTMLElement), |
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.
The changed implementation is different from what we used to deliver. This method will return on the instance of the first element. Whereas our prev implementation signified that we return all the elements. As you said there can be race condition happening on the express side and the Dialog is waiting for it to mount on page causing successive re-renders. nodes.find is a memory intensive implementation which works for you since it delays your render and the issue gets solved. But I don't feel this is a right approach to do this change on our side since there can be instances where the expected returned elements should be an array and not the first element.
A possible improvement: Adding a check or delay to ensure the slot is ready
private getAssignedElementsFromSlot(slot: HTMLSlotElement): HTMLElement[] {
const nodes = slot.assignedNodes({ flatten: true });
return nodes.filter((node): node is HTMLElement => node instanceof HTMLElement);
}
@zolar Also please check the tests which are failing in await waitUntil(() => {
const localName = (
this.el as unknown as { targetContent: HTMLElement }
).targetContent?.localName; |
Only return first element form
assignedElements
instead of an array of elements.Description
This PR reverses a helper method that was used in the previous version of the
OverLayTrigger
. In that version, theslotchange
handler usesassignedNodes
instead ofassignedElements
. I think usingassignedElements
renders the slot so fast, that our dialog component has not completed loading, leading to forcing a reload, in which it does goes threw the same process.spectrum-web-components/packages/overlay/src/OverlayTrigger.ts
Line 454 in a532ff8
Related issue(s)
[Bug]: OverlayTrigger can get stuck in a render loop causing page to crash
Motivation and context
Resolves an issue related to endless render loop.
How has this been tested?
Screenshots (if appropriate)
N/A
Types of changes
Checklist
Best practices
This repository uses conventional commit syntax for each commit message; note that the GitHub UI does not use this by default so be cautious when accepting suggested changes. Avoid the "Update branch" button on the pull request and opt instead for rebasing your branch against
main
.