1
0
mirror of https://github.com/laurent22/joplin.git synced 2025-01-11 18:24:43 +02:00

Desktop: Fix End key behavior with Codemirror spellcheck (#4215)

* Manually fudge the codemirror cursor handling when in contenteditable mode
This commit is contained in:
Caleb John 2020-12-19 18:04:02 -07:00 committed by GitHub
parent 1aebcbb27c
commit 0a2364f917
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 102 additions and 21 deletions

View File

@ -138,4 +138,87 @@ export default function useCursorUtils(CodeMirror: any) {
this.setSelection(anchor, head);
});
//
// START of HACK to support contenteditable
//
// This is a HACK to enforce proper cursor positioning when using
// codemirror in contenteditable mode
// The problem is that chrome collapses trailing whitespace (for wrapped lines)
// so when codemirror places the cursor after the trailing whitespace, chrome will
// register that as being the start of the following line.
//
// An alternative fix for this would be to disable codemirror handling of Left/Right and Home/End
// but that breaks multicursor support in codemirror.
CodeMirror.defineExtension('isAfterTrailingWhitespace', function() {
const { line, ch } = this.getCursor('head');
const beforeCursor = this.charCoords({ line: line, ch: ch - 1 });
const afterCursor = this.charCoords({ line: line, ch: ch });
const currentLine = this.getLine(line);
return beforeCursor.top < afterCursor.top && !!currentLine[ch - 1].match(/\s/);
});
CodeMirror.commands.goLineRightSmart = function(cm: any) {
// Only apply the manual cursor adjustments for contenteditable mode
if (cm.options.inputStyle !== 'contenteditable') {
cm.execCommand('goLineRight');
return;
}
// This detects the condition where the cursor is visibly placed at the beginning of
// the current line, but codemirror treats it like it was on the end of the
// previous line.
// The fix is to step forward twice, then re-initiate goLineRight
if (cm.isAfterTrailingWhitespace()) {
cm.execCommand('goColumnRight');
cm.execCommand('goColumnRight');
cm.execCommand('goLineRightSmart');
return;
}
cm.execCommand('goLineRight');
// This detects the situation where the cursor moves to the end of a wrapped line
// and is placed after a whitespace character.
// In this situation we step the curso back once to put it on the correct line.
if (cm.isAfterTrailingWhitespace()) {
cm.execCommand('goCharLeft');
}
};
CodeMirror.commands.goLineUpSmart = function(cm: any) {
if (cm.options.inputStyle !== 'contenteditable') {
cm.execCommand('goLineUp');
return;
}
// In this situation the codemirror editor thinks it's a line above where it is.
if (cm.isAfterTrailingWhitespace()) {
cm.execCommand('goCharLeft');
cm.execCommand('goLineLeft');
} else {
cm.execCommand('goLineUp');
}
};
CodeMirror.commands.goLineDownSmart = function(cm: any) {
if (cm.options.inputStyle !== 'contenteditable') {
cm.execCommand('goLineDown');
return;
}
// In this situation the codemirror editor thinks it's a line above where it is.
if (cm.isAfterTrailingWhitespace()) {
cm.execCommand('goLineRightSmart');
cm.execCommand('goCharRight');
} else {
cm.execCommand('goLineDown');
}
};
//
// END of HACK to support contenteditable
//
}

View File

@ -104,9 +104,9 @@ export default function useKeymap(CodeMirror: any) {
CodeMirror.keyMap.basic = {
'Left': 'goCharLeft',
'Right': 'goCharRight',
'Up': 'goLineUp',
'Down': 'goLineDown',
'End': 'goLineRight',
'Up': 'goLineUpSmart',
'Down': 'goLineDownSmart',
'End': 'goLineRightSmart',
'Home': 'goLineLeftSmart',
'PageUp': 'goPageUp',
'PageDown': 'goPageDown',
@ -130,16 +130,16 @@ export default function useKeymap(CodeMirror: any) {
'Ctrl-Z': 'undo',
'Shift-Ctrl-Z': 'redo',
'Ctrl-Y': 'redo',
'Ctrl-Up': 'goLineUp',
'Ctrl-Down': 'go,ineDown',
'Ctrl+Home': 'goDocStart',
'Ctrl+End': 'goDocEnd',
'Ctrl+Left': 'goGroupLeft',
'Ctrl+Right': 'goGroupRight',
'Alt+Left': 'goLineStart',
'Alt+Right': 'goLineEnd',
'Ctrl+Backspace': 'delGroupBefore',
'Ctrl+Delete': 'delGroupAfter',
'Ctrl-Up': 'goLineUpSmart',
'Ctrl-Down': 'goLineDownSmart',
'Ctrl-Home': 'goDocStart',
'Ctrl-End': 'goDocEnd',
'Ctrl-Left': 'goGroupLeft',
'Ctrl-Right': 'goGroupRight',
'Alt-Left': 'goLineStart',
'Alt-Right': 'goLineEnd',
'Ctrl-Backspace': 'delGroupBefore',
'Ctrl-Delete': 'delGroupAfter',
'fallthrough': 'basic',
};
@ -153,14 +153,12 @@ export default function useKeymap(CodeMirror: any) {
'Cmd-Home': 'goDocStart',
'Cmd-Up': 'goDocStart',
'Ctrl-D': 'delCharAfter',
'Cmd+Home': 'goDocStart',
'Cmd+End': 'goDocEnd',
'Cmd+Left': 'goGroupLeft',
'Cmd+Right': 'goGroupRight',
'Ctrl+A': 'goLineStart',
'Ctrl+E': 'goLineEnd',
'Alt+Backspace': 'delGroupBefore',
'Alt+Delete': 'delGroupAfter',
'Cmd-Left': 'goGroupLeft',
'Cmd-Right': 'goGroupRight',
'Ctrl-A': 'goLineStart',
'Ctrl-E': 'goLineEnd',
'Alt-Backspace': 'delGroupBefore',
'Alt-Delete': 'delGroupAfter',
'fallthrough': 'basic',
};