Skip to content

Commit

Permalink
[lexical-react][lexical-playground] Bug Fix: Workaround for yjs disco…
Browse files Browse the repository at this point in the history
…nnect race in React StrictMode (#6644)
  • Loading branch information
etrepum authored Sep 19, 2024
1 parent fc8cf09 commit deb5894
Showing 1 changed file with 21 additions and 14 deletions.
35 changes: 21 additions & 14 deletions packages/lexical-react/src/shared/useYjsCollaboration.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -155,9 +155,18 @@ export function useYjsCollaboration(

return () => {
if (isReloadingDoc.current === false) {
Promise.resolve(connectionPromise).then(() => {
if (connectionPromise) {
connectionPromise.then(disconnect);
} else {
// Workaround for race condition in StrictMode. It's possible there
// is a different race for the above case where connect returns a
// promise, but we don't have an example of that in-repo.
// It's possible that there is a similar issue with
// TOGGLE_CONNECT_COMMAND below when the provider connect returns a
// promise.
// https://github.com/facebook/lexical/issues/6640
disconnect();
});
}
}

provider.off('sync', onSync);
Expand Down Expand Up @@ -198,18 +207,16 @@ export function useYjsCollaboration(
return editor.registerCommand(
TOGGLE_CONNECT_COMMAND,
(payload) => {
if (connect !== undefined && disconnect !== undefined) {
const shouldConnect = payload;

if (shouldConnect) {
// eslint-disable-next-line no-console
console.log('Collaboration connected!');
connect();
} else {
// eslint-disable-next-line no-console
console.log('Collaboration disconnected!');
disconnect();
}
const shouldConnect = payload;

if (shouldConnect) {
// eslint-disable-next-line no-console
console.log('Collaboration connected!');
connect();
} else {
// eslint-disable-next-line no-console
console.log('Collaboration disconnected!');
disconnect();
}

return true;
Expand Down

0 comments on commit deb5894

Please sign in to comment.