1
0
mirror of https://github.com/laurent22/joplin.git synced 2025-01-23 18:53:36 +02:00

Fixed updating view when note is deleted

This commit is contained in:
Laurent Cozic 2017-10-09 20:57:00 +01:00
parent 30480a8029
commit 8c7cd8de88
7 changed files with 74 additions and 29 deletions

View File

@ -21,6 +21,7 @@ const WindowWidget = require('tkwidgets/WindowWidget.js');
const NoteWidget = require('./gui/NoteWidget.js');
const FolderListWidget = require('./gui/FolderListWidget.js');
const NoteListWidget = require('./gui/NoteListWidget.js');
class AppGui {
@ -49,7 +50,7 @@ class AppGui {
this.inputMode_ = AppGui.INPUT_MODE_NORMAL;
this.currentShortcutKeys_ = '';
this.currentShortcutKeys_ = [];
this.lastShortcutKeyTime_ = 0;
}
@ -75,15 +76,7 @@ class AppGui {
};
});
const noteList = new ListWidget();
noteList.items = [];
noteList.itemRenderer = (note) => {
let label = note.title;
if (note.is_todo) {
label = '[' + (note.todo_completed ? 'X' : ' ') + '] ' + label;
}
return label;
};
const noteList = new NoteListWidget();
noteList.name = 'noteList';
noteList.vStretch = true;
noteList.style = {
@ -329,6 +322,7 @@ class AppGui {
this.widget('noteText').text = text;
}
// Any key after which a shortcut is not possible.
isSpecialKey(name) {
return ['ENTER', 'DOWN', 'UP', 'LEFT', 'RIGHT', 'DELETE', 'BACKSPACE', 'ESCAPE', 'TAB', 'SHIFT_TAB'].indexOf(name) >= 0;
}
@ -353,26 +347,33 @@ class AppGui {
process.exit();
return;
}
const now = (new Date()).getTime();
if (now - this.lastShortcutKeyTime_ > 1000 || this.isSpecialKey(name)) {
this.currentShortcutKeys_ = name;
if (now - this.lastShortcutKeyTime_ > 800 || this.isSpecialKey(name)) {
this.currentShortcutKeys_ = [name];
} else {
this.currentShortcutKeys_ += name;
// If the previous key was a special key (eg. up, down arrow), this new key
// starts a new shortcut.
if (this.currentShortcutKeys_.length && this.isSpecialKey(this.currentShortcutKeys_[0])) {
this.currentShortcutKeys_ = [name];
} else {
this.currentShortcutKeys_.push(name);
}
}
this.lastShortcutKeyTime_ = now;
// Don't process shortcut keys if the console is active, except if the shortcut
// starts with CTRL (eg. CTRL+J CTRL+Z to maximize the console window).
if (!consoleWidget.hasFocus || this.currentShortcutKeys_.indexOf('CTRL') === 0) {
this.logger().debug('Now: ' + name + ', Keys: ' + this.currentShortcutKeys_);
if (!consoleWidget.hasFocus || (this.currentShortcutKeys_.length && this.currentShortcutKeys_[0].indexOf('CTRL') === 0)) {
this.logger().debug('Now: ' + name + ', Keys: ', this.currentShortcutKeys_);
if (this.currentShortcutKeys_ in this.shortcuts_) {
const cmd = this.shortcuts_[this.currentShortcutKeys_].action;
const shortcutKey = this.currentShortcutKeys_.join('');
if (shortcutKey in this.shortcuts_) {
const cmd = this.shortcuts_[shortcutKey].action;
if (!cmd.isDocOnly) {
this.currentShortcutKeys_ = '';
this.currentShortcutKeys_ = [];
if (typeof cmd === 'function') {
cmd();
} else {

View File

@ -408,7 +408,7 @@ class Application {
generalMiddleware() {
const middleware = store => next => async (action) => {
this.logger().info('Middleware reducer action', action.type);
this.logger().info('Reducer action', action.type);
const result = next(action);
const newState = store.getState();

View File

@ -1,4 +1,5 @@
import { _ } from 'lib/locale.js';
import { reg } from 'lib/registry.js';
class BaseCommand {
@ -75,6 +76,10 @@ class BaseCommand {
};
}
logger() {
return reg.logger();
}
}
export { BaseCommand };

View File

@ -6,20 +6,32 @@ class NoteListWidget extends ListWidget {
constructor() {
super();
this.selectedNoteId_ = 0;
this.itemRenderer = (item) => {
return item.title;
};
}
get selectedNoteId() {
return this.selectedNoteId_;
this.updateIndexFromSelectedNoteId_ = false;
this.itemRenderer = (note) => {
let label = note.title + ' ' + note.id;
if (note.is_todo) {
label = '[' + (note.todo_completed ? 'X' : ' ') + '] ' + label;
}
return label;
};
}
set selectedNoteId(v) {
if (v === this.selectedNoteId_) return;
this.updateIndexFromSelectedNoteId_ = true;
this.selectedNoteId_ = v;
const index = this.itemIndexByKey('id', this.selectedNoteId_);
this.currentIndex = index >= 0 ? index : 0;
}
render() {
if (this.updateIndexFromSelectedNoteId_) {
const index = this.itemIndexByKey('id', this.selectedNoteId_);
this.currentIndex = index >= 0 ? index : 0;
this.updateIndexFromSelectedNoteId_ = false;
}
super.render();
}
}

View File

@ -77,6 +77,12 @@ class Folder extends BaseItem {
});
}
static batchDelete(ids, options = null) {
for (let i = 0; i < ids.length; i++) {
this.delete(ids[i], options);
}
}
static conflictFolderTitle() {
return _('Conflicts');
}

View File

@ -345,6 +345,17 @@ class Note extends BaseItem {
});
}
static batchDelete(ids, options = null) {
const result = super.batchDelete(ids, options);
for (let i = 0; i < ids.length; i++) {
this.dispatch({
type: 'NOTES_DELETE',
noteId: ids[i],
});
}
return result;
}
}
Note.updateGeolocationEnabled_ = true;

View File

@ -191,15 +191,25 @@ const reducer = (state = defaultState, action) => {
case 'NOTES_DELETE':
var previousIndex = 0;
var newNotes = [];
for (let i = 0; i < state.notes.length; i++) {
let f = state.notes[i];
if (f.id == action.noteId) continue;
if (f.id == action.noteId) {
previousIndex = i;
continue;
}
newNotes.push(f);
}
newState = Object.assign({}, state);
newState.notes = newNotes;
if (previousIndex >= newNotes.length) {
previousIndex = newNotes.length - 1;
}
newState.selectedNoteId = previousIndex >= 0 ? newNotes[previousIndex].id : null;
break;
case 'FOLDERS_UPDATE_ALL':