2020-11-07 17:59:37 +02:00
|
|
|
import shim from '@joplin/lib/shim';
|
2021-01-22 19:41:11 +02:00
|
|
|
import Setting from '@joplin/lib/models/Setting';
|
|
|
|
import Note from '@joplin/lib/models/Note';
|
|
|
|
import BaseModel from '@joplin/lib/BaseModel';
|
|
|
|
import Resource from '@joplin/lib/models/Resource';
|
2020-10-09 19:35:46 +02:00
|
|
|
const bridge = require('electron').remote.require('./bridge').default;
|
2021-01-22 19:41:11 +02:00
|
|
|
import ResourceFetcher from '@joplin/lib/services/ResourceFetcher';
|
2020-11-07 17:59:37 +02:00
|
|
|
const { reg } = require('@joplin/lib/registry.js');
|
|
|
|
const joplinRendererUtils = require('@joplin/renderer').utils;
|
2020-05-11 20:26:04 +02:00
|
|
|
const { clipboard } = require('electron');
|
2020-11-07 17:59:37 +02:00
|
|
|
const mimeUtils = require('@joplin/lib/mime-utils.js').mime;
|
2020-05-11 20:26:04 +02:00
|
|
|
const md5 = require('md5');
|
2020-05-02 17:41:07 +02:00
|
|
|
|
|
|
|
export async function handleResourceDownloadMode(noteBody: string) {
|
|
|
|
if (noteBody && Setting.value('sync.resourceDownloadMode') === 'auto') {
|
|
|
|
const resourceIds = await Note.linkedResourceIds(noteBody);
|
|
|
|
await ResourceFetcher.instance().markForDownload(resourceIds);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
let resourceCache_: any = {};
|
|
|
|
|
|
|
|
export function clearResourceCache() {
|
|
|
|
resourceCache_ = {};
|
|
|
|
}
|
|
|
|
|
|
|
|
export async function attachedResources(noteBody: string): Promise<any> {
|
|
|
|
if (!noteBody) return {};
|
|
|
|
const resourceIds = await Note.linkedItemIdsByType(BaseModel.TYPE_RESOURCE, noteBody);
|
|
|
|
|
|
|
|
const output: any = {};
|
|
|
|
for (let i = 0; i < resourceIds.length; i++) {
|
|
|
|
const id = resourceIds[i];
|
|
|
|
|
|
|
|
if (resourceCache_[id]) {
|
|
|
|
output[id] = resourceCache_[id];
|
|
|
|
} else {
|
|
|
|
const resource = await Resource.load(id);
|
|
|
|
const localState = await Resource.localState(resource);
|
|
|
|
|
|
|
|
const o = {
|
|
|
|
item: resource,
|
|
|
|
localState: localState,
|
|
|
|
};
|
|
|
|
|
|
|
|
// eslint-disable-next-line require-atomic-updates
|
|
|
|
resourceCache_[id] = o;
|
|
|
|
output[id] = o;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return output;
|
|
|
|
}
|
|
|
|
|
2020-11-12 21:13:28 +02:00
|
|
|
export async function commandAttachFileToBody(body: string, filePaths: string[] = null, options: any = null) {
|
2020-05-02 17:41:07 +02:00
|
|
|
options = {
|
|
|
|
createFileURL: false,
|
|
|
|
position: 0,
|
|
|
|
...options,
|
|
|
|
};
|
|
|
|
|
|
|
|
if (!filePaths) {
|
|
|
|
filePaths = bridge().showOpenDialog({
|
|
|
|
properties: ['openFile', 'createDirectory', 'multiSelections'],
|
|
|
|
});
|
|
|
|
if (!filePaths || !filePaths.length) return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
for (let i = 0; i < filePaths.length; i++) {
|
|
|
|
const filePath = filePaths[i];
|
|
|
|
try {
|
|
|
|
reg.logger().info(`Attaching ${filePath}`);
|
|
|
|
const newBody = await shim.attachFileToNoteBody(body, filePath, options.position, {
|
|
|
|
createFileURL: options.createFileURL,
|
|
|
|
resizeLargeImages: 'ask',
|
|
|
|
});
|
|
|
|
|
|
|
|
if (!newBody) {
|
|
|
|
reg.logger().info('File attachment was cancelled');
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
body = newBody;
|
|
|
|
reg.logger().info('File was attached.');
|
|
|
|
} catch (error) {
|
|
|
|
reg.logger().error(error);
|
|
|
|
bridge().showErrorMessageBox(error.message);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return body;
|
|
|
|
}
|
|
|
|
|
|
|
|
export function resourcesStatus(resourceInfos: any) {
|
|
|
|
let lowestIndex = joplinRendererUtils.resourceStatusIndex('ready');
|
|
|
|
for (const id in resourceInfos) {
|
|
|
|
const s = joplinRendererUtils.resourceStatus(Resource, resourceInfos[id]);
|
|
|
|
const idx = joplinRendererUtils.resourceStatusIndex(s);
|
|
|
|
if (idx < lowestIndex) lowestIndex = idx;
|
|
|
|
}
|
|
|
|
return joplinRendererUtils.resourceStatusName(lowestIndex);
|
|
|
|
}
|
2020-05-11 20:26:04 +02:00
|
|
|
|
2020-11-12 21:13:28 +02:00
|
|
|
export async function handlePasteEvent(event: any) {
|
2020-05-11 20:26:04 +02:00
|
|
|
const output = [];
|
|
|
|
const formats = clipboard.availableFormats();
|
|
|
|
for (let i = 0; i < formats.length; i++) {
|
|
|
|
const format = formats[i].toLowerCase();
|
|
|
|
const formatType = format.split('/')[0];
|
|
|
|
|
|
|
|
if (formatType === 'image') {
|
|
|
|
if (event) event.preventDefault();
|
|
|
|
|
|
|
|
const image = clipboard.readImage();
|
|
|
|
|
|
|
|
const fileExt = mimeUtils.toFileExtension(format);
|
|
|
|
const filePath = `${Setting.value('tempDir')}/${md5(Date.now())}.${fileExt}`;
|
|
|
|
|
|
|
|
await shim.writeImageToFile(image, format, filePath);
|
|
|
|
const md = await commandAttachFileToBody('', [filePath]);
|
|
|
|
await shim.fsDriver().remove(filePath);
|
|
|
|
|
2020-06-04 10:08:13 +02:00
|
|
|
if (md) output.push(md);
|
2020-05-11 20:26:04 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return output;
|
|
|
|
}
|