mirror of
https://github.com/laurent22/joplin.git
synced 2025-01-26 18:58:21 +02:00
More logging on import enex
This commit is contained in:
parent
09c1d58358
commit
6aa7ea0c6c
@ -89,23 +89,28 @@ async function saveNoteToStorage(note, fuzzyMatching = false) {
|
||||
|
||||
let existingNote = fuzzyMatching ? await fuzzyMatch(note) : null;
|
||||
|
||||
let result = {
|
||||
noteCreated: false,
|
||||
noteUpdated: false,
|
||||
resourcesCreated: 0,
|
||||
};
|
||||
|
||||
if (existingNote) {
|
||||
let diff = BaseModel.diffObjects(existingNote, note);
|
||||
delete diff.tags;
|
||||
delete diff.resources;
|
||||
delete diff.id;
|
||||
|
||||
// console.info('======================================');
|
||||
// console.info(note);
|
||||
// console.info(existingNote);
|
||||
// console.info(diff);
|
||||
// console.info('======================================');
|
||||
// TODO: also save resources
|
||||
|
||||
if (!Object.getOwnPropertyNames(diff).length) return;
|
||||
|
||||
diff.id = existingNote.id;
|
||||
diff.type_ = existingNote.type_;
|
||||
return Note.save(diff, { autoTimestamp: false });
|
||||
return Note.save(diff, { autoTimestamp: false }).then(() => {
|
||||
result.noteUpdated = true;
|
||||
return result;
|
||||
});
|
||||
} else {
|
||||
for (let i = 0; i < note.resources.length; i++) {
|
||||
let resource = note.resources[i];
|
||||
@ -119,12 +124,16 @@ async function saveNoteToStorage(note, fuzzyMatching = false) {
|
||||
if (existingResource) continue;
|
||||
|
||||
await Resource.save(toSave, { isNew: true });
|
||||
await filePutContents(Resource.fullPath(toSave), resource.data);
|
||||
await filePutContents(Resource.fullPath(toSave), resource.data)
|
||||
result.resourcesCreated++;
|
||||
}
|
||||
|
||||
return Note.save(note, {
|
||||
isNew: true,
|
||||
autoTimestamp: false,
|
||||
}).then(() => {
|
||||
result.noteCreated = true;
|
||||
return result;
|
||||
});
|
||||
}
|
||||
}
|
||||
@ -138,7 +147,9 @@ function importEnex(parentFolderId, filePath, importOptions = null) {
|
||||
return new Promise((resolve, reject) => {
|
||||
let progressState = {
|
||||
loaded: 0,
|
||||
imported: 0,
|
||||
created: 0,
|
||||
updated: 0,
|
||||
resourcesCreated: 0,
|
||||
};
|
||||
|
||||
let stream = fs.createReadStream(filePath);
|
||||
@ -188,8 +199,13 @@ function importEnex(parentFolderId, filePath, importOptions = null) {
|
||||
note.body = body;
|
||||
|
||||
return saveNoteToStorage(note, importOptions.fuzzyMatching);
|
||||
}).then(() => {
|
||||
progressState.imported++;
|
||||
}).then((result) => {
|
||||
if (result.noteUpdated) {
|
||||
progressState.updated++;
|
||||
} else if (result.noteCreated) {
|
||||
progressState.created++;
|
||||
}
|
||||
progressState.resourcesCreated += result.resourcesCreated;
|
||||
importOptions.onProgress(progressState);
|
||||
});
|
||||
});
|
||||
|
@ -348,9 +348,13 @@ commands.push({
|
||||
let options = {
|
||||
fuzzyMatching: args.options['fuzzy-matching'] === true,
|
||||
onProgress: (progressState) => {
|
||||
let line = sprintf(_('Found: %d. Imported: %d.', progressState.loaded, progressState.imported));
|
||||
let line = [];
|
||||
line.push(_('Found: %d.', progressState.loaded));
|
||||
line.push(_('Created: %d.', progressState.created));
|
||||
if (progressState.updated) line.push(_('Updated: %d.', progressState.updated));
|
||||
if (progressState.resourcesCreated) line.push(_('Resources: %d.', progressState.resourcesCreated));
|
||||
redrawnCalled = true;
|
||||
vorpal.ui.redraw(line);
|
||||
vorpal.ui.redraw(line.join(' '));
|
||||
},
|
||||
onError: (error) => {
|
||||
let s = error.trace ? error.trace : error.toString();
|
||||
|
Loading…
x
Reference in New Issue
Block a user