mirror of
https://github.com/zadam/trilium.git
synced 2025-10-20 07:08:55 +02:00
607 lines
15 KiB
CSS
607 lines
15 KiB
CSS
@import url(./forms.css);
|
|
@import url(./shell.css);
|
|
@import url(./dialogs.css);
|
|
@import url(./pages.css);
|
|
@import url(./ribbon.css);
|
|
@import url(./notes/text.css);
|
|
@import url(./notes/canvas.css);
|
|
@import url(./notes/collections/table.css);
|
|
|
|
@font-face {
|
|
font-family: "Inter";
|
|
src: url(../../fonts/Inter/Inter-VariableFont_opsz,wght.ttf);
|
|
}
|
|
|
|
/*
|
|
* GLOBAL VARIABLES
|
|
*/
|
|
|
|
:root {
|
|
--main-font-family: "Inter", sans-serif;
|
|
|
|
--main-font-size: normal;
|
|
|
|
--tree-font-family: var(--main-font-family);
|
|
--tree-font-size: normal;
|
|
|
|
--detail-font-family: var(--main-font-family);
|
|
--detail-font-size: normal;
|
|
|
|
--monospace-font-family: JetBrainsLight, monospace;
|
|
--monospace-font-size: normal;
|
|
|
|
--left-pane-item-selected-shadow-size: 2px;
|
|
|
|
--launcher-pane-vert-size: 58px;
|
|
--launcher-pane-vert-icon-size: 150%;
|
|
--launcher-pane-vert-button-margin: 6px;
|
|
--launcher-pane-vert-button-gap: 3px;
|
|
|
|
--launcher-pane-horiz-size: 54px;
|
|
--launcher-pane-horiz-icon-size: 20px;
|
|
--launcher-pane-horiz-button-margin: 8px;
|
|
--launcher-pane-horiz-button-gap: 3px;
|
|
|
|
--tree-actions-toolbar-horizontal-margin: 8px;
|
|
--tree-actions-toolbar-vertical-margin: 8px;
|
|
--tree-actions-toolbar-padding-size: 4px;
|
|
--tree-actions-toolbar-collapsed-width: 40px;
|
|
--tree-actions-toolbar-expand-button-size: 25px;
|
|
|
|
--tab-bar-height: 50px;
|
|
--tab-height: 36px;
|
|
--tab-first-item-horiz-offset: 1px;
|
|
--new-tab-button-size: 24px;
|
|
|
|
--center-pane-border-radius: 10px;
|
|
|
|
--floating-button-height: 34px;
|
|
--floating-button-width: 40px;
|
|
--floating-button-icon-size: 20px;
|
|
--floating-button-show-hide-button-size: 26px;
|
|
|
|
--menu-padding-size: 8px;
|
|
--menu-item-icon-vert-offset: -2px;
|
|
|
|
--more-accented-background-color: var(--card-background-hover-color);
|
|
|
|
--timeline-left-gap: 20px;
|
|
--timeline-right-gap: 20px;
|
|
--timeline-item-top-padding: 4px;
|
|
--timeline-item-bottom-padding: 8px;
|
|
--timeline-bullet-size: 10px;
|
|
--timeline-bullet-vertical-pos: 0.75em;
|
|
--timeline-connector-size: 4px;
|
|
|
|
--help-backdrop-blur: 10px;
|
|
|
|
--icon-button-size: 32px;
|
|
--icon-button-icon-ratio: 0.65;
|
|
|
|
--modal-control-button-size: 22px;
|
|
|
|
/* Theme capabilities */
|
|
--tab-note-icons: true;
|
|
}
|
|
|
|
body.backdrop-effects-disabled {
|
|
/* Backdrop effects are disabled, replace the menu background color with the
|
|
* no-backdrop fallback color */
|
|
--menu-background-color: var(--menu-background-color-no-backdrop);
|
|
}
|
|
|
|
/*
|
|
* MENUS
|
|
*
|
|
* Note: apply the "tn-dropdown-list" class for scrollable dropdown menus. Submenus are not
|
|
* supported when this class is used.
|
|
*/
|
|
|
|
.dropdown-menu:not(.static),
|
|
:root .excalidraw .popover {
|
|
border-radius: var(--dropdown-border-radius);
|
|
padding: var(--menu-padding-size) !important;
|
|
font-size: 0.9rem !important;
|
|
}
|
|
|
|
body.mobile .dropdown-menu {
|
|
backdrop-filter: var(--dropdown-backdrop-filter);
|
|
border-radius: var(--dropdown-border-radius);
|
|
position: relative;
|
|
}
|
|
|
|
body.mobile .dropdown-menu .dropdown-menu {
|
|
backdrop-filter: unset !important;
|
|
border-radius: unset !important;
|
|
}
|
|
|
|
body.desktop .dropdown-menu::before,
|
|
:root .ck.ck-dropdown__panel::before,
|
|
:root .excalidraw .popover::before {
|
|
content: "";
|
|
backdrop-filter: var(--dropdown-backdrop-filter);
|
|
border-radius: var(--dropdown-border-radius);
|
|
position: absolute;
|
|
top: 0;
|
|
inset-inline-start: 0;
|
|
inset-inline-end: 0;
|
|
bottom: 0;
|
|
z-index: -1;
|
|
}
|
|
|
|
body.desktop .dropdown-menu.tn-dropdown-list {
|
|
backdrop-filter: var(--dropdown-backdrop-filter);
|
|
}
|
|
|
|
body.desktop .dropdown-menu.tn-dropdown-list::before {
|
|
display: none;
|
|
}
|
|
|
|
body.desktop .dropdown-submenu .dropdown-menu::before {
|
|
content: unset;
|
|
}
|
|
|
|
body.mobile .dropdown-submenu .dropdown-menu {
|
|
background: transparent !important;
|
|
}
|
|
|
|
body.desktop .dropdown-submenu .dropdown-menu {
|
|
backdrop-filter: var(--dropdown-backdrop-filter);
|
|
background: transparent;
|
|
}
|
|
|
|
.dropdown-item,
|
|
body.mobile .dropdown-submenu .dropdown-toggle,
|
|
:root .excalidraw .context-menu .context-menu-item {
|
|
padding: 2px 2px 2px 8px !important;
|
|
padding-inline-end: 22px !important;
|
|
/* Note: the right padding should also accommodate the submenu arrow. */
|
|
border-radius: 6px;
|
|
cursor: default !important;
|
|
}
|
|
|
|
:root .dropdown-item:focus-visible {
|
|
outline: 2px solid var(--input-focus-outline-color) !important;
|
|
background-color: transparent;
|
|
color: unset;
|
|
}
|
|
|
|
:root .dropdown-item:active {
|
|
background: unset;
|
|
}
|
|
|
|
body.mobile .dropdown-submenu {
|
|
padding: 0 !important;
|
|
}
|
|
|
|
body.mobile .dropdown-item:not(:last-of-type) {
|
|
margin-bottom: 0.5em;
|
|
}
|
|
|
|
body.mobile .dropdown-submenu:hover {
|
|
background: transparent !important;
|
|
}
|
|
|
|
html body .dropdown-item.disabled,
|
|
html body .dropdown-item[disabled] {
|
|
color: var(--menu-text-color) !important;
|
|
opacity: var(--menu-item-disabled-opacity);
|
|
}
|
|
|
|
/* Badges */
|
|
:root .badge {
|
|
--bs-badge-color: var(--badge-text-color);
|
|
--bs-badge-font-weight: 500;
|
|
|
|
background: var(--badge-background-color);
|
|
text-transform: uppercase;
|
|
letter-spacing: .2pt;
|
|
}
|
|
|
|
/* Menu item icon */
|
|
.dropdown-item .bx {
|
|
translate: 0 var(--menu-item-icon-vert-offset);
|
|
color: var(--menu-item-icon-color) !important;
|
|
font-size: 1.1em;
|
|
}
|
|
|
|
/* Menu item keyboard shortcut */
|
|
.dropdown-item kbd,
|
|
.excalidraw .context-menu-item__shortcut {
|
|
font-family: unset !important;
|
|
font-size: unset !important;
|
|
color: var(--menu-item-keyboard-shortcut-color) !important;
|
|
padding-top: 0;
|
|
}
|
|
|
|
.dropdown-item span.keyboard-shortcut {
|
|
color: var(--menu-item-keyboard-shortcut-color) !important;
|
|
margin-inline-start: 16px;
|
|
}
|
|
|
|
.dropdown-divider,
|
|
.excalidraw .context-menu hr {
|
|
position: relative;
|
|
border-color: transparent !important;
|
|
overflow: visible;
|
|
}
|
|
|
|
.dropdown-divider::after,
|
|
.excalidraw .context-menu hr::before {
|
|
position: absolute;
|
|
content: "";
|
|
top: -1px;
|
|
inset-inline-start: calc(0px - var(--menu-padding-size));
|
|
inset-inline-end: calc(0px - var(--menu-padding-size));
|
|
border-top: 1px solid var(--menu-item-delimiter-color);
|
|
}
|
|
|
|
/* Menu item arrow */
|
|
.dropdown-menu .dropdown-toggle::after {
|
|
content: "\ed3b" !important;
|
|
position: absolute;
|
|
display: flex !important;
|
|
align-items: center;
|
|
justify-content: center;
|
|
top: 0;
|
|
inset-inline-end: 0;
|
|
margin: unset !important;
|
|
border: unset !important;
|
|
padding: 0 4px;
|
|
font-family: boxicons;
|
|
font-size: 1.2em;
|
|
color: var(--menu-item-arrow-color) !important;
|
|
}
|
|
|
|
body[dir=rtl] .dropdown-menu:not([data-popper-placement="bottom-start"]) .dropdown-toggle::after {
|
|
content: "\ea4d" !important;
|
|
}
|
|
|
|
/* Menu item group heading */
|
|
|
|
/* The heading body */
|
|
.dropdown-menu h6 {
|
|
position: relative;
|
|
background: transparent;
|
|
padding: 1em 8px 14px 8px;
|
|
text-transform: uppercase;
|
|
font-size: 0.8em;
|
|
letter-spacing: 1pt;
|
|
color: var(--menu-item-group-header-color) !important;
|
|
}
|
|
|
|
/* The delimiter line */
|
|
.dropdown-menu h6::before {
|
|
content: "";
|
|
position: absolute;
|
|
bottom: 8px;
|
|
inset-inline-start: calc(0px - var(--menu-padding-size));
|
|
inset-inline-end: calc(0px - var(--menu-padding-size));
|
|
border-top: 1px solid var(--menu-item-delimiter-color);
|
|
}
|
|
|
|
/* Static menus (used as a list, such as on the note revisions dialog) */
|
|
body.desktop .dropdown-menu.static {
|
|
box-shadow: unset;
|
|
border-radius: 4px;
|
|
border: unset;
|
|
background-color: var(--card-background-color) !important;
|
|
padding: var(--menu-padding-size) !important;
|
|
user-select: none;
|
|
}
|
|
|
|
body.desktop .dropdown-menu.static .dropdown-item.active {
|
|
--active-item-text-color: var(--menu-text-color);
|
|
}
|
|
|
|
body.desktop .dropdown-menu .dropdown-toggle::after {
|
|
height: 100%;
|
|
}
|
|
|
|
body.mobile .dropdown-menu .dropdown-toggle::after {
|
|
transform: rotate(90deg);
|
|
}
|
|
|
|
body.mobile .dropdown-menu .dropdown-item.submenu-open .dropdown-toggle::after {
|
|
transform: rotate(270deg);
|
|
}
|
|
|
|
/* Dropdown item button (used in zoom buttons in global menu) */
|
|
|
|
li.dropdown-item a.dropdown-item-button {
|
|
border: unset;
|
|
}
|
|
|
|
li.dropdown-item a.dropdown-item-button.bx {
|
|
color: var(--menu-text-color) !important;
|
|
}
|
|
|
|
li.dropdown-item a.dropdown-item-button:focus-visible {
|
|
outline: 2px solid var(--input-focus-outline-color) !important;
|
|
}
|
|
|
|
/*
|
|
* TOASTS
|
|
*/
|
|
|
|
#toast-container {
|
|
/* The vertical gap between toasts */
|
|
gap: 10px;
|
|
}
|
|
|
|
#toast-container .toast {
|
|
--bs-toast-padding-x: 12px;
|
|
--bs-border-radius: 8px;
|
|
--bs-toast-bg: var(--toast-background);
|
|
--bs-toast-color: var(--toast-text-color);
|
|
--modal-control-button-background: var(--toast-close-button-background);
|
|
--modal-control-button-color: var(--bs-toast-color);
|
|
|
|
display: flex;
|
|
flex-direction: column;
|
|
backdrop-filter: blur(6px);
|
|
}
|
|
|
|
#toast-container .toast .toast-header {
|
|
background: transparent !important;
|
|
border-bottom: none;
|
|
color: var(--toast-text-color) !important;
|
|
}
|
|
|
|
#toast-container .toast .toast-header strong > * {
|
|
vertical-align: middle;
|
|
}
|
|
|
|
#toast-container .toast .toast-header .btn-close {
|
|
margin: 0 0 0 12px;
|
|
}
|
|
|
|
#toast-container .toast.no-title {
|
|
flex-direction: row;
|
|
}
|
|
|
|
#toast-container .toast .toast-body {
|
|
flex-grow: 1;
|
|
overflow: hidden;
|
|
text-overflow: ellipsis;
|
|
padding-top: 0;
|
|
}
|
|
|
|
#toast-container .toast:not(.no-title) .bx {
|
|
margin-inline-end: 0.5em;
|
|
font-size: 1.1em;
|
|
opacity: 0.85;
|
|
}
|
|
|
|
#toast-container .toast.no-title .bx {
|
|
margin-inline-end: 0;
|
|
font-size: 1.3em;
|
|
}
|
|
|
|
#toast-container .toast.no-title .toast-body {
|
|
padding-top: var(--bs-toast-padding-x);
|
|
color: var(--toast-text-color);
|
|
}
|
|
|
|
/*
|
|
* NOTE TOOLTIPS
|
|
*/
|
|
|
|
.tooltip .tooltip-inner:has(.note-tooltip-content) {
|
|
border-radius: 8px;
|
|
}
|
|
|
|
.note-tooltip-content {
|
|
padding: 8px;
|
|
min-height: 56px;
|
|
}
|
|
|
|
.note-tooltip-title .note-title-with-path {
|
|
display: flex;
|
|
flex-direction: column-reverse;
|
|
}
|
|
|
|
.note-tooltip-title a {
|
|
color: inherit !important;
|
|
}
|
|
|
|
.note-tooltip-title.note-no-content {
|
|
margin: 0;
|
|
}
|
|
|
|
.note-tooltip-title:not(.note-no-content) .note-title-with-path {
|
|
padding-bottom: 6px;
|
|
border-bottom: 2px solid currentColor;
|
|
}
|
|
|
|
.note-tooltip-content .note-path {
|
|
display: block;
|
|
color: var(--muted-text-color);
|
|
font-size: 0.75em;
|
|
}
|
|
|
|
.note-tooltip-content .note-tooltip-attributes {
|
|
margin-top: -4px;
|
|
font-size: 0.75em;
|
|
}
|
|
|
|
.note-tooltip-content .rendered-content {
|
|
padding-top: 12px;
|
|
}
|
|
|
|
/* NOTE PATHS */
|
|
|
|
.note-path .path-bracket {
|
|
/* Hide the leading and trailing bracket from the path */
|
|
display: none;
|
|
}
|
|
|
|
.note-path .path-delimiter {
|
|
/* Hide the path delimiters (slashes) */
|
|
display: none;
|
|
}
|
|
|
|
.note-path .path-delimiter + span::before {
|
|
/* Replace the path delimiters with arrows */
|
|
display: inline-block;
|
|
content: "\ed3b";
|
|
padding: 0 0.25em;
|
|
font-family: boxicons;
|
|
opacity: 0.75;
|
|
transform: translateY(4%);
|
|
}
|
|
|
|
/*
|
|
* NOTE LIST
|
|
*/
|
|
|
|
.note-list .note-book-card {
|
|
--note-list-horizontal-padding: 22px;
|
|
--note-list-vertical-padding: 15px;
|
|
background-color: var(--card-background-color);
|
|
border: 1px solid var(--card-border-color) !important;
|
|
box-shadow: 2px 3px 4px var(--card-shadow-color);
|
|
border-radius: 12px;
|
|
user-select: none;
|
|
padding: 0;
|
|
margin: 5px 10px 5px 0;
|
|
}
|
|
|
|
.note-list.list-view .note-book-card {
|
|
box-shadow: 0 0 3px var(--card-shadow-color);
|
|
}
|
|
|
|
.note-list.list-view .note-book-card .note-book-header .note-icon {
|
|
vertical-align: middle;
|
|
}
|
|
|
|
.note-list-wrapper .note-book-card:active {
|
|
background-color: var(--card-background-press-color);
|
|
}
|
|
|
|
.note-list-wrapper .note-book-card a {
|
|
color: inherit !important;
|
|
}
|
|
|
|
.note-list-wrapper .note-book-card .note-book-header {
|
|
font-size: 1em;
|
|
font-weight: bold;
|
|
padding: 0.5em 1rem;
|
|
border-bottom-color: var(--card-border-color);
|
|
}
|
|
|
|
.note-list-wrapper .note-book-card .note-book-header .note-icon {
|
|
font-size: 17px;
|
|
vertical-align: text-bottom;
|
|
}
|
|
|
|
.note-list-wrapper .note-book-card .note-book-header .note-book-title {
|
|
font-size: 1em;
|
|
color: var(--active-item-text-color);
|
|
vertical-align: middle;
|
|
}
|
|
|
|
.note-list-wrapper .note-book-card .note-book-header .rendered-note-attributes {
|
|
font-size: 0.7em;
|
|
font-weight: normal;
|
|
margin-bottom: 0;
|
|
}
|
|
|
|
.note-list-wrapper .note-book-card .note-book-header:last-child {
|
|
border-bottom: 0;
|
|
}
|
|
|
|
.note-list-wrapper .note-book-card .note-book-content {
|
|
padding: 0 !important;
|
|
font-size: 0.8rem;
|
|
}
|
|
|
|
.note-list-wrapper .note-book-card .note-book-content .rendered-content {
|
|
padding: 1rem;
|
|
}
|
|
|
|
.note-list-wrapper .note-book-card .note-book-content.type-image .rendered-content,
|
|
.note-list-wrapper .note-book-card .note-book-content.type-pdf .rendered-content {
|
|
padding: 0;
|
|
}
|
|
|
|
.note-list-wrapper .note-book-card .note-book-content .rendered-content.text-with-ellipsis {
|
|
padding: 1rem !important;
|
|
}
|
|
|
|
.note-list-wrapper .note-book-card .note-book-content h1,
|
|
.note-list-wrapper .note-book-card .note-book-content h2,
|
|
.note-list-wrapper .note-book-card .note-book-content h3,
|
|
.note-list-wrapper .note-book-card .note-book-content h4,
|
|
.note-list-wrapper .note-book-card .note-book-content h5,
|
|
.note-list-wrapper .note-book-card .note-book-content h6 {
|
|
font-size: 1rem;
|
|
color: var(--active-item-text-color);
|
|
}
|
|
|
|
.note-list-wrapper .note-book-card .note-book-content p:last-child {
|
|
margin-bottom: 0;
|
|
}
|
|
|
|
.note-list-wrapper .note-book-card .note-book-content.type-canvas .rendered-content,
|
|
.note-list-wrapper .note-book-card .note-book-content.type-mindMap .rendered-content,
|
|
.note-list-wrapper .note-book-card .note-book-content.type-code .rendered-content,
|
|
.note-list-wrapper .note-book-card .note-book-content.type-video .rendered-content {
|
|
padding: 0;
|
|
}
|
|
|
|
.note-list-wrapper .note-book-card .note-book-content.type-code pre {
|
|
height: 100%;
|
|
padding: 1em;
|
|
}
|
|
|
|
.note-list-wrapper .note-book-card .bx {
|
|
color: var(--left-pane-icon-color) !important;
|
|
}
|
|
|
|
.note-list.grid-view .note-book-card:hover {
|
|
background: var(--card-background-color) !important;
|
|
filter: contrast(105%);
|
|
}
|
|
|
|
.note-list.grid-view .note-book-card img {
|
|
object-fit: cover !important;
|
|
width: 100%;
|
|
}
|
|
|
|
.note-list.grid-view .ck-content {
|
|
line-height: 1.3;
|
|
}
|
|
|
|
.note-list.grid-view .ck-content p {
|
|
margin-bottom: 0.5em;
|
|
}
|
|
|
|
.note-list.grid-view .ck-content figure.image {
|
|
width: 25%;
|
|
}
|
|
|
|
/*
|
|
* NOTE SEARCH SUGGESTIONS
|
|
*/
|
|
|
|
/* List body */
|
|
.jump-to-note-dialog .jump-to-note-results .aa-suggestions,
|
|
.note-detail-empty .aa-suggestions {
|
|
padding: 0;
|
|
}
|
|
|
|
/* List item */
|
|
.jump-to-note-dialog .aa-suggestion,
|
|
.note-detail-empty .aa-suggestion {
|
|
border-radius: 6px;
|
|
color: var(--menu-text-color);
|
|
cursor: default;
|
|
}
|
|
|
|
/* Selected list item */
|
|
.jump-to-note-dialog .aa-suggestions div.aa-cursor,
|
|
.note-detail-empty .aa-suggestions div.aa-cursor {
|
|
background: var(--hover-item-background-color);
|
|
color: var(--hover-item-text-color);
|
|
} |