Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/Gerrnperl/outline-map

A visual, interactive outline map that combines the clarity of the outline with the intuitive overview of the minimap. Alternative Minimap.
https://github.com/Gerrnperl/outline-map

extension outline tool vscode vscode-extension

Last synced: 29 days ago
JSON representation

A visual, interactive outline map that combines the clarity of the outline with the intuitive overview of the minimap. Alternative Minimap.

Awesome Lists containing this project

README

        

# Outline Map

EN | [中文](README_ZH_CN.md)

![overview](screenshots/overview.png)

A visual, interactive outline map that combines the clarity of the outline with the intuitive overview of the minimap. Enhanced version of vscode built-in outline.

![version](https://img.shields.io/visual-studio-marketplace/v/gerrnperl.outline-map?color=8bf7c7&logo=visualstudio&style=flat-square)
![installs](https://img.shields.io/visual-studio-marketplace/i/gerrnperl.outline-map?color=56b6c2&logo=visualstudiocode&style=flat-square)
![rating](https://img.shields.io/visual-studio-marketplace/stars/gerrnperl.outline-map?color=97dbf3&style=flat-square)
![downloads](https://img.shields.io/visual-studio-marketplace/d/gerrnperl.outline-map?color=62abf5&logo=visualstudiocode&style=flat-square)
![stars](https://img.shields.io/github/stars/gerrnperl/outline-map?color=f2c661&logo=github&style=flat-square)
![license](https://img.shields.io/github/license/gerrnperl/outline-map?color=f9e2ae&logo=github&style=flat-square)

## Features

### Follow

Automatically scroll, expand and collapse the outline tree when the cursor moves or the viewport scrolls.

![follow](screenshots/follow.gif)

### Navigation

You can navigate to the symbol by clicking on the outline node like the built-in outline.

Keyboard navigation is also supported.

![navigation](screenshots/nav.gif)

### Diagnostics

Show diagnostics of the current file.

![Flag diagnostics](screenshots/diagnostics.gif)

### Search

default keybinding: ``

Search for symbols in the current file. You can use the following syntax to achieve different search effects:

- `/`: Normal search
- `=`: Regex
- `?`: Fuzzy search

You can append `@` to filter by symbol kind before the search expression.

![Search](screenshots/search.gif)

### Region and tag

Supports region and tag syntax

You can define regions to group code symbols anywhere in the code (usually comments), or tags to mark locations.

#### Grammar

```md
#region
#tag
#endregion
```

#### Features
- Allows customizing identifiers for regions and labels.
- Tag syntax highlighting (semantic highlighting needs to be enabled)
- Region folding

![region and tag](screenshots/region.png)

### Workspace symbols

You can display symbols of multiple files in the workspace, such as regions, tags, functions, etc., and quickly jump to the corresponding location.

After enabling this feature, the symbols of newly opened files will be automatically added to the list. You can manage the symbols in the list in the following ways:

- Set an interval to automatically remove inactive files from the list
- Manually close the symbols of files that are not needed, exclude a specific symbol, or exclude symbols that match a pattern
- Sort the list by last access time to find the symbols of the recently used files

By default, region and tag symbols will be added. You can customize the symbols to be added by modifying the `outline-map.IncludeSymbols` setting.

---

## Configuration

### Customization

- `outline-map.customFont`: Custom font for the outline.

Syntax: `[ | ]#`

- `outline-map.customCSS`: Custom css for the outline. The css will be injected into the outline's webview.

- You can customize the color of the outline by `workbench.colorCustomizations`. Outline Map uses the symbol color settings built into vscode, i.e. `symbolsIcon.*Foreground`, and you can also set the color for the two symbols added by the extension and some UI elements:
- `symbolIcon.om_TagForeground` - The color of the tag symbol
- `symbolIcon.om_RegionForeground` - The color of the region symbol
- `outline-map.visibleRangeBackground` - The background color of the visible area in the outline view
- `outline-map.focusingItemBackground` - The background color of the focusing item in the outline view
- `outline-map.focusingItemForeground` - The foreground color of the focusing item in the outline view

### Behavior

- `outline-map.follow`: Scroll the outline when the cursor moves or the viewport scrolls

- `outline-map.expand`: Set the automatic expansion mode of the outline view. Select `cursor` to expand only to the node where the cursor is located, and `viewport` to expand all nodes in the viewport.

- `outline-map.hiddenItem`: Choose items you do not want to see in the outline.

- `outline-map.defaultMaxDepth`: Set the default maximum depth of the outline tree. Set this to non-zero to enable the depth button `>` & `<`.

- `outline-map.findRef.enabled`: Enable references to be displayed when clicking to jump.

- `outline-map.findRef.useFindImpl`: Display implements instead of references.

### Region and tag

- `outline-map.region.enabled`: Enable region and tag support

- `outline-map.region.startRegion`: The start of a region.

- `outline-map.region.endRegion`: The end of a region.

- `outline-map.region.tag`: The start of a tag.

- `outline-map.region.highlight`: Enable region and tag syntax highlighting

## Commands


- `outline-map.focusSearch`: Focus the search box, default keybinding ``
- `outline-map.toggleSearch`: Toggle the visibility of the search and navigation area.

### View Actions

- Depth limit: Increase / decrease the outline by one level. Available when `outline-map.defaultMaxDepth` is a positive value.
- `Increase depth >`
- `Decrease depth <`

- Temporarily fix
- `Fixed`: The outline node will not be automatically expanded;
- `Frozen`: The outline node will not be automatically expanded, and the outline view will not automatically scroll;

- Sort
- `Sort by position`: Sort the outline nodes by position;
- `Sort by name`: Sort the outline nodes by name;
- `Sort by kind`: Sort the outline nodes by kind;

---

Suggestion: move view to secondary side panel (vscode ^1.64)

> Outline Map does not perform language-specific symbol parsing, symbol information is provided by vscode or other extensions.
>
> Refer to the following links for more information: [vscode-code-outline/ language-support](https://github.com/patrys/vscode-code-outline#language-support)

---

**Enjoy! ❤️**