1
0
mirror of https://github.com/BoostIo/Boostnote synced 2025-12-13 01:36:22 +00:00

importAttachments

This commit is contained in:
anasasilva
2018-12-12 12:11:58 +00:00
committed by Junyoung Choi
parent 1be208d96b
commit 85cb94d99d
2 changed files with 77 additions and 30 deletions

View File

@@ -919,6 +919,11 @@ class NoteList extends React.Component {
} }
dataApi.createNote(storage.key, newNote) dataApi.createNote(storage.key, newNote)
.then((note) => { .then((note) => {
attachmentManagement.importAttachments(note.content, filepath, storage.key, note.key)
.then((newcontent) => {
note.content = newcontent;
dispatch({ dispatch({
type: 'UPDATE_NOTE', type: 'UPDATE_NOTE',
note: note note: note
@@ -927,6 +932,8 @@ class NoteList extends React.Component {
pathname: location.pathname, pathname: location.pathname,
query: {key: getNoteKey(note)} query: {key: getNoteKey(note)}
}) })
})
}) })
}) })
}) })

View File

@@ -449,6 +449,45 @@ function getAbsolutePathsOfAttachmentsInContent (markdownContent, storagePath) {
return result return result
} }
/**
* @description Copies the attachments to the storage folder and returns the mardown content it should be replaced with
* @param {String} markDownContent content in which the attachment paths should be found
* @param {String} filepath The path of the file with attachments to import
* @param {String} storageKey Storage key of the destination storage
* @param {String} noteKey Key of the current note. Will be used as subfolder in :storage
*/
function importAttachments (markDownContent, filepath, storageKey, noteKey) {
return new Promise((resolve, reject) => {
let attach_names = markDownContent.match(/!\[.+?]\((?:.+?\..+?\))/g);
if (!attach_names)
resolve(markDownContent);
else {
let promise_array = [];
let end_path = []
for (let i = 0; i < attach_names.length; i++){
end_path[i] = attach_names[i].match(/(?<=]\()(?:.+?\..+?)(?=\))/)[0];
let begin_path = filepath.match(/\/.+\//)[0];
let final_path = path.join(begin_path, end_path[i]);
promise_array.push(this.copyAttachment(final_path, storageKey, noteKey));
}
Promise.all(promise_array).then((file_names) => {
for (let j = 0; j < file_names.length; j++) {
let new_path = path.join(STORAGE_FOLDER_PLACEHOLDER, noteKey, file_names[j]);
markDownContent = markDownContent.replace(end_path[j], new_path);
}
resolve(markDownContent);
})
}
})
}
/** /**
* @description Moves the attachments of the current note to the new location. * @description Moves the attachments of the current note to the new location.
* Returns a modified version of the given content so that the links to the attachments point to the new note key. * Returns a modified version of the given content so that the links to the attachments point to the new note key.
@@ -656,6 +695,7 @@ module.exports = {
handlePasteNativeImage, handlePasteNativeImage,
getAttachmentsInMarkdownContent, getAttachmentsInMarkdownContent,
getAbsolutePathsOfAttachmentsInContent, getAbsolutePathsOfAttachmentsInContent,
importAttachments,
removeStorageAndNoteReferences, removeStorageAndNoteReferences,
deleteAttachmentFolder, deleteAttachmentFolder,
deleteAttachmentsNotPresentInNote, deleteAttachmentsNotPresentInNote,