mirror of
https://github.com/hedgedoc/hedgedoc.git
synced 2025-04-20 22:42:02 +00:00
Merge pull request #1233 from hedgedoc/fix/insertOnStartOfLines
Fix insertOnStartOfLines behaviour
This commit is contained in:
commit
dc1f621eb8
1 changed files with 7 additions and 4 deletions
|
@ -1,4 +1,5 @@
|
|||
const wrapSymbols = ['*', '_', '~', '^', '+', '=']
|
||||
|
||||
export function wrapTextWith (editor, cm, symbol) {
|
||||
if (!cm.getSelection()) {
|
||||
return CodeMirror.Pass
|
||||
|
@ -106,12 +107,14 @@ export function insertOnStartOfLines (cm, symbol) {
|
|||
for (let i = 0; i < ranges.length; i++) {
|
||||
const range = ranges[i]
|
||||
if (!range.empty()) {
|
||||
const from = range.from()
|
||||
const to = range.to()
|
||||
let selection = cm.getRange({ line: from.line, ch: 0 }, to)
|
||||
const cursorFrom = range.from()
|
||||
const cursorTo = range.to()
|
||||
const firstLineStart = { line: cursorFrom.line, ch: 0 }
|
||||
const lastLineEnd = { line: cursorTo.line, ch: cm.getLine(cursorTo.line).length }
|
||||
let selection = cm.getRange(firstLineStart, lastLineEnd)
|
||||
selection = selection.replace(/\n/g, '\n' + symbol)
|
||||
selection = symbol + selection
|
||||
cm.replaceRange(selection, from, to)
|
||||
cm.replaceRange(selection, firstLineStart, lastLineEnd)
|
||||
} else {
|
||||
cm.replaceRange(symbol, { line: cursor.line, ch: 0 }, { line: cursor.line, ch: 0 })
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue