0
Fork 0
mirror of https://github.com/fastmail/Squire.git synced 2025-01-08 16:00:06 -05:00

Fix backspace sometimes not handled on mobile

With soft keyboards, e.g. on an iPhone, the shift key is automatically activated
when the cursor is at the beginning of the paragraph. However, this meant that
when you hit backspace, we were not handling the event and the browser was doing
it for us, resulting in broken styling.
This commit is contained in:
Neil Jenkins 2020-05-11 11:16:11 +10:00
parent 896c6b6a27
commit 6b3ce94406
3 changed files with 11 additions and 5 deletions

View file

@ -1285,10 +1285,13 @@ var onKey = function ( event ) {
if ( event.altKey ) { modifiers += 'alt-'; } if ( event.altKey ) { modifiers += 'alt-'; }
if ( event.ctrlKey ) { modifiers += 'ctrl-'; } if ( event.ctrlKey ) { modifiers += 'ctrl-'; }
if ( event.metaKey ) { modifiers += 'meta-'; } if ( event.metaKey ) { modifiers += 'meta-'; }
if ( event.shiftKey ) { modifiers += 'shift-'; }
} }
// However, on Windows, shift-delete is apparently "cut" (WTF right?), so // However, on Windows, shift-delete is apparently "cut" (WTF right?), so
// we want to let the browser handle shift-delete. // we want to let the browser handle shift-delete in this situation.
if ( event.shiftKey ) { modifiers += 'shift-'; } if ( isWin && event.shiftKey && key === 'delete' ) {
modifiers += 'shift-';
}
key = modifiers + key; key = modifiers + key;

File diff suppressed because one or more lines are too long

View file

@ -44,10 +44,13 @@ var onKey = function ( event ) {
if ( event.altKey ) { modifiers += 'alt-'; } if ( event.altKey ) { modifiers += 'alt-'; }
if ( event.ctrlKey ) { modifiers += 'ctrl-'; } if ( event.ctrlKey ) { modifiers += 'ctrl-'; }
if ( event.metaKey ) { modifiers += 'meta-'; } if ( event.metaKey ) { modifiers += 'meta-'; }
if ( event.shiftKey ) { modifiers += 'shift-'; }
} }
// However, on Windows, shift-delete is apparently "cut" (WTF right?), so // However, on Windows, shift-delete is apparently "cut" (WTF right?), so
// we want to let the browser handle shift-delete. // we want to let the browser handle shift-delete in this situation.
if ( event.shiftKey ) { modifiers += 'shift-'; } if ( isWin && event.shiftKey && key === 'delete' ) {
modifiers += 'shift-';
}
key = modifiers + key; key = modifiers + key;