mirror of
				https://github.com/zadam/trilium.git
				synced 2025-10-26 07:46:30 +01:00 
			
		
		
		
	fix(codemirror): search not unfolding results
This commit is contained in:
		| @@ -1,5 +1,6 @@ | ||||
| import { EditorView, Decoration, MatchDecorator, ViewPlugin, ViewUpdate } from "@codemirror/view"; | ||||
| import { Range, RangeSet } from "@codemirror/state"; | ||||
| import { foldState, unfoldEffect } from "@codemirror/language"; | ||||
| import { Range, RangeSet, StateEffect } from "@codemirror/state"; | ||||
|  | ||||
| const searchMatchDecoration = Decoration.mark({ class: "cm-searchMatch" }); | ||||
| const activeMatchDecoration = Decoration.mark({ class: "cm-activeMatch" }); | ||||
| @@ -79,8 +80,23 @@ export class SearchHighlighter { | ||||
|         const match = this.parsedMatches[matchIndex]; | ||||
|         this.currentFound = matchIndex + 1; | ||||
|         this.activeMatch = activeMatchDecoration.range(match.from, match.to); | ||||
|  | ||||
|         // Check if the match is inside a folded region. | ||||
|         const unfoldEffects: StateEffect<unknown>[] = []; | ||||
|         const folded = this.view.state.field(foldState); | ||||
|         const iter = folded.iter(); | ||||
|         while (iter.value) { | ||||
|             if (match.from >= iter.from && match.to <= iter.to) { | ||||
|                 unfoldEffects.push(unfoldEffect.of({ from: iter.from, to: iter.to })); | ||||
|             } | ||||
|             iter.next(); | ||||
|         } | ||||
|  | ||||
|         this.view.dispatch({ | ||||
|             effects: EditorView.scrollIntoView(match.from, { y: "center" }), | ||||
|             effects: [ | ||||
|                 ...unfoldEffects, | ||||
|                 EditorView.scrollIntoView(match.from, { y: "center" }) | ||||
|             ], | ||||
|             scrollIntoView: true | ||||
|         }); | ||||
|     } | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| import { defaultKeymap, history, historyKeymap } from "@codemirror/commands"; | ||||
| import { EditorView, highlightActiveLine, keymap, lineNumbers, placeholder, ViewPlugin, ViewUpdate, type EditorViewConfig } from "@codemirror/view"; | ||||
| import { defaultHighlightStyle, StreamLanguage, syntaxHighlighting, indentUnit, bracketMatching, foldGutter } from "@codemirror/language"; | ||||
| import { defaultHighlightStyle, StreamLanguage, syntaxHighlighting, indentUnit, bracketMatching, foldGutter, codeFolding } from "@codemirror/language"; | ||||
| import { Compartment, EditorSelection, EditorState, type Extension } from "@codemirror/state"; | ||||
| import { highlightSelectionMatches } from "@codemirror/search"; | ||||
| import { vim } from "@replit/codemirror-vim"; | ||||
| @@ -73,6 +73,7 @@ export default class CodeMirror extends EditorView { | ||||
|                 ]), | ||||
|                 highlightSelectionMatches(), | ||||
|                 bracketMatching(), | ||||
|                 codeFolding(), | ||||
|                 foldGutter(), | ||||
|                 indentationMarkers(), | ||||
|             ]; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user