Fist Commit

This commit is contained in:
Fabian 2021-03-03 22:44:30 +01:00
parent b05e2d3c55
commit bc0a036aea
10 changed files with 1512 additions and 91 deletions

63
package-lock.json generated
View File

@ -26,9 +26,9 @@
} }
}, },
"@hibas123/theme": { "@hibas123/theme": {
"version": "1.0.5", "version": "1.0.6",
"resolved": "https://registry.npmjs.org/@hibas123/theme/-/theme-1.0.5.tgz", "resolved": "https://registry.npmjs.org/@hibas123/theme/-/theme-1.0.6.tgz",
"integrity": "sha512-D3qZVNz/lVKVh9olarxPyae0QF47OZCChVt6waRCr5j01zrLk/P7EVzM0Gzw8wf39LXVZTc63XbUm3whwKcutQ==", "integrity": "sha512-NRODYM8714IlqE6DQKLunfNi/8uspKYrEtDH/bBeYQmYqCUYWRYIWGqQn05ym97GVRQW+6lrYzF6Ik4LqXojfQ==",
"requires": { "requires": {
"sass": "^1.21.0" "sass": "^1.21.0"
} }
@ -38,6 +38,21 @@
"resolved": "https://registry.npmjs.org/@hibas123/utils/-/utils-2.1.0.tgz", "resolved": "https://registry.npmjs.org/@hibas123/utils/-/utils-2.1.0.tgz",
"integrity": "sha512-rS0SMENN7ta6pv9bNmIls8lvEOHbbDQXpiDI3u3z0Vx8B43ngEmEXbu5vKBA58ekYLr1WdHH6iIiySDChoi/RQ==" "integrity": "sha512-rS0SMENN7ta6pv9bNmIls8lvEOHbbDQXpiDI3u3z0Vx8B43ngEmEXbu5vKBA58ekYLr1WdHH6iIiySDChoi/RQ=="
}, },
"@types/codemirror": {
"version": "0.0.76",
"resolved": "https://registry.npmjs.org/@types/codemirror/-/codemirror-0.0.76.tgz",
"integrity": "sha512-k/hpUb+Ebyn9z63qM8IbsRiW0eYHZ+pi/1e2reGzBKAZJzkjWmNTXXqLLiNv5d9ekyxkajxRBr5Hu2WZq/nokw==",
"dev": true,
"requires": {
"@types/tern": "*"
}
},
"@types/estree": {
"version": "0.0.39",
"resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.39.tgz",
"integrity": "sha512-EYNwp3bU+98cpU4lAWYYL7Zz+2gryWH1qbdDTidVd6hkiR6weksdbMadyXKXNPEkQFhXM+hVO9ZygomHXp+AIw==",
"dev": true
},
"@types/events": { "@types/events": {
"version": "3.0.0", "version": "3.0.0",
"resolved": "https://registry.npmjs.org/@types/events/-/events-3.0.0.tgz", "resolved": "https://registry.npmjs.org/@types/events/-/events-3.0.0.tgz",
@ -97,6 +112,15 @@
"integrity": "sha512-7EJYyKTL7tFR8+gDbB6Wwz/arpGa0Mywk1TJbNzKzHtzbwVmY4HR9WqS5VV7dsBUKQmPNr192jHr/VpBluj/hg==", "integrity": "sha512-7EJYyKTL7tFR8+gDbB6Wwz/arpGa0Mywk1TJbNzKzHtzbwVmY4HR9WqS5VV7dsBUKQmPNr192jHr/VpBluj/hg==",
"dev": true "dev": true
}, },
"@types/tern": {
"version": "0.23.3",
"resolved": "https://registry.npmjs.org/@types/tern/-/tern-0.23.3.tgz",
"integrity": "sha512-imDtS4TAoTcXk0g7u4kkWqedB3E4qpjXzCpD2LU5M5NAXHzCDsypyvXSaG7mM8DKYkCRa7tFp4tS/lp/Wo7Q3w==",
"dev": true,
"requires": {
"@types/estree": "*"
}
},
"@types/uikit": { "@types/uikit": {
"version": "2.27.7", "version": "2.27.7",
"resolved": "https://registry.npmjs.org/@types/uikit/-/uikit-2.27.7.tgz", "resolved": "https://registry.npmjs.org/@types/uikit/-/uikit-2.27.7.tgz",
@ -1173,6 +1197,19 @@
"integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=", "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=",
"dev": true "dev": true
}, },
"codemirror": {
"version": "5.48.0",
"resolved": "https://registry.npmjs.org/codemirror/-/codemirror-5.48.0.tgz",
"integrity": "sha512-3Ter+tYtRlTNtxtYdYNPxGxBL/b3cMcvPdPm70gvmcOO2Rauv/fUEewWa0tT596Hosv6ea2mtpx28OXBy1mQCg=="
},
"codemirror-spell-checker": {
"version": "1.1.2",
"resolved": "https://registry.npmjs.org/codemirror-spell-checker/-/codemirror-spell-checker-1.1.2.tgz",
"integrity": "sha1-HGYPkIlIPMtRE7m6nKGcP0mTNx4=",
"requires": {
"typo-js": "*"
}
},
"collection-visit": { "collection-visit": {
"version": "1.0.0", "version": "1.0.0",
"resolved": "https://registry.npmjs.org/collection-visit/-/collection-visit-1.0.0.tgz", "resolved": "https://registry.npmjs.org/collection-visit/-/collection-visit-1.0.0.tgz",
@ -1855,6 +1892,16 @@
"stream-shift": "^1.0.0" "stream-shift": "^1.0.0"
} }
}, },
"easymde": {
"version": "2.6.1",
"resolved": "https://registry.npmjs.org/easymde/-/easymde-2.6.1.tgz",
"integrity": "sha512-DNdAn7xADNJBGQSULncZJXOlHSyK1IqvOPIaFOSKv18GBKItuCFy/f6KEUhFx47MDLQpWgznJgfvh9VKjavzaQ==",
"requires": {
"codemirror": "^5.47.0",
"codemirror-spell-checker": "1.1.2",
"marked": "^0.6.2"
}
},
"ecc-jsbn": { "ecc-jsbn": {
"version": "0.1.2", "version": "0.1.2",
"resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz", "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz",
@ -4170,6 +4217,11 @@
"object-visit": "^1.0.0" "object-visit": "^1.0.0"
} }
}, },
"marked": {
"version": "0.6.3",
"resolved": "https://registry.npmjs.org/marked/-/marked-0.6.3.tgz",
"integrity": "sha512-Fqa7eq+UaxfMriqzYLayfqAE40WN03jf+zHjT18/uXNuzjq3TY0XTbrAoPeqSJrAmPz11VuUA+kBPYOhHt9oOQ=="
},
"md5.js": { "md5.js": {
"version": "1.3.5", "version": "1.3.5",
"resolved": "https://registry.npmjs.org/md5.js/-/md5.js-1.3.5.tgz", "resolved": "https://registry.npmjs.org/md5.js/-/md5.js-1.3.5.tgz",
@ -7003,6 +7055,11 @@
"integrity": "sha512-7KxJovlYhTX5RaRbUdkAXN1KUZ8PwWlTzQdHV6xNqvuFOs7+WBo10TQUqT19Q/Jz2hk5v9TQDIhyLhhJY4p5AA==", "integrity": "sha512-7KxJovlYhTX5RaRbUdkAXN1KUZ8PwWlTzQdHV6xNqvuFOs7+WBo10TQUqT19Q/Jz2hk5v9TQDIhyLhhJY4p5AA==",
"dev": true "dev": true
}, },
"typo-js": {
"version": "1.0.3",
"resolved": "https://registry.npmjs.org/typo-js/-/typo-js-1.0.3.tgz",
"integrity": "sha1-VNjrx5SfGngQkItgAsaEFSbJnVo="
},
"ua-parser-js": { "ua-parser-js": {
"version": "0.7.19", "version": "0.7.19",
"resolved": "https://registry.npmjs.org/ua-parser-js/-/ua-parser-js-0.7.19.tgz", "resolved": "https://registry.npmjs.org/ua-parser-js/-/ua-parser-js-0.7.19.tgz",

View File

@ -14,9 +14,10 @@
"license": "MIT", "license": "MIT",
"dependencies": { "dependencies": {
"@hibas123/secure-file-wrapper": "^2.5.0", "@hibas123/secure-file-wrapper": "^2.5.0",
"@hibas123/theme": "^1.0.5", "@hibas123/theme": "^1.0.6",
"@hibas123/utils": "^2.1.0", "@hibas123/utils": "^2.1.0",
"aes-js": "^3.1.2", "aes-js": "^3.1.2",
"easymde": "^2.6.1",
"feather-icons": "^4.22.1", "feather-icons": "^4.22.1",
"idb": "^4.0.3", "idb": "^4.0.3",
"js-sha256": "^0.9.0", "js-sha256": "^0.9.0",
@ -25,6 +26,7 @@
"uuid": "^3.3.2" "uuid": "^3.3.2"
}, },
"devDependencies": { "devDependencies": {
"@types/codemirror": "0.0.76",
"@types/lodash.clonedeep": "^4.5.6", "@types/lodash.clonedeep": "^4.5.6",
"@types/uikit": "^2.27.7", "@types/uikit": "^2.27.7",
"@types/uuid": "^3.4.5", "@types/uuid": "^3.4.5",

View File

@ -56,9 +56,9 @@ export class Footer extends Component<{}, { synced: boolean, syncing: boolean }>
text = "not synced"; text = "not synced";
} }
} }
return <footer class="elv-8"> return <footer class="elv-8" style="line-height: 1.1rem;">
<span> <span>
<span class={extrac} ><a onClick={() => this.onSyncClick()} ><Refresh style="height: 1em; width: 1em;"></Refresh></a></span> <span><a class={extrac} onClick={() => this.onSyncClick()} ><Refresh style="height: 1.1em; width: 1.1em;"></Refresh></a></span>
<span style={"margin-left: 8px; color:" + color}>{text}</span> <span style={"margin-left: 8px; color:" + color}>{text}</span>
</span> </span>
<span> <span>

View File

@ -0,0 +1,51 @@
import { Component, h } from "preact";
import * as EasyMDE from "easymde";
// import "./easymde.css";
// import "./dark.css";
import "easymde/dist/easymde.min.css";
// import "codemirror/theme/monokai.css";
export interface EditorProps {
value: string;
valueChange: (value: string) => void;
save: () => void;
exit: () => void;
}
export default class Editor extends Component<EditorProps, {}> {
element: HTMLInputElement;
easymde: EasyMDE;
componentDidMount() {
if (this.easymde)
this.easymde.toTextArea();
this.easymde = new EasyMDE({
element: this.element,
initialValue: this.props.value,
autofocus: true,
spellChecker: false
// theme: "monokai"
// autoDownloadFontAwesome: true
})
this.easymde.codemirror.on("change", () => {
this.props.valueChange(this.easymde.value());
});
this.easymde.codemirror.addKeyMap({
"Ctrl-S": () => this.props.save(),
"Esc": () => this.props.exit()
})
}
shouldComponentUpdate(props: EditorProps) {
if (this.easymde.value() !== props.value)
this.easymde.value(props.value);
return false;
}
render() {
return <textarea ref={ta => this.element = ta}></textarea>
}
}

View File

@ -0,0 +1,188 @@
import { h, Component } from "preact"
import { IVault, ViewNote } from "../../../notes";
import Trash from "feather-icons/dist/icons/trash-2.svg"
import X from "feather-icons/dist/icons/x.svg"
import Save from "feather-icons/dist/icons/save.svg"
import Navigation from "../../../navigation";
import { YesNoModal } from "../../modals/YesNoModal";
import Notifications, { MessageType } from "../../../notifications";
const minRows = 3;
export default class EntryComponent extends Component<{ vault: Promise<IVault>, id: string | undefined, note: string | undefined }, { title: string, changed: boolean }> {
private text: string = "";
private vault: IVault;
// private lineHeight: number = 24;
private note: ViewNote;
private rows: number = minRows;
private skip_save: boolean = false;
private inputElm: HTMLInputElement;
constructor(props) {
super(props);
this.state = { changed: false, title: "" };
this.textAreaChange = this.textAreaChange.bind(this);
this.textAreaKeyPress = this.textAreaKeyPress.bind(this);
}
private toVault() {
history.back();
}
componentDidMount() {
this.inputElm.focus();
}
async componentWillMount() {
this.text = "";
this.vault = undefined;
this.note = undefined;
this.rows = minRows;
this.skip_save = false;
this.setState({ changed: false, title: "" });
try {
this.skip_save = false;
this.vault = await this.props.vault;
let note: ViewNote;
let changed = false;
if (this.props.id)
note = await this.vault.getNote(this.props.id)
else {
note = this.vault.newNote();
if (this.props.note) {
note.__value = this.props.note;
changed = true;
}
}
if (!note) {
Notifications.sendNotification("Note not found!", MessageType.ERROR);
} else {
this.note = note;
this.text = note.__value;
let rows = this.getRows(this.text);
if (rows !== this.rows) {
this.rows = rows;
}
let [title] = this.text.split("\n", 1);
this.setState({ title, changed })
}
} catch (err) {
Notifications.sendError(err);
}
}
private async save() {
try {
if (this.state.changed) {
this.note.__value = this.text;
await this.vault.saveNote(this.note);
this.setState({ changed: false })
}
} catch (err) {
Notifications.sendError(err);
}
}
componentWillUnmount() {
if (!this.skip_save)
this.save()
}
strToNr(value: string) {
let match = value.match(/\d/g)
return Number(match.join(""))
}
getRows(value: string) {
const lines = (value.match(/\r?\n/g) || '').length + 1
return Math.max(lines + 1, minRows);
}
textAreaChange(evt: KeyboardEvent) {
if (evt.keyCode === 17 || evt.keyCode === 27) return; //No character, so not relevant for this function
if (!this.state.changed && this.textAreaKeyPress(evt)) this.setState({ changed: true })
let target = (evt.target as HTMLTextAreaElement)
let value = target.value;
this.text = value;
let [title] = value.split("\n", 1);
if (title !== this.state.title)
this.setState({ title });
let rows = this.getRows(value);
if (rows !== this.rows) {
target.rows = rows;
this.rows = rows;
}
}
async exitHandler() {
if (this.state.changed) {
let modal = new YesNoModal("Really want to quit?");
let res = await modal.getResult();
if (res === true) {
this.skip_save = true;
this.toVault();
}
} else
this.toVault()
}
textAreaKeyPress(evt: KeyboardEvent) {
console.log(evt);
if ((evt.keyCode === 83 || evt.keyCode === 13) && evt.ctrlKey) {
evt.preventDefault()
this.save();
return false;
}
else if (evt.keyCode === 27) {
evt.preventDefault();
this.exitHandler();
return false;
}
return true;
}
render() {
const save_handler = async () => {
await this.save()
Navigation.setPage("/vault", { id: this.vault.id }, { entry: "false" }, true);
this.toVault()
}
const delete_handler = async () => {
await this.vault.deleteNote(this.props.id);
this.toVault()
}
console.log("Rerender")
return <div>
<header class="header">
<a class="header-icon-button" onClick={() => this.exitHandler()}><X height={undefined} width={undefined} /></a>
{this.state.changed ? <a class="header-icon-button" style="margin-left: 0.5em;" onClick={() => save_handler()}><Save height={undefined} width={undefined} /></a> : undefined}
<h3 style="display:inline" class="button header-title">{this.state.title}</h3>
<a class="header-icon-button" onClick={() => delete_handler()}><Trash height={undefined} width={undefined} /></a>
</header>
<div class="container">
<textarea
value={this.text}
rows={this.rows}
class="inp"
style="width:100%;"
onInput={this.textAreaChange}
onKeyDown={this.textAreaKeyPress}
onChange={this.textAreaChange}
ref={elm => this.inputElm = elm}
/>
</div>
</div>
}
}

View File

@ -7,6 +7,9 @@ import Save from "feather-icons/dist/icons/save.svg"
import Navigation from "../../../navigation"; import Navigation from "../../../navigation";
import { YesNoModal } from "../../modals/YesNoModal"; import { YesNoModal } from "../../modals/YesNoModal";
import Notifications, { MessageType } from "../../../notifications"; import Notifications, { MessageType } from "../../../notifications";
import Theme from "../../../theme";
import Editor from "./Editor";
const minRows = 3; const minRows = 3;
export default class EntryComponent extends Component<{ vault: Promise<IVault>, id: string | undefined, note: string | undefined }, { title: string, changed: boolean }> { export default class EntryComponent extends Component<{ vault: Promise<IVault>, id: string | undefined, note: string | undefined }, { title: string, changed: boolean }> {
@ -15,37 +18,27 @@ export default class EntryComponent extends Component<{ vault: Promise<IVault>,
// private lineHeight: number = 24; // private lineHeight: number = 24;
private note: ViewNote; private note: ViewNote;
private rows: number = minRows;
private skip_save: boolean = false; private skip_save: boolean = false;
private inputElm: HTMLInputElement;
constructor(props) { constructor(props) {
super(props); super(props);
this.state = { changed: false, title: "" }; this.state = { changed: false, title: "" };
this.textAreaChange = this.textAreaChange.bind(this);
this.textAreaKeyPress = this.textAreaKeyPress.bind(this);
} }
private toVault() { private toVault() {
history.back(); history.back();
} }
componentDidMount() { componentDidMount() { }
this.inputElm.focus();
}
async componentWillMount() { async componentWillMount() {
this.text = ""; this.text = "";
this.vault = undefined; this.vault = undefined;
this.note = undefined; this.note = undefined;
this.rows = minRows;
this.skip_save = false; this.skip_save = false;
this.setState({ changed: false, title: "" }); this.setState({ changed: false, title: "" });
try { try {
this.skip_save = false;
this.vault = await this.props.vault; this.vault = await this.props.vault;
let note: ViewNote; let note: ViewNote;
let changed = false; let changed = false;
@ -64,10 +57,7 @@ export default class EntryComponent extends Component<{ vault: Promise<IVault>,
} else { } else {
this.note = note; this.note = note;
this.text = note.__value; this.text = note.__value;
let rows = this.getRows(this.text);
if (rows !== this.rows) {
this.rows = rows;
}
let [title] = this.text.split("\n", 1); let [title] = this.text.split("\n", 1);
this.setState({ title, changed }) this.setState({ title, changed })
} }
@ -93,37 +83,18 @@ export default class EntryComponent extends Component<{ vault: Promise<IVault>,
this.save() this.save()
} }
strToNr(value: string) { private textChange(value: string) {
let match = value.match(/\d/g) if (!this.state.changed && value !== this.text)
return Number(match.join("")) this.setState({ changed: true })
}
getRows(value: string) {
const lines = (value.match(/\r?\n/g) || '').length + 1
return Math.max(lines + 1, minRows);
}
textAreaChange(evt: KeyboardEvent) {
if (evt.keyCode === 17 || evt.keyCode === 27) return; //No character, so not relevant for this function
if (!this.state.changed && this.textAreaKeyPress(evt)) this.setState({ changed: true })
let target = (evt.target as HTMLTextAreaElement)
let value = target.value;
this.text = value; this.text = value;
let [title] = value.split("\n", 1); let [title] = value.split("\n", 1);
if (title !== this.state.title) if (title !== this.state.title)
this.setState({ title }); this.setState({ title });
let rows = this.getRows(value);
if (rows !== this.rows) {
target.rows = rows;
this.rows = rows;
}
} }
async exitHandler() { private async exitHandler() {
if (this.state.changed) { if (this.state.changed) {
let modal = new YesNoModal("Really want to quit?"); let modal = new YesNoModal("Really want to quit?");
let res = await modal.getResult(); let res = await modal.getResult();
@ -135,21 +106,6 @@ export default class EntryComponent extends Component<{ vault: Promise<IVault>,
this.toVault() this.toVault()
} }
textAreaKeyPress(evt: KeyboardEvent) {
console.log(evt);
if ((evt.keyCode === 83 || evt.keyCode === 13) && evt.ctrlKey) {
evt.preventDefault()
this.save();
return false;
}
else if (evt.keyCode === 27) {
evt.preventDefault();
this.exitHandler();
return false;
}
return true;
}
render() { render() {
const save_handler = async () => { const save_handler = async () => {
await this.save() await this.save()
@ -171,17 +127,12 @@ export default class EntryComponent extends Component<{ vault: Promise<IVault>,
<h3 style="display:inline" class="button header-title">{this.state.title}</h3> <h3 style="display:inline" class="button header-title">{this.state.title}</h3>
<a class="header-icon-button" onClick={() => delete_handler()}><Trash height={undefined} width={undefined} /></a> <a class="header-icon-button" onClick={() => delete_handler()}><Trash height={undefined} width={undefined} /></a>
</header> </header>
<div class="container"> <div class="container" style={Theme.isDark() ? "filter: invert(100%);" : ""}>
<textarea <Editor
value={this.text} value={this.text}
rows={this.rows} valueChange={value => this.textChange(value)}
class="inp" save={() => this.save()}
style="width:100%;" exit={() => this.exitHandler()} />
onInput={this.textAreaChange}
onKeyDown={this.textAreaKeyPress}
onChange={this.textAreaChange}
ref={elm => this.inputElm = elm}
/>
</div> </div>
</div> </div>
} }

View File

@ -0,0 +1,858 @@
/* SimpleMDE Theme Dark v0.0.0 https://github.com/xcatliu/simplemde-theme-dark#readme */
@charset "UTF-8";
.CodeMirror-gutter-filler,
.CodeMirror-scrollbar-filler {
background-color: #fff
}
.CodeMirror-gutters {
border-right: 1px solid #ddd;
background-color: #f7f7f7;
white-space: nowrap
}
.CodeMirror-linenumber {
padding: 0 3px 0 5px;
min-width: 20px;
text-align: right;
color: #999;
white-space: nowrap
}
.CodeMirror-guttermarker {
color: #000
}
.CodeMirror-guttermarker-subtle {
color: #999
}
.CodeMirror-cursor {
border-left: 1px solid #000;
border-right: none;
width: 0
}
.CodeMirror div.CodeMirror-secondarycursor {
border-left: 1px solid silver
}
.cm-fat-cursor .CodeMirror-cursor {
width: auto;
border: 0 !important;
background: #7e7
}
.cm-fat-cursor div.CodeMirror-cursors {
z-index: 1
}
.cm-animate-fat-cursor {
width: auto;
border: 0;
-webkit-animation: blink 1.06s steps(1) infinite;
animation: blink 1.06s steps(1) infinite;
background-color: #7e7
}
@-webkit-keyframes blink {
50% {
background-color: transparent
}
}
@keyframes blink {
50% {
background-color: transparent
}
}
.cm-tab {
display: inline-block;
text-decoration: inherit
}
.CodeMirror-rulers {
position: absolute;
left: 0;
right: 0;
top: -50px;
bottom: -20px;
overflow: hidden
}
.CodeMirror-ruler {
border-left: 1px solid #ccc;
top: 0;
bottom: 0;
position: absolute
}
.CodeMirror,
.CodeMirror-scroll {
position: relative;
min-height: 300px
}
.cm-s-default .cm-header {
color: #00f
}
.cm-s-default .cm-quote {
color: #090
}
.cm-negative {
color: #d44
}
.cm-positive {
color: #292
}
.cm-header,
.cm-strong {
font-weight: 700
}
.cm-em {
font-style: italic
}
.cm-link {
text-decoration: underline
}
.CodeMirror .CodeMirror-code .cm-strikethrough,
.cm-strikethrough {
text-decoration: line-through
}
.cm-s-default .cm-keyword {
color: #708
}
.cm-s-default .cm-atom {
color: #219
}
.cm-s-default .cm-number {
color: #164
}
.cm-s-default .cm-def {
color: #00f
}
.cm-s-default .cm-variable-2 {
color: #05a
}
.cm-s-default .cm-variable-3 {
color: #085
}
.cm-s-default .cm-comment {
color: #a50
}
.cm-s-default .cm-string {
color: #a11
}
.cm-s-default .cm-string-2 {
color: #f50
}
.cm-s-default .cm-meta,
.cm-s-default .cm-qualifier {
color: #555
}
.cm-s-default .cm-builtin {
color: #30a
}
.cm-s-default .cm-bracket {
color: #997
}
.cm-s-default .cm-tag {
color: #170
}
.cm-s-default .cm-attribute {
color: #00c
}
.cm-s-default .cm-hr {
color: #999
}
.cm-s-default .cm-link {
color: #00c
}
.cm-invalidchar,
.cm-s-default .cm-error {
color: red
}
.CodeMirror-composing {
border-bottom: 2px solid
}
div.CodeMirror span.CodeMirror-matchingbracket {
color: #0f0
}
div.CodeMirror span.CodeMirror-nonmatchingbracket {
color: #f22
}
.CodeMirror-matchingtag {
background: rgba(255, 150, 0, .3)
}
.CodeMirror-activeline-background {
background: #e8f2ff
}
.CodeMirror {
position: relative;
overflow: hidden;
background: #fff
}
.CodeMirror-scroll {
overflow: scroll !important;
height: 100%;
outline: 0;
position: relative
}
.CodeMirror-sizer {
position: relative;
border-right: 30px solid transparent
}
.CodeMirror-gutter-filler,
.CodeMirror-hscrollbar,
.CodeMirror-scrollbar-filler,
.CodeMirror-vscrollbar {
position: absolute;
z-index: 6;
display: none
}
.CodeMirror-vscrollbar {
right: 0;
top: 0;
overflow-x: hidden;
overflow-y: scroll
}
.CodeMirror-hscrollbar {
bottom: 0;
left: 0;
overflow-y: hidden;
overflow-x: scroll
}
.CodeMirror-scrollbar-filler {
right: 0;
bottom: 0
}
.CodeMirror-gutter-filler {
left: 0;
bottom: 0
}
.CodeMirror-gutters {
position: absolute;
left: 0;
top: 0;
min-height: 100%;
z-index: 3
}
.CodeMirror-gutter {
white-space: normal;
height: 100%;
display: inline-block;
vertical-align: top;
margin-bottom: -30px
}
.CodeMirror-gutter-wrapper {
position: absolute;
z-index: 4;
background: 0 0 !important;
border: none !important;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none
}
.CodeMirror-gutter-background {
position: absolute;
top: 0;
bottom: 0;
z-index: 4
}
.CodeMirror-gutter-elt {
position: absolute;
cursor: default;
z-index: 4
}
.CodeMirror-lines {
cursor: text;
min-height: 1px
}
.CodeMirror pre {
border-radius: 0;
border-width: 0;
background: 0 0;
font-family: inherit;
font-size: inherit;
margin: 0;
white-space: pre;
word-wrap: normal;
line-height: inherit;
color: inherit;
z-index: 2;
position: relative;
overflow: visible;
-webkit-tap-highlight-color: transparent;
-webkit-font-variant-ligatures: contextual;
font-variant-ligatures: contextual
}
.CodeMirror-wrap pre {
word-wrap: break-word;
white-space: pre-wrap;
word-break: normal
}
.CodeMirror-linebackground {
position: absolute;
left: 0;
right: 0;
top: 0;
bottom: 0;
z-index: 0
}
.CodeMirror-linewidget {
position: relative;
z-index: 2;
overflow: auto
}
.CodeMirror-code {
outline: 0
}
.CodeMirror-gutter,
.CodeMirror-gutters,
.CodeMirror-linenumber,
.CodeMirror-scroll,
.CodeMirror-sizer {
box-sizing: content-box
}
.CodeMirror-measure {
position: absolute;
width: 100%;
height: 0;
overflow: hidden;
visibility: hidden
}
.CodeMirror-cursor {
position: absolute;
pointer-events: none
}
.CodeMirror-measure pre {
position: static
}
div.CodeMirror-cursors {
visibility: hidden;
position: relative;
z-index: 3
}
.CodeMirror-focused div.CodeMirror-cursors,
div.CodeMirror-dragcursors {
visibility: visible
}
.CodeMirror-selected {
background: #d9d9d9
}
.CodeMirror-focused .CodeMirror-selected {
background: #d7d4f0
}
.CodeMirror-crosshair {
cursor: crosshair
}
.CodeMirror-line::selection,
.CodeMirror-line>span::selection,
.CodeMirror-line>span>span::selection {
background: #d7d4f0
}
.CodeMirror-line::-moz-selection,
.CodeMirror-line>span::-moz-selection,
.CodeMirror-line>span>span::-moz-selection {
background: #d7d4f0
}
.cm-searching {
background: #ffa;
background: rgba(255, 255, 0, .4)
}
.cm-force-border {
padding-right: .1px
}
@media print {
.CodeMirror div.CodeMirror-cursors {
visibility: hidden
}
}
.cm-tab-wrap-hack:after {
content: ''
}
span.CodeMirror-selectedtext {
background: 0 0
}
.CodeMirror {
background-color: #444;
border: 1px solid #555;
border-bottom-left-radius: 3px;
border-bottom-right-radius: 3px;
color: #aaa;
font-family: inherit;
font-size: 18px;
height: auto;
line-height: 1.5;
padding: 14px;
z-index: 1
}
.CodeMirror-scroll {
margin-bottom: -32px;
margin-right: -32px;
padding-bottom: 32px
}
.CodeMirror-fullscreen {
background-color: #444;
border: 0;
border-top: 1px solid #555;
bottom: 0;
height: auto;
left: 0;
position: fixed !important;
right: 0;
top: 58px;
z-index: 9
}
.CodeMirror-sided {
width: 50% !important
}
.CodeMirror .CodeMirror-placeholder {
color: #777
}
.CodeMirror-cursor {
border-left-color: #aaa
}
.CodeMirror pre,
.CodeMirror-lines {
padding: 0
}
.CodeMirror-focused .CodeMirror-selected,
.CodeMirror-line::-moz-selection,
.CodeMirror-line>span::-moz-selection,
.CodeMirror-line>span>span::-moz-selection,
.CodeMirror-selected {
background-color: rgba(255, 255, 255, .1)
}
.CodeMirror-focused .CodeMirror-selected,
.CodeMirror-line::selection,
.CodeMirror-line>span::selection,
.CodeMirror-line>span>span::selection,
.CodeMirror-selected {
background-color: rgba(255, 255, 255, .1)
}
.CodeMirror .CodeMirror-code .cm-attribute,
.CodeMirror .CodeMirror-code .cm-tag {
color: #95bf40
}
.CodeMirror .CodeMirror-code .cm-string {
color: #777
}
.CodeMirror .CodeMirror-code .cm-link {
color: #ffd500
}
.CodeMirror .CodeMirror-code .cm-formatting-code,
.CodeMirror .CodeMirror-code .cm-formatting-code-block,
.CodeMirror .CodeMirror-code .cm-formatting-em,
.CodeMirror .CodeMirror-code .cm-formatting-header,
.CodeMirror .CodeMirror-code .cm-formatting-strikethrough,
.CodeMirror .CodeMirror-code .cm-formatting-strong,
.CodeMirror .CodeMirror-code .cm-hr,
.CodeMirror .CodeMirror-code .cm-quote,
.CodeMirror .CodeMirror-code .cm-url {
color: #777
}
.CodeMirror .CodeMirror-code .cm-header-1,
.CodeMirror .CodeMirror-code .cm-header-2,
.CodeMirror .CodeMirror-code .cm-header-3,
.CodeMirror .CodeMirror-code .cm-header-4,
.CodeMirror .CodeMirror-code .cm-header-5,
.CodeMirror .CodeMirror-code .cm-header-6 {
line-height: 2
}
.CodeMirror .CodeMirror-code .cm-header-1 {
font-size: 32px
}
.CodeMirror .CodeMirror-code .cm-header-2 {
font-size: 26px
}
.CodeMirror .CodeMirror-code .cm-header-3 {
font-size: 24px
}
.CodeMirror .CodeMirror-code .cm-header-4 {
font-size: 22px
}
.CodeMirror .CodeMirror-code .cm-header-5 {
font-size: 20px
}
.CodeMirror .CodeMirror-code .cm-header-6 {
font-size: 18px
}
.CodeMirror .CodeMirror-code .cm-header,
.CodeMirror .CodeMirror-code .cm-strong {
font-weight: 600
}
.CodeMirror .CodeMirror-code .cm-comment {
background-color: rgba(255, 255, 255, .05);
font-family: Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
font-size: 14px;
padding: 6px 0 4px
}
.CodeMirror .CodeMirror-code span.CodeMirror-selectedtext.cm-comment {
background-color: rgba(255, 255, 255, .05)
}
.editor-preview {
height: 100%;
left: 0;
position: absolute;
top: 0;
width: 100%;
z-index: 2
}
.editor-preview-side {
border: 0;
border-left: 1px solid #555;
border-top: 1px solid #555;
bottom: 0;
position: fixed;
right: 0;
top: 58px;
width: 50%;
z-index: 9
}
.editor-preview,
.editor-preview-side {
background-color: #444;
box-sizing: border-box;
color: #aaa;
display: none;
font-family: inherit;
font-size: 18px;
line-height: 1.5;
overflow: auto;
padding: 0 14px 14px
}
.editor-preview pre,
.editor-preview-side pre {
background-color: rgba(255, 255, 255, .05);
font-family: Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
font-size: 14px;
line-height: 1.2;
margin-top: 14px;
overflow: auto;
-webkit-overflow-scrolling: touch;
padding: 14px
}
.editor-preview pre code,
.editor-preview-side pre code {
background-color: transparent;
font-size: 14px;
padding: 0
}
.editor-preview-active,
.editor-preview-active-side {
display: block
}
.editor-preview table,
.editor-preview-side table {
background-color: #444;
border: 0;
border-collapse: collapse;
border-spacing: 0;
width: 100%
}
.editor-preview table caption,
.editor-preview-side table caption {
caption-side: bottom;
color: #777;
padding: 7px;
text-align: left
}
.editor-preview table td,
.editor-preview table th,
.editor-preview-side table td,
.editor-preview-side table th {
border: 0;
border-bottom: 1px solid #555;
padding: 7px;
text-align: left
}
.editor-preview table th,
.editor-preview-side table th {
background-color: rgba(255, 255, 255, .05);
font-weight: 600
}
.editor-preview audio:not([controls]),
.editor-preview-side audio:not([controls]) {
display: none;
height: 0
}
.editor-preview img,
.editor-preview-side img {
max-width: 100%;
vertical-align: middle
}
.editor-preview audio,
.editor-preview video,
.editor-preview-side audio,
.editor-preview-side video {
width: 100%
}
.editor-toolbar {
background-color: #444;
border: 1px solid #555;
border-bottom: 0;
border-top-left-radius: 3px;
border-top-right-radius: 3px;
font-size: 18px;
padding: 0 14px;
position: relative;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none
}
.editor-toolbar::after,
.editor-toolbar::before {
content: ' ';
display: block;
height: 1px
}
.editor-toolbar::before {
margin-bottom: 7px
}
.editor-toolbar::after {
margin-top: 7px
}
.editor-toolbar a {
border: 1px solid transparent;
border-radius: 3px;
color: #777 !important;
cursor: pointer;
display: inline-block;
font-size: 80%;
height: 30px;
margin: 0;
text-align: center;
text-decoration: none !important;
width: 30px
}
.editor-toolbar a.active,
.editor-toolbar a:hover {
border-color: #555;
color: #aaa !important
}
.editor-toolbar a::before {
line-height: 30px
}
.editor-toolbar a.fa-header-x::after {
bottom: -.25em;
font-family: inherit;
font-size: 80%;
line-height: 0;
position: relative;
vertical-align: baseline
}
.editor-toolbar a.fa-header-1::after {
content: "1"
}
.editor-toolbar a.fa-header-2::after {
content: "2"
}
.editor-toolbar a.fa-header-3::after {
content: "3"
}
.editor-toolbar a.fa-header-bigger::after {
content: "▲"
}
.editor-toolbar a.fa-header-smaller::after {
content: "▼"
}
.editor-toolbar i.separator {
border-right: 1px solid #555;
color: transparent;
display: inline-block;
margin: 0 7px;
text-indent: -10px;
width: 0
}
.editor-toolbar:hover a {
color: #aaa !important
}
.editor-toolbar.fullscreen {
background-color: #444;
border: 0;
box-sizing: border-box;
height: 58px;
left: 0;
overflow-x: auto;
overflow-y: hidden;
padding-bottom: 14px;
padding-top: 14px;
position: fixed;
top: 0;
white-space: nowrap;
width: 100%;
z-index: 9
}
.editor-toolbar.fullscreen::after,
.editor-toolbar.fullscreen::before {
height: 58px;
left: 0;
margin: 0;
padding: 0;
position: fixed;
top: 0;
width: 20px
}
@media only screen and (max-width:700px) {
.editor-toolbar a.no-mobile {
display: none
}
}
.editor-toolbar.disabled-for-preview a:not(.no-disable) {
background-color: #444;
border-color: transparent;
pointer-events: none;
text-shadow: inherit
}
.editor-statusbar {
color: #777;
font-family: inherit;
font-size: 80%;
padding: 7px 14px;
text-align: right
}
.editor-statusbar span {
display: inline-block;
margin-left: 1em
}
.editor-statusbar .lines::before {
content: 'lines: '
}
.editor-statusbar .words::before {
content: 'words: '
}
.editor-statusbar .characters::before {
content: 'characters: '
}
/*# sourceMappingURL=simplemde-theme-dark.min.css.map */

View File

@ -0,0 +1,321 @@
.CodeMirror {
box-sizing: border-box;
height: auto;
border: 1px solid #ddd;
border-bottom-left-radius: 4px;
border-bottom-right-radius: 4px;
padding: 10px;
font: inherit;
z-index: 1;
word-wrap: break-word;
}
.CodeMirror-scroll {
cursor: text;
}
.CodeMirror-fullscreen {
background: #fff;
position: fixed !important;
top: 50px;
left: 0;
right: 0;
bottom: 0;
height: auto;
z-index: 9;
border-right: none !important;
border-bottom-right-radius: 0 !important;
}
.CodeMirror-sided {
width: 50% !important;
}
.CodeMirror-placeholder {
opacity: .5;
}
.CodeMirror-focused .CodeMirror-selected {
background: #d9d9d9;
}
.editor-toolbar {
position: relative;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
-o-user-select: none;
user-select: none;
padding: 0 10px;
border-top: 1px solid #bbb;
border-left: 1px solid #bbb;
border-right: 1px solid #bbb;
border-top-left-radius: 4px;
border-top-right-radius: 4px;
}
.editor-toolbar:after,
.editor-toolbar:before {
display: block;
content: ' ';
height: 1px;
}
.editor-toolbar:before {
margin-bottom: 8px
}
.editor-toolbar:after {
margin-top: 8px
}
.editor-toolbar.fullscreen {
width: 100%;
height: 50px;
overflow-x: auto;
overflow-y: hidden;
white-space: nowrap;
padding-top: 10px;
padding-bottom: 10px;
box-sizing: border-box;
background: #fff;
border: 0;
position: fixed;
top: 0;
left: 0;
opacity: 1;
z-index: 9;
}
.editor-toolbar.fullscreen::before {
width: 20px;
height: 50px;
background: -moz-linear-gradient(left, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0) 100%);
background: -webkit-gradient(linear, left top, right top, color-stop(0%, rgba(255, 255, 255, 1)), color-stop(100%, rgba(255, 255, 255, 0)));
background: -webkit-linear-gradient(left, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0) 100%);
background: -o-linear-gradient(left, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0) 100%);
background: -ms-linear-gradient(left, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0) 100%);
background: linear-gradient(to right, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0) 100%);
position: fixed;
top: 0;
left: 0;
margin: 0;
padding: 0;
}
.editor-toolbar.fullscreen::after {
width: 20px;
height: 50px;
background: -moz-linear-gradient(left, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 1) 100%);
background: -webkit-gradient(linear, left top, right top, color-stop(0%, rgba(255, 255, 255, 0)), color-stop(100%, rgba(255, 255, 255, 1)));
background: -webkit-linear-gradient(left, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 1) 100%);
background: -o-linear-gradient(left, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 1) 100%);
background: -ms-linear-gradient(left, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 1) 100%);
background: linear-gradient(to right, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 1) 100%);
position: fixed;
top: 0;
right: 0;
margin: 0;
padding: 0;
}
.editor-toolbar button {
background: transparent;
display: inline-block;
text-align: center;
text-decoration: none !important;
width: 30px;
height: 30px;
margin: 0;
padding: 0;
border: 1px solid transparent;
border-radius: 3px;
cursor: pointer;
}
.editor-toolbar button.active,
.editor-toolbar button:hover {
background: #fcfcfc;
border-color: #95a5a6;
}
.editor-toolbar i.separator {
display: inline-block;
width: 0;
border-left: 1px solid #d9d9d9;
border-right: 1px solid #fff;
color: transparent;
text-indent: -10px;
margin: 0 6px;
}
.editor-toolbar button:after {
font-family: Arial, "Helvetica Neue", Helvetica, sans-serif;
font-size: 65%;
vertical-align: text-bottom;
position: relative;
top: 2px;
}
.editor-toolbar button.heading-1:after {
content: "1";
}
.editor-toolbar button.heading-2:after {
content: "2";
}
.editor-toolbar button.heading-3:after {
content: "3";
}
.editor-toolbar button.heading-bigger:after {
content: "▲";
}
.editor-toolbar button.heading-smaller:after {
content: "▼";
}
.editor-toolbar.disabled-for-preview button:not(.no-disable) {
opacity: .6;
pointer-events: none;
}
@media only screen and (max-width: 700px) {
.editor-toolbar i.no-mobile {
display: none;
}
}
.editor-statusbar {
padding: 8px 10px;
font-size: 12px;
color: #959694;
text-align: right;
}
.editor-statusbar span {
display: inline-block;
min-width: 4em;
margin-left: 1em;
}
.editor-statusbar .lines:before {
content: 'lines: '
}
.editor-statusbar .words:before {
content: 'words: '
}
.editor-statusbar .characters:before {
content: 'characters: '
}
.editor-preview {
padding: 10px;
position: absolute;
width: 100%;
height: 100%;
top: 0;
left: 0;
background: #fafafa;
z-index: 7;
overflow: auto;
display: none;
box-sizing: border-box;
}
.editor-preview-side {
padding: 10px;
position: fixed;
bottom: 0;
width: 50%;
top: 50px;
right: 0;
background: #fafafa;
z-index: 9;
overflow: auto;
display: none;
box-sizing: border-box;
border: 1px solid #ddd;
word-wrap: break-word;
}
.editor-preview-active-side {
display: block
}
.editor-preview-active {
display: block
}
.editor-preview>p,
.editor-preview-side>p {
margin-top: 0
}
.editor-preview pre,
.editor-preview-side pre {
background: #eee;
margin-bottom: 10px;
}
.editor-preview table td,
.editor-preview table th,
.editor-preview-side table td,
.editor-preview-side table th {
border: 1px solid #ddd;
padding: 5px;
}
.cm-s-easymde .cm-tag {
color: #63a35c;
}
.cm-s-easymde .cm-attribute {
color: #795da3;
}
.cm-s-easymde .cm-string {
color: #183691;
}
.cm-s-easymde .cm-header-1 {
font-size: 200%;
line-height: 200%;
}
.cm-s-easymde .cm-header-2 {
font-size: 160%;
line-height: 160%;
}
.cm-s-easymde .cm-header-3 {
font-size: 125%;
line-height: 125%;
}
.cm-s-easymde .cm-header-4 {
font-size: 110%;
line-height: 110%;
}
.cm-s-easymde .cm-comment {
background: rgba(0, 0, 0, .05);
border-radius: 2px;
}
.cm-s-easymde .cm-link {
color: #7f8c8d;
}
.cm-s-easymde .cm-url {
color: #aab2b3;
}
.cm-s-easymde .cm-quote {
color: #7f8c8d;
font-style: italic;
}

View File

@ -53,41 +53,34 @@ window.cancelIdleCallback =
clearTimeout(id as any); clearTimeout(id as any);
}; };
console.log(window.requestIdleCallback); // console.log(window.requestIdleCallback);
window.debug = {}; window.debug = {};
import "@hibas123/theme/out/base.css";
import { h, render } from 'preact'; import { h, render } from 'preact';
import App from './components/App'; import App from './components/App';
// import "uikit";
// import "uikit/dist/css/uikit.css"
import "@hibas123/theme/out/base.css"
// import "@hibas123/theme/out/light.css"
// import "@hibas123/theme/out/dark.css"
import "./index.scss";
import Navigation from './navigation';
import VaultsPage from './components/routes/vaults/Vaults';
import { Page } from './page';
import Notes from "./notes"
import DemoPage from './components/demo'; import DemoPage from './components/demo';
import VaultPage from './components/routes/vault/Vault';
import SharePage from './components/routes/share/Share';
import Notifications from './notifications';
import Error404Page from './components/routes/404'; import Error404Page from './components/routes/404';
import SettingsPage from './components/routes/settings/Settings'; import SettingsPage from './components/routes/settings/Settings';
import SharePage from './components/routes/share/Share';
import VaultPage from './components/routes/vault/Vault';
import VaultsPage from './components/routes/vaults/Vaults';
import "./index.scss";
import Navigation from './navigation';
import Notes from "./notes";
import Notifications from './notifications';
import { Page } from './page';
window.debug.notes = Notes; window.debug.notes = Notes;
import Theme from "./theme"; // import Theme from "./theme";
console.log("Dark mode:", Theme.active);
(async () => { (async () => {
// Initialize notes provider // Initialize notes provider

View File

@ -21,7 +21,6 @@ if (window.matchMedia) {
mediaIsDark = ev.matches; mediaIsDark = ev.matches;
apply(); apply();
} }
console.log(mediaq);
} }
@ -47,6 +46,7 @@ function change(state: ThemeStates) {
export default { export default {
active: () => themeConfig, active: () => themeConfig,
change: (state: ThemeStates) => change(state) change: (state: ThemeStates) => change(state),
isDark: () => isDark
} }