-
-
Notifications
You must be signed in to change notification settings - Fork 344
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
Selection breaks while composition in iPad Safari + ShadowDOM #1498
Comments
Found a similar issue. #1455 |
In order to flip back the selection, I use this for workaround. appendTransaction(transactions, prevState, state) {
let shouldUpdateSel = false;
for (const tr of transactions) {
if (tr.getMeta('composition')) {
shouldUpdateSel = true;
break;
}
}
if (shouldUpdateSel) {
const { tr, doc, selection } = state;
const { from, to } = selection;
return tr.setSelection(TextSelection.create(doc, from, to));
}
} |
And that is correct—the position after the text node and the position at the end of the text node are the same cursor position. Do you think the position reported by the browser doesn't match the selection at this point? |
No, I don't think what browser reports is wrong. I think maybe the flip when the positions are equivalent doesn't work properly for composition? I compared the behaviour between the non-ShadowDOM scenario and the ShadowDOM scenario. Following the same reproducible steps, I printed In the non-ShadowDOM scenario, when I pressed But in the ShadowDOM scenario, when I pressed |
FIX: Fix an issue on Safari where the (incorrect) top-level selection was used, instead of the workaround that also works inside shadow roots. Issue ProseMirror/prosemirror#1455 Issue ProseMirror/prosemirror#1498
I think I found the issue. I don't think it really was at the place you point at, though indeed, turning off that check accidentally makes it behave a bit better. Attached patch should be more robust though. Could you give it a try? |
Issue
Minimal example: https://siubaak.github.io/siudnote/pmbug
Minimal code: https://github.com/Siubaak/siubaak.github.io/blob/master/siudnote/pmbug.html
I've built a ProseMirror editor mounted at a shadow dom. It works great in all platforms except iPad Safari. When composing a Chinese input, selection will automatically wrap the whole input in iPad Safari.
And I digged a litte bit into prosemirror-view. I found that, when I'm inputing,
flush
will be called due to composition events, dom mutations, selection changed or whatever. It doesn't matter. Then, insideflush
, it will get current selection byview.domSelectionRange()
. Because of the true condition in this scenario by checkingsafari && this.root.nodeType === 11
,safariShadowSelectionRange
will be called eventually. InsidesafariShadowSelectionRange
,selection.getComposedRanges
will be called since we're right now inside a shadow root in Safari, andrangeToSelectionRange
will also be called for transforming the result ofselection.getComposedRanges
to a valid selection range.Here's the point. I think
data:image/s3,"s3://crabby-images/29f4c/29f4c119dd5393cf6b8dab13943a3aad6b31d769" alt="image"
isEquivalentPosition
insiderangeToSelectionRange
is where the problem occurs in. Let me explain further.Reproducing
At the beginning, I press
data:image/s3,"s3://crabby-images/3cbc5/3cbc5dd405326187a6f11ec053793393f0939ec6" alt="image"
n
, thenisEquivalentPosition
will be called with parameters<section>n</section>, 0, #text n, 1
. The result will befalse
. Fair enough.Then, I press
data:image/s3,"s3://crabby-images/45549/45549422a656485b1d447e989fa0ea84ddd2e4f5" alt="image"
h
and something seems to be wrong.isEquivalentPosition
will be called with parameters<section>n h</section>, 1, #text n h, 3
. The result will betrue
, so the anchor and the focus will get swapped from[0, 3]
to[3, 0]
, which next will make the selection wrap the whole input.After that, no matter what I input,
data:image/s3,"s3://crabby-images/1b316/1b31608e9d6c81cc5a1d5881bed3d5733de0a408" alt="image"
isEquivalentPosition
will be called with parameters<section>anything</section>, 1, #text anything, n
. The result will remaintrue
constantly, then the anchor and the focus will get swapped from[0, n]
to[n, 0]
. The selection will keep wrapping what I input in this composition. Even thoughcompositionend
occurs, this selection still wrap the whole input.What I tried
Since if I don't mount the editor inside a shadow dom, the editor works totally fine. I think it is because of the mistaken swap, so I tried to comment out the
isEquivalentPosition
clause inrangeToSelectionRange
, to prevent the swap. Everything works fine again while composition. I don't think it's a good idea to comment it out, though. So I decided to report this issue here.Anyway, ProseMirror is a wonderful lib to build a editor. I really appreciate what you have done. :)
The text was updated successfully, but these errors were encountered: