slate
slate copied to clipboard
Chrome 105 breaks slate 0.27.x
Description Our application (an electronic health record) uses slate in production; versions:
"slate": "0.27.4",
"slate-auto-replace": "0.8.1",
"slate-react": "0.7.2",
The update to Chrome 105 now rolling out breaks the ability for slate to find a DOM point, it looks like.

In the above screenshot you can see that leaf will be null as end
is zero and point.offset
is 2, meaning the condition of end >= point.offset
will never be satisfied.
I realize we're on an old version of slate but if there's a known fix for Chrome 105 issues or a link to crbug for whatever the regression is there we would be very grateful.
Recording Will follow up with a GIF.
Environment
- Slate Version: 0.27.4
- Operating System: macOS
- Browser: Chrome 105
Sorry in advance for the stream of consciousness as I debug this...
I removed the placeholder
key from our Editor
component. Typing the first character results in a point
with an offset
of 1
.
node.getLeaves()
returns a list of 1 leaf, and that leaf has a text
attribute of ''
, which has length
of 0
.
Because of this leaves.find(...)
does not return a leaf (it's looking for the leaf that is equal to or after the point
).
I think we can infer that something in Chrome 105 changed the point findPoint
is returning? I will try to verify exactly what is returned on Chrome < 105.
Interesting, prior to Chrome 105 onInput
never triggers, only onBeforeInput
does. The code that fails is not called in our workflow prior to Chrome 105.
Chrome 104:

vs. Chrome 105 (the traceback happens immediately after the last line):

Realized I never included the traceback above:
I'm also experiencing some critical issues in Chrome 105 that I've never seen before 105 release, using immutable.js based version of SlateJS editor ([email protected]
+ [email protected]
)
https://codesandbox.io/s/cfdps
- Try to type some word in empty editor, then move caret somewhere in the middle of your word and type some one char - your char will be added, but caret will be moved to the end of current text node, so it's impossible even to type a few chars in a row in the middle of any text node w/o caret jumping to the end.
- Try to press
Enter/Return
a few times to make a few empty paragraphs in your editor, then type just one char in any of your empty paragraph and after that try to press Backspace to remove your last char in your last typed char - it will not be deleted, because your just deletedZWNBSP
char that was added after your first char in paragraph. Slate usesZWNBPS
to make it possible to put caret into an empty paragraph, so it seems that just after you typed your first char in an empty paragraph, theZWNBSP
also added after your char. - Try to type some one char in the empty editor with placeholder. Instead your placeholder hidden and just one char added into editor, the placeholder text will be added at first, followed by your char and then
ZWNBSP
also added as the last character, that is really strange.
I don't think it's the complete list of issues described above, just ones that I was able to reproduce and describe, so the Slate-based editor's behaviour is completely broken in Chrome 105.
None of these issues, described above, have ever been reproduced before, neither in any Chrome version prior 105 nor in any other browsers (Safari on macOS, Safari on iOS, FF on any OS, etc.).
@beaugunderson
OMG! I can't believe that all the issues in Chrome 105 described in my previous comment here were because of style WebkitUserModify: 'read-write-plaintext-only'
on contentEditable
container.
After some deep investigation, I realized that event.getTargetRanges()
returns an empty array in onBeforeInput
handler in after
plugin when that WebkitUserModify
style applied. In this case onBeforeInput
handler returns and does nothing, so that you can see onInput
event handler works instead as a fallback that leads to some unexpected behaviour in my cases.
Please check it out for your case - it might be the root of the issue you are experiencing.
it's related to #5108 no?
it's related to #5108 no?
https://github.com/ianstormtaylor/slate/issues/5108#issuecomment-1235137908
@beaugunderson
OMG! I can't believe that all the issues in Chrome 105 described in my previous comment here were because of style
WebkitUserModify: 'read-write-plaintext-only'
oncontentEditable
container.After some deep investigation, I realized that
event.getTargetRanges()
returns an empty array inonBeforeInput
handler inafter
plugin when thatWebkitUserModify
style applied. In this caseonBeforeInput
handler returns and does nothing, so that you can seeonInput
event handler works instead as a fallback that leads to some unexpected behaviour in my cases.Please check it out for your case - it might be the root of the issue you are experiencing.
Hi @zarv1k. We're experiencing the exact same problems that you mentioned in the previous comment. And changing the style on contentEditable
from WebkitUserModify: 'read-write-plaintext-only'
to WebkitUserModify: 'read-write'
fix every issue we got so far.
I'm wondering if this is the best workaround for now, or do you have a better way to solve this?
@beaugunderson
OMG! I can't believe that all the issues in Chrome 105 described in my previous comment here were because of style
WebkitUserModify: 'read-write-plaintext-only'
oncontentEditable
container.After some deep investigation, I realized that
event.getTargetRanges()
returns an empty array inonBeforeInput
handler inafter
plugin when thatWebkitUserModify
style applied. In this caseonBeforeInput
handler returns and does nothing, so that you can seeonInput
event handler works instead as a fallback that leads to some unexpected behaviour in my cases.Please check it out for your case - it might be the root of the issue you are experiencing.
Hi @zarv1k. We're experiencing the exact same problems that you mentioned in the previous comment. And changing the style on
contentEditable
fromWebkitUserModify: 'read-write-plaintext-only'
toWebkitUserModify: 'read-write'
fix every issue we got so far.I'm wondering if this is the best workaround for now, or do you have a better way to solve this?
According to comment in sources this style was added just to hide b/i/u menu on iOS (it also disables the same menu items in context menu Font -> Bold etc... on Safari desktop). I'm not sure about Chrome mobile (has no device to check), but you definitely could remove this style completely for Chrome desktop
Note this does not appear to be an issue with any recent versions of Slate, only with versions released more than 3 years ago. We'll leave this open so you can sort through it, but Slate won't be releasing an update to a version this far back.
Just want to add that it's also happening on 0.47.8
. So it might be any versions before v0.50+
.
Just want to add that it's also happening on
0.47.8
. So it might be any versions beforev0.50+
.
FWIW, anything before 0.59 is ~2.5 to 3 years old at this point.
FWIW, anything before 0.59 is ~2.5 to 3 years old at this point.
Point definitely taken :) I appreciate you leaving this open so people still on the old versions can figure out a workaround until we can upgrade (or more likely rewrite in our case since so much has changed) 🙏
Hi thanks for this thread, it's very helpful :) Any new workaround found ? We're experiencing big issues on our side as well, especially on production builds (Slate 0.47)
@ThomasEsseul Why some another workaround needed? Didn't this help you? - https://github.com/ianstormtaylor/slate/issues/5110#issuecomment-1235150979
I have no issues in Chrome 105 using Slate 0.47.8 after I removed WebkitUserModify: 'read-write-plaintext-only'
completely. But I kept it for Safari iOS, Chrome Mobile on iOS and Safari on Mac, coz it hides BIU
in context menu which doesn't work in sync with Slate.
@zarv1k It does help yes ! I was just wondering if there were any new informations on this. I think I will go for this solution then, thanks :)
We have same problem with version:
- slate 0.44.22
- slate-react 0.21.23
We have some schema validation as below:
// common schema validation for cloud nodes
const createCloudValidation = nodeType => ({
// check if cloud node text
// has whitespace at the beginning and the end
text: txt => {
const isFirstCharValid = txt[0] === ' ';
const isLastCharValid = txt.slice(-1) === ' ';
const isLengthValid = txt.length > 1;
return isFirstCharValid && isLastCharValid && isLengthValid;
},
normalize: (editor, { code, node }) => {
const nodeText = node.text;
if (code === 'node_text_invalid') {
if (nodeText.length === 1) {
editor.unwrapInline(nodeType);
return;
}
const isFirstCharValid = nodeText[0] === ' ';
if (!isFirstCharValid) {
// find first text node
const firstTextNode = node.getFirstText();
// append space on the beginning of text
editor.insertTextByKey(firstTextNode.key, 0, ' ');
return;
}
const isLastCharValid = nodeText.slice(-1) === ' ';
if (!isLastCharValid) {
// find last text node
const lastTextNode = node.getLastText();
const textLength = lastTextNode.text.length;
// append space on the end of text
editor.insertTextByKey(lastTextNode.key, textLength, ' ').moveBackward();
}
}
},
});
Firstly, when we add node with 'cloud' type everything works great, but when i want to change text inside, text goes at beginning of whole document and node disappear. While debugging i noticed that text method of validator is called twice - first call with empty string, second call with actual content so validator fail.
If i removed unwrapInline, all works seems to works great but validation fire twice so every typed char it added me spaces at end... ;d
I think we should plan complety rewrite editor to latest version 😄
My team found that in previous versions of Chrome (before 105), the event fired was actually a React synthetic event. We spent a while trying to debug what changed with event.getTargetRanges()
but ultimately what changed is that we were calling that function at all.
We quickly fixed our prod issues by, for now, forking our version of slate and returning early if we are in in Chromium 105+, but we may explore the WebkitUserModify fix as well.
My team published a hotfix with the WebkitUserModify solution, it seems to work fine ! But we have some users (Mac + Chrome 105+ users only) who experience problems when typing some specific special characters (i.e. ê, â, ï, ô... 🥖). Did anyone hear about such a case on their side ?
@beaugunderson
OMG! I can't believe that all the issues in Chrome 105 described in my previous comment here were because of style
WebkitUserModify: 'read-write-plaintext-only'
oncontentEditable
container.
Thank you.
Code like this works for me:
#editor-id:not(.disabled) { -webkit-user-modify: read-write; }
Back from out of internet range and can confirm that the -webkit-user-modify
fix does work for us as well. Thank you everyone for chiming in with help. 🙏
Just chiming in - my team is at the tail end of a rewrite on the latest and greatest, but our production app is facing this issue as well.
"slate": "npm:slate@^0.39.3",
"slate-react": "npm:slate-react@^0.17.3",
So far, the WebkitUserModify
isn't working for us at all. Now I'm trying to explore the package resolution workaround suggested in the other open issue.
So far, the WebkitUserModify isn't working for us at all. Now I'm trying to explore the package resolution workaround suggested in https://github.com/ianstormtaylor/slate/issues/5108.
The fix to resolve to an earlier version of slate-dev-environment
worked for us 🚀
"resolutions": {
"slate-dev-environment": "0.1.4"
},
It seems like between the two workarounds mentioned in this issue, everyone should be able to workaround this issue.
Is anyone not able to get their editor working with the provided workarounds?
@ThomasEsseul Why some another workaround needed? Didn't this help you? - #5110 (comment)
I have no issues in Chrome 105 using Slate 0.47.8 after I removed
WebkitUserModify: 'read-write-plaintext-only'
completely. But I kept it for Safari iOS, Chrome Mobile on iOS and Safari on Mac, coz it hidesBIU
in context menu which doesn't work in sync with Slate.
Thank you for pointing this out. I was seeing the following bugs on slate 0.47
- cursor jumps to the end of a line when I attempt to insert text in the middle of the line
- bold, italics, subscript and superscript aren't working with the textbox
- placeholder text (greyed out) became real text when you clicked on it.
But now they are fixed, and I used the following modification:
...(readOnly || (!IS_IOS && !IS_SAFARI) ? {} : { WebkitUserModify: 'read-write-plaintext-only' }),
(line 600 of slate-react/src/components/content.js)
As well as importing
IS_IOS, IS_SAFARI,
(line 13 and 14)
Hope that helps someone.
If you want a CSS only solution to targeting Blink-based browsers (i.e. not Safari), you can use:
@supports not (-apple-trailing-word: inherit) {
div[data-slate-editor] {
-webkit-user-modify: read-write !important;
}
}
@ThomasEsseul
My team published a hotfix with the WebkitUserModify solution, it seems to work fine ! But we have some users (Mac + Chrome 105+ users only) who experience problems when typing some specific special characters (i.e. ê, â, ï, ô... 🥖). Did anyone hear about such a case on their side ?
Yes, we meet the exact same problem with ê, â ... characters.
@Slapbox
Is anyone not able to get their editor working with the provided workarounds?
We applied the -webkit-user-modify
fix but still have problems with accented characters.
Does anyone knows a fix around this particular issue?
@bobey did you try forcing resolution of slate-dev-environment
to an older version as mentioned by @CodyJamesCasey?
Note that the syntax @CodyJamesCasey provided is for yarn
, but this can be achieved with npm
/pnpm
as well with the correct syntax.
@bobey did you try forcing resolution of
slate-dev-environment
to an older version as mentioned by @CodyJamesCasey?Note that the syntax @CodyJamesCasey provided is for
yarn
, but this can be achieved withnpm
/pnpm
as well with the correct syntax.
Hi @Slapbox, thanks for your help on this. I tried indeed but I get a compilation error as my slate version seems to try loading a constant which is not exported anymore:
./.yarn/__virtual__/slate-react-virtual-956c00d07a/0/cache/slate-react-npm-0.22.4-d1696dbb04-f463ef2279.zip/node_modules/slate-react/lib/slate-react.es.js
Attempted import error: 'ANDROID_API_VERSION' is not exported from 'slate-dev-environment'.
Am I missing something here?
We're using the following versions ATM:
{
"dependencies": {
"slate": "0.47.4",
"slate-html-serializer": "0.8.6",
"slate-plain-serializer": "0.7.6",
"slate-react": "0.22.4",
"...": "..."
},
"resolutions": {
"slate-dev-environment": "0.1.6"
}
}