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:
parent
896c6b6a27
commit
6b3ce94406
3 changed files with 11 additions and 5 deletions
|
@ -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
|
@ -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;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue