obsidian-visualiser/assets/canvas.css

1065 lines
26 KiB
CSS

.mod-canvas-color-1 {
--canvas-color: var(--canvas-color-1);
}
.mod-canvas-color-2 {
--canvas-color: var(--canvas-color-2);
}
.mod-canvas-color-3 {
--canvas-color: var(--canvas-color-3);
}
.mod-canvas-color-4 {
--canvas-color: var(--canvas-color-4);
}
.mod-canvas-color-5 {
--canvas-color: var(--canvas-color-5);
}
.mod-canvas-color-6 {
--canvas-color: var(--canvas-color-6);
}
.workspace-leaf-content[data-type='canvas'] .view-content {
padding: 0;
position: relative;
}
body {
--canvas-color: 192, 192, 192;
}
body.theme-dark {
--canvas-color: 126, 126, 126;
}
.canvas-wrapper {
position: absolute;
width: 100%;
height: 100%;
left: 0;
top: 0;
--resizer-size: 20px;
--shadow-stationary: 0px 0.5px 1px 0.5px rgba(0, 0, 0, 0.1);
--shadow-drag: 0px 2px 10px rgba(0, 0, 0, 0.1);
--shadow-border-accent: 0 0 0 2px var(--color-accent);
--zoom-multiplier: 1;
background-color: var(--canvas-background);
overflow: hidden;
contain: strict;
touch-action: none;
user-select: none;
}
.canvas-wrapper.is-dragging {
cursor: grabbing;
}
.canvas-wrapper.is-dragging iframe:not(.is-controlled),
.canvas-wrapper.is-dragging webview {
pointer-events: none;
}
.canvas-wrapper.is-screenshotting {
z-index: 999999;
}
.canvas-wrapper.is-screenshotting .canvas-card-menu,
.canvas-wrapper.is-screenshotting .canvas-controls {
display: none !important;
}
.canvas-wrapper.is-screenshotting * {
pointer-events: none !important;
}
.canvas-mover {
position: absolute;
width: 100%;
height: 100%;
left: 0;
top: 0;
cursor: grab;
}
.canvas-mover:active {
cursor: grabbing;
}
.canvas-background {
position: absolute;
width: 100%;
height: 100%;
left: 0;
top: 0;
pointer-events: none;
}
.canvas-background circle {
fill: var(--canvas-dot-pattern);
}
.canvas {
position: absolute;
width: 100%;
height: 100%;
left: 0;
top: 0;
transform-origin: 0 0;
pointer-events: none;
}
.canvas>* {
pointer-events: initial;
}
.canvas-selection {
pointer-events: none;
position: absolute;
background-color: hsla(var(--color-accent-hsl), 0.1);
border: 2px solid var(--color-accent);
z-index: -1;
}
.canvas-selection.mod-group-selection {
border-width: 3px;
border-radius: 3px;
background-color: hsla(var(--color-accent-hsl), 0.03);
border-color: hsla(var(--color-accent-hsl), 0.3);
pointer-events: initial;
}
.canvas-wrapper:not(.mod-readonly) .canvas-selection.mod-group-selection {
cursor: grab;
}
.canvas-wrapper:not(.mod-readonly) .canvas-selection.mod-group-selection:active {
cursor: grabbing;
}
.canvas-selection.mod-node-highlight {
border-radius: var(--radius-m);
}
.canvas-controls,
.canvas-card-menu {
display: flex;
position: absolute;
z-index: var(--layer-cover);
font-size: var(--font-ui-medium);
}
.canvas-card-menu {
background-color: var(--background-primary);
border-radius: var(--radius-s);
box-shadow: var(--input-shadow);
bottom: var(--size-4-4);
left: 50%;
transform: translatex(-50%);
align-items: stretch;
}
.is-phone .canvas-card-menu,
.mod-toolbar-open .canvas-card-menu {
display: none;
}
.theme-dark .canvas-card-menu {
background-color: var(--background-secondary);
}
.canvas-card-menu .canvas-card-menu-divider {
width: 1px;
background-color: var(--background-modifier-border);
}
.canvas-card-menu .canvas-card-menu-button {
color: var(--text-muted);
height: auto;
display: flex;
line-height: 1;
align-items: center;
justify-content: center;
padding: var(--size-4-2);
--icon-size: var(--icon-xl);
--icon-stroke: var(--icon-xl-stroke-width);
}
@media (hover: hover) {
.canvas-card-menu .canvas-card-menu-button:hover {
color: var(--color-accent);
}
}
.canvas-card-menu .canvas-card-menu-button svg {
fill: var(--background-primary);
}
.theme-dark .canvas-card-menu .canvas-card-menu-button svg {
fill: var(--background-secondary);
}
.canvas-card-menu .canvas-card-menu-button.mod-draggable {
cursor: grab;
}
.canvas-card-menu .canvas-card-menu-button.mod-draggable:active {
cursor: grabbing;
}
.canvas-card-menu .canvas-card-menu-button.mod-draggable svg {
transition: 90ms transform ease-out;
}
@media (hover: hover) {
.canvas-card-menu .canvas-card-menu-button.mod-draggable:hover svg {
transform: translateY(-6px);
filter: drop-shadow(0px 6px 2px rgba(0, 0, 0, 0.1));
}
}
.canvas-controls {
left: var(--size-4-2);
top: var(--size-4-2);
gap: var(--size-4-2);
display: flex;
flex-direction: column;
}
.canvas-control-group {
border-radius: var(--radius-s);
background-color: var(--background-primary);
border: 1px solid var(--background-modifier-border);
box-shadow: var(--input-shadow);
display: flex;
flex-direction: column;
overflow: hidden;
}
.canvas-control-item {
border-radius: 0;
box-shadow: none;
height: auto;
display: flex;
line-height: 1;
font-size: inherit;
align-items: center;
justify-content: center;
cursor: var(--cursor);
padding: var(--size-4-2);
border-bottom: 1px solid var(--background-modifier-border);
color: var(--text-muted);
background-color: var(--interactive-normal);
--icon-size: var(--icon-s);
--icon-stroke: var(--icon-s-stroke-width);
}
.canvas-control-item:last-child {
border-bottom: none;
}
@media (hover: hover) {
.canvas-control-item:hover {
color: var(--text-normal);
background-color: var(--interactive-hover);
}
}
.canvas-control-item.is-active {
color: var(--color-accent);
}
.canvas-control-item.is-disabled svg {
color: var(--text-faint);
}
.canvas-control-item svg {
pointer-events: none;
}
.canvas-node-container {
background-color: var(--background-primary);
border-radius: var(--radius-m);
border: 2px solid rgb(var(--canvas-color));
contain: strict;
display: flex;
flex-direction: column;
overflow: hidden;
position: absolute;
left: 0;
top: 0;
width: 100%;
height: 100%;
box-shadow: var(--shadow-stationary);
}
.canvas-wrapper:not(.mod-readonly) .canvas-node:not(.is-editing) .canvas-node-container {
cursor: grab;
}
.canvas-wrapper:not(.mod-readonly) .canvas-node:not(.is-editing) .canvas-node-container:active {
cursor: grabbing;
}
.canvas-node-label {
position: absolute;
left: 0;
top: calc(-1 * var(--size-4-1) * var(--zoom-multiplier));
transform: translate(0, -100%) scale(var(--zoom-multiplier));
transform-origin: bottom left;
max-width: calc(100% / var(--zoom-multiplier));
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
color: var(--canvas-card-label-color);
--icon-size: 1em;
}
body:not(.is-ios) .canvas-wrapper.mod-animating .canvas-node-label {
transition: transform 500ms cubic-bezier(0.16, 1, 0.3, 1);
}
.canvas-node-label svg {
position: relative;
top: 2px;
margin-right: var(--size-4-1);
}
.canvas-node-label.mod-hover-label {
opacity: 0;
}
@media (hover: hover) {
.canvas-node-label:hover {
color: var(--text-muted);
}
.canvas-node:hover .canvas-node-label.mod-hover-label {
opacity: 1;
}
}
@media (hover: none) {
.canvas-node.is-focused .canvas-node-label.mod-hover-label {
opacity: 1;
}
}
.canvas-wrapper.mod-zoomed-out .canvas-node-label {
display: none;
}
.canvas-node-placeholder {
display: flex;
align-items: center;
justify-content: center;
text-align: center;
width: 100%;
height: 100%;
overflow: hidden;
overflow-wrap: anywhere;
padding: var(--size-4-6);
font-size: 32px;
font-weight: var(--font-semibold);
}
.canvas-node-placeholder::after {
border-radius: var(--radius-s);
content: ' ';
display: block;
position: absolute;
top: var(--size-4-4);
right: var(--size-4-4);
bottom: var(--size-4-4);
left: var(--size-4-4);
background-color: rgba(var(--canvas-color), 0.1);
}
.canvas-icon-placeholder {
display: flex;
width: 40%;
height: 40%;
}
.canvas-icon-placeholder svg {
opacity: 0.3;
color: rgb(var(--canvas-color));
width: 100%;
height: 100%;
}
.canvas-node-interaction-layer {
position: absolute;
width: 0;
height: 0;
pointer-events: none;
}
.canvas-node-interaction-layer>* {
pointer-events: initial;
}
.canvas-node {
--shadow-border-themed-inset: inset 0 0 0 1px rgb(var(--canvas-color));
--shadow-border-themed: 0 0 0 2px rgb(var(--canvas-color));
position: absolute;
width: 0;
height: 0;
}
.canvas-node.is-dragging {
pointer-events: none;
}
.canvas-node.is-dragging .canvas-node-container {
box-shadow: var(--shadow-drag);
}
.canvas-node.is-selected,
.canvas-node.is-focused {
touch-action: initial;
}
.canvas-node.is-selected .canvas-node-label,
.canvas-node.is-focused .canvas-node-label {
color: var(--text-muted);
}
.canvas-node.is-selected .canvas-node-container,
.canvas-node.is-focused .canvas-node-container {
border-color: var(--color-accent);
box-shadow: var(--shadow-stationary), var(--shadow-border-accent);
}
.canvas-node.is-selected.is-dragging .canvas-node-container,
.canvas-node.is-focused.is-dragging .canvas-node-container {
box-shadow: var(--shadow-drag), var(--shadow-border-accent);
}
.canvas-node.is-themed .canvas-node-container {
border-color: rgba(var(--canvas-color), 0.7);
box-shadow: inset 0 0 0 1px rgba(var(--canvas-color), 0.7), var(--shadow-stationary);
}
.canvas-node.is-selected.is-themed .canvas-node-container,
.canvas-node.is-focused.is-themed .canvas-node-container {
border-color: rgb(var(--canvas-color));
box-shadow: var(--shadow-border-themed-inset), var(--shadow-border-themed);
}
.canvas-node.is-selected.is-themed.is-dragging .canvas-node-container,
.canvas-node.is-focused.is-themed.is-dragging .canvas-node-container {
box-shadow: var(--shadow-border-themed-inset), var(--shadow-border-themed);
}
.canvas-node.is-dummy {
cursor: grabbing;
}
.canvas-node.is-dummy .canvas-node-container {
border: 4px solid var(--color-accent);
box-shadow: 0px 2px 10px rgba(0, 0, 0, 0.15);
background-color: hsla(var(--color-accent-hsl), 0.2);
}
.canvas-node.is-focused:not(.is-dragging) .canvas-node-content-blocker {
display: none;
}
.canvas-node-content-blocker {
position: absolute;
width: 100%;
height: 100%;
left: 0;
top: 0;
z-index: var(--layer-cover);
}
.canvas-node-group:not(.is-focused):not(.is-selected) {
pointer-events: none;
}
.canvas-node-group .canvas-node-resizer {
pointer-events: initial;
}
.canvas-node-group .canvas-node-container {
background-color: transparent;
}
.canvas-node-group .canvas-node-content {
background-color: rgba(var(--canvas-color), 0.07);
}
.canvas-group-label {
position: absolute;
left: 0;
top: calc(-1 * var(--size-4-1) * var(--zoom-multiplier));
transform: translate(0, -100%) scale(var(--zoom-multiplier));
transform-origin: bottom left;
max-width: calc(100% / var(--zoom-multiplier));
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
pointer-events: initial;
font-size: 1.5em;
padding: var(--size-4-1) var(--size-4-2);
border-radius: var(--radius-s);
color: var(--text-muted);
background-color: rgba(var(--canvas-color), 0.1);
line-height: 1;
}
body:not(.is-ios) .canvas-wrapper.mod-animating .canvas-group-label {
transition: transform 500ms cubic-bezier(0.16, 1, 0.3, 1);
}
.canvas-wrapper:not(.mod-readonly) .canvas-group-label {
cursor: grab;
}
.canvas-wrapper:not(.mod-readonly) .canvas-group-label:active {
cursor: grabbing;
}
.canvas-group-label[contenteditable="true"] {
cursor: text;
background-color: var(--background-primary);
box-shadow: 0 0 0 2px rgb(var(--canvas-color));
color: var(--text-normal);
text-overflow: initial;
}
.canvas-node-group.is-themed .canvas-group-label:not([contenteditable="true"]) {
background-color: rgb(var(--canvas-color));
}
.canvas-node-group.is-themed .canvas-group-label:not([contenteditable="true"]).mod-foreground-light {
color: var(--text-on-accent);
}
.canvas-node-group.is-themed .canvas-group-label:not([contenteditable="true"]).mod-foreground-dark {
color: var(--text-on-accent-inverted);
}
.canvas-node-content {
backface-visibility: hidden;
width: 100%;
height: 100%;
overflow: hidden;
position: relative;
}
.canvas-node-content.markdown-embed {
border: none;
padding: 0;
}
.canvas-node-content.markdown-embed .inline-title {
cursor: text;
}
.canvas-node-content.markdown-embed>.markdown-embed-content>.markdown-preview-view {
padding: 0 var(--size-4-4) 0 var(--size-4-6);
display: flex;
flex-direction: column;
}
.canvas-wrapper:not(.mod-readonly) .canvas-node-content.markdown-embed>.markdown-embed-content>.markdown-preview-view {
user-select: none;
-webkit-user-select: none;
}
/*.canvas-node-content.markdown-embed>.markdown-embed-content>.markdown-preview-view::before,
.canvas-node-content.markdown-embed>.markdown-embed-content>.markdown-preview-view::after {
content: " ";
display: block;
min-height: min(calc(var(--canvas-node-height) * 0.1 - 3px), var(--size-4-6));
max-height: var(--size-4-4);
flex: 1 1 0;
}*/
.canvas-node-content.markdown-embed>.markdown-embed-content>.markdown-preview-view>.markdown-preview-sizer>div p {
padding: 0;
margin: 0;
}
.canvas-node-content.markdown-embed>.markdown-embed-content>.markdown-preview-view>.markdown-preview-sizer {
flex: 1 0 0;
padding: min(calc(var(--canvas-node-height) * 0.2 - 5px), var(--size-4-4)) 0;
}
.canvas-node-content.markdown-embed>.markdown-embed-content>.markdown-preview-view .callout {
mix-blend-mode: normal;
}
.canvas-node-content.markdown-embed>.markdown-embed-content>.markdown-preview-view .markdown-preview-pusher+div>*:first-child {
margin-top: 0;
}
.canvas-node-content.markdown-embed>.markdown-embed-content>.markdown-preview-view .mod-header+div>*:first-child {
margin-top: 0;
}
.canvas-node-content.markdown-embed>.markdown-embed-content>.markdown-preview-view .markdown-preview-sizer>div:last-child>*:last-child {
margin-bottom: 0;
}
.is-focused .canvas-node-content.markdown-embed>.markdown-embed-content>.markdown-preview-view {
transform: translateZ(0);
}
.canvas-node.is-themed .canvas-node-content {
background-color: rgba(var(--canvas-color), 0.07);
}
.canvas-node-content.media-embed {
justify-content: center;
align-items: center;
display: flex;
}
.canvas-node-content.media-embed img,
.canvas-node-content.media-embed video,
.canvas-node-content.media-embed audio {
flex-shrink: 0;
flex-grow: 1;
}
.canvas-node-content.media-embed img:not([width]),
.canvas-node-content.media-embed video,
.canvas-node-content.media-embed audio {
max-width: 100%;
}
.canvas-node-resizer {
position: absolute;
height: calc(var(--resizer-size) * var(--zoom-multiplier));
width: calc(var(--resizer-size) * var(--zoom-multiplier));
}
.is-selected .canvas-node-resizer {
pointer-events: none;
}
body.is-mobile .canvas-node-resizer {
--zoom-multiplier: 1;
}
.canvas-wrapper.mod-readonly .canvas-node-resizer {
display: none;
}
.canvas-node-resizer[data-resize='top'] {
left: 0;
right: 0;
width: auto;
top: calc(var(--resizer-size) * var(--zoom-multiplier) * -0.5);
cursor: ns-resize;
}
.canvas-node-resizer[data-resize='bottom'] {
left: 0;
right: 0;
width: auto;
bottom: calc(var(--resizer-size) * var(--zoom-multiplier) * -0.5);
cursor: ns-resize;
}
.canvas-node-resizer[data-resize='left'] {
top: 0;
bottom: 0;
height: auto;
left: calc(var(--resizer-size) * var(--zoom-multiplier) * -0.5);
cursor: ew-resize;
}
.canvas-node-resizer[data-resize='right'] {
top: 0;
bottom: 0;
height: auto;
right: calc(var(--resizer-size) * var(--zoom-multiplier) * -0.5);
cursor: ew-resize;
}
.canvas-node-resizer[data-resize='topright'] {
right: calc(var(--resizer-size) * var(--zoom-multiplier) * -0.5);
top: calc(var(--resizer-size) * var(--zoom-multiplier) * -0.5);
cursor: nesw-resize;
}
.canvas-node-resizer[data-resize='bottomright'] {
right: calc(var(--resizer-size) * var(--zoom-multiplier) * -0.5);
bottom: calc(var(--resizer-size) * var(--zoom-multiplier) * -0.5);
cursor: nwse-resize;
}
.canvas-node-resizer[data-resize='topleft'] {
left: calc(var(--resizer-size) * var(--zoom-multiplier) * -0.5);
top: calc(var(--resizer-size) * var(--zoom-multiplier) * -0.5);
cursor: nwse-resize;
}
.canvas-node-resizer[data-resize='bottomleft'] {
left: calc(var(--resizer-size) * var(--zoom-multiplier) * -0.5);
bottom: calc(var(--resizer-size) * var(--zoom-multiplier) * -0.5);
cursor: nesw-resize;
}
.is-mobile .canvas-node-resizer {
pointer-events: none;
}
.is-mobile .canvas-wrapper:not(.mod-readonly) .canvas-node-interaction-layer .canvas-node-resizer[data-resize='topright'],
.is-mobile .canvas-wrapper:not(.mod-readonly) .canvas-node-interaction-layer .canvas-node-resizer[data-resize='bottomright'],
.is-mobile .canvas-wrapper:not(.mod-readonly) .canvas-node-interaction-layer .canvas-node-resizer[data-resize='topleft'],
.is-mobile .canvas-wrapper:not(.mod-readonly) .canvas-node-interaction-layer .canvas-node-resizer[data-resize='bottomleft'] {
pointer-events: all;
width: 20px;
height: 20px;
display: block;
background-color: var(--background-primary);
border: 2px solid var(--color-accent);
border-radius: 3px;
}
.canvas-node-connection-point {
width: calc(var(--resizer-size) * var(--zoom-multiplier));
height: calc(var(--resizer-size) * var(--zoom-multiplier));
position: absolute;
pointer-events: all;
cursor: pointer;
}
.canvas-node-connection-point[data-side='top'] {
top: 1px;
left: calc(50% - var(--resizer-size) * var(--zoom-multiplier) / 2);
}
.canvas-node-connection-point[data-side='right'] {
right: 1px;
top: calc(50% - var(--resizer-size) * var(--zoom-multiplier) / 2);
}
.canvas-node-connection-point[data-side='bottom'] {
bottom: 1px;
left: calc(50% - var(--resizer-size) * var(--zoom-multiplier) / 2);
}
.canvas-node-connection-point[data-side='left'] {
left: 1px;
top: calc(50% - var(--resizer-size) * var(--zoom-multiplier) / 2);
}
.canvas-node-connection-point::after {
content: ' ';
background-color: var(--color-accent);
border-radius: 50%;
border: 3px solid var(--background-modifier-border);
box-sizing: border-box;
display: block;
height: calc(var(--resizer-size) * var(--zoom-multiplier));
opacity: 0;
position: relative;
width: calc(var(--resizer-size) * var(--zoom-multiplier));
left: 0;
top: 0;
}
.is-mobile .canvas-node-interaction-layer .canvas-node-connection-point::after,
.canvas-node-resizer:hover .canvas-node-connection-point::after {
opacity: 1;
}
.canvas-snaps {
position: absolute;
width: 100%;
height: 100%;
left: 0;
top: 0;
overflow: visible;
pointer-events: none;
opacity: 0.6;
}
.canvas-snaps line {
stroke-width: 1px;
stroke: var(--color-accent);
}
.canvas-snaps circle {
fill: var(--color-accent);
}
.canvas-edges {
position: absolute;
width: 100%;
height: 100%;
left: 0;
top: 0;
overflow: visible;
pointer-events: none;
}
.canvas-edges>* {
pointer-events: initial;
}
.canvas-edges path.canvas-display-path {
pointer-events: none;
stroke-width: calc(3px * var(--zoom-multiplier));
stroke: rgb(var(--canvas-color));
fill: none;
transition: stroke-width 100ms ease-out;
}
.canvas-edges path.canvas-interaction-path {
pointer-events: stroke;
stroke-width: calc(24px * var(--zoom-multiplier));
stroke-linecap: round;
stroke: transparent;
fill: none;
transition: stroke 100ms ease-out;
}
.canvas-wrapper:not(.mod-readonly) .canvas-edges path.canvas-interaction-path {
cursor: grab;
}
.canvas-wrapper:not(.mod-readonly) .canvas-edges path.canvas-interaction-path:active {
cursor: grabbing;
}
.canvas-edges polygon.canvas-path-end {
pointer-events: none;
stroke: rgb(var(--canvas-color));
fill: rgb(var(--canvas-color));
stroke-linecap: round;
stroke-linejoin: round;
stroke-width: 1px;
transform-box: fill-box;
transform: scale(var(--zoom-multiplier));
transform-origin: center top;
}
.canvas-edges g.is-focused path.canvas-display-path,
.canvas:not(.is-connecting) .canvas-edges g:hover path.canvas-display-path {
stroke-width: calc(5.5px * var(--zoom-multiplier));
}
.canvas-edges g.is-focused path.canvas-interaction-path,
.canvas:not(.is-connecting) .canvas-edges g:hover path.canvas-interaction-path {
stroke: rgba(var(--canvas-color), 0.1);
}
.canvas-path-label-wrapper {
position: absolute;
width: fit-content;
height: fit-content;
}
.canvas-path-label {
font-size: calc(var(--font-ui-large) * var(--zoom-multiplier));
background-color: var(--background-primary);
border-radius: var(--radius-s);
padding: calc(var(--size-2-3) * var(--zoom-multiplier));
line-height: var(--line-height-tight);
white-space: pre-wrap;
transform: translate(-50%, -50%);
text-align: center;
max-width: calc(17em * var(--zoom-multiplier));
}
.canvas-path-label.is-editing {
border-color: rgb(var(--canvas-color));
box-shadow: var(--shadow-stationary), 0 0 0 calc(3px * var(--zoom-multiplier)) rgb(var(--canvas-color));
}
.canvas-menu-container {
position: absolute;
width: 0;
height: 0;
top: 0;
left: 0;
}
.canvas-menu {
position: relative;
width: fit-content;
height: fit-content;
line-height: 1;
background-color: var(--background-primary);
border: 1px solid var(--background-modifier-border);
border-radius: var(--radius-s);
box-shadow: 0px 2px 10px rgba(0, 0, 0, 0.07);
display: flex;
padding: var(--size-2-1);
gap: 1px;
}
.canvas-menu .clickable-icon {
padding: var(--size-2-3) var(--size-4-2);
}
.canvas-submenu {
display: flex;
position: absolute;
top: calc(100% + 5px);
left: 50%;
transform: translateX(-50%);
padding: var(--size-4-2);
border: 1px solid var(--background-modifier-border);
background-color: var(--background-primary);
border-radius: var(--radius-s);
box-shadow: 0px 2px 10px rgba(0, 0, 0, 0.07);
overflow: hidden;
gap: 1px;
}
.canvas-submenu .clickable-icon {
padding: var(--size-2-2) var(--size-2-3);
}
.canvas-color-picker-item {
cursor: var(--cursor);
width: 24px;
height: 24px;
margin: 2px;
border-radius: 12px;
border: 2px solid var(--background-primary);
background-color: rgb(var(--canvas-color));
}
.canvas-color-picker-item.is-active {
box-shadow: 0 0 0 2px rgb(var(--canvas-color));
}
@media (hover: hover) {
.canvas-color-picker-item:hover {
box-shadow: 0 0 0 2px rgb(var(--canvas-color));
}
}
.canvas-color-picker-item input[type="color"] {
margin: -4px 0 0 -2px;
--swatch-width: 20px;
--swatch-height: 20px;
opacity: 0;
}
.canvas-color-picker-item.canvas-color-picker-custom:not(.is-active) {
background: conic-gradient(var(--color-red), var(--color-yellow), var(--color-green), var(--color-blue), var(--color-purple), var(--color-red));
}
@media (hover: hover) {
.canvas-color-picker-item.canvas-color-picker-custom:not(.is-active):hover {
box-shadow: 0 0 0 2px var(--background-modifier-border-hover);
}
}
.canvas-empty-embed-container {
align-items: center;
display: flex;
flex-direction: column;
gap: var(--size-4-6);
justify-content: center;
height: 100%;
padding: var(--size-4-3);
text-align: center;
}
.canvas-empty-embed-action-list {
display: flex;
flex-direction: column;
gap: var(--size-4-3);
}
.canvas-empty-embed-action-list button {
font-size: var(--font-text-size);
padding: var(--size-4-5) var(--size-4-9);
}
.canvas-help {
display: flex;
flex-direction: column;
gap: var(--size-4-3);
}
.canvas-instruction {
display: flex;
justify-content: space-between;
}
.canvas-instruction-desc {
display: flex;
gap: var(--size-4-1);
}
.canvas-instruction-desc .setting-hotkey {
display: inline;
align-self: unset;
padding: var(--size-4-1);
margin: 0;
line-height: 1;
}
.canvas-placeholder-message {
max-width: 70vw;
background: hsla(var(--color-accent-hsl), 0.1);
border-radius: var(--radius-m);
color: var(--color-accent);
font-size: var(--font-ui-large);
line-height: var(--line-height-normal);
padding: var(--size-4-4) var(--size-4-6);
pointer-events: none;
position: absolute;
text-align: center;
transform: translate(-50%, -50%);
}
.canvas-minimap {
width: 100%;
height: 100%;
padding: var(--size-4-1);
}
.inline-embed>.canvas-minimap {
max-height: var(--embed-canvas-max-height);
}
.canvas-minimap rect {
stroke-width: 5px;
stroke: var(--background-modifier-border);
fill: var(--background-modifier-border);
fill-opacity: 0.65;
}
.canvas-minimap rect.is-themed {
stroke: rgb(var(--canvas-color));
fill: rgb(var(--canvas-color));
fill-opacity: 0.5;
}
.canvas-minimap path {
stroke: #c0c0c0;
fill: none;
}
.canvas-minimap path.is-themed {
stroke: rgb(var(--canvas-color));
}
.canvas-cursor {
position: absolute;
width: 1px;
height: 1px;
border: 5px solid var(--color-accent);
border-radius: 5px;
pointer-events: none;
}
.canvas-watermark * {
font-family: var(--font-default) !important;
}