-
Notifications
You must be signed in to change notification settings - Fork 1.8k
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
Bug: Undo hotkey stops working in a specific case #6674
Comments
Thanks for reporting @Ulop I've tried to repro with Greek and Korean layouts and in both cases it worked well, is it the same for you in all browsers, or specific one? Regarding event handlers: as long as isUndo check passes in onKeyDown it preventsDefault so onBeforeInput won't be called (so it'll avoid double triggering for undo command) |
@fantactuka, Thanks for answer. Maybe it's a browser-dependent issue? I asked a colleague to check this situation on his MacBook (MacOS 17.6) in Safari - everything worked as expected. On MacBook in Chrome the editor state is not restored after pressing the undo hotkey. On Win(10|11) in Chrome\FireFox the situation is similar. |
I can assume that I may have found the cause, but I can’t suggest a simple solution. As I'm mentioned above, Lexical has two point that can dispatch
So in other cases we must rely on the A simallar issue was closed a comment that is expected behaviour. More simple example:
|
Having thought about this problem once again, I came to the conclusion that it is most likely worth solution is changing hotkeys handling in the I decided to see how VSCode solves the hotkey problem. And as far as I understand, they follow the points from these recomendations and rely on Similar issues with hotkeys handling: |
Lexical version:
lexical: 0.17.1
Steps To Reproduce
Link to code example: https://playground.lexical.dev/
The current behavior
Nothing happens
The expected behavior
The editor restores the last state from the undoStack field of the history when you press the
Ctrl + Z
hotkey.By default, in the
LexicalEvents.ts
file there are two points that dispatch theUNDO_COMMAND
command:onKeyDown
listener (by checking whetherevent.ctrlKey
is true andevent.key
equals toz
character)onBeforeInput
listener (by checking whetherevent.inputType
equals tohistoryUndo
)When the content has been cleared as described above (in the
Steps To Reproduce
section) only the first listener (onKeyDown
) is called and never the second one.For Latin layout, it works correctly because it passes the
isUndo
function test. But it doesn't work for other layouts, since theevent.key
value is not the 'z' character.However, if we modify the content (e.g. type in any character) before step 3 and then execute steps 3-5 everything will work as expected. The
onBeforeInput
event is called and the previous state is restored.The text was updated successfully, but these errors were encountered: