mirror of
https://github.com/leanote/desktop-app.git
synced 2026-01-19 07:03:24 +08:00
笔记和标签同步BUGs
1. 修复不能添加已删除的tag 2. FullSync时可能导致一些笔记为Dirty 3. 笔记错误同步信息显示
This commit is contained in:
24
node_modules/api.js
generated
vendored
24
node_modules/api.js
generated
vendored
@@ -571,7 +571,7 @@ var Api = {
|
||||
break;
|
||||
}
|
||||
|
||||
|
||||
|
||||
// for test
|
||||
// data.FileDatas = null;
|
||||
|
||||
@@ -687,12 +687,9 @@ var Api = {
|
||||
return callback && callback(false);
|
||||
}
|
||||
var ret = resp.body;
|
||||
console.log('add tag ret ==========');
|
||||
console.log(ret);
|
||||
console.log(' add tag ret: ', ret);
|
||||
if(Common.isOk(ret)) {
|
||||
// Tag.setNotDirty(title);
|
||||
// 更新, 添加usn
|
||||
Tag.setNotDirtyAndUsn(title, ret.Usn);
|
||||
|
||||
callback && callback(ret);
|
||||
} else {
|
||||
callback && callback(false);
|
||||
@@ -708,19 +705,8 @@ var Api = {
|
||||
return callback && callback(false);
|
||||
}
|
||||
var ret = resp.body;
|
||||
log('delete tag ret ===========');
|
||||
log(ret);
|
||||
if(Common.isOk(ret)) {
|
||||
// 以后不要再发了
|
||||
Tag.setNotDirty(tag.Tag);
|
||||
callback && callback(ret);
|
||||
} else {
|
||||
// 出错了也不要发了, 万一是网络原因呢?
|
||||
if(ret.Msg == 'conflict') {
|
||||
Tag.setNotDirty(tag.Tag);
|
||||
}
|
||||
callback && callback(false);
|
||||
}
|
||||
console.log(' delete tag ret:', ret);
|
||||
callback && callback(ret);
|
||||
});
|
||||
},
|
||||
|
||||
|
||||
32
node_modules/note.js
generated
vendored
32
node_modules/note.js
generated
vendored
@@ -616,7 +616,7 @@ var Note = {
|
||||
var me = this;
|
||||
// 修复内容, 修改图片, 附件链接为本地链接
|
||||
content = me.fixNoteContent(content);
|
||||
db.notes.update({NoteId: noteId}, { $set: {Err: null, Content: content, InitSync: false, IsContentDirty: false} }, {}, function (err, numReplaced) {
|
||||
db.notes.update({NoteId: noteId}, { $set: {Err: '', Content: content, InitSync: false, IsContentDirty: false} }, {}, function (err, numReplaced) {
|
||||
if(err) {
|
||||
log(err);
|
||||
callback && callback(false);
|
||||
@@ -965,7 +965,7 @@ var Note = {
|
||||
// 不要服务器上的
|
||||
delete note['UpdatedTime'];
|
||||
delete note['CreatedTime'];
|
||||
note.Err = null;
|
||||
note.Err = '';
|
||||
|
||||
db.notes.update({NoteId: note.NoteId}, {$set: note}, {}, function (err, cnt) { // Callback is optional
|
||||
// console.log('re:');
|
||||
@@ -1056,6 +1056,7 @@ var Note = {
|
||||
delete note['Files'];
|
||||
delete note['UpdatedTime'];
|
||||
delete note['CreatedTime'];
|
||||
note.Err = '';
|
||||
|
||||
// multi: true, 避免有历史的笔记有问题
|
||||
db.notes.update({NoteId: note.NoteId}, {$set: note}, {multi: true}, function(err, n) {
|
||||
@@ -1663,10 +1664,10 @@ var Note = {
|
||||
var me = this;
|
||||
setTimeout(function() {
|
||||
// 内容
|
||||
console.log("syncContentAndImagesAndAttachs..................." + note.NoteId);
|
||||
console.log(" syncContentAndImagesAndAttachs..... " + note.NoteId);
|
||||
me.getNoteContent(note.NoteId, function(noteAndContent) {
|
||||
if(noteAndContent) {
|
||||
console.log('sync content ' + note.NoteId + ' ok');
|
||||
console.log(' sync content ' + note.NoteId + ' ok');
|
||||
var content = noteAndContent.Content;
|
||||
Web.contentSynced(note.NoteId, note.Content);
|
||||
// 图片
|
||||
@@ -1812,21 +1813,30 @@ var Note = {
|
||||
})(title);
|
||||
}
|
||||
},
|
||||
|
||||
// 这里,有一个大BUG, 导致全量同步时会修改一些笔记的IsDirty
|
||||
// title==null时传过来
|
||||
// tag.js调用
|
||||
// 删除包含title的笔记
|
||||
// 先删除tag, 再删除tag.js
|
||||
updateNoteToDeleteTag: function(title, callback) {
|
||||
if (!title) {
|
||||
return callback({});
|
||||
}
|
||||
var updates = {}; // noteId =>
|
||||
var userId = User.getCurActiveUserId();
|
||||
// console.log('updateNoteToDeleteTag--');
|
||||
console.log(' updateNoteToDeleteTag', title);
|
||||
db.notes.find({UserId: userId, LocalIsDelete: false , Tags: {$in: [title]}}, function(err, notes) {
|
||||
console.log(notes);
|
||||
console.log( 'updateNoteToDeleteTag notes', err, title, notes);
|
||||
if(!err && notes && notes.length > 0) {
|
||||
for(var i in notes) {
|
||||
for(var i = 0; i < notes.length; ++i) {
|
||||
var note = notes[i];
|
||||
var tags = note.Tags;
|
||||
// 删除之
|
||||
for(var j in tags) {
|
||||
for(var j = 0; j < tags.length; ++j) {
|
||||
if(tags[j] == title) {
|
||||
tags = tags.splice(j, 1);
|
||||
// tags = tags.splice(j, 1); // 之前是这样, 返回的是删除之后的
|
||||
tags.splice(j, 1);
|
||||
break;
|
||||
}
|
||||
}
|
||||
@@ -1834,8 +1844,8 @@ var Note = {
|
||||
note.IsDirty = true;
|
||||
updates[note.NoteId] = note;
|
||||
db.notes.update({_id: note._id}, {$set: {Tags: tags, IsDirty: true}}, function(err) {
|
||||
console.log("??");
|
||||
console.log(err);
|
||||
// console.log("??");
|
||||
// console.log(err);
|
||||
callback(updates);
|
||||
});
|
||||
}
|
||||
|
||||
36
node_modules/sync.js
generated
vendored
36
node_modules/sync.js
generated
vendored
@@ -497,20 +497,19 @@ var Sync = {
|
||||
|
||||
// 1) 服务器端删除了, 本地肯定删除
|
||||
if(tag.IsDeleted) {
|
||||
log('delete tag: ');
|
||||
log(tag);
|
||||
console.log(' delete tag: ', tag);
|
||||
Tag.deleteTag(tag.Tag, function() {
|
||||
// me._syncInfo.tag.deletes.push(tag.Tag);
|
||||
me.fixSynced('tag', 'deletes', tag.Tag);
|
||||
canCall();
|
||||
}, true);
|
||||
}, true, me.fullSyncStart);
|
||||
return;
|
||||
}
|
||||
// 2) 查看本地的, 与本地合并
|
||||
Tag.getTag(tag.Tag, function(tagLocal) {
|
||||
// 2.1 本地没有, 表示是新建
|
||||
if(!tagLocal) {
|
||||
log('add tag: ...')
|
||||
console.log(' add tag: ...')
|
||||
Tag.addOrUpdateTag(tag.Tag, function(tagAdded) {
|
||||
// me._syncInfo.tag.adds.push(tagAdded);
|
||||
me.fixSynced('tag', 'adds', tagAdded);
|
||||
@@ -586,6 +585,7 @@ var Sync = {
|
||||
var me = this;
|
||||
me._stop = false;
|
||||
me._initSyncInfo();
|
||||
me.fullSyncStart = true;
|
||||
|
||||
User.getAllLastSyncState(function(lastUsn, notebookUsn, noteUsn, tagUsn) {
|
||||
// 不可能会有lastUsn吧
|
||||
@@ -605,7 +605,7 @@ var Sync = {
|
||||
tagUsn = -1;
|
||||
}
|
||||
|
||||
// console.log('fullSync------ ' + notebookUsn + ' ' + noteUsn + ' ' + tagUsn);
|
||||
console.log('fullSync ' + notebookUsn + ' ' + noteUsn + ' ' + tagUsn);
|
||||
|
||||
// Web.syncNotebookFinish();
|
||||
// 同步笔记本
|
||||
@@ -620,6 +620,7 @@ var Sync = {
|
||||
// 同步标签
|
||||
me.syncTag(tagUsn, function(ok) {
|
||||
if (ok) {
|
||||
me.fullSyncStart = false;
|
||||
// 更新上次同步时间
|
||||
me.updateLastSyncState(function() {
|
||||
// send changes
|
||||
@@ -628,16 +629,19 @@ var Sync = {
|
||||
});
|
||||
}
|
||||
else {
|
||||
me.fullSyncStart = false;
|
||||
console.error('syncTag error....');
|
||||
callback && callback(me._syncInfo, false);
|
||||
}
|
||||
});
|
||||
} else {
|
||||
me.fullSyncStart = false;
|
||||
console.error('syncNote error.... 跳过tag');
|
||||
callback && callback(me._syncInfo, false);
|
||||
}
|
||||
});
|
||||
} else {
|
||||
me.fullSyncStart = false;
|
||||
console.error('syncNotebook error.... 跳过note,tag');
|
||||
callback && callback(me._syncInfo, false);
|
||||
}
|
||||
@@ -1015,6 +1019,11 @@ var Sync = {
|
||||
Api.deleteTrash(note, function(ret) {
|
||||
if(Common.isOk(ret)) {
|
||||
me.checkNeedIncSyncAgain(ret.Usn);
|
||||
|
||||
// 本地删除了的, 服务端没有, 直接删除本地的
|
||||
} else if (typeof ret == 'object' && ret.Msg == 'notExists') {
|
||||
console.log( '本地删除了的, 服务端没有, 直接删除本地的');
|
||||
Note.deleteLocalNote(note.NoteId);
|
||||
}
|
||||
return cb();
|
||||
});
|
||||
@@ -1121,7 +1130,10 @@ var Sync = {
|
||||
if(!Common.isOk(newTag)) {
|
||||
return cb();
|
||||
}
|
||||
me._syncInfo.note.changeAdds.push(newTag);
|
||||
// 更新, 添加usn
|
||||
Tag.setNotDirtyAndUsn(tag.Tag, newTag.Usn);
|
||||
|
||||
me._syncInfo.tag.changeAdds.push(newTag); // 之前是note.changeAdds
|
||||
// Tag.updateTagForce(newTag);
|
||||
me.checkNeedIncSyncAgain(newTag.Usn);
|
||||
cb();
|
||||
@@ -1130,10 +1142,16 @@ var Sync = {
|
||||
// 删除, 不管它了
|
||||
Api.deleteTag(tag, function(ret) {
|
||||
if(Common.isOk(ret)) {
|
||||
Tag.setNotDirty(tag.Tag);
|
||||
me.checkNeedIncSyncAgain(ret.Usn);
|
||||
} else {
|
||||
// 有问题, 可能本地不存在
|
||||
Tag.setNotDirty(tag);
|
||||
// 本地删除了的, 服务端没有, 直接删除本地的
|
||||
} else if (typeof ret == 'object') {
|
||||
if (ret.Msg == 'notExists') {
|
||||
console.log( 'tag本地删除了的, 服务端没有, 直接删除本地的');
|
||||
Tag.deleteLocalTag(tag.Tag);
|
||||
} else if(ret.Msg == 'conflict') {
|
||||
Tag.setNotDirty(tag.Tag);
|
||||
}
|
||||
}
|
||||
return cb();
|
||||
});
|
||||
|
||||
43
node_modules/tag.js
generated
vendored
43
node_modules/tag.js
generated
vendored
@@ -26,13 +26,15 @@ var Tag = {
|
||||
// 已存的, 不更新IsDirty
|
||||
var Note = require('note');
|
||||
if(!err && tag) {
|
||||
Note.countNoteByTag(title, function(cnt) {
|
||||
tag.Count = cnt;
|
||||
db.tags.update({UserId: userId, Title: title}, {$set: {Count: cnt, UpdatedTime: new Date()}}, function() {
|
||||
console.log('已存在tag' + title);
|
||||
// Note.countNoteByTag(title, function(cnt) {
|
||||
// tag.Count = cnt;
|
||||
// LocalIsDelete变为false, 可能之前删除了, 后来又重新添加了
|
||||
// {Tag: title}, 之前是 {Title: title}
|
||||
db.tags.update({UserId: userId, Tag: title}, {$set: {UpdatedTime: new Date(), LocalIsDelete: false, IsDirty: true}}, function() {
|
||||
console.log('已存在tag ' + title);
|
||||
callback(tag);
|
||||
});
|
||||
});
|
||||
// });
|
||||
} else {
|
||||
var date = new Date();
|
||||
db.tags.insert({
|
||||
@@ -55,27 +57,44 @@ var Tag = {
|
||||
}
|
||||
});
|
||||
},
|
||||
|
||||
getTags: function(callback) {
|
||||
db.tags.find({UserId: User.getCurActiveUserId(), LocalIsDelete: false}, function(err, tags) {
|
||||
if(err) {
|
||||
callback && callback(false);
|
||||
} else {
|
||||
// 排序, 用UpdatedTime来排序
|
||||
tags.sort(function (a, b) {
|
||||
return a.UpdatedTime < b.UpdatedTime;
|
||||
});
|
||||
callback && callback(tags);
|
||||
}
|
||||
});
|
||||
},
|
||||
|
||||
// 删除标签, 更新为LocaleIsDelete = true
|
||||
deleteTag: function(title, callback, isForce) {
|
||||
deleteTag: function(title, callback, isForce, isFullSync) {
|
||||
title += '';
|
||||
var me = this;
|
||||
db.tags.update({UserId: User.getCurActiveUserId(), Tag: title}, {$set: {LocalIsDelete: true, IsDirty: !isForce, UpdatedTime: new Date()}}, function() {
|
||||
});
|
||||
//
|
||||
var Note = require('./note');
|
||||
// console.log(Note);
|
||||
Note.updateNoteToDeleteTag(title, function(updates) {
|
||||
callback && callback(updates);
|
||||
});
|
||||
|
||||
// 不是fullSync才更新笔记的标签, 防止fullSync时还有一批IsDirty的
|
||||
if (!isFullSync) {
|
||||
// 删除笔记内的tag
|
||||
var Note = require('./note');
|
||||
Note.updateNoteToDeleteTag(title, function(updates) {
|
||||
callback && callback(updates);
|
||||
});
|
||||
} else {
|
||||
console.log(' isFullSync not need updateNoteToDeleteTag');
|
||||
callback && callback({});
|
||||
}
|
||||
},
|
||||
|
||||
deleteLocalTag: function (title) {
|
||||
console.log(' deleteLocalTag', title)
|
||||
db.tags.remove({Tag: title});
|
||||
},
|
||||
|
||||
// 更新标签的数量, 在彻底删除笔记时调用
|
||||
|
||||
Reference in New Issue
Block a user