1
0
mirror of https://github.com/laurent22/joplin.git synced 2025-03-29 21:21:15 +02:00

Don't needlessly reload resources

This commit is contained in:
Laurent Cozic 2017-11-28 21:15:22 +00:00
parent 444c96d5e7
commit 2e8fe88f53
3 changed files with 45 additions and 3 deletions

View File

@ -110,8 +110,6 @@ class NoteTextComponent extends React.Component {
} }
async reloadNote(props) { async reloadNote(props) {
this.mdToHtml_ = null;
const noteId = props.noteId; const noteId = props.noteId;
this.lastLoadedNoteId_ = noteId; this.lastLoadedNoteId_ = noteId;
const note = noteId ? await Note.load(noteId) : null; const note = noteId ? await Note.load(noteId) : null;
@ -124,6 +122,8 @@ class NoteTextComponent extends React.Component {
if (!Object.getOwnPropertyNames(diff).length) return; if (!Object.getOwnPropertyNames(diff).length) return;
} }
this.mdToHtml_ = null;
// If we are loading nothing (noteId == null), make sure to // If we are loading nothing (noteId == null), make sure to
// set webviewReady to false too because the webview component // set webviewReady to false too because the webview component
// is going to be removed in render(). // is going to be removed in render().

View File

@ -2,6 +2,7 @@ const MarkdownIt = require('markdown-it');
const Entities = require('html-entities').AllHtmlEntities; const Entities = require('html-entities').AllHtmlEntities;
const htmlentities = (new Entities()).encode; const htmlentities = (new Entities()).encode;
const { Resource } = require('lib/models/resource.js'); const { Resource } = require('lib/models/resource.js');
const ModelCache = require('lib/ModelCache');
const { shim } = require('lib/shim.js'); const { shim } = require('lib/shim.js');
const md5 = require('md5'); const md5 = require('md5');
@ -14,6 +15,7 @@ class MdToHtml {
this.loadedResources_ = {}; this.loadedResources_ = {};
this.cachedContent_ = null; this.cachedContent_ = null;
this.cachedContentKey_ = null; this.cachedContentKey_ = null;
this.modelCache_ = new ModelCache();
// Must include last "/" // Must include last "/"
this.resourceBaseUrl_ = ('resourceBaseUrl' in options) ? options.resourceBaseUrl : null; this.resourceBaseUrl_ = ('resourceBaseUrl' in options) ? options.resourceBaseUrl : null;
@ -80,10 +82,11 @@ class MdToHtml {
this.loadedResources_[id] = {}; this.loadedResources_[id] = {};
const resource = await Resource.load(id); const resource = await Resource.load(id);
//const resource = await this.modelCache_.load(Resource, id);
if (!resource) { if (!resource) {
// Can happen for example if an image is attached to a note, but the resource hasn't // Can happen for example if an image is attached to a note, but the resource hasn't
// been download from the sync target yet. // been downloaded from the sync target yet.
console.warn('Cannot load resource: ' + id); console.warn('Cannot load resource: ' + id);
return; return;
} }

View File

@ -0,0 +1,39 @@
class ModelCache {
constructor(maxSize) {
this.cache_ = [];
this.maxSize_ = maxSize;
}
fromCache(ModelClass, id) {
for (let i = 0; i < this.cache_.length; i++) {
const c = this.cache_[i];
if (c.id === id && c.modelType === ModelClass.modelType()) return c
}
return null;
}
cache(ModelClass, id, model) {
if (this.fromCache(ModelClass, model.id)) return;
this.cache_.push({
id: id,
model: model,
modelType: ModelClass.modelType(),
});
if (this.cache_.length > this.maxSize_) {
this.cache_.splice(0, 1);
}
}
async load(ModelClass, id) {
const cached = this.fromCache(ModelClass, id);
if (cached) return cached.model;
const output = await ModelClass.load(id);
this.cache(ModelClass, id, output);
return output;
}
}
module.exports = ModelCache;