-
-
Notifications
You must be signed in to change notification settings - Fork 342
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
Looks-Like-Enter heuristic in readDOMChange
produces wrong state
#1481
Comments
Is this some kind of widget you're displaying as part of a node view? If so, wouldn't just filtering out the DOM changes with And yes, the heuristic is still very much necessary. |
Thanks for the quick reply! You're right, I did further testing and noticed removing the heuristic introduces many other issues, anyway - not a solution. The issue is that I am dealing with nested custom elements via slots. Custom elements may contain other custom elements that way, so in turn, ProseMirror nodes are nested as well. Ignoring the changes was the first thing I tried, but this just leads to faulty editor states. Next I tried calculating the new node from the changed DOM, but that is just reinventing ProseMirror's wheel. For example, this may be a subtree: <webwriter-choice class="ww-widget ww-v0.0.1" contenteditable="" mode="single">
<p slot="prompt">What came first?</p>
<webwriter-choice-item class="ww-widget ww-v0.0.1" contenteditable=""><p>Chicken</p></webwriter-choice-item>
<webwriter-choice-item class="ww-widget ww-v0.0.1" contenteditable=""><p>Egg</p></webwriter-choice-item>
</webwriter-choice> Using the normal DOM methods, |
Arbitrary DOM manipulation within its content is not really a usage model ProseMirror supports, I'm afraid. |
A shame! I understand, though, it introduces a lot of cases to consider. I'll fork and experiment more to see if I can make it work for myself. Thanks anyway. :) |
If someone else encounters this, I worked around the issue. I wouldn't be surprised if this introduces more issues, but it works for my case so far. Simply:
ignoreMutation(mutation: MutationRecord) {
...
if(type === "childList") {
// re-parse the whole node, readDOMChange is from prosemirror-view/src/domchange.ts
readDOMChange(this.view, this.getPos(), this.getPos() + this.node.nodeSize, true, Array.from(mutation.addedNodes))
// Prevent the default handling
return true
}
...
} @marijnh It would only be handy if ignoreMutation(mutation: MutationRecord) {
...
if(type === "childList") {
return {start: this.getPos(), end: this.getPos() + this.node.nodeSize}
}
...
} |
Hello! I encountered a bug in the DOM observer logic. The setup: I have a custom element
webwriter-choice
(becoming a nodewebwriter_choice
) and an elementwebwriter-choice-item
(webwriter_choice_item
). Then, I have this logic onwebwriter-choice
:This works fine outside of ProseMirror. Inside a ProseMirror view, it breaks exactly when the selection is at the end of the previous item (see GIFs below).
I am sure the heuristic added in #175 is the problem. I specifically found that if I remove the heuristic, the issue doesn't occur at all. EDIT: Not true, see below.
With the heuristic
Without the heuristic
Possible solutions
The heuristic is from 2016 - is it still needed 8 years later? Otherwise, it might be worth improving since this is close to impossible to work around in user land (can't disable it, can't influence the DOM reading process).
Platform info
The text was updated successfully, but these errors were encountered: