From 61657087f5c86852217a8577043b47042f71a0d6 Mon Sep 17 00:00:00 2001 From: Tom <7283497+thfrei@users.noreply.github.com> Date: Tue, 10 May 2022 13:26:29 +0200 Subject: [PATCH] move debounce to library, remove unnecessary binds, replaceassets only for canvas --- .../lodash.debounce.js | 0 .../app/widgets/type_widgets/canvas_note.js | 27 ++++++++++++------- 2 files changed, 18 insertions(+), 9 deletions(-) rename {src/public/app/widgets/type_widgets/canvas-note-utils => libraries}/lodash.debounce.js (100%) diff --git a/src/public/app/widgets/type_widgets/canvas-note-utils/lodash.debounce.js b/libraries/lodash.debounce.js similarity index 100% rename from src/public/app/widgets/type_widgets/canvas-note-utils/lodash.debounce.js rename to libraries/lodash.debounce.js diff --git a/src/public/app/widgets/type_widgets/canvas_note.js b/src/public/app/widgets/type_widgets/canvas_note.js index 405ad5e6f..1d6de953e 100644 --- a/src/public/app/widgets/type_widgets/canvas_note.js +++ b/src/public/app/widgets/type_widgets/canvas_note.js @@ -2,8 +2,7 @@ import libraryLoader from "../../services/library_loader.js"; import TypeWidget from "./type_widget.js"; import utils from '../../services/utils.js'; import froca from "../../services/froca.js"; -import debounce from "./canvas-note-utils/lodash.debounce.js"; -import replaceExternalAssets from "./canvas-note-utils/replaceExternalAssets.js"; +import debounce from "../../../../../libraries/lodash.debounce.js"; const {sleep} = utils; @@ -80,14 +79,8 @@ export default class ExcalidrawTypeWidget extends TypeWidget { this.reactHandlers; // used to control react state this.ExcalidrawReactApp = this.ExcalidrawReactApp.bind(this); - this.doRefresh = this.doRefresh.bind(this); - this.getContent = this.getContent.bind(this); - this.saveData = this.saveData.bind(this); - this.refreshWithNote = this.refreshWithNote.bind(this); this.onChangeHandler = this.onChangeHandler.bind(this); this.isNewSceneVersion = this.isNewSceneVersion.bind(this); - this.updateSceneVersion = this.updateSceneVersion.bind(this); - this.getSceneVersion = this.getSceneVersion.bind(this); } /** @@ -253,7 +246,7 @@ export default class ExcalidrawTypeWidget extends TypeWidget { /** * workaround until https://github.com/excalidraw/excalidraw/pull/5065 is merged and published */ - const svgSafeString = replaceExternalAssets(svgString); + const svgSafeString = this.replaceExternalAssets(svgString); const activeFiles = {}; elements.forEach((element) => { @@ -454,4 +447,20 @@ export default class ExcalidrawTypeWidget extends TypeWidget { console.log(title, "=", this.noteId, "==", ...args); } + + /** + * replaces exlicraw.com with own assets + * + * workaround until https://github.com/excalidraw/excalidraw/pull/5065 is merged and published + * needed for v0.11.0 + * + * @param {string} string + * @returns + */ + replaceExternalAssets = (string) => { + let result = string; + // exlidraw.com asset in react usage + result = result.replaceAll("https://excalidraw.com/", window.EXCALIDRAW_ASSET_PATH+"excalidraw-assets/"); + return result; + } }