Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[editable] Fix Memory Leak when switching between focused editables (#…
…5542) * [editable] Fix Memory Leak when switching between focused editable containers I've found a memory leak in Slate React where-in when you'd switch between two pages, each with their own editor instance, auto-focusing on these elements causes a memory leak, where there would be a lot of Detached HTML Element's just floating around. At first I thought it a bunch of different bugs with chromium, but noticed that when I force removed the input elements from the dom before the component would unmount, we would still see small leak referencing "latestElement" (while simultaniously, I would still the element & children references in the `IN_FOCUSE` WeakMap) Looking at editable's code, I realized that we're storing state in a weird way, directly mutating it using `useMemo`, and React isn't removing all references (probably because its still stored in the WeakMap. The simple fix for this is what I've commited; using `useLayoutEffect`, we forcably remove the `latestElement` and references to it. * Update editable.tsx * Add changeset --------- Co-authored-by: Dylan Schiemann <[email protected]>
- Loading branch information