1
0
silverbullet/web/styles/editor.scss

616 lines
11 KiB
SCSS
Raw Normal View History

.cm-focused {
outline: none !important;
}
#sb-main .cm-editor {
2022-08-02 12:40:04 +00:00
font-size: 18px;
2022-12-15 14:55:50 +00:00
height: 100%;
.cm-content {
2023-07-02 09:50:53 +00:00
width: 100%;
2022-12-15 14:55:50 +00:00
margin-left: auto;
margin-right: auto;
max-width: var(--#{"editor-width"});
2022-12-16 10:39:46 +00:00
padding: 5px 20px;
2022-08-29 13:47:16 +00:00
}
2022-12-15 14:55:50 +00:00
.cm-line {
padding: 0;
&.sb-line-h1,
&.sb-line-h2,
&.sb-line-h3,
&.sb-line-h4 {
font-weight: bold;
padding: 2px;
}
}
.sb-line-h1 {
font-size: 1.5em;
}
.sb-line-h2 {
font-size: 1.2em;
}
.sb-line-h3 {
font-size: 1.1em;
}
.sb-line-h4 {
font-size: 1em;
2022-12-15 14:55:50 +00:00
}
2022-08-29 13:47:16 +00:00
.sb-inline-img {
2022-11-18 15:59:55 +00:00
max-width: 100%;
}
.cm-panels-bottom .cm-vim-panel {
padding: 0 20px;
max-width: var(--editor-width);
margin: auto;
}
2023-06-14 17:27:18 +00:00
// Gutter styling
.cm-gutters {
background-color: transparent;
border-right: none;
}
.cm-foldPlaceholder {
background-color: transparent;
border: 0;
}
// Indentation of follow-up lines
@mixin lineOverflow($baseIndent, $bulletIndent: 0) {
text-indent: -1 * ($baseIndent + 2ch);
padding-left: $baseIndent + 2ch;
2022-08-02 12:40:04 +00:00
&.sb-line-task {
text-indent: -1 * ($baseIndent + 5ch);
padding-left: $baseIndent + 5ch;
.cm-list-bullet::after {
left: ($baseIndent + 5ch);
}
}
2022-08-02 12:40:04 +00:00
&.sb-line-blockquote {
text-indent: -1 * ($baseIndent + 4ch);
padding-left: $baseIndent + 4ch;
}
.cm-list-bullet::after {
left: ($baseIndent + $bulletIndent + 2ch);
}
}
2022-08-02 12:40:04 +00:00
.sb-line-ul {
&.sb-line-li-1 {
@include lineOverflow(0);
}
2022-08-02 12:40:04 +00:00
&.sb-line-li-1.sb-line-li-2 {
@include lineOverflow(2);
}
2022-08-02 12:40:04 +00:00
&.sb-line-li-1.sb-line-li-2.sb-line-li-3 {
@include lineOverflow(4);
}
2022-08-02 12:40:04 +00:00
&.sb-line-li-1.sb-line-li-2.sb-line-li-3.sb-line-li-4 {
@include lineOverflow(6);
}
2022-08-02 12:40:04 +00:00
&.sb-line-li-1.sb-line-li-2.sb-line-li-3.sb-line-li-4.sb-line-li-5 {
@include lineOverflow(8);
}
}
2022-08-02 12:40:04 +00:00
.sb-line-ol {
&.sb-line-li-1 {
@include lineOverflow(1);
}
2022-08-02 12:40:04 +00:00
&.sb-line-li-1.sb-line-li-2 {
@include lineOverflow(4);
}
2022-08-02 12:40:04 +00:00
&.sb-line-li-1.sb-line-li-2.sb-line-li-3 {
@include lineOverflow(7);
}
2022-08-02 12:40:04 +00:00
&.sb-line-li-1.sb-line-li-2.sb-line-li-3.sb-line-li-4 {
@include lineOverflow(10);
}
&.sb-line-li-1.sb-line-li-2.sb-line-li-3.sb-line-li-4.sb-line-li-5 {
@include lineOverflow(13);
}
}
.sb-line-ol.sb-line-ul {
// &.sb-line-li-1 {
// @include lineOverflow(1);
// }
&.sb-line-li-1.sb-line-li-2 {
@include lineOverflow(3);
}
&.sb-line-li-1.sb-line-li-2.sb-line-li-3 {
@include lineOverflow(6);
}
&.sb-line-li-1.sb-line-li-2.sb-line-li-3.sb-line-li-4 {
@include lineOverflow(9);
}
2022-08-02 12:40:04 +00:00
&.sb-line-li-1.sb-line-li-2.sb-line-li-3.sb-line-li-4.sb-line-li-5 {
@include lineOverflow(12);
}
}
.sb-line-blockquote {
&.sb-line-li-1 {
@include lineOverflow(-1, 2);
}
&.sb-line-li-1.sb-line-li-2 {
@include lineOverflow(1, 2);
}
&.sb-line-li-1.sb-line-li-2.sb-line-li-3 {
@include lineOverflow(4);
}
&.sb-line-li-1.sb-line-li-2.sb-line-li-3.sb-line-li-4 {
@include lineOverflow(6);
}
&.sb-line-li-1.sb-line-li-2.sb-line-li-3.sb-line-li-4.sb-line-li-5 {
@include lineOverflow(8);
}
}
2022-08-02 12:40:04 +00:00
.sb-line-comment {
text-indent: -1 * 3ch;
padding-left: 3ch;
}
.cm-list-bullet {
2022-12-19 11:35:58 +00:00
position: relative;
visibility: hidden;
}
.cm-list-bullet::after {
visibility: visible;
position: absolute;
content: "\2022";
/* U+2022 BULLET */
}
2022-12-19 11:35:58 +00:00
.cm-task-checked {
text-decoration: line-through !important;
}
2023-07-10 11:16:22 +00:00
.cm-tooltip-autocomplete {
.cm-completionDetail {
font-style: normal;
display: block;
font-size: 80%;
margin-left: 5px;
}
.cm-completionLabel {
display: block;
margin-left: 5px;
}
.cm-completionIcon {
display: none;
}
}
.sb-header-inside.sb-line-h1 {
text-indent: -2ch;
}
.sb-header-inside.sb-line-h2 {
text-indent: -3ch;
}
.sb-header-inside.sb-line-h3 {
text-indent: -4ch;
}
.sb-header-inside.sb-line-h4 {
text-indent: -5ch;
}
2023-07-10 11:16:22 +00:00
.sb-checkbox>input[type="checkbox"] {
width: 3ch;
}
.sb-hashtag {
border-radius: 6px;
padding: 0 3px;
margin: 0 1px 0 0;
font-size: 0.9em;
}
.sb-strikethrough {
text-decoration: line-through;
&.sb-meta {
text-decoration: none;
}
}
.sb-line-hr {
margin-top: 1em;
margin-bottom: -1em;
}
.sb-hr {
font-weight: bold;
}
.sb-naked-url {
cursor: pointer;
}
.sb-command-button {
cursor: pointer;
font-size: 1em;
border-radius: 4px;
}
.sb-command-link-name {
cursor: pointer;
border-radius: 4px;
padding: 0 4px;
}
.sb-link:not(.sb-url) {
cursor: pointer;
}
.sb-link:not(.sb-meta, .sb-url) {
text-decoration: underline;
}
.sb-url:not(.sb-link) {
text-decoration: underline;
cursor: pointer;
}
.sb-wiki-link-page {
border-radius: 5px;
padding: 0 5px;
// white-space: nowrap;
text-decoration: none;
cursor: pointer;
}
a.sb-wiki-link-page-missing,
2023-07-10 11:16:22 +00:00
.sb-wiki-link-page-missing>.sb-wiki-link-page {
border-radius: 5px;
padding: 0 5px;
// white-space: nowrap;
text-decoration: none;
cursor: pointer;
}
.sb-wiki-link {
cursor: pointer;
}
.sb-task-mark {
font-size: 91%;
}
.sb-task-state {
font-size: 91%;
}
.sb-directive-start {
border-top-left-radius: 10px;
border-top-right-radius: 10px;
border-style: solid;
border-width: 1px 1px 0 1px;
padding: 3px;
}
.sb-directive-end {
border-bottom-left-radius: 10px;
border-bottom-right-radius: 10px;
border-style: solid;
border-width: 0 1px 1px 1px;
padding: 3px;
2022-12-19 11:35:58 +00:00
}
2022-12-19 11:35:58 +00:00
.sb-directive-start .sb-comment,
.sb-directive-end .sb-comment {
position: relative;
left: -12px;
}
.sb-directive-start-outside,
.sb-directive-end-outside {
color: transparent;
pointer-events: none;
2023-09-09 19:06:15 +00:00
height: 1.3em;
.sb-directive-placeholder {
padding-right: 7px;
float: right;
font-size: 80%;
}
2023-07-10 11:16:22 +00:00
&>span,
&.sb-directive-start,
&.sb-directive-end {
color: transparent;
}
}
2022-12-19 11:35:58 +00:00
.sb-line-frontmatter-outside,
.sb-line-code-outside {
.sb-meta {
color: transparent;
}
2023-07-10 11:16:22 +00:00
2022-12-19 11:35:58 +00:00
color: transparent;
}
.sb-line-blockquote {
text-indent: -2ch;
}
.sb-blockquote-outside {
text-indent: -1ch;
min-height: 1em;
}
.sb-line-table-outside {
display: none;
}
.sb-line-tbl-header {
font-weight: bold;
}
.sb-line-tbl-header .meta {
font-weight: normal;
}
.sb-table-widget {
display: block;
font-weight: normal;
margin-bottom: -3rem;
overflow: auto;
2023-10-29 09:02:50 +00:00
}
2022-12-19 11:35:58 +00:00
2023-10-29 09:02:50 +00:00
table {
width: 100%;
border-spacing: 0;
}
2022-12-19 11:35:58 +00:00
2023-10-29 09:02:50 +00:00
thead tr {
font-weight: bold;
}
2022-12-19 11:35:58 +00:00
2023-10-29 09:02:50 +00:00
th,
td {
padding: 8px;
white-space: nowrap;
}
// dont apply background color twice for (fenced) code blocks
.sb-line-code .sb-code {
background-color: transparent;
}
.sb-line-code-outside .sb-code-info {
display: block;
float: right;
font-size: 90%;
padding-right: 7px;
}
.sb-line-fenced-code .sb-code {
background-color: transparent;
}
.sb-line-fenced-code .sb-comment {
border-radius: 0;
font-style: inherit;
font-size: inherit;
line-height: inherit;
}
.sb-keyword {
font-weight: bold;
}
2023-11-16 08:59:37 +00:00
// Allow for cursor movement into a code widget fenced code block from bottom-up
2022-12-22 15:20:05 +00:00
.sb-fenced-code-hide {
background-color: transparent;
2022-12-22 15:20:05 +00:00
line-height: 0;
}
.sb-markdown-widget {
margin: 0 0 -4ch 0;
}
.sb-markdown-top-widget h1,
.sb-markdown-bottom-widget h1 {
border-top-right-radius: 5px;
border-top-left-radius: 5px;
margin: 0 0 5px 0;
padding: 10px !important;
background-color: var(--editor-directive-background-color);
font-size: 1.2em;
}
.sb-markdown-top-widget:has(*) {
margin-bottom: 10px;
}
.sb-markdown-bottom-widget {
margin-top: 10px;
}
.sb-markdown-widget,
.sb-markdown-top-widget:has(*),
.sb-markdown-bottom-widget:has(*) {
2023-12-29 19:03:54 +00:00
overflow-y: auto;
border: 1px solid var(--editor-directive-background-color);
border-radius: 5px;
2024-01-02 10:01:34 +00:00
white-space: normal;
position: relative;
ul,
ol {
margin-top: 0;
margin-bottom: 0;
}
ul {
list-style: none;
// padding-left: 1ch;
}
ul li::before {
content: "\2022";
/* Add content: \2022 is the CSS Code/unicode for a bullet */
color: var(--editor-list-bullet-color);
display: inline-block;
/* Needed to add space between the bullet and the text */
width: 1em;
/* Also needed for space (tweak if needed) */
margin-left: -1em;
}
h1,
h2,
h3,
h4,
h5 {
margin: 0;
}
a.wiki-link {
border-radius: 5px;
padding: 0 5px;
color: var(--editor-wiki-link-page-color);
background-color: var(--editor-wiki-link-page-background-color);
text-decoration: none;
}
span.task-deadline {
background-color: rgba(22, 22, 22, 0.07);
}
tt {
background-color: var(--editor-code-background-color);
}
2024-01-02 10:01:34 +00:00
// Only show the button bar on hover on non-touch devices
&:hover .button-bar {
display: block;
}
2024-01-02 10:01:34 +00:00
// Always show button bar on touch devices
@media (hover: none) and (pointer: coarse) {
.button-bar {
display: block !important;
}
}
.button-bar {
position: absolute;
2024-01-02 10:01:34 +00:00
right: 0;
top: 0;
display: none;
background: var(--editor-directive-background-color);
padding-inline: 3px;
2024-01-02 10:01:34 +00:00
padding: 4px 0;
// border-radius: 0 5px;
button {
border: none;
background: none;
cursor: pointer;
color: var(--root-color);
margin-right: -8px;
}
2024-01-02 10:01:34 +00:00
button:last-of-type {
margin-right: 2px;
}
}
}
2022-12-22 15:20:05 +00:00
.sb-fenced-code-iframe {
background-color: transparent;
2022-12-22 15:20:05 +00:00
iframe {
border: 0;
width: 100%;
max-width: 100%;
2022-12-22 15:20:05 +00:00
padding: 0;
2023-12-19 15:18:18 +00:00
margin: 0 0 -2ch 0;
border: 1px solid var(--editor-directive-background-color);
border-radius: 5px;
2022-12-22 15:20:05 +00:00
}
}
2023-07-10 11:16:22 +00:00
.sb-line-blockquote.sb-line-ul.sb-line-li>.sb-quote.sb-meta:first-child {
margin-left: -1ch;
}
.sb-admonition {
border-left-width: 4px !important;
border-left-style: solid;
}
2022-12-19 11:35:58 +00:00
.sb-admonition-icon {
display: inline-flex;
vertical-align: middle;
padding-left: 16px;
padding-right: 8px;
}
.sb-frontmatter-marker {
float: right;
font-size: 80%;
padding-right: 7px;
}
.cm-scroller {
// Give some breathing space at the bottom of the screen
padding-bottom: 20em;
}
}
div:not(.cm-focused).cm-fat-cursor {
outline: none !important;
}
2023-07-10 11:16:22 +00:00
2023-09-09 19:06:15 +00:00
// @media only screen and (max-width: 600px) {
// #sb-editor {
2023-07-10 11:16:22 +00:00
2023-09-09 19:06:15 +00:00
// .sb-directive-start-outside,
// .sb-directive-end-outside {
// height: 22px;
// }
// }
// }