mozilla / pontoon

Mozilla's Localization Platform
https://pontoon.mozilla.org
BSD 3-Clause "New" or "Revised" License
1.45k stars 526 forks source link

Comment editor crashes when writing diacritics #2298

Open bugzilla-to-github opened 3 years ago

bugzilla-to-github commented 3 years ago

This issue was created automatically by a script.

Bug 1713496

Bug Reporter: @MikkCZ CC: @Pike

STR:

  1. Open any string, e.g. https://pontoon.mozilla.org/cs/firefox/all-resources/?string=74127.
  2. Open the comment textarea either on a suggestion or the string in general.
  3. On Czech keyboard do two times: -- press acute/caron key (with or without Shift), followed by e.g. E, to write either "é" or "ě" -- press space bar

What should happen:

What happens:

bugzilla-to-github commented 3 years ago

Comment Author: @MikkCZ

Created attachment 9224166 screen recording.webm

Attached file: Nahrávka obrazovky z 30.5.2021 11:50:27.webm (video/webm, 1206739 bytes) Description: screen recording.webm

bugzilla-to-github commented 3 years ago

Comment Author: @MikkCZ

Observation, the "offset" in the error message differs based on what you write. This happens in the middle of the text as well.

Also when you use the keys in the row below F-keys, which by default in Czech layout write "ěščřžýáíé", directly, everything works. But note, this is only a partial workaround, because not all letters with diacritics can be written like that.

bugzilla-to-github commented 3 years ago

Comment Author: @Pike

Can you test this on https://www.slatejs.org/examples/mentions? Maybe this is an upstream bug.

bugzilla-to-github commented 3 years ago

Comment Author: @MikkCZ

I wasn't able to reproduce it there, however I see that https://github.com/mozilla/pontoon/pull/1955 updated slate, and in the issue tracker of slate there is a ton of bugs (some specific to Firefox) that it does not handle the cursor position properly under all conditions.

In this specific case and after looking at the error message in more detail, I guess something looses the information about number of characters being actually typed. When you start by pressing the acute/caron key (with or without Shift), ´ or ˇ appears, and is then merged with what's written next. That's normal behaviour. But if the library or frontend code does not account for that, it will definitely cause an index to go out of bounds of the text actually written in the area.

Mitch4sho commented 2 years ago

@mathjazz can I be assigned to this one

Pike commented 2 years ago

I was able to reproduce this upstream, and https://github.com/ianstormtaylor/slate/issues/4136 is exactly this, AFAICT.

I don't know that we have a way to fix this, short of wrapping slate in an error boundary, and reloading it with an empty comment on crash?

mathjazz commented 2 years ago

I tried to reproduce (using the Apple Wireless Keyboard with Slovenian layout) and the sequence of characters in the original comment didn't trigger the error. However, I could reproduce the issue using the following sequence:

  1. Alt + E
  2. Alt + Space
  3. Alt + Space

However, I was unable to reproduce on https://www.slatejs.org/examples/plaintext (which is what https://github.com/ianstormtaylor/slate/issues/4136 references).

Pike commented 2 years ago

The kicker is that you need to start with an empty inbox.

Then add a diacritic, add a char, move, delete, crash.

mathjazz commented 2 years ago

Ah, thanks. Let's continue as agreed on the meeting (i.e. as you suggested), sorry for the false alarm.

mathjazz commented 2 years ago

The same error appears when you type @ and paste some text.

mathjazz commented 8 months ago

I am no longer able to reproduce this upstream, so it seems like updating Slate could be the way forward here?

At least as a short-term fix. A long-term fix is #3010.

mathjazz commented 8 months ago

@Mitch4sho Welcome back. :)

Please start here: https://mozilla-pontoon.readthedocs.io/en/latest/dev/setup.html