/* @settings name: Execute Code Settings id: obsidian-execute-code settings: - id: color-section-title title: Color Settings type: heading level: 3 - id: use-custom-output-color title: Custom Code Output Color description: Use a custom color for the output of code blocks type: class-toggle default: false - id: code-output-text-color title: Output Text Color type: variable-color format: hex opacity: false default: '#FFFFFF' - id: use-custom-error-color title: Custom Code Error Color description: Use a custom color for the error output of code blocks type: class-toggle default: false - id: code-error-text-color title: Error Text Color type: variable-color format: hex opacity: false default: '#FF0000' */ button.run-code-button { display: none; color: var(--text-muted); position: absolute; bottom: 0; right: 0; margin: 5px; padding: 5px 20px 5px 20px; z-index: 100; } button.clear-button { display: none; color: var(--text-muted); position: absolute; bottom: 0; left: 0; margin: 5px; padding: 5px 20px 5px 20px; z-index: 100; } pre:hover .run-code-button, pre:hover .clear-button { display: block; } pre:hover .run-button-disabled, pre:hover .clear-button-disabled { display: none; } .run-button-disabled, .clear-button-disabled { display: none; } pre:hover code.language-output { margin-bottom: 28px; } :not(.use-custom-output-color) code.language-output span.stdout { color: var(--text-muted) !important; } .use-custom-output-color code.language-output span.stdout { color: var(--code-output-text-color) !important; } :not(.use-custom-error-color) code.language-output span.stderr { color: red !important; } .use-custom-error-color code.language-output span.stderr { color: var(--code-error-text-color) !important; } code.language-output hr { margin: 0 0 1em; } .settings-code-input-box textarea, .settings-code-input-box input { min-width: 400px; min-height: 100px; font-family: monospace; resize: vertical; } input.interactive-stdin { font: inherit; } .manage-executors-view h3 { margin: 1em; } .manage-executors-view ul { margin: 1em; padding: 0; list-style-type: none; } .manage-executors-view ul li { padding: 0.5em; background: var(--background-primary-alt); border-radius: 4px; display: grid; flex-direction: column; margin-bottom: 0.5em; } .manage-executors-view small { text-transform: uppercase; font-weight: bold; letter-spacing: 0.1ch; grid-row: 1; } .manage-executors-view .filename { grid-row: 2; } .manage-executors-view li button { grid-column: 2; grid-row: 1 / 3; margin: 0; padding: 0.25em; display: flex; align-items: center; justify-content: center; color: var(--text-muted); background: none; } .manage-executors-view li button:hover { background: var(--background-tertiary); color: var(--icon-color-hover); } .manage-executors-view > div { position: relative; } .manage-executors-view .empty-state { color: var(--text-muted); padding: 0.5em; } .has-run-code-button { position: relative; } .has-run-code-button pre { z-index: 1; } .load-state-indicator { position: absolute; top: 0.1em; left: -2em; width: 2em; height: 2em; background: var(--background-primary-alt); border-top-left-radius: 4px; border-bottom-left-radius: 4px; color: var(--tx1); transform: translateX(2em); transition: transform 0.25s, opacity 0.25s; opacity: 0; pointer-events: none; cursor: pointer; } .load-state-indicator svg { width: 1.5em; height: 1.5em; margin: 0.25em; } .load-state-indicator.visible { transform: translateX(0); transform: translateX(var(--folding-offset, 0)); opacity: 1; pointer-events: all; } .load-state-indicator::before { content: ""; box-shadow: -1em 0 1em -0.75em inset var(--background-modifier-box-shadow); position: absolute; display: block; width: 100%; height: 100%; transform: translateX(-2em); opacity: 0; transition: transform 0.25s, opacity 0.25s; pointer-events: none; } .load-state-indicator.visible::before { transform: translateX(0); opacity: 1; }