mirror of
https://github.com/laurent22/joplin.git
synced 2025-01-11 18:24:43 +02:00
Electron: Supports non-image files in notes
This commit is contained in:
parent
6e9e3fc9bd
commit
e48d2ed64b
@ -62,6 +62,10 @@ class Bridge {
|
||||
return require('electron').shell.openExternal(url)
|
||||
}
|
||||
|
||||
openItem(fullPath) {
|
||||
return require('electron').shell.openItem(fullPath)
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
let bridge_ = null;
|
||||
|
@ -58,7 +58,7 @@ class NoteTextComponent extends React.Component {
|
||||
|
||||
mdToHtml() {
|
||||
if (this.mdToHtml_) return this.mdToHtml_;
|
||||
this.mdToHtml_ = new MdToHtml();
|
||||
this.mdToHtml_ = new MdToHtml({ supportsResourceLinks: true });
|
||||
return this.mdToHtml_;
|
||||
}
|
||||
|
||||
@ -175,6 +175,12 @@ class NoteTextComponent extends React.Component {
|
||||
} else if (msg === 'percentScroll') {
|
||||
this.ignoreNextEditorScroll_ = true;
|
||||
this.setEditorPercentScroll(arg0);
|
||||
} else if (msg.indexOf('joplin://') === 0) {
|
||||
const resourceId = msg.substr('joplin://'.length);
|
||||
Resource.load(resourceId).then((resource) => {
|
||||
const filePath = Resource.fullPath(resource);
|
||||
bridge().openItem(filePath);
|
||||
});
|
||||
} else {
|
||||
bridge().showMessageBox({
|
||||
type: 'error',
|
||||
|
@ -7,7 +7,10 @@ const md5 = require('md5');
|
||||
|
||||
class MdToHtml {
|
||||
|
||||
constructor() {
|
||||
constructor(options = null) {
|
||||
if (!options) options = {};
|
||||
|
||||
this.supportsResourceLinks_ = !!options.supportsResourceLinks;
|
||||
this.loadedResources_ = {};
|
||||
this.cachedContent_ = null;
|
||||
this.cachedContentKey_ = null;
|
||||
@ -118,15 +121,21 @@ class MdToHtml {
|
||||
}
|
||||
|
||||
renderOpenLink_(attrs, options) {
|
||||
const href = this.getAttr_(attrs, 'href');
|
||||
let href = this.getAttr_(attrs, 'href');
|
||||
const title = this.getAttr_(attrs, 'title');
|
||||
const text = this.getAttr_(attrs, 'text');
|
||||
const isResourceUrl = Resource.isResourceUrl(href);
|
||||
|
||||
if (Resource.isResourceUrl(href)) {
|
||||
if (isResourceUrl && !this.supportsResourceLinks_) {
|
||||
// In mobile, links to local resources, such as PDF, etc. currently aren't supported.
|
||||
// Ideally they should be opened in the user's browser.
|
||||
return '[Resource not yet supported: ' + htmlentities(text) + ']';
|
||||
return '[Resource not yet supported: '; //+ htmlentities(text) + ']';
|
||||
} else {
|
||||
if (isResourceUrl) {
|
||||
const resourceId = Resource.pathToId(href);
|
||||
href = 'joplin://' + resourceId;
|
||||
}
|
||||
|
||||
const js = options.postMessageSyntax + "(" + JSON.stringify(href) + "); return false;";
|
||||
let output = "<a title='" + htmlentities(title) + "' href='#' onclick='" + js + "'>";
|
||||
return output;
|
||||
@ -135,9 +144,10 @@ class MdToHtml {
|
||||
|
||||
renderCloseLink_(attrs, options) {
|
||||
const href = this.getAttr_(attrs, 'href');
|
||||
const isResourceUrl = Resource.isResourceUrl(href);
|
||||
|
||||
if (Resource.isResourceUrl(href)) {
|
||||
return '';
|
||||
if (isResourceUrl && !this.supportsResourceLinks_) {
|
||||
return ']';
|
||||
} else {
|
||||
return '</a>';
|
||||
}
|
||||
|
@ -18,7 +18,7 @@ class NoteBodyViewer extends Component {
|
||||
}
|
||||
|
||||
componentWillMount() {
|
||||
this.mdToHtml_ = new MdToHtml();
|
||||
this.mdToHtml_ = new MdToHtml({ supportsResourceLinks: false });
|
||||
this.isMounted_ = true;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user