livebook/assets/css/editor.css
2023-06-28 18:29:44 +02:00

218 lines
4.7 KiB
CSS

/* === Monaco overrides === */
/*
CSS normalization removes the default styles of HTML elements,
so we need to adjust styles of Monaco-rendered Markdown docs.
Also some spacing adjustments.
*/
.monaco-hover p,
.suggest-details p,
.parameter-hints-widget p {
@apply my-2 !important;
}
.suggest-details h1,
.monaco-hover h1,
.parameter-hints-widget h1 {
@apply text-xl font-semibold mt-4 mb-2;
}
.suggest-details h2,
.monaco-hover h2,
.parameter-hints-widget h2 {
@apply text-lg font-medium mt-4 mb-2;
}
.suggest-details h3,
.monaco-hover h3,
.parameter-hints-widget h3 {
@apply font-medium mt-4 mb-2;
}
.suggest-details ul,
.monaco-hover ul,
.parameter-hints-widget ul {
@apply list-disc;
}
.suggest-details ol,
.monaco-hover ol,
.parameter-hints-widget ol {
@apply list-decimal;
}
.suggest-details hr,
.monaco-hover hr,
.parameter-hints-widget hr {
@apply my-2 !important;
}
.suggest-details blockquote,
.monaco-hover blockquote,
.parameter-hints-widget blockquote {
@apply border-l-4 border-gray-200 pl-4 py-0.5 my-2;
}
/* Add some spacing to code snippets in completion suggestions */
.suggest-details div.monaco-tokenized-source,
.monaco-hover div.monaco-tokenized-source,
.parameter-hints-widget div.monaco-tokenized-source {
@apply my-2 whitespace-pre-wrap;
}
/* Use z-index over cell icons */
.suggest-details,
.monaco-hover,
.parameter-hints-widget {
z-index: 100 !important;
}
/* Adjust header spacing in completion details */
.suggest-details .header p {
@apply pb-0 pt-3 !important;
}
/* Adjust divider in signature help widget */
.parameter-hints-widget .markdown-docs hr {
border-top: 1px solid rgba(69, 69, 69, 0.5);
margin-right: -8px;
margin-left: -8px;
}
/* Increase the hover box limits */
.monaco-hover-content {
max-width: 1000px !important;
max-height: 300px !important;
}
/* Increase the completion details box limits */
.suggest-details-container,
.suggest-details {
width: fit-content !important;
height: fit-content !important;
max-width: 420px !important;
max-height: 250px !important;
}
/* Adjust completion details spacing */
.suggest-details .header .type {
padding-top: 0 !important;
}
/* The content already has some padding */
.docs.markdown-docs {
margin: 0 !important;
}
/* Command palette height is computed based on editor height,
which is not what we want, since the editor can have just
a single line, hence we override with a fixed height */
.monaco-editor .quick-input-list .monaco-list {
max-height: 300px !important;
}
/* === Monaco cursor widget === */
.monaco-cursor-widget-container {
pointer-events: none;
z-index: 100;
}
.monaco-cursor-widget-container .monaco-cursor-widget-cursor {
pointer-events: initial;
width: 2px;
}
.monaco-cursor-widget-container .monaco-cursor-widget-label {
pointer-events: initial;
transform: translateY(-200%);
white-space: nowrap;
padding: 1px 8px;
font-size: 12px;
color: #f8fafc;
visibility: hidden;
transition-property: visibility;
transition-duration: 0s;
transition-delay: 1.5s;
}
.monaco-cursor-widget-container .monaco-cursor-widget-label:hover {
visibility: visible;
}
.monaco-cursor-widget-container
.monaco-cursor-widget-cursor:hover
+ .monaco-cursor-widget-label {
visibility: visible;
transition-delay: 0s;
}
/* When in the first line, we want to display cursor and label in the same line */
.monaco-cursor-widget-container.inline {
display: flex !important;
}
.monaco-cursor-widget-container.inline .monaco-cursor-widget-label {
margin-left: 2px;
transform: none;
}
/* === Doctest status decoration === */
.doctest-status-decoration-running,
.doctest-status-decoration-success,
.doctest-status-decoration-failed {
height: 100%;
position: relative;
--decoration-size: 10px;
}
@media screen(md) {
.doctest-status-decoration-running,
.doctest-status-decoration-success,
.doctest-status-decoration-failed {
--decoration-size: 12px;
}
}
.doctest-status-decoration-running::after,
.doctest-status-decoration-success::after,
.doctest-status-decoration-failed::after {
box-sizing: border-box;
border-radius: 2px;
content: "";
display: block;
height: var(--decoration-size);
width: var(--decoration-size);
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
}
.doctest-status-decoration-running::after {
@apply bg-gray-400;
}
.doctest-status-decoration-success::after {
@apply bg-green-bright-400;
}
.doctest-status-decoration-failed::after {
@apply bg-red-400;
}
/* === Doctest failure details === */
.doctest-details-widget {
@apply font-editor;
white-space: pre;
background-color: rgba(0, 0, 0, 0.05);
padding-top: 6px;
padding-bottom: 6px;
position: absolute;
width: 100%;
overflow-y: auto;
}