From e8c727742c234e10cafcf47a2e41c6a1f214a000 Mon Sep 17 00:00:00 2001 From: Jonas Jenwald Date: Tue, 30 May 2023 16:48:04 +0200 Subject: [PATCH] Limit some `PDFRenderingQueue`-related code to the GENERIC viewer Given that this functionality is only relevant in third-party use-cases, for example the viewer-components, we can avoid needlessly including it in e.g. the MOZCENTRAL build. --- web/pdf_rendering_queue.js | 13 ++++++------- web/pdf_viewer.js | 5 ++++- 2 files changed, 10 insertions(+), 8 deletions(-) diff --git a/web/pdf_rendering_queue.js b/web/pdf_rendering_queue.js index 94644df57..60e885e22 100644 --- a/web/pdf_rendering_queue.js +++ b/web/pdf_rendering_queue.js @@ -36,6 +36,12 @@ class PDFRenderingQueue { this.idleTimeout = null; this.printing = false; this.isThumbnailViewEnabled = false; + + if (typeof PDFJSDev === "undefined" || PDFJSDev.test("GENERIC")) { + Object.defineProperty(this, "hasViewer", { + value: () => !!this.pdfViewer, + }); + } } /** @@ -60,13 +66,6 @@ class PDFRenderingQueue { return this.highestPriorityPage === view.renderingId; } - /** - * @returns {boolean} - */ - hasViewer() { - return !!this.pdfViewer; - } - /** * @param {Object} currentlyVisiblePages */ diff --git a/web/pdf_viewer.js b/web/pdf_viewer.js index 14b18e3be..fdf3a429f 100644 --- a/web/pdf_viewer.js +++ b/web/pdf_viewer.js @@ -301,7 +301,10 @@ class PDFViewer { } this.defaultRenderingQueue = !options.renderingQueue; - if (this.defaultRenderingQueue) { + if ( + (typeof PDFJSDev === "undefined" || PDFJSDev.test("GENERIC")) && + this.defaultRenderingQueue + ) { // Custom rendering queue is not specified, using default one this.renderingQueue = new PDFRenderingQueue(); this.renderingQueue.setViewer(this);