Publish packages 🚀#614
Merged
Merged
Conversation
robin-drexler
approved these changes
May 8, 2026
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
This PR was opened by the Changesets release GitHub action. When you're ready to do a release, you can merge this and the packages will be published to npm automatically. If you're not ready to do a release yet, that's fine, whenever you add more changesets to main, this PR will be updated.
Releases
@remote-dom/core@1.11.1
Patch Changes
#611
f20f6e7Thanks @eddiechan! - Guard receivers against late mutations on detached nodesRemoteReceiverandSignalRemoteReceivernow dropinsertChild,removeChild,updateProperty, andupdateTextmutations whose target node is no longer in the receiver'sattachedmap, instead of throwing aTypeErrorwhile dereferencing the missing node.This race surfaces in production as unhandled promise rejections such as
TypeError: undefined is not an object (evaluating 'x.properties')(Safari) /TypeError: Cannot read properties of undefined (reading 'properties')(V8) when a remote sender dispatches a mutation for a node whose host-side state has just been removed (for example, aremoveChildfor an ancestor was processed earlier in the same batch, or arrived first from a separate batched payload).PR Make
removeChildin receivers less strict #533 previously added a similar guard toremoveChildfor the case where the child slot at a given index was empty, but did not handle the case where the parent itself was missing, and did not touchupdatePropertyorupdateText. This change applies the same defensive pattern uniformly to every connection callback that dereferencesattached.get(id).Late mutations targeting a detached subtree are by definition no-ops — there is nothing left to mutate.
@remote-dom/signals@2.1.1
Patch Changes
#611
f20f6e7Thanks @eddiechan! - Guard receivers against late mutations on detached nodesRemoteReceiverandSignalRemoteReceivernow dropinsertChild,removeChild,updateProperty, andupdateTextmutations whose target node is no longer in the receiver'sattachedmap, instead of throwing aTypeErrorwhile dereferencing the missing node.This race surfaces in production as unhandled promise rejections such as
TypeError: undefined is not an object (evaluating 'x.properties')(Safari) /TypeError: Cannot read properties of undefined (reading 'properties')(V8) when a remote sender dispatches a mutation for a node whose host-side state has just been removed (for example, aremoveChildfor an ancestor was processed earlier in the same batch, or arrived first from a separate batched payload).PR Make
removeChildin receivers less strict #533 previously added a similar guard toremoveChildfor the case where the child slot at a given index was empty, but did not handle the case where the parent itself was missing, and did not touchupdatePropertyorupdateText. This change applies the same defensive pattern uniformly to every connection callback that dereferencesattached.get(id).Late mutations targeting a detached subtree are by definition no-ops — there is nothing left to mutate.
Updated dependencies [
f20f6e7]:example-custom-element@0.0.26
Patch Changes
f20f6e7]:example-getting-started@0.0.26
Patch Changes
f20f6e7]:example-kitchen-sink@0.0.33
Patch Changes
f20f6e7]: