Added automatic quote insertion (#897)

pull/900/head
MrMugame 2024-06-23 05:33:16 +02:00 committed by GitHub
parent e535ef14ff
commit 2a2cdef0f4
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
1 changed files with 32 additions and 14 deletions

View File

@ -1,5 +1,6 @@
import { KeyBinding } from "@codemirror/view";
import { syntaxTree } from "@codemirror/language";
import { EditorSelection } from "@codemirror/state";
const straightQuoteContexts = [
"CommentBlock",
@ -14,7 +15,7 @@ const straightQuoteContexts = [
// TODO: Add support for selection (put quotes around or create blockquote block?)
function keyBindingForQuote(
quote: string,
originalQuote: string,
left: string,
right: string,
): KeyBinding {
@ -22,7 +23,7 @@ function keyBindingForQuote(
any: (target, event): boolean => {
// Moving this check here rather than using the regular "key" property because
// for some reason the "ä" key is not recognized as a quote key by CodeMirror.
if (event.key !== quote) {
if (event.key !== originalQuote) {
return false;
}
const cursorPos = target.state.selection.main.from;
@ -42,19 +43,36 @@ function keyBindingForQuote(
}
// Ok, still here, let's use a smart quote
let q = right;
if (/\W/.exec(chBefore) && !/[!\?,\.\-=“]/.exec(chBefore)) {
q = left;
}
target.dispatch({
const changes = target.state.changeByRange((range) => {
if (!range.empty) {
return {
changes: [
{ insert: left, from: range.from },
{ insert: right, from: range.to },
],
range: EditorSelection.range(
range.anchor + left.length,
range.head + left.length,
),
};
} else {
const quote = (/\W/.exec(chBefore) && !/[!\?,\.\-=“]/.exec(chBefore))
? left
: right;
return {
changes: {
insert: q,
insert: quote,
from: cursorPos,
},
selection: {
anchor: cursorPos + 1,
},
range: EditorSelection.cursor(
range.anchor + quote.length,
),
};
}
});
target.dispatch(changes);
return true;
},
};