Skip to content

Commit

Permalink
fix: fix/improve hideCodeWithoutDecoration using source
Browse files Browse the repository at this point in the history
  • Loading branch information
Loïc Mangeonjean committed Feb 21, 2024
1 parent 834ab9e commit 5059bd6
Show file tree
Hide file tree
Showing 2 changed files with 12 additions and 29 deletions.
39 changes: 11 additions & 28 deletions src/tools.ts
Original file line number Diff line number Diff line change
Expand Up @@ -182,18 +182,20 @@ export function lockCodeWithoutDecoration (
return disposableStore
}

let hideCodeWithoutDecorationCounter = 0
export function hideCodeWithoutDecoration (editor: monaco.editor.ICodeEditor, decorationFilter: (decoration: monaco.editor.IModelDecoration) => boolean): monaco.IDisposable {
let otherHiddenAreas: monaco.IRange[] = editor._getViewModel()?.getHiddenAreas() ?? []
function getHiddenAreas () {
const hideId = `hideCodeWithoutDecoration:${hideCodeWithoutDecorationCounter++}`

function updateHiddenAreas (): void {
const model = editor.getModel()
if (model == null) {
return []
return
}

const decorations = model.getAllDecorations()
.filter(decorationFilter)
if (decorations.length === 0) {
return otherHiddenAreas
return
}

const ranges = decorations
Expand All @@ -218,40 +220,22 @@ export function hideCodeWithoutDecoration (editor: monaco.editor.ICodeEditor, de
}
}, [])

let hiddenAreas: monaco.IRange[] = [...otherHiddenAreas]
const hiddenAreas: monaco.IRange[] = []
let position = new monaco.Position(1, 1)
for (const range of ranges) {
const startPosition = model.modifyPosition(range.getStartPosition(), -1)
const endPosition = model.modifyPosition(range.getEndPosition(), 1)
hiddenAreas = [
...hiddenAreas,
monaco.Range.fromPositions(position, startPosition)
]
hiddenAreas.push(monaco.Range.fromPositions(position, startPosition))
position = endPosition
}
hiddenAreas = [
...hiddenAreas,
monaco.Range.fromPositions(position, model.getFullModelRange().getEndPosition())
]

return hiddenAreas
}

const originalSetHiddenAreas = editor.setHiddenAreas.bind(editor)
function updateHiddenAreas () {
originalSetHiddenAreas(getHiddenAreas())
}
hiddenAreas.push(monaco.Range.fromPositions(position, model.getFullModelRange().getEndPosition()))

// Hack to make it work with the folding service calling setHiddenAreas with its own areas
editor.setHiddenAreas = (ranges) => {
otherHiddenAreas = ranges
updateHiddenAreas()
editor.setHiddenAreas(hiddenAreas, hideId)
}

const disposableStore = new DisposableStore()

disposableStore.add(editor.onDidChangeModel(() => {
otherHiddenAreas = editor._getViewModel()?.getHiddenAreas() ?? []
updateHiddenAreas()
}))
disposableStore.add(editor.onDidChangeModelDecorations(() => {
Expand All @@ -261,8 +245,7 @@ export function hideCodeWithoutDecoration (editor: monaco.editor.ICodeEditor, de

disposableStore.add({
dispose () {
editor.setHiddenAreas = originalSetHiddenAreas
editor.setHiddenAreas(otherHiddenAreas)
editor.setHiddenAreas([], hideId)
}
})

Expand Down
2 changes: 1 addition & 1 deletion src/types/monaco.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ declare module 'monaco-editor' {
interface ICodeEditor {
// This method is internal and is supposed to be used by the folding feature
// We still use it to hide parts of the code in the `hideCodeWithoutDecoration` function
setHiddenAreas(ranges: IRange[]): void
setHiddenAreas(ranges: IRange[], source?: unknown): void

_getViewModel(): {
getHiddenAreas(): IRange[]
Expand Down

0 comments on commit 5059bd6

Please sign in to comment.