From d595b3f1957b38e1ae1a7ae574425cdcd2bdf547 Mon Sep 17 00:00:00 2001 From: Martynas Bagdonas Date: Mon, 25 Jul 2022 18:04:00 +0300 Subject: [PATCH] Freeze note schema version to 8 We can do it because it was only used to create a note from annotations. No need to update schema version in Zotero client, unless using new features when creating a note from annotations. --- chrome/content/zotero/xpcom/editorInstance.js | 8 +++----- test/tests/itemPaneTest.js | 6 +++++- 2 files changed, 8 insertions(+), 6 deletions(-) diff --git a/chrome/content/zotero/xpcom/editorInstance.js b/chrome/content/zotero/xpcom/editorInstance.js index eec35f901e..5e4bf51774 100644 --- a/chrome/content/zotero/xpcom/editorInstance.js +++ b/chrome/content/zotero/xpcom/editorInstance.js @@ -43,9 +43,6 @@ const DOWNLOADED_IMAGE_TYPE = [ 'image/png' ]; -// Schema version here has to be the same as in note-editor! -const SCHEMA_VERSION = 8; - class EditorInstance { constructor() { this.instanceID = Zotero.Utilities.randomString(); @@ -1258,7 +1255,9 @@ class EditorInstance { let { html: serializedHTML, citationItems } = Zotero.EditorInstanceUtilities.serializeAnnotations(jsonAnnotations, true); html += serializedHTML; citationItems = encodeURIComponent(JSON.stringify(citationItems)); - html = `
${html}
`; + // Note: Update schema version only if using new features + let schemaVersion = 8; + html = `
${html}
`; note.setNote(html); await note.saveTx(); return note; @@ -1552,5 +1551,4 @@ class EditorInstanceUtilities { } Zotero.EditorInstance = EditorInstance; -Zotero.EditorInstance.SCHEMA_VERSION = SCHEMA_VERSION; Zotero.EditorInstanceUtilities = new EditorInstanceUtilities(); diff --git a/test/tests/itemPaneTest.js b/test/tests/itemPaneTest.js index 804445e983..5841ff17ae 100644 --- a/test/tests/itemPaneTest.js +++ b/test/tests/itemPaneTest.js @@ -307,7 +307,11 @@ describe("Item pane", function () { // Wait for asynchronous editor update do { yield Zotero.Promise.delay(10); - } while(noteEditor._editorInstance._iframeWindow.wrappedJSObject.getDataSync().html.replace(/\n/g,'') != `

Test

`); + } while ( + !/

Test<\/p><\/div>/.test( + noteEditor._editorInstance._iframeWindow.wrappedJSObject.getDataSync().html.replace(/\n/g, '') + ) + ); }); });