2025-05-10 19:32:46 +02:00

1191 lines
28 KiB
CSS

/* @settings
name: Dynamic Outline
id: obsidian-dynamic-outline
settings:
-
id: active-heading
title: 'Active heading'
type: heading
level: 2
collapsed: true
-
id: dynamic-outline-highlight-font-weight
title: 'Active heading font weight'
description: 'Font weight of active heading'
type: variable-select
allowEmpty: false
default: var(--font-normal)
options:
-
label: Normal
value: var(--font-normal)
-
label: Semibold
value: var(--font-semibold)
-
label: Bold
value: var(--font-bold)
-
id: dynamic-outline-active-heading-pill-color
title: 'Active heading indication color'
description: 'Color of active heading pill'
type: variable-select
allowEmpty: false
default: var(--text-accent)
options:
-
label: Accent
value: var(--text-accent)
-
label: Mono
value: var(--text-normal)
-
id: dynamic-outline-active-heading-background
title: 'Active heading background color'
description: 'Background color of the active heading'
type: variable-select
allowEmpty: false
default: var(--background-modifier-hover)
options:
-
label: Mono
value: var(--background-modifier-hover)
-
label: Accent
value: var(--dynamic-outline-background-accent)
-
label: None
value: none
-
id: button
title: 'Button'
type: heading
level: 2
collapsed: true
-
id: hide-button-from-toolbar
title: 'Hide button'
description: 'Hide button from the toolbar'
type: class-toggle
default: false
-
id: headings
title: 'Headings'
type: heading
level: 2
collapsed: true
-
id: dynamic-outline-font-size
title: 'Font size'
description: 'Font size of the outline headings'
type: variable-select
default: var(--font-text-size)
options:
-
label: 'Default'
value: var(--font-text-size)
-
label: 'Small'
value: var(--font-small)
-
label: 'Smaller'
value: var(--font-smaller)
-
label: 'Smallest'
value: var(--font-smallest)
-
id: dynamic-outline-li-padding-tab-size
title: 'Tab size'
description: 'Left padding multiplier size (in pixels). Will be applied on next outline refresh'
type: variable-number-slider
default: 16
min: 0
max: 32
step: 1
format: px
-
id: heading-level-styling
title: 'Heading level styling'
description: 'Add heading level styling to the outline'
type: class-select
allowEmpty: true
default: none
options:
-
label: "H1, H2…"
value: heading-level-styling-1
-
label: "#, ##…"
value: heading-level-styling-2
-
id: disable-heading-word-wrap
title: "Disable heading word wrap"
description: 'Prevent line breaks in headings, ensuring they are displayed on a single line without wrapping'
type: class-toggle
default: false
-
id: headings-level-1
title: 'Headings level 1'
type: heading
level: 3
collapsed: true
-
id: dynamic-outline-h1-text-color
title: 'H1 text color'
description: 'Use `--h1-color` from theme or apply monochrome color'
markdown: true
type: variable-select
default: var(--h1-color)
options:
-
label: Theme
value: var(--h1-color)
-
label: Mono
value: var(--text-normal)
-
id: dynamic-outline-h1-font-style
title: 'H1 font style'
description: 'Use `--h1-style` from theme or apply custom styling'
type: variable-select
default: var(--h1-style)
options:
-
label: Theme
value: var(--h1-style)
-
label: Normal
value: normal
-
label: Italic
value: italic
-
id: dynamic-outline-h1-font-variant
title: 'H1 font variant'
description: 'Use `--h1-variant` from theme of apply custom variant'
type: variable-select
default: var(--h1-variant)
options:
-
label: Theme
value: var(--h1-variant)
-
label: Normal
value: normal
-
label: Small-caps
value: small-caps
-
label: All small-caps
value: all-small-caps
-
id: dynamic-outline-h1-font-weight
title: 'H1 font weight'
description: 'Use `--h1-weight` from theme or apply custom weight'
type: variable-select
default: var(--font-bold)
options:
-
label: Theme
value: var(--h1-weight)
-
label: Normal
value: var(--font-normal)
-
label: Semibold
value: var(--font-semibold)
-
label: Bold
value: var(--font-bold)
-
id: headings-level-2
title: 'Headings level 2'
type: heading
level: 3
collapsed: true
-
id: dynamic-outline-h2-text-color
title: 'H2 text color'
description: 'Use `--h2-color` from theme or apply monochrome color'
markdown: true
type: variable-select
default: var(--h2-color)
options:
-
label: Theme
value: var(--h2-color)
-
label: Mono
value: var(--text-normal)
-
id: dynamic-outline-h2-font-style
title: 'H2 font style'
description: 'Use `--h2-style` from theme or apply custom styling'
type: variable-select
default: var(--h2-style)
options:
-
label: Theme
value: var(--h2-style)
-
label: Normal
value: normal
-
label: Italic
value: italic
-
id: dynamic-outline-h2-font-variant
title: 'H2 font variant'
description: 'Use `--h2-variant` from theme of apply custom variant'
type: variable-select
default: var(--h2-variant)
options:
-
label: Theme
value: var(--h2-variant)
-
label: Normal
value: normal
-
label: Small-caps
value: small-caps
-
label: All small-caps
value: all-small-caps
-
id: dynamic-outline-h2-font-weight
title: 'H2 font weight'
description: 'Use `--h2-weight` from theme or apply custom weight'
type: variable-select
default: var(--font-normal)
options:
-
label: Theme
value: var(--h2-weight)
-
label: Normal
value: var(--font-normal)
-
label: Semibold
value: var(--font-semibold)
-
label: Bold
value: var(--font-bold)
-
id: headings-level-3
title: 'Headings level 3'
type: heading
level: 3
collapsed: true
-
id: dynamic-outline-h3-text-color
title: 'H3 text color'
description: 'Use `--h3-color` from theme or apply monochrome color'
markdown: true
type: variable-select
default: var(--h3-color)
options:
-
label: Theme
value: var(--h3-color)
-
label: Mono
value: var(--text-normal)
-
id: dynamic-outline-h3-font-style
title: 'H3 font style'
description: 'Use `--h3-style` from theme or apply custom styling'
type: variable-select
default: var(--h3-style)
options:
-
label: Theme
value: var(--h3-style)
-
label: Normal
value: normal
-
label: Italic
value: italic
-
id: dynamic-outline-h3-font-variant
title: 'H3 font variant'
description: 'Use `--h3-variant` from theme of apply custom variant'
type: variable-select
default: var(--h3-variant)
options:
-
label: Theme
value: var(--h3-variant)
-
label: Normal
value: normal
-
label: Small-caps
value: small-caps
-
label: All small-caps
value: all-small-caps
-
id: dynamic-outline-h3-font-weight
title: 'H3 font weight'
description: 'Use `--h3-weight` from theme or apply custom weight'
type: variable-select
default: var(--font-normal)
options:
-
label: Theme
value: var(--h3-weight)
-
label: Normal
value: var(--font-normal)
-
label: Semibold
value: var(--font-semibold)
-
label: Bold
value: var(--font-bold)
-
id: headings-level-4
title: 'Headings level 4'
type: heading
level: 3
collapsed: true
-
id: dynamic-outline-h4-text-color
title: 'H4 text color'
description: 'Use `--h4-color` from theme or apply monochrome color'
markdown: true
type: variable-select
default: var(--h4-color)
options:
-
label: Theme
value: var(--h4-color)
-
label: Mono
value: var(--text-normal)
-
id: dynamic-outline-h4-font-style
title: 'H4 font style'
description: 'Use `--h4-style` from theme or apply custom styling'
type: variable-select
default: var(--h4-style)
options:
-
label: Theme
value: var(--h4-style)
-
label: Normal
value: normal
-
label: Italic
value: italic
-
id: dynamic-outline-h4-font-variant
title: 'H4 font variant'
description: 'Use `--h4-variant` from theme of apply custom variant'
type: variable-select
default: var(--h4-variant)
options:
-
label: Theme
value: var(--h4-variant)
-
label: Normal
value: normal
-
label: Small-caps
value: small-caps
-
label: All small-caps
value: all-small-caps
-
id: dynamic-outline-h4-font-weight
title: 'H4 font weight'
description: 'Use `--h4-weight` from theme or apply custom weight'
type: variable-select
default: var(--font-normal)
options:
-
label: Theme
value: var(--h4-weight)
-
label: Normal
value: var(--font-normal)
-
label: Semibold
value: var(--font-semibold)
-
label: Bold
value: var(--font-bold)
-
id: headings-level-5
title: 'Headings level 5'
type: heading
level: 3
collapsed: true
-
id: dynamic-outline-h5-text-color
title: 'H5 text color'
description: 'Use `--h5-color` from theme or apply monochrome color'
markdown: true
type: variable-select
default: var(--h5-color)
options:
-
label: Theme
value: var(--h5-color)
-
label: Mono
value: var(--text-normal)
-
id: dynamic-outline-h5-font-style
title: 'H5 font style'
description: 'Use `--h5-style` from theme or apply custom styling'
type: variable-select
default: var(--h5-style)
options:
-
label: Theme
value: var(--h5-style)
-
label: Normal
value: normal
-
label: Italic
value: italic
-
id: dynamic-outline-h5-font-variant
title: 'H5 font variant'
description: 'Use `--h5-variant` from theme of apply custom variant'
type: variable-select
default: var(--h5-variant)
options:
-
label: Theme
value: var(--h5-variant)
-
label: Normal
value: normal
-
label: Small-caps
value: small-caps
-
label: All small-caps
value: all-small-caps
-
id: dynamic-outline-h5-font-weight
title: 'H5 font weight'
description: 'Use `--h5-weight` from theme or apply custom weight'
type: variable-select
default: var(--font-normal)
options:
-
label: Theme
value: var(--h5-weight)
-
label: Normal
value: var(--font-normal)
-
label: Semibold
value: var(--font-semibold)
-
label: Bold
value: var(--font-bold)
-
id: headings-level-6
title: 'Headings level 6'
type: heading
level: 3
collapsed: true
-
id: dynamic-outline-h6-text-color
title: 'H6 text color'
description: 'Use `--h6-color` from theme or apply monochrome color'
markdown: true
type: variable-select
default: var(--h6-color)
options:
-
label: Theme
value: var(--h6-color)
-
label: Mono
value: var(--text-normal)
-
id: dynamic-outline-h6-font-style
title: 'H6 font style'
description: 'Use `--h6-style` from theme or apply custom styling'
type: variable-select
default: var(--h6-style)
options:
-
label: Theme
value: var(--h6-style)
-
label: Normal
value: normal
-
label: Italic
value: italic
-
id: dynamic-outline-h6-font-variant
title: 'H6 font variant'
description: 'Use `--h6-variant` from theme of apply custom variant'
type: variable-select
default: var(--h6-variant)
options:
-
label: Theme
value: var(--h6-variant)
-
label: Normal
value: normal
-
label: Small-caps
value: small-caps
-
label: All small-caps
value: all-small-caps
-
id: dynamic-outline-h6-font-weight
title: 'H6 font weight'
description: 'Use `--h6-weight` from theme or apply custom weight'
type: variable-select
default: var(--font-normal)
options:
-
label: Theme
value: var(--h6-weight)
-
label: Normal
value: var(--font-normal)
-
label: Semibold
value: var(--font-semibold)
-
label: Bold
value: var(--font-bold)
-
id: window-layout
title: 'Window layout'
type: heading
level: 2
collapsed: true
-
id: dynamic-outline-window-width
title: 'Window width'
description: 'Outline window width (in pixels)'
type: variable-number-slider
default: 256
min: 128
max: 512
step: 32
format: px
-
id: dynamic-outline-window-offset-top
title: 'Window offset top'
description: 'Add more space before the outline window'
type: variable-number-slider
allowEmpty: false
default: 0
min: -100
max: 100
step: 1
format: px
-
id: dynamic-outline-window-offset-bottom
title: 'Window offset bottom'
description: 'Add more space after the outline window'
type: variable-number-slider
allowEmpty: false
default: 0
min: -100
max: 100
step: 1
format: px
-
id: dynamic-outline-opacity
title: 'Window opacity'
description: 'Outline window opacity when the outline is not hovered over'
type: variable-number-slider
default: 1.0
min: 0.0
max: 1.0
step: 0.05
*/
/* TODO: transfer variables to :root. */
:root {
/* Applied to the li.style directly with dynamic tab levels. */
--dynamic-outline-li-padding-tab-size: 16px;
--dynamic-outline-collapse-icon-width: 12px;
}
.theme-dark,
.theme-light {
/* New color variables */
--dynamic-outline-background-modifier-hover-lighter: rgba(
var(--mono-rgb-100),
0.045
);
--dynamic-outline-background-accent: hsla(
var(--accent-h),
var(--accent-s),
var(--accent-l),
0.075
);
/* Outline Window */
--dynamic-outline-input-height: var(--input-height);
--dynamic-outline-input-background-color: var(--background-primary);
--dynamic-outline-background: var(--background-primary);
--dynamic-outline-text-color: var(--text-normal);
--dynamic-outline-font-size: var(--font-text-size);
--dynamic-outline-color: var(--text-normal);
--dynamic-outline-border-color: var(--background-modifier-border);
--dynamic-outline-window-width: 256px;
--dynamic-outline-opacity: 1;
--dynamic-outline-window-gap: 4px;
--dynamic-outline-window-offset-top: 0px;
--dynamic-outline-window-offset-bottom: 0px;
--dynamic-outline-status-bar-height-offset-bottom: 30px;
--dynamic-outline-top: calc(
var(--header-height) + var(--dynamic-outline-window-gap) +
var(--dynamic-outline-window-offset-top)
);
--dynamic-outline-top-editing-toolbar: calc(
var(--header-height) + 38px + var(--dynamic-outline-window-gap) +
var(--dynamic-outline-window-offset-top)
);
--dynamic-outline-bottom: calc(
var(--dynamic-outline-window-gap) +
var(--dynamic-outline-window-offset-bottom) +
var(--dynamic-outline-status-bar-height-offset-bottom)
);
/* List items */
--dynamic-outline-background-hover: var(
--dynamic-outline-background-modifier-hover-lighter
);
/* Active Heading */
--dynamic-outline-active-heading-pill-color: var(--interactive-accent);
--dynamic-outline-highlight-font-weight: var(--font-normal);
--dynamic-outline-active-heading-background: var(
--background-modifier-hover
);
/* Headings */
--dynamic-outline-h1-text-color: var(--h1-color);
--dynamic-outline-h2-text-color: var(--h2-color);
--dynamic-outline-h3-text-color: var(--h3-color);
--dynamic-outline-h4-text-color: var(--h4-color);
--dynamic-outline-h5-text-color: var(--h5-color);
--dynamic-outline-h6-text-color: var(--h6-color);
--dynamic-outline-h1-font-weight: var(--font-bold);
--dynamic-outline-h2-font-weight: var(--font-normal);
--dynamic-outline-h3-font-weight: var(--font-normal);
--dynamic-outline-h4-font-weight: var(--font-normal);
--dynamic-outline-h5-font-weight: var(--font-normal);
--dynamic-outline-h6-font-weight: var(--font-normal);
--dynamic-outline-h1-font-style: var(--h1-style);
--dynamic-outline-h2-font-style: var(--h2-style);
--dynamic-outline-h3-font-style: var(--h3-style);
--dynamic-outline-h4-font-style: var(--h4-style);
--dynamic-outline-h5-font-style: var(--h5-style);
--dynamic-outline-h6-font-style: var(--h6-style);
--dynamic-outline-h1-font-variant: var(--h1-variant);
--dynamic-outline-h2-font-variant: var(--h2-variant);
--dynamic-outline-h3-font-variant: var(--h3-variant);
--dynamic-outline-h4-font-variant: var(--h4-variant);
--dynamic-outline-h5-font-variant: var(--h5-variant);
--dynamic-outline-h6-font-variant: var(--h6-variant);
}
.theme-light {
--dynamic-outline-shadow-color: rgba(99, 99, 99, 0.2);
}
.theme-dark {
--dynamic-outline-shadow-color: rgba(0, 0, 0, 0.2);
}
#dynamic-outline,
#dynamic-outline ul,
#dynamic-outline li {
margin: 0;
padding: 0;
list-style: none;
}
.setting-item.is-disabled {
pointer-events: none;
opacity: 0.5;
}
/*
* Dynamic Outline Window
*/
#dynamic-outline {
position: fixed;
display: flex;
flex-direction: column;
z-index: var(--layer-popover);
top: var(--dynamic-outline-top);
max-height: calc(
100% - var(--dynamic-outline-top) - var(--dynamic-outline-bottom)
);
width: var(--dynamic-outline-window-width);
/* padding: 10px 0 5px; */
padding: 5px 0 5px;
right: 20px;
font-size: var(--dynamic-outline-font-size);
background-color: var(--dynamic-outline-background);
border: 1px solid var(--dynamic-outline-border-color);
border-radius: 12px;
box-shadow: var(--dynamic-outline-shadow-color) 0px 2px 8px 0px;
box-sizing: border-box;
opacity: var(--dynamic-outline-opacity);
}
#dynamic-outline.hidden {
display: none;
}
/* Corner case for the Editing Toolbar plugin */
.view-content
> .markdown-source-view[style=""]
~ #dynamic-outline.obstruction-top {
top: var(--dynamic-outline-top-editing-toolbar);
max-height: calc(
100% - var(--dynamic-outline-top-editing-toolbar) -
var(--dynamic-outline-bottom)
);
}
#dynamic-outline.location-left {
right: unset;
left: 20px;
}
#dynamic-outline:hover {
opacity: 1;
}
button.dynamic-outline-reload[disabled] {
display: none;
}
/*
* Dynamic Outline Search Container
*/
.dynamic-outline-search-container.hidden {
display: none;
}
.dynamic-outline-search-container {
display: flex;
align-items: center;
margin-top: 5px;
margin-bottom: 5px;
}
.dynamic-outline-search-container::before {
display: block;
content: "";
height: var(--search-icon-size);
width: var(--search-icon-size);
position: absolute;
inset-inline-start: 22px;
background-color: var(--search-icon-color);
-webkit-mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='11' cy='11' r='8'></circle><line x1='21' y1='21' x2='16.65' y2='16.65'></line></svg>");
-webkit-mask-repeat: no-repeat;
}
/* Tweak pixels */
.dynamic-outline-search-container input {
display: block;
width: 100%;
padding-inline-start: 32px;
}
.dynamic-outline-search-container input.has-content {
padding-inline-end: 32px;
}
.dynamic-outline-search-clear-button {
display: none;
margin: 0;
top: calc((var(--input-height) - var(--search-icon-size)) + 6px);
right: 10px;
}
.dynamic-outline-search-clear-button.visible {
display: block;
}
/*
* Dynamic Outline Content Container
*/
.dynamic-outline-search-container.hidden ~ .dynamic-outline-content-container {
margin-top: 10px;
margin-bottom: 5px;
}
.dynamic-outline-content-container {
overflow-y: auto;
padding: 0 15px;
}
.dynamic-outline-search-container {
padding: 0 15px;
}
/*
* Dynamic Outline List Items
*/
#dynamic-outline li {
display: flex;
align-items: center;
padding: 7px 0;
margin: 1px 0;
transition: background 25ms linear;
border-radius: 6px;
}
.dynamic-outline-collapse-icon {
/* background-color: var(--color-green); */
display: flex;
align-items: center;
justify-content: center;
width: var(--dynamic-outline-collapse-icon-width);
height: var(--dynamic-outline-collapse-icon-width);
margin-left: 8px;
color: var(--text-muted);
transition: transform 0.1s ease-in-out, visibility 0s linear;
flex-shrink: 0;
}
.dynamic-outline-collapse-icon svg {
width: var(--dynamic-outline-collapse-icon-width);
height: var(--dynamic-outline-collapse-icon-width);
stroke-width: 3;
}
#dynamic-outline li:not(.has-children) .dynamic-outline-collapse-icon {
visibility: hidden !important;
cursor: default;
}
/* Hide collapse icon for single top-level items, even if they have children */
#dynamic-outline li.is-single-top-level .dynamic-outline-collapse-icon {
visibility: hidden !important;
cursor: default;
}
#dynamic-outline li.collapsed > .dynamic-outline-collapse-icon {
color: var(--text-accent);
transform: rotate(-90deg);
}
.dynamic-outline-collapse-icon:hover {
color: var(--text-normal);
}
#dynamic-outline li:hover,
#dynamic-outline li.highlight:hover,
#dynamic-outline li.hovered,
#dynamic-outline li.highlight.hovered {
background-color: var(--dynamic-outline-background-hover);
}
#dynamic-outline li.highlight {
position: relative;
background-color: var(--dynamic-outline-active-heading-background);
}
#dynamic-outline li.highlight::before {
color: var(--dynamic-outline-active-heading-pill-color) !important;
}
#dynamic-outline li.highlight::after {
content: "";
position: absolute;
inset-inline-start: -8px;
width: 4px;
background-color: var(--dynamic-outline-active-heading-pill-color);
border-radius: 8px;
/*
* Center the highlight indicator vertically.
*/
top: 50%;
transform: translateY(-50%);
height: 22px;
}
.heading-level-styling-1 #dynamic-outline li::before,
.heading-level-styling-2 #dynamic-outline li::before {
font-size: var(--font-smallest);
color: var(--text-faint);
margin-left: 0.5em;
margin-right: 0.25em;
}
.heading-level-styling-1 #dynamic-outline li.li-heading-level-1::before {
content: "H1";
}
.heading-level-styling-1 #dynamic-outline li.li-heading-level-2::before {
content: "H2";
}
.heading-level-styling-1 #dynamic-outline li.li-heading-level-3::before {
content: "H3";
}
.heading-level-styling-1 #dynamic-outline li.li-heading-level-4::before {
content: "H4";
}
.heading-level-styling-1 #dynamic-outline li.li-heading-level-5::before {
content: "H5";
}
.heading-level-styling-1 #dynamic-outline li.li-heading-level-6::before {
content: "H6";
}
.heading-level-styling-2 #dynamic-outline li.li-heading-level-1::before {
content: "#";
}
.heading-level-styling-2 #dynamic-outline li.li-heading-level-2::before {
content: "##";
}
.heading-level-styling-2 #dynamic-outline li.li-heading-level-3::before {
content: "###";
}
.heading-level-styling-2 #dynamic-outline li.li-heading-level-4::before {
content: "####";
}
.heading-level-styling-2 #dynamic-outline li.li-heading-level-5::before {
content: "#####";
}
.heading-level-styling-2 #dynamic-outline li.li-heading-level-6::before {
content: "######";
}
#dynamic-outline li a {
padding: 0px 8px;
color: var(--dynamic-outline-text-color);
text-decoration: none;
cursor: default;
flex-grow: 1; /* Allow text to take remaining space */
min-width: 0; /* Prevent overflow issues with flex */
}
.disable-heading-word-wrap #dynamic-outline li a {
/* Text Handling */
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
/* Default padding */
#dynamic-outline li.tab-level-2 {
padding-left: var(--dynamic-outline-li-padding-tab-size);
}
#dynamic-outline li.tab-level-3 {
padding-left: calc(var(--dynamic-outline-li-padding-tab-size) * 2);
}
#dynamic-outline li.tab-level-4 {
padding-left: calc(var(--dynamic-outline-li-padding-tab-size) * 3);
}
#dynamic-outline li.tab-level-5 {
padding-left: calc(var(--dynamic-outline-li-padding-tab-size) * 4);
}
#dynamic-outline li.tab-level-6 {
padding-left: calc(var(--dynamic-outline-li-padding-tab-size) * 5);
}
/* Override padding when there is only one top-level heading */
#dynamic-outline.has-single-top-level li.tab-level-2 {
padding-left: 0;
}
#dynamic-outline.has-single-top-level li.tab-level-3 {
padding-left: var(--dynamic-outline-li-padding-tab-size); /* Effectively level 2 */
}
#dynamic-outline.has-single-top-level li.tab-level-4 {
padding-left: calc(var(--dynamic-outline-li-padding-tab-size) * 2); /* Effectively level 3 */
}
#dynamic-outline.has-single-top-level li.tab-level-5 {
padding-left: calc(var(--dynamic-outline-li-padding-tab-size) * 3); /* Effectively level 4 */
}
#dynamic-outline.has-single-top-level li.tab-level-6 {
padding-left: calc(var(--dynamic-outline-li-padding-tab-size) * 4); /* Effectively level 5 */
}
#dynamic-outline li a.heading-level-1 {
color: var(--dynamic-outline-h1-text-color);
font-weight: var(--dynamic-outline-h1-font-weight);
font-style: var(--dynamic-outline-h1-font-style);
font-variant: var(--dynamic-outline-h1-font-variant);
}
#dynamic-outline li a.heading-level-2 {
color: var(--dynamic-outline-h2-text-color);
font-weight: var(--dynamic-outline-h2-font-weight);
font-style: var(--dynamic-outline-h2-font-style);
font-variant: var(--dynamic-outline-h2-font-variant);
}
#dynamic-outline li a.heading-level-3 {
color: var(--dynamic-outline-h3-text-color);
font-weight: var(--dynamic-outline-h3-font-weight);
font-style: var(--dynamic-outline-h3-font-style);
font-variant: var(--dynamic-outline-h3-font-variant);
}
#dynamic-outline li a.heading-level-4 {
color: var(--dynamic-outline-h4-text-color);
font-weight: var(--dynamic-outline-h4-font-weight);
font-style: var(--dynamic-outline-h4-font-style);
font-variant: var(--dynamic-outline-h4-font-variant);
}
#dynamic-outline li a.heading-level-5 {
color: var(--dynamic-outline-h5-text-color);
font-weight: var(--dynamic-outline-h5-font-weight);
font-style: var(--dynamic-outline-h5-font-style);
font-variant: var(--dynamic-outline-h5-font-variant);
}
#dynamic-outline li a.heading-level-6 {
color: var(--dynamic-outline-h6-text-color);
font-weight: var(--dynamic-outline-h6-font-weight);
font-style: var(--dynamic-outline-h6-font-style);
font-variant: var(--dynamic-outline-h6-font-variant);
}
#dynamic-outline li.highlight .heading-level-1 {
font-weight: max(
var(--dynamic-outline-h1-font-weight),
var(--dynamic-outline-highlight-font-weight)
); /* Preserve the maximum font weight on highlight. */
}
#dynamic-outline li.highlight .heading-level-2 {
font-weight: max(
var(--dynamic-outline-h2-font-weight),
var(--dynamic-outline-highlight-font-weight)
); /* Preserve the maximum font weight on highlight. */
}
#dynamic-outline li.highlight .heading-level-3 {
font-weight: max(
var(--dynamic-outline-h3-font-weight),
var(--dynamic-outline-highlight-font-weight)
); /* Preserve the maximum font weight on highlight. */
}
#dynamic-outline li.highlight .heading-level-4 {
font-weight: max(
var(--dynamic-outline-h4-font-weight),
var(--dynamic-outline-highlight-font-weight)
); /* Preserve the maximum font weight on highlight. */
}
#dynamic-outline li.highlight .heading-level-5 {
font-weight: max(
var(--dynamic-outline-h5-font-weight),
var(--dynamic-outline-highlight-font-weight)
); /* Preserve the maximum font weight on highlight. */
}
#dynamic-outline li.highlight .heading-level-6 {
font-weight: max(
var(--dynamic-outline-h6-font-weight),
var(--dynamic-outline-highlight-font-weight)
); /* Preserve the maximum font weight on highlight. */
}
#dynamic-outline .outline-item-hidden { /* Rule for items hidden by search */
display: none !important;
}
/* Hide by collapse ONLY when NOT searching */
#dynamic-outline:not(.is-searching) li.hidden-by-collapse {
display: none !important;
}
/*
* Dynamic Outline Button
*/
.dynamic-outline-button.button-active {
box-shadow: none;
opacity: var(--icon-opacity-hover);
color: var(--icon-color-hover);
background-color: var(--background-modifier-hover);
}
.dynamic-outline-button.pinned {
color: var(--text-normal);
}
.dynamic-outline-button.hidden,
.hide-button-from-toolbar .dynamic-outline-button {
display: none;
}
/*
* Other
*/
/* Custom Style Settings left padding for the headings sublist. */
.setting-item[data-id="obsidian-dynamic-outline"]
+ .style-settings-container
.setting-item[data-id="headings"]
+ .style-settings-container {
padding-left: 17px;
}
/* Custom hide logic for settings options */
.setting-item.dynamic-outline-setting-item-hidden.is-disabled {
display: none;
}