Auto save note

pull/41/head
Laurent Cozic 2017-11-07 21:46:23 +00:00
parent 8bf85b6b88
commit 5a7fde7d21
1 changed files with 24 additions and 17 deletions

View File

@ -28,6 +28,7 @@ class NoteTextComponent extends React.Component {
this.webviewListeners_ = null;
this.ignoreNextEditorScroll_ = false;
this.scheduleSaveTimeout_ = null;
}
mdToHtml() {
@ -37,18 +38,32 @@ class NoteTextComponent extends React.Component {
}
async componentWillMount() {
await shared.initState(this);
}
componentWillUnmount() {
this.saveIfNeeded();
this.mdToHtml_ = null;
this.destroyWebview();
}
async saveIfNeeded() {
if (this.scheduleSaveTimeout_) clearTimeout(this.scheduleSaveTimeout_);
this.scheduleSaveTimeout_ = null;
if (!shared.isModified(this)) return;
await shared.saveNoteButton_press(this);
}
scheduleSave() {
if (this.scheduleSaveTimeout_) clearTimeout(this.scheduleSaveTimeout_);
this.scheduleSaveTimeout_ = setTimeout(() => {
this.saveIfNeeded();
}, 500);
}
async componentWillReceiveProps(nextProps) {
if ('noteId' in nextProps) {
if ('noteId' in nextProps && nextProps.noteId !== this.props.noteId) {
this.mdToHtml_ = null;
const noteId = nextProps.noteId;
@ -73,23 +88,17 @@ class NoteTextComponent extends React.Component {
title_changeText(text) {
shared.noteComponent_change(this, 'title', text);
this.scheduleSave();
}
body_changeText(text) {
shared.noteComponent_change(this, 'body', text);
//this.updateScrollHeight();
}
async saveNoteButton_press() {
await shared.saveNoteButton_press(this);
}
async saveOneProperty(name, value) {
await shared.saveOneProperty(this, name, value);
editor_change(event) {
shared.noteComponent_change(this, 'body', event.target.value);
this.scheduleSave();
}
toggleIsTodo_onPress() {
shared.toggleIsTodo_onPress(this);
this.scheduleSave();
}
showMetadata_onPress() {
@ -210,8 +219,6 @@ class NoteTextComponent extends React.Component {
const note = this.state.note;
const body = note ? note.body : '';
console.info(this.state.scrollHeight);
const viewerStyle = {
width: Math.floor(style.width / 2),
height: style.height,
@ -240,7 +247,7 @@ class NoteTextComponent extends React.Component {
}
const viewer = <webview style={viewerStyle} nodeintegration="1" src="note-content.html" ref={(elem) => { this.webview_ref(elem); } } />
const editor = <textarea style={editorStyle} value={body} onScroll={() => { this.editor_scroll(); }} onChange={(text) => { this.body_changeText(text) }} ref={(elem) => { this.editor_ref(elem); } }></textarea>
const editor = <textarea style={editorStyle} value={body} onScroll={() => { this.editor_scroll(); }} onChange={(event) => { this.editor_change(event) }} ref={(elem) => { this.editor_ref(elem); } }></textarea>
return (
<div style={style}>