mirror of
https://github.com/leanote/desktop-app.git
synced 2025-12-23 01:00:08 +08:00
move & copy note [ok]
This commit is contained in:
89
node_modules/note.js
generated
vendored
89
node_modules/note.js
generated
vendored
@@ -186,6 +186,27 @@ var Note = {
|
||||
});
|
||||
},
|
||||
|
||||
// 移动note
|
||||
// 重新统计另一个notebookId的笔记数
|
||||
moveNote: function(noteId, notebookId, callback) {
|
||||
var me = this;
|
||||
me.getNote(noteId, function(note) {
|
||||
if(note) {
|
||||
var to = !note.Star;
|
||||
var preNotebookId = note.NotebookId;
|
||||
note.NotebookId = notebookId;
|
||||
Notes.update({_id: note._id}, {$set: {NotebookId: notebookId, IsTrash: false, LocalIsDelete: false, UpdatedTime: new Date()}}, function(err, n) {
|
||||
// 重新统计
|
||||
Notebook.reCountNotebookNumberNotes(preNotebookId);
|
||||
Notebook.reCountNotebookNumberNotes(notebookId);
|
||||
callback(note);
|
||||
});
|
||||
} else {
|
||||
callback(false);
|
||||
}
|
||||
});
|
||||
},
|
||||
|
||||
// 加星或取消
|
||||
star: function(noteId, callback) {
|
||||
var me = this;
|
||||
@@ -637,6 +658,7 @@ var Note = {
|
||||
note.IsDirty = true;
|
||||
note.LocalIsNew = true; // 新增加的
|
||||
note.InitSync = false; // 都是本地的, 相当于新建的笔记
|
||||
note.LocalIsDelete = false;
|
||||
|
||||
// 只复制有path的
|
||||
var attachs = note.Attachs || [];
|
||||
@@ -677,8 +699,75 @@ var Note = {
|
||||
Notes.insert(note, function(err, newNote) {
|
||||
if(err) {
|
||||
callback(false);
|
||||
|
||||
} else {
|
||||
callback(newNote);
|
||||
// 重新统计笔记本的笔记数量
|
||||
Notebook.reCountNotebookNumberNotes(newNote.NotebookId);
|
||||
}
|
||||
});
|
||||
});
|
||||
});
|
||||
},
|
||||
|
||||
// 复制笔记到某笔记本下, 本地使用
|
||||
copyNote: function(noteId, notebookId, callback) {
|
||||
var me = this;
|
||||
me.getNote(noteId, function(note) {
|
||||
if(!note) {
|
||||
callback(false);
|
||||
return;
|
||||
}
|
||||
// 新Id
|
||||
delete note['_id'];
|
||||
delete note['ServerNoteId'];
|
||||
note.NoteId = Common.objectId();
|
||||
note.IsDirty = true;
|
||||
note.LocalIsNew = true; // 新增加的
|
||||
note.InitSync = false; // 都是本地的, 相当于新建的笔记
|
||||
note.LocalIsDelete = false;
|
||||
note.IsTrash = false;
|
||||
note.NotebookId = notebookId;
|
||||
|
||||
// 只复制有path的
|
||||
var attachs = note.Attachs || [];
|
||||
var newAttachs = [];
|
||||
async.eachSeries(attachs, function(attach, cb) {
|
||||
if(!attach.Path) {
|
||||
return cb();
|
||||
}
|
||||
// 新路径
|
||||
var filePathAttr = Common.splitFile(attach.Path);
|
||||
filePathAttr.nameNotExt += '_cp_' + attach.FileId; // 另一个
|
||||
var newPath = filePathAttr.getFullPath();
|
||||
// 复制之
|
||||
// try {
|
||||
Common.copyFile(attach.Path, newPath, function(ret) {
|
||||
if(ret) {
|
||||
attach.FileId = Common.objectId();
|
||||
attach.IsDirty = true;
|
||||
attach.Path = newPath;
|
||||
delete attach['ServerFileId'];
|
||||
newAttachs.push(attach);
|
||||
}
|
||||
cb();
|
||||
});
|
||||
/*
|
||||
} catch(e) {
|
||||
cb();
|
||||
}
|
||||
*/
|
||||
}, function() {
|
||||
note.Attachs = newAttachs;
|
||||
console.log('conflict 复制后的');
|
||||
console.log(note.Attachs);
|
||||
Notes.insert(note, function(err, newNote) {
|
||||
if(err) {
|
||||
callback(false);
|
||||
} else {
|
||||
callback(newNote);
|
||||
// 重新统计下
|
||||
Notebook.reCountNotebookNumberNotes(newNote.NotebookId);
|
||||
}
|
||||
});
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user