Work on #10 theming
parent
ce83680ac5
commit
1e574a81c3
|
@ -1 +0,0 @@
|
||||||
See [website/CHANGELOG.md](https://github.com/silverbulletmd/silverbullet/blob/main/website/CHANGELOG.md)
|
|
|
@ -0,0 +1 @@
|
||||||
|
website/CHANGELOG.md
|
|
@ -124,9 +124,9 @@ export function FilterList({
|
||||||
let exiting = false;
|
let exiting = false;
|
||||||
|
|
||||||
const returnEl = (
|
const returnEl = (
|
||||||
<div className="filter-wrapper">
|
<div className="sb-filter-wrapper">
|
||||||
<div className="filter-box">
|
<div className="sb-filter-box">
|
||||||
<div className="header">
|
<div className="sb-header">
|
||||||
<label>{label}</label>
|
<label>{label}</label>
|
||||||
<input
|
<input
|
||||||
type="text"
|
type="text"
|
||||||
|
@ -187,17 +187,17 @@ export function FilterList({
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
<div
|
<div
|
||||||
className="help-text"
|
className="sb-help-text"
|
||||||
dangerouslySetInnerHTML={{ __html: helpText }}
|
dangerouslySetInnerHTML={{ __html: helpText }}
|
||||||
></div>
|
></div>
|
||||||
<div className="result-list">
|
<div className="sb-result-list">
|
||||||
{matchingOptions && matchingOptions.length > 0
|
{matchingOptions && matchingOptions.length > 0
|
||||||
? matchingOptions.map((option, idx) => (
|
? matchingOptions.map((option, idx) => (
|
||||||
<div
|
<div
|
||||||
key={"" + idx}
|
key={"" + idx}
|
||||||
ref={selectedOption === idx ? selectedElementRef : undefined}
|
ref={selectedOption === idx ? selectedElementRef : undefined}
|
||||||
className={
|
className={
|
||||||
selectedOption === idx ? "selected-option" : "option"
|
selectedOption === idx ? "sb-selected-option" : "sb-option"
|
||||||
}
|
}
|
||||||
onMouseOver={(e) => {
|
onMouseOver={(e) => {
|
||||||
setSelectionOption(idx);
|
setSelectionOption(idx);
|
||||||
|
@ -207,18 +207,20 @@ export function FilterList({
|
||||||
onSelect(option);
|
onSelect(option);
|
||||||
}}
|
}}
|
||||||
>
|
>
|
||||||
<span className="icon">
|
<span className="sb-icon">
|
||||||
{icon && <FontAwesomeIcon icon={icon} />}
|
{icon && <FontAwesomeIcon icon={icon} />}
|
||||||
</span>
|
</span>
|
||||||
<span
|
<span
|
||||||
className="name"
|
className="sb-name"
|
||||||
dangerouslySetInnerHTML={{
|
dangerouslySetInnerHTML={{
|
||||||
__html: option?.result?.indexes
|
__html: option?.result?.indexes
|
||||||
? fuzzysort.highlight(option.result, "<b>", "</b>")!
|
? fuzzysort.highlight(option.result, "<b>", "</b>")!
|
||||||
: escapeHtml(option.name),
|
: escapeHtml(option.name),
|
||||||
}}
|
}}
|
||||||
></span>
|
></span>
|
||||||
{option.hint && <span className="hint">{option.hint}</span>}
|
{option.hint && (
|
||||||
|
<span className="sb-hint">{option.hint}</span>
|
||||||
|
)}
|
||||||
</div>
|
</div>
|
||||||
))
|
))
|
||||||
: null}
|
: null}
|
||||||
|
|
|
@ -54,7 +54,7 @@ export function Panel({
|
||||||
}, []);
|
}, []);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className="panel" style={{ flex }}>
|
<div className="sb-panel" style={{ flex }}>
|
||||||
<iframe srcDoc={iframeHtml} ref={iFrameRef} />
|
<iframe srcDoc={iframeHtml} ref={iFrameRef} />
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
|
|
|
@ -34,23 +34,25 @@ export function TopBar({
|
||||||
<div className="main">
|
<div className="main">
|
||||||
<div className="inner">
|
<div className="inner">
|
||||||
<span
|
<span
|
||||||
className={`current-page ${unsavedChanges ? "unsaved" : "saved"}`}
|
className={`sb-current-page ${
|
||||||
|
unsavedChanges ? "sb-unsaved" : "sb-saved"
|
||||||
|
}`}
|
||||||
>
|
>
|
||||||
{prettyName(pageName)}
|
{prettyName(pageName)}
|
||||||
</span>
|
</span>
|
||||||
{notifications.length > 0 && (
|
{notifications.length > 0 && (
|
||||||
<div className="notifications">
|
<div className="sb-notifications">
|
||||||
{notifications.map((notification) => (
|
{notifications.map((notification) => (
|
||||||
<div
|
<div
|
||||||
key={notification.id}
|
key={notification.id}
|
||||||
className={`notification-${notification.type}`}
|
className={`sb-notification-${notification.type}`}
|
||||||
>
|
>
|
||||||
{notification.message}
|
{notification.message}
|
||||||
</div>
|
</div>
|
||||||
))}
|
))}
|
||||||
</div>
|
</div>
|
||||||
)}
|
)}
|
||||||
<div className="actions">
|
<div className="sb-actions">
|
||||||
<button
|
<button
|
||||||
onClick={(e) => {
|
onClick={(e) => {
|
||||||
onHomeClick();
|
onHomeClick();
|
||||||
|
|
|
@ -395,18 +395,18 @@ export class Editor {
|
||||||
}),
|
}),
|
||||||
EditorView.lineWrapping,
|
EditorView.lineWrapping,
|
||||||
lineWrapper([
|
lineWrapper([
|
||||||
{ selector: "ATXHeading1", class: "line-h1" },
|
{ selector: "ATXHeading1", class: "sb-line-h1" },
|
||||||
{ selector: "ATXHeading2", class: "line-h2" },
|
{ selector: "ATXHeading2", class: "sb-line-h2" },
|
||||||
{ selector: "ATXHeading3", class: "line-h3" },
|
{ selector: "ATXHeading3", class: "sb-line-h3" },
|
||||||
{ selector: "ListItem", class: "line-li", nesting: true },
|
{ selector: "ListItem", class: "sb-line-li", nesting: true },
|
||||||
{ selector: "Blockquote", class: "line-blockquote" },
|
{ selector: "Blockquote", class: "sb-line-blockquote" },
|
||||||
{ selector: "Task", class: "line-task" },
|
{ selector: "Task", class: "sb-line-task" },
|
||||||
{ selector: "CodeBlock", class: "line-code" },
|
{ selector: "CodeBlock", class: "sb-line-code" },
|
||||||
{ selector: "FencedCode", class: "line-fenced-code" },
|
{ selector: "FencedCode", class: "sb-line-fenced-code" },
|
||||||
{ selector: "Comment", class: "line-comment" },
|
{ selector: "Comment", class: "sb-line-comment" },
|
||||||
{ selector: "BulletList", class: "line-ul" },
|
{ selector: "BulletList", class: "sb-line-ul" },
|
||||||
{ selector: "OrderedList", class: "line-ol" },
|
{ selector: "OrderedList", class: "sb-line-ol" },
|
||||||
{ selector: "TableHeader", class: "line-tbl-header" },
|
{ selector: "TableHeader", class: "sb-line-tbl-header" },
|
||||||
]),
|
]),
|
||||||
keymap.of([
|
keymap.of([
|
||||||
...smartQuoteKeymap,
|
...smartQuoteKeymap,
|
||||||
|
@ -754,7 +754,7 @@ export class Editor {
|
||||||
)}
|
)}
|
||||||
</div>
|
</div>
|
||||||
{!!viewState.showBHS && (
|
{!!viewState.showBHS && (
|
||||||
<div className="bhs">
|
<div className="sb-bhs">
|
||||||
<Panel
|
<Panel
|
||||||
html={viewState.bhsHTML}
|
html={viewState.bhsHTML}
|
||||||
script={viewState.bhsScript}
|
script={viewState.bhsScript}
|
||||||
|
|
|
@ -14,6 +14,7 @@
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
<link rel="stylesheet" href="styles/main.scss" />
|
<link rel="stylesheet" href="styles/main.scss" />
|
||||||
|
<link rel="stylesheet" href="styles/theme.css" />
|
||||||
<script type="module" src="boot.ts"></script>
|
<script type="module" src="boot.ts"></script>
|
||||||
<link rel="manifest" href="manifest.json" />
|
<link rel="manifest" href="manifest.json" />
|
||||||
<link rel="icon" type="image/x-icon" href="images/favicon.gif" />
|
<link rel="icon" type="image/x-icon" href="images/favicon.gif" />
|
||||||
|
|
|
@ -5,43 +5,43 @@ import { MDExt } from "@silverbulletmd/common/markdown_ext";
|
||||||
|
|
||||||
export default function highlightStyles(mdExtension: MDExt[]) {
|
export default function highlightStyles(mdExtension: MDExt[]) {
|
||||||
const hls = HighlightStyle.define([
|
const hls = HighlightStyle.define([
|
||||||
{ tag: t.heading1, class: "h1" },
|
{ tag: t.heading1, class: "sb-h1" },
|
||||||
{ tag: t.heading2, class: "h2" },
|
{ tag: t.heading2, class: "sb-h2" },
|
||||||
{ tag: t.heading3, class: "h3" },
|
{ tag: t.heading3, class: "sb-h3" },
|
||||||
{ tag: t.link, class: "link" },
|
{ tag: t.link, class: "sb-link" },
|
||||||
{ tag: t.meta, class: "meta" },
|
{ tag: t.meta, class: "sb-meta" },
|
||||||
{ tag: t.quote, class: "quote" },
|
{ tag: t.quote, class: "sb-quote" },
|
||||||
{ tag: t.monospace, class: "code" },
|
{ tag: t.monospace, class: "sb-code" },
|
||||||
{ tag: t.url, class: "url" },
|
{ tag: t.url, class: "sb-url" },
|
||||||
{ tag: ct.WikiLinkTag, class: "wiki-link" },
|
{ tag: ct.WikiLinkTag, class: "sb-wiki-link" },
|
||||||
{ tag: ct.WikiLinkPageTag, class: "wiki-link-page" },
|
{ tag: ct.WikiLinkPageTag, class: "sb-wiki-link-page" },
|
||||||
{ tag: ct.TaskTag, class: "task" },
|
{ tag: ct.TaskTag, class: "sb-task" },
|
||||||
{ tag: ct.TaskMarkerTag, class: "task-marker" },
|
{ tag: ct.TaskMarkerTag, class: "sb-task-marker" },
|
||||||
{ tag: ct.CodeInfoTag, class: "code-info" },
|
{ tag: ct.CodeInfoTag, class: "sb-code-info" },
|
||||||
{ tag: ct.CommentTag, class: "comment" },
|
{ tag: ct.CommentTag, class: "sb-comment" },
|
||||||
{ tag: ct.CommentMarkerTag, class: "comment-marker" },
|
{ tag: ct.CommentMarkerTag, class: "sb-comment-marker" },
|
||||||
{ tag: ct.Highlight, class: "highlight" },
|
{ tag: ct.Highlight, class: "sb-highlight" },
|
||||||
{ tag: t.emphasis, class: "emphasis" },
|
{ tag: t.emphasis, class: "sb-emphasis" },
|
||||||
{ tag: t.strong, class: "strong" },
|
{ tag: t.strong, class: "sb-strong" },
|
||||||
{ tag: t.atom, class: "atom" },
|
{ tag: t.atom, class: "sb-atom" },
|
||||||
{ tag: t.bool, class: "bool" },
|
{ tag: t.bool, class: "sb-bool" },
|
||||||
{ tag: t.url, class: "url" },
|
{ tag: t.url, class: "sb-url" },
|
||||||
{ tag: t.inserted, class: "inserted" },
|
{ tag: t.inserted, class: "sb-inserted" },
|
||||||
{ tag: t.deleted, class: "deleted" },
|
{ tag: t.deleted, class: "sb-deleted" },
|
||||||
{ tag: t.literal, class: "literal" },
|
{ tag: t.literal, class: "sb-literal" },
|
||||||
{ tag: t.keyword, class: "keyword" },
|
{ tag: t.keyword, class: "sb-keyword" },
|
||||||
{ tag: t.list, class: "list" },
|
{ tag: t.list, class: "sb-list" },
|
||||||
// { tag: t.def, class: "li" },
|
// { tag: t.def, class: "sb-li" },
|
||||||
{ tag: t.string, class: "string" },
|
{ tag: t.string, class: "sb-string" },
|
||||||
{ tag: t.number, class: "number" },
|
{ tag: t.number, class: "sb-number" },
|
||||||
{ tag: [t.regexp, t.escape, t.special(t.string)], class: "string2" },
|
{ tag: [t.regexp, t.escape, t.special(t.string)], class: "sb-string2" },
|
||||||
{ tag: t.variableName, class: "variableName" },
|
{ tag: t.variableName, class: "sb-variableName" },
|
||||||
{ tag: t.typeName, class: "typeName" },
|
{ tag: t.typeName, class: "sb-typeName" },
|
||||||
{ tag: t.comment, class: "comment" },
|
{ tag: t.comment, class: "sb-comment" },
|
||||||
{ tag: t.invalid, class: "invalid" },
|
{ tag: t.invalid, class: "sb-invalid" },
|
||||||
{ tag: t.processingInstruction, class: "meta" },
|
{ tag: t.processingInstruction, class: "sb-meta" },
|
||||||
// { tag: t.content, class: "tbl-content" },
|
// { tag: t.content, class: "tbl-content" },
|
||||||
{ tag: t.punctuation, class: "punctuation" },
|
{ tag: t.punctuation, class: "sb-punctuation" },
|
||||||
...mdExtension.map((mdExt) => {
|
...mdExtension.map((mdExt) => {
|
||||||
return { tag: mdExt.tag, ...mdExt.styles };
|
return { tag: mdExt.tag, ...mdExt.styles };
|
||||||
}),
|
}),
|
||||||
|
|
|
@ -1,5 +0,0 @@
|
||||||
$max-editor-width: 800px;
|
|
||||||
$top-bar-height: 55px;
|
|
||||||
$bottom-bar-height: 30px;
|
|
||||||
$editor-font: "iA-Mono", "Menlo";
|
|
||||||
$ui-font: "Arial";
|
|
|
@ -1,257 +1,78 @@
|
||||||
@import "constants.scss";
|
|
||||||
|
|
||||||
.cm-editor {
|
.cm-editor {
|
||||||
font-size: var(--ident);
|
font-size: 18px;
|
||||||
padding: 0 20px;
|
padding: 0 20px;
|
||||||
|
|
||||||
.cm-content {
|
.cm-content {
|
||||||
font-family: $editor-font;
|
|
||||||
margin: auto;
|
margin: auto;
|
||||||
max-width: $max-editor-width;
|
max-width: 800px;
|
||||||
}
|
}
|
||||||
|
|
||||||
&.cm-focused {
|
&.cm-focused {
|
||||||
outline: none !important;
|
outline: none !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
.cm-selectionBackground {
|
|
||||||
background-color: #d7e1f6 !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.line-h1,
|
|
||||||
.line-h2,
|
|
||||||
.line-h3 {
|
|
||||||
background-color: rgba(0, 30, 77, 0.5);
|
|
||||||
color: #fff;
|
|
||||||
font-weight: bold;
|
|
||||||
padding: 2px 2px;
|
|
||||||
|
|
||||||
.meta {
|
|
||||||
color: orange;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.line-h1 {
|
|
||||||
font-size: 1.5em;
|
|
||||||
}
|
|
||||||
|
|
||||||
.line-h2 {
|
|
||||||
font-size: 1.2em;
|
|
||||||
}
|
|
||||||
|
|
||||||
.line-h3 {
|
|
||||||
font-size: 1.1em;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Color list item this way */
|
|
||||||
.line-li .meta {
|
|
||||||
color: rgb(150, 150, 150);
|
|
||||||
}
|
|
||||||
/* Then undo other meta */
|
|
||||||
.line-li .meta ~ .meta {
|
|
||||||
color: #650007;
|
|
||||||
}
|
|
||||||
|
|
||||||
.line-code {
|
|
||||||
background-color: rgba(72, 72, 72, 0.1);
|
|
||||||
|
|
||||||
.code {
|
|
||||||
background-color: transparent;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.line-tbl-header {
|
|
||||||
font-weight: bold;
|
|
||||||
|
|
||||||
.meta {
|
|
||||||
font-weight: normal;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.struct {
|
|
||||||
color: darkred;
|
|
||||||
}
|
|
||||||
|
|
||||||
.code {
|
|
||||||
background-color: rgba(72, 72, 72, 0.1);
|
|
||||||
}
|
|
||||||
|
|
||||||
.highlight {
|
|
||||||
background-color: rgba(255, 255, 0, 0.5);
|
|
||||||
}
|
|
||||||
|
|
||||||
.line-fenced-code {
|
|
||||||
background-color: rgba(72, 72, 72, 0.1);
|
|
||||||
|
|
||||||
.code {
|
|
||||||
background-color: transparent;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Set this to defaults
|
|
||||||
.comment {
|
|
||||||
color: #989797;
|
|
||||||
background-color: transparent;
|
|
||||||
border-radius: 0;
|
|
||||||
font-style: inherit;
|
|
||||||
font-size: inherit;
|
|
||||||
line-height: inherit;
|
|
||||||
}
|
|
||||||
|
|
||||||
.keyword {
|
|
||||||
color: #830000;
|
|
||||||
}
|
|
||||||
|
|
||||||
.variableName {
|
|
||||||
color: #036d9b;
|
|
||||||
}
|
|
||||||
|
|
||||||
.typeName {
|
|
||||||
color: #038138;
|
|
||||||
}
|
|
||||||
|
|
||||||
.string,
|
|
||||||
.string2 {
|
|
||||||
color: #440377;
|
|
||||||
}
|
|
||||||
|
|
||||||
//.code-info {
|
|
||||||
// background: black;
|
|
||||||
// border-radius: 3px;
|
|
||||||
//}
|
|
||||||
}
|
|
||||||
|
|
||||||
.meta {
|
|
||||||
color: #650007;
|
|
||||||
}
|
|
||||||
|
|
||||||
.line-blockquote {
|
|
||||||
background-color: rgba(220, 220, 220, 0.5);
|
|
||||||
color: #676767;
|
|
||||||
text-indent: -2ch;
|
|
||||||
padding-left: 2ch;
|
|
||||||
}
|
|
||||||
|
|
||||||
.emphasis {
|
|
||||||
font-style: italic;
|
|
||||||
}
|
|
||||||
|
|
||||||
.strong {
|
|
||||||
font-weight: 900;
|
|
||||||
}
|
|
||||||
|
|
||||||
.link {
|
|
||||||
cursor: pointer;
|
|
||||||
}
|
|
||||||
|
|
||||||
.link:not(.meta, .url) {
|
|
||||||
color: #0330cb;
|
|
||||||
text-decoration: underline;
|
|
||||||
}
|
|
||||||
|
|
||||||
.link.url {
|
|
||||||
color: #7e7d7d;
|
|
||||||
}
|
|
||||||
|
|
||||||
.url:not(.link) {
|
|
||||||
color: #0330cb;
|
|
||||||
text-decoration: underline;
|
|
||||||
cursor: pointer;
|
|
||||||
}
|
|
||||||
|
|
||||||
.atom {
|
|
||||||
color: darkred;
|
|
||||||
}
|
|
||||||
|
|
||||||
.wiki-link-page {
|
|
||||||
color: #0330cb;
|
|
||||||
background-color: rgba(77, 141, 255, 0.07);
|
|
||||||
border-radius: 5px;
|
|
||||||
padding: 0 5px;
|
|
||||||
cursor: pointer;
|
|
||||||
}
|
|
||||||
.wiki-link {
|
|
||||||
cursor: pointer;
|
|
||||||
color: #a8abbd;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Indentation of follow-up lines
|
// Indentation of follow-up lines
|
||||||
@mixin lineOverflow($baseIndent) {
|
@mixin lineOverflow($baseIndent) {
|
||||||
text-indent: -1 * ($baseIndent + 2ch);
|
text-indent: -1 * ($baseIndent + 2ch);
|
||||||
padding-left: $baseIndent + 2ch;
|
padding-left: $baseIndent + 2ch;
|
||||||
|
|
||||||
&.line-task {
|
&.sb-line-task {
|
||||||
text-indent: -1 * ($baseIndent + 6ch);
|
text-indent: -1 * ($baseIndent + 6ch);
|
||||||
padding-left: $baseIndent + 6ch;
|
padding-left: $baseIndent + 6ch;
|
||||||
}
|
}
|
||||||
|
|
||||||
&.line-blockquote {
|
&.sb-line-blockquote {
|
||||||
text-indent: -1 * ($baseIndent + 4ch);
|
text-indent: -1 * ($baseIndent + 4ch);
|
||||||
padding-left: $baseIndent + 4ch;
|
padding-left: $baseIndent + 4ch;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.line-ul {
|
.sb-line-ul {
|
||||||
&.line-li-1 {
|
&.sb-line-li-1 {
|
||||||
@include lineOverflow(0);
|
@include lineOverflow(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
&.line-li-1.line-li-2 {
|
&.sb-line-li-1.sb-line-li-2 {
|
||||||
@include lineOverflow(2);
|
@include lineOverflow(2);
|
||||||
}
|
}
|
||||||
|
|
||||||
&.line-li-1.line-li-2.line-li-3 {
|
&.sb-line-li-1.sb-line-li-2.sb-line-li-3 {
|
||||||
@include lineOverflow(4);
|
@include lineOverflow(4);
|
||||||
}
|
}
|
||||||
|
|
||||||
&.line-li-1.line-li-2.line-li-3.line-li-4 {
|
&.sb-line-li-1.sb-line-li-2.sb-line-li-3.sb-line-li-4 {
|
||||||
@include lineOverflow(6);
|
@include lineOverflow(6);
|
||||||
}
|
}
|
||||||
|
|
||||||
&.line-li-1.line-li-2.line-li-3.line-li-4.line-li-5 {
|
&.sb-line-li-1.sb-line-li-2.sb-line-li-3.sb-line-li-4.sb-line-li-5 {
|
||||||
@include lineOverflow(8);
|
@include lineOverflow(8);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.line-ol {
|
.sb-line-ol {
|
||||||
&.line-li-1 {
|
&.sb-line-li-1 {
|
||||||
@include lineOverflow(1);
|
@include lineOverflow(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
&.line-li-1.line-li-2 {
|
&.sb-line-li-1.sb-line-li-2 {
|
||||||
@include lineOverflow(2);
|
@include lineOverflow(2);
|
||||||
}
|
}
|
||||||
|
|
||||||
&.line-li-1.line-li-2.line-li-3 {
|
&.sb-line-li-1.sb-line-li-2.sb-line-li-3 {
|
||||||
@include lineOverflow(4);
|
@include lineOverflow(4);
|
||||||
}
|
}
|
||||||
|
|
||||||
&.line-li-1.line-li-2.line-li-3.line-li-4 {
|
&.sb-line-li-1.sb-line-li-2.sb-line-li-3.sb-line-li-4 {
|
||||||
@include lineOverflow(6);
|
@include lineOverflow(6);
|
||||||
}
|
}
|
||||||
|
|
||||||
&.line-li-1.line-li-2.line-li-3.line-li-4.line-li-5 {
|
&.sb-line-li-1.sb-line-li-2.sb-line-li-3.sb-line-li-4.sb-line-li-5 {
|
||||||
@include lineOverflow(8);
|
@include lineOverflow(8);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.line-comment {
|
.sb-line-comment {
|
||||||
text-indent: -1 * 3ch;
|
text-indent: -1 * 3ch;
|
||||||
padding-left: 3ch;
|
padding-left: 3ch;
|
||||||
}
|
}
|
||||||
|
|
||||||
.task-marker {
|
|
||||||
background-color: #ddd;
|
|
||||||
}
|
|
||||||
|
|
||||||
.line-comment {
|
|
||||||
background-color: rgba(255, 255, 0, 0.5);
|
|
||||||
}
|
|
||||||
|
|
||||||
.comment {
|
|
||||||
color: #989797;
|
|
||||||
background-color: rgba(210, 210, 210, 0.2);
|
|
||||||
border-radius: 5px;
|
|
||||||
font-size: 75%;
|
|
||||||
line-height: 75%;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,4 @@
|
||||||
@import "constants";
|
.sb-filter-wrapper {
|
||||||
|
|
||||||
.filter-wrapper {
|
|
||||||
position: absolute;
|
position: absolute;
|
||||||
margin: auto;
|
margin: auto;
|
||||||
max-width: 500px;
|
max-width: 500px;
|
||||||
|
@ -10,21 +8,15 @@
|
||||||
top: 0;
|
top: 0;
|
||||||
bottom: 0;
|
bottom: 0;
|
||||||
max-height: 290px;
|
max-height: 290px;
|
||||||
// overflow: hide;
|
|
||||||
z-index: 100;
|
z-index: 100;
|
||||||
}
|
}
|
||||||
|
|
||||||
.filter-box {
|
.sb-filter-box {
|
||||||
font-family: $ui-font;
|
|
||||||
background-color: #fff;
|
|
||||||
border: rgb(103, 103, 103) 1px solid;
|
|
||||||
border-radius: 8px;
|
border-radius: 8px;
|
||||||
box-shadow: rgba(0, 0, 0, 0.35) 0px 20px 20px;
|
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
margin: 10px;
|
margin: 10px;
|
||||||
|
|
||||||
.header {
|
.sb-header {
|
||||||
border-bottom: 1px rgb(108, 108, 108) solid;
|
|
||||||
padding: 13px 10px 10px 10px;
|
padding: 13px 10px 10px 10px;
|
||||||
display: flex;
|
display: flex;
|
||||||
label {
|
label {
|
||||||
|
@ -33,56 +25,45 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
input {
|
input {
|
||||||
font-family: "Arial";
|
|
||||||
background: transparent;
|
background: transparent;
|
||||||
color: #000;
|
|
||||||
border: 0;
|
border: 0;
|
||||||
padding: 3px;
|
padding: 3px;
|
||||||
outline: 0;
|
outline: 0;
|
||||||
font-size: 1em;
|
font-size: 1em;
|
||||||
flex-grow: 100;
|
flex-grow: 100;
|
||||||
}
|
}
|
||||||
input::placeholder {
|
|
||||||
color: rgb(199, 199, 199);
|
|
||||||
font-weight: normal;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.help-text {
|
.sb-help-text {
|
||||||
background-color: #eee;
|
|
||||||
border-bottom: 1px rgb(108, 108, 108) solid;
|
|
||||||
padding: 5px;
|
padding: 5px;
|
||||||
color: #555;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.result-list {
|
.sb-result-list {
|
||||||
max-height: 216px;
|
max-height: 216px;
|
||||||
overflow-y: scroll;
|
overflow-y: scroll;
|
||||||
|
|
||||||
.icon {
|
.sb-icon {
|
||||||
padding: 0 8px 0 5px;
|
padding: 0 8px 0 5px;
|
||||||
}
|
}
|
||||||
.name {
|
.sb-name {
|
||||||
padding-top: -3px;
|
padding-top: -3px;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.option,
|
.sb-option,
|
||||||
.selected-option {
|
.sb-selected-option {
|
||||||
padding: 8px;
|
padding: 8px;
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
height: 20px;
|
height: 20px;
|
||||||
line-height: 20px;
|
line-height: 20px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.selected-option {
|
.sb-selected-option {
|
||||||
background-color: var(--highlight-color);
|
background-color: var(--highlight-color);
|
||||||
color: #eee;
|
|
||||||
// border-radius: 5px;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.option .hint,
|
.sb-option .sb-hint,
|
||||||
.selected-option .hint {
|
.sb-selected-option .sb-hint {
|
||||||
float: right;
|
float: right;
|
||||||
margin-right: 0;
|
margin-right: 0;
|
||||||
margin-top: -4px;
|
margin-top: -4px;
|
||||||
|
@ -90,8 +71,6 @@
|
||||||
padding-right: 5px;
|
padding-right: 5px;
|
||||||
padding-top: 3px;
|
padding-top: 3px;
|
||||||
padding-bottom: 3px;
|
padding-bottom: 3px;
|
||||||
color: #eee;
|
|
||||||
background-color: #212476;
|
|
||||||
border-radius: 5px;
|
border-radius: 5px;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
@use "editor.scss";
|
@use "editor.scss";
|
||||||
@use "filter_box.scss";
|
@use "filter_box.scss";
|
||||||
@import "constants";
|
|
||||||
|
|
||||||
@font-face {
|
@font-face {
|
||||||
font-family: "iA-Mono";
|
font-family: "iA-Mono";
|
||||||
|
@ -30,12 +29,6 @@
|
||||||
font-style: italic;
|
font-style: italic;
|
||||||
}
|
}
|
||||||
|
|
||||||
#sb-root {
|
|
||||||
--ident: 18px;
|
|
||||||
--top-bar-bg: rgb(41, 41, 41);
|
|
||||||
--highlight-color: #464cfc;
|
|
||||||
}
|
|
||||||
|
|
||||||
#sb-root {
|
#sb-root {
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
|
@ -48,25 +41,22 @@
|
||||||
flex-direction: row;
|
flex-direction: row;
|
||||||
z-index: 20;
|
z-index: 20;
|
||||||
|
|
||||||
height: $top-bar-height;
|
height: 55px;
|
||||||
background-color: rgb(213, 213, 213);
|
|
||||||
border-bottom: rgb(193, 193, 193) 1px solid;
|
|
||||||
color: rgb(55, 55, 55);
|
|
||||||
.main {
|
.main {
|
||||||
flex: 2;
|
flex: 2;
|
||||||
max-width: 100%;
|
max-width: 100%;
|
||||||
|
|
||||||
.inner {
|
.inner {
|
||||||
max-width: $max-editor-width;
|
max-width: 800px;
|
||||||
margin: auto;
|
margin: auto;
|
||||||
font-size: 28px;
|
font-size: 28px;
|
||||||
padding: 10px 20px;
|
padding: 10px 20px;
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: row;
|
flex-direction: row;
|
||||||
|
|
||||||
.notifications {
|
.sb-notifications {
|
||||||
position: absolute;
|
position: absolute;
|
||||||
font-family: "iA-Mono";
|
|
||||||
bottom: 0;
|
bottom: 0;
|
||||||
left: 5px;
|
left: 5px;
|
||||||
right: 5px;
|
right: 5px;
|
||||||
|
@ -77,19 +67,10 @@
|
||||||
padding: 3px;
|
padding: 3px;
|
||||||
margin-bottom: 3px;
|
margin-bottom: 3px;
|
||||||
border-radius: 5px;
|
border-radius: 5px;
|
||||||
border: rgb(41, 41, 41) 1px solid;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notification-info {
|
|
||||||
background-color: rgb(187, 221, 247);
|
|
||||||
}
|
|
||||||
.notification-error {
|
|
||||||
background-color: rgb(255, 84, 84);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.current-page {
|
.sb-current-page {
|
||||||
font-family: $ui-font;
|
|
||||||
font-weight: bold;
|
font-weight: bold;
|
||||||
flex: 1;
|
flex: 1;
|
||||||
font-size: 28px;
|
font-size: 28px;
|
||||||
|
@ -100,30 +81,14 @@
|
||||||
display: block;
|
display: block;
|
||||||
text-overflow: ellipsis;
|
text-overflow: ellipsis;
|
||||||
}
|
}
|
||||||
|
|
||||||
.saved {
|
|
||||||
color: #111;
|
|
||||||
}
|
|
||||||
|
|
||||||
.unsaved {
|
|
||||||
color: #5e5e5e;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
.actions {
|
|
||||||
text-align: right;
|
|
||||||
|
|
||||||
button {
|
.sb-actions {
|
||||||
border: 1px solid #7897d0;
|
text-align: right;
|
||||||
border-radius: 3px;
|
|
||||||
margin: 3px;
|
|
||||||
font-size: 15px;
|
|
||||||
padding: 5px;
|
|
||||||
background-color: #e6e6e6;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.panel {
|
.sb-panel {
|
||||||
flex: 1;
|
flex: 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -134,9 +99,8 @@
|
||||||
flex-grow: 1;
|
flex-grow: 1;
|
||||||
height: 0;
|
height: 0;
|
||||||
|
|
||||||
.panel {
|
.sb-panel {
|
||||||
flex: 1;
|
flex: 1;
|
||||||
border-left: 1px solid #eee;
|
|
||||||
|
|
||||||
iframe {
|
iframe {
|
||||||
border: 0;
|
border: 0;
|
||||||
|
@ -154,12 +118,11 @@
|
||||||
height: 100%;
|
height: 100%;
|
||||||
}
|
}
|
||||||
|
|
||||||
.bhs {
|
.sb-bhs {
|
||||||
height: 300px;
|
height: 300px;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
border-top: rgb(193, 193, 193) 1px solid;
|
|
||||||
|
|
||||||
.panel {
|
.sb-panel {
|
||||||
height: 100%;
|
height: 100%;
|
||||||
|
|
||||||
iframe {
|
iframe {
|
||||||
|
|
|
@ -0,0 +1,272 @@
|
||||||
|
#sb-root {
|
||||||
|
font-family: Arial;
|
||||||
|
--highlight-color: #464cfc;
|
||||||
|
}
|
||||||
|
|
||||||
|
#sb-top {
|
||||||
|
background-color: rgb(213, 213, 213);
|
||||||
|
border-bottom: rgb(193, 193, 193) 1px solid;
|
||||||
|
color: rgb(55, 55, 55);
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-panel {
|
||||||
|
border-left: 1px solid #eee;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-bhs {
|
||||||
|
border-top: rgb(193, 193, 193) 1px solid;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-notifications {
|
||||||
|
font-family: "iA-Mono";
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-notifications > div {
|
||||||
|
border: rgb(41, 41, 41) 1px solid;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-notification-info {
|
||||||
|
background-color: rgb(187, 221, 247);
|
||||||
|
}
|
||||||
|
.sb-notification-error {
|
||||||
|
background-color: rgb(255, 84, 84);
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-saved {
|
||||||
|
color: #111;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-unsaved {
|
||||||
|
color: #5e5e5e;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-actions button {
|
||||||
|
border: 1px solid #7897d0;
|
||||||
|
border-radius: 3px;
|
||||||
|
margin: 3px;
|
||||||
|
font-size: 15px;
|
||||||
|
padding: 5px;
|
||||||
|
background-color: #e6e6e6;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Filter boxes */
|
||||||
|
.sb-filter-box {
|
||||||
|
background-color: #fff;
|
||||||
|
border: rgb(103, 103, 103) 1px solid;
|
||||||
|
box-shadow: rgba(0, 0, 0, 0.35) 0px 20px 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-filter-box .sb-header {
|
||||||
|
border-bottom: 1px rgb(108, 108, 108) solid;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-filter-box .sb-header input {
|
||||||
|
font-family: "Arial";
|
||||||
|
color: #000;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-filter-box .sb-header input::placeholder {
|
||||||
|
color: rgb(199, 199, 199);
|
||||||
|
font-weight: normal;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-filter-box .sb-help-text {
|
||||||
|
background-color: #eee;
|
||||||
|
border-bottom: 1px rgb(108, 108, 108) solid;
|
||||||
|
color: #555;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-filter-box .sb-selected-option {
|
||||||
|
color: #eee;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-filter-box .sb-option .sb-hint,
|
||||||
|
.sb-filter-box .sb-selected-option .sb-hint {
|
||||||
|
color: #eee;
|
||||||
|
background-color: #212476;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Editor */
|
||||||
|
|
||||||
|
.cm-content {
|
||||||
|
font-family: "iA-Mono", "Menlo";
|
||||||
|
}
|
||||||
|
|
||||||
|
.cm-selectionBackground {
|
||||||
|
background-color: #d7e1f6 !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-line-h1,
|
||||||
|
.sb-line-h2,
|
||||||
|
.sb-line-h3 {
|
||||||
|
background-color: rgba(0, 30, 77, 0.5);
|
||||||
|
color: #fff;
|
||||||
|
font-weight: bold;
|
||||||
|
padding: 2px 2px !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-line-h1 .sb-meta {
|
||||||
|
color: orange;
|
||||||
|
}
|
||||||
|
.sb-line-h2 .sb-meta {
|
||||||
|
color: orange;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-line-h3 .sb-meta {
|
||||||
|
color: orange;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-line-h1 {
|
||||||
|
font-size: 1.5em;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-line-h2 {
|
||||||
|
font-size: 1.2em;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-line-h3 {
|
||||||
|
font-size: 1.1em;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Color list item this way */
|
||||||
|
.sb-line-li .sb-meta {
|
||||||
|
color: rgb(150, 150, 150);
|
||||||
|
}
|
||||||
|
/* Then undo other meta */
|
||||||
|
.sb-line-li .sb-meta ~ .sb-meta {
|
||||||
|
color: #650007;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-line-code {
|
||||||
|
background-color: rgba(72, 72, 72, 0.1);
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-line-code .sb-code {
|
||||||
|
background-color: transparent;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-line-tbl-header {
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-line-tbl-header .meta {
|
||||||
|
font-weight: normal;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-struct {
|
||||||
|
color: darkred;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-code {
|
||||||
|
background-color: rgba(72, 72, 72, 0.1);
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-highlight {
|
||||||
|
background-color: rgba(255, 255, 0, 0.5);
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-line-fenced-code {
|
||||||
|
background-color: rgba(72, 72, 72, 0.1);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Mostly for JS when that comes back */
|
||||||
|
.sb-line-fenced-code .sb-code {
|
||||||
|
background-color: transparent;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-line-fenced-code .sb-comment {
|
||||||
|
color: #989797;
|
||||||
|
background-color: transparent;
|
||||||
|
border-radius: 0;
|
||||||
|
font-style: inherit;
|
||||||
|
font-size: inherit;
|
||||||
|
line-height: inherit;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-line-fenced-code .sb-keyword {
|
||||||
|
color: #830000;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-line-fenced-code .sb-variableName {
|
||||||
|
color: #036d9b;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-line-fenced-code .sb-typeName {
|
||||||
|
color: #038138;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-line-fenced-code .sb-string,
|
||||||
|
.sb-line-fenced-code .sb-string2 {
|
||||||
|
color: #440377;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-meta {
|
||||||
|
color: #650007;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-line-blockquote {
|
||||||
|
background-color: rgba(220, 220, 220, 0.5);
|
||||||
|
color: #676767;
|
||||||
|
text-indent: -2ch;
|
||||||
|
padding-left: 2ch;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-emphasis {
|
||||||
|
font-style: italic;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-strong {
|
||||||
|
font-weight: 900;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-link {
|
||||||
|
cursor: pointer;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-link:not(.sb-meta, .sb-url) {
|
||||||
|
color: #0330cb;
|
||||||
|
text-decoration: underline;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-link.sb-url {
|
||||||
|
color: #7e7d7d;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-url:not(.sb-link) {
|
||||||
|
color: #0330cb;
|
||||||
|
text-decoration: underline;
|
||||||
|
cursor: pointer;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-atom {
|
||||||
|
color: darkred;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-wiki-link-page {
|
||||||
|
color: #0330cb;
|
||||||
|
background-color: rgba(77, 141, 255, 0.07);
|
||||||
|
border-radius: 5px;
|
||||||
|
padding: 0 5px;
|
||||||
|
cursor: pointer;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-wiki-link {
|
||||||
|
cursor: pointer;
|
||||||
|
color: #a8abbd;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-task-marker {
|
||||||
|
background-color: #ddd;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-line-comment {
|
||||||
|
background-color: rgba(255, 255, 0, 0.5);
|
||||||
|
}
|
||||||
|
|
||||||
|
.sb-comment {
|
||||||
|
color: #989797;
|
||||||
|
background-color: rgba(210, 210, 210, 0.2);
|
||||||
|
border-radius: 5px;
|
||||||
|
font-size: 75%;
|
||||||
|
line-height: 75%;
|
||||||
|
}
|
Loading…
Reference in New Issue