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:
parent
1aebcbb27c
commit
0a2364f917
@ -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
|
||||
//
|
||||
}
|
||||
|
@ -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',
|
||||
};
|
||||
|
Loading…
Reference in New Issue
Block a user