Skip to content

Implement displaying specific content around headings based on their levels.

License

Notifications You must be signed in to change notification settings

dragonish/obsidian-heading-decorator

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Heading Decorator

English | 简体中文 | 繁體中文

Introduction

This is a plugin for Obsidian.

Implement displaying specific content around headings based on their levels.

This plugin supports optional decoration for reading view, editing view (Live Preview and Source mode), Outline, Quiet Outline and Headings in Explorer plugin. This plugin does not modify any note content, only decorates the heading section based on the existing note content.

Preview

In Live Preview:

Preview

The interaction between the decorator and the collapse button:

Collapse Button Interaction

Settings

Metadata keyword

The key name that reads the enabled status from the properties. The default value is: heading. Usage reference: Enabled status of notes.

Enabled

The plugin supports configure heading decorator for each editor mode. You can control the effect range:

  • Enabled in reading view: Allow to decorate the heading under the Reading view.
  • Enabled in live preview: Allow to decorate the heading under the Live Preview.
  • Enabled in source mode: Allow to decorate the heading under the Source mode.
  • Enabled in outline plugin: Allow to decorate the heading under the Outline plugin.
  • Enabled in "Quiet Outline" plugin: Allow to decorate the heading under the Quiet Outline plugin.
  • Enabled in "Headings in Explorer" plugin: Allow to decorate the heading under the Headings in Explorer plugin.

In addition, you can enable the default status of each note within the Config subpage. It mainly works together with Enabled status of notes.

Effect

Control the display effect of the decorator.

  • Ordered: Toggle this setting to enable the decoration of headings as an ordered or unordered list.
  • Opacity: Set the opacity of the heading decorator. The value is the form of percentage.
  • Position: Set the position of the heading decorator. You can configure the content to appear before or after the heading.
  • Maximum level recognized: Specify the maximum level of headings to be recognized, ignoring headings above this level.

Here are some examples of the differences between different positions:

Before the heading Before the heading (inside) After the heading
before before-inside after

Here are examples of different recognized maximum levels:

The maximum level recognized is 6 The maximum level recognized is 4
max-6 max4

Ordered

Similar to the effect displayed in the Preview.

You can control the counter style type and delimiter. There are two special types of counter styles:

  • Custom list styles: Set custom list styles for ordered list. Using spaces to separate entries.
  • Specified string: Set a specified string for ordered list.

For example:

Decimal numbers Custom List Styles (using Ⓐ Ⓑ Ⓒ) Specified String (using # with empty delimiter)
Decimal numbers Custom list styles Specified string

Allow zero level

For the Allow zero level setting, if the next heading is more than one level higher, the omitted level is zero instead of one. For example:

Default Allow zero level
Default Allow zero level

Based on the existing highest level

For the Based on the existing highest level setting, use the highest level of headings in the note as the base for ordered list. For example:

Default Based on the existing highest level
Default Based on the existing highest level

Always ignore the top-level headings

Exclude the top-level heading when building ordered lists. controlled by the Maximum number of ignored levels option. For example:

Default Enabled (Maximum number of ignored levels set to 2)
Default Always ignore the top-level headings

Ignore the single heading at the top-level

For the Ignore the single heading at the top-level setting, if the top-level has only a single heading, exclude it when building an ordered list. controlled by the Maximum number of ignored levels option. This setting contains Based on the existing highest level, but it deals with more "aggressive". For example:

Default Enabled (Maximum ignored levels: 1) Enabled (Maximum ignored levels: 6)
Default Ignore the single heading at the top-level The maximum number of ignored is 1

Unordered

Directly decorate the heading according to the level. For example:

Ordered (Decimal numbers) Unordered (using H1 H2 H3 H4 H5 H6)
Ordered Unordered

Other settings for reading view

Render policy for reading view

When editing note content, the render policy used by the heading decorator in the reading view.

  • Partial: Rerender active heading decorator after the update.
  • Full: Rerender all heading decorators after the update.

Other settings for source mode

Hide number signs on inactive lines

Hide number signs (#) on inactive lines similar to live preview.

Blocklist

Folder blocklist

Disables the heading decorator in notes within the specified folder. For notes that are on the blocklist, you can still use Enabled status of notes.

Note name regex blocklist

Disables the heading decorator in notes whose note name matches the specified regular expression. The format uses JavaScript regular expression, for example: /^daily.*/i. For notes that are on the blocklist, you can still use Enabled status of notes.

Enabled status of notes

This plugin allows for configure the enabled status based on specific fields in the note properties. You can individually control the enabled status of a note.

You can specify the status after the configured property keyword:

---
heading: false
---

The values true, yes, on or 1 indicates enabled; the values false, no, off or 0 indicates disabled. Other values are equivalent to undeclared.

You can also use the following subfields to specify the status of a specific mode:

  • reading: the status of the decorator in the reading view.
  • preview: the status of the decorator in the live preview.
  • source: the status of the decorator in the source mode.
  • outline: the status of the decorator in the outline plugin.
  • quiet-outline: the status of the decorator in the "Quiet Outline" plugin.
  • file-explorer: the status of the decorator in the "Headings in Explorer" plugin.
  • all: the status of the decorator in all modes.

For example, you can set all other modes to be disabled and enable the decorator in the reading view alone:

---
heading:
  all: false
  reading: true
---

If you prefer to use Obsidian's default property cssclasses, you can also fill in cssclasses with some equivalent class names:

  • reading: enable-reading-heading/disable-reading-heading
  • preview: enable-preview-heading/disable-preview-heading
  • source: enable-source-heading/disable-source-heading
  • outline: enable-outline-heading/disable-outline-heading
  • quiet-outline: enable-quiet-outline-heading/disable-quiet-outline-heading
  • file-explorer: enable-file-explorer-heading/disable-file-explorer-heading
  • all: enable-heading/disable-heading

For example, a value equivalent to the above example:

---
cssclasses:
  - disable-heading
  - enable-reading-heading
---

Custom decorator styles

You can customize the heading decorator style by CSS classes. For decorators in the editor, .custom-heading-decorator can be used. Or for specific editor modes:

  • Reading view: .reading-custom-heading-decorator.
  • Live Preview: .preview-custom-heading-decorator.
  • Source mode: .source-custom-heading-decorator.

For decorators in other plugins, it is necessary to combine pseudo-element keywords:

  • Outline: .outline-custom-heading-decorator::before or .outline-custom-heading-decorator::after.
  • Quiet Outline: .quiet-outline-custom-heading-decorator::before or .quiet-outline-custom-heading-decorator::after.
  • Headings in Explorer: .file-explorer-custom-heading-decorator::before or .file-explorer-custom-heading-decorator::after.

For example, make all the decorators display in green:

.custom-heading-decorator,
.outline-custom-heading-decorator::before,
.outline-custom-heading-decorator::after,
.quiet-outline-custom-heading-decorator::before,
.quiet-outline-custom-heading-decorator::after,
.file-explorer-custom-heading-decorator::before,
.file-explorer-custom-heading-decorator::after {
  color: green;
}

In addition, the plugin provides a set of CSS variables for customizing the spacing of decorators:

  • --reading-heading-decorator-margin: the margin of the heading decorator in the reading view.
  • --reading-heading-decorator-translate: the translating vector value of the heading decorator in the reading view.
  • --preview-heading-decorator-margin: the margin of the heading decorator in the live preview.
  • --preview-heading-decorator-translate: the translating vector value of the heading decorator in the live preview.
  • --source-heading-decorator-margin: the margin of the heading decorator in the source mode.
  • --source-heading-decorator-translate: the translating vector value of the heading decorator in the source mode.
  • --outline-heading-decorator-margin: the margin of the heading decorator in the outline plugin.
  • --quiet-outline-heading-decorator-margin: the margin of the heading decorator in the "Quiet Outline" plugin.
  • --file-explorer-heading-decorator-margin: the margin of the heading decorator in the "Headings in Explorer" plugin.

For example, to adjust the spacing in the reading view to 8px:

body {
  --reading-heading-decorator-margin: 8px;
}

Credits

License

MIT license

About

Implement displaying specific content around headings based on their levels.

Topics

Resources

License

Stars

Watchers

Forks

Sponsor this project