From 1753f91c6b3f614fa8c7f7dc7f2c88bc275cbe44 Mon Sep 17 00:00:00 2001 From: Jonas Jenwald Date: Sun, 24 Feb 2019 13:12:23 +0100 Subject: [PATCH] Re-factor the `PDFSidebar` constructor to simplify its call-site (PR 10123 follow-up) --- web/app.js | 19 ++++++++++--------- web/pdf_sidebar.js | 45 +++++++++++++++++++++++++-------------------- 2 files changed, 35 insertions(+), 29 deletions(-) diff --git a/web/app.js b/web/app.js index 21cc50d10..65e31def5 100644 --- a/web/app.js +++ b/web/app.js @@ -287,8 +287,8 @@ let PDFViewerApplication = { this.overlayManager = new OverlayManager(); - const dispatchToDOM = AppOptions.get('eventBusDispatchToDOM'); - const eventBus = appConfig.eventBus || getGlobalEventBus(dispatchToDOM); + const eventBus = appConfig.eventBus || + getGlobalEventBus(AppOptions.get('eventBusDispatchToDOM')); this.eventBus = eventBus; let pdfRenderingQueue = new PDFRenderingQueue(); @@ -336,9 +336,8 @@ let PDFViewerApplication = { pdfRenderingQueue.setViewer(this.pdfViewer); pdfLinkService.setViewer(this.pdfViewer); - let thumbnailContainer = appConfig.sidebar.thumbnailView; this.pdfThumbnailViewer = new PDFThumbnailViewer({ - container: thumbnailContainer, + container: appConfig.sidebar.thumbnailView, renderingQueue: pdfRenderingQueue, linkService: pdfLinkService, l10n: this.l10n, @@ -393,11 +392,13 @@ let PDFViewerApplication = { downloadManager, }); - // TODO: improve `PDFSidebar` constructor parameter passing - let sidebarConfig = Object.create(appConfig.sidebar); - sidebarConfig.pdfViewer = this.pdfViewer; - sidebarConfig.pdfThumbnailViewer = this.pdfThumbnailViewer; - this.pdfSidebar = new PDFSidebar(sidebarConfig, eventBus, this.l10n); + this.pdfSidebar = new PDFSidebar({ + elements: appConfig.sidebar, + pdfViewer: this.pdfViewer, + pdfThumbnailViewer: this.pdfThumbnailViewer, + eventBus, + l10n: this.l10n, + }); this.pdfSidebar.onToggled = this.forceRendering.bind(this); this.pdfSidebarResizer = new PDFSidebarResizer(appConfig.sidebarResizer, diff --git a/web/pdf_sidebar.js b/web/pdf_sidebar.js index 246901b92..4e2ef24f6 100644 --- a/web/pdf_sidebar.js +++ b/web/pdf_sidebar.js @@ -29,8 +29,17 @@ const SidebarView = { /** * @typedef {Object} PDFSidebarOptions + * @property {PDFSidebarElements} elements - The DOM elements. * @property {PDFViewer} pdfViewer - The document viewer. * @property {PDFThumbnailViewer} pdfThumbnailViewer - The thumbnail viewer. + * @property {EventBus} eventBus - The application event bus. + * @property {IL10n} l10n - The localization service. + * @property {boolean} disableNotification - (optional) Disable the notification + * for documents containing outline/attachments. The default value is `false`. + */ + +/** + * @typedef {Object} PDFSidebarElements * @property {HTMLDivElement} outerContainer - The outer container * (encasing both the viewer and sidebar elements). * @property {HTMLDivElement} viewerContainer - The viewer container @@ -49,17 +58,14 @@ const SidebarView = { * the outline is placed. * @property {HTMLDivElement} attachmentsView - The container in which * the attachments are placed. - * @property {boolean} disableNotification - (optional) Disable the notification - * for documents containing outline/attachments. The default value is `false`. */ class PDFSidebar { /** * @param {PDFSidebarOptions} options - * @param {EventBus} eventBus - The application event bus. - * @param {IL10n} l10n - Localization service. */ - constructor(options, eventBus, l10n = NullL10n) { + constructor({ elements, pdfViewer, pdfThumbnailViewer, eventBus, + l10n = NullL10n, disableNotification = false, }) { this.isOpen = false; this.active = SidebarView.THUMBS; this.isInitialViewSet = false; @@ -70,25 +76,24 @@ class PDFSidebar { */ this.onToggled = null; - this.pdfViewer = options.pdfViewer; - this.pdfThumbnailViewer = options.pdfThumbnailViewer; + this.pdfViewer = pdfViewer; + this.pdfThumbnailViewer = pdfThumbnailViewer; - this.outerContainer = options.outerContainer; - this.viewerContainer = options.viewerContainer; - this.toggleButton = options.toggleButton; + this.outerContainer = elements.outerContainer; + this.viewerContainer = elements.viewerContainer; + this.toggleButton = elements.toggleButton; - this.thumbnailButton = options.thumbnailButton; - this.outlineButton = options.outlineButton; - this.attachmentsButton = options.attachmentsButton; + this.thumbnailButton = elements.thumbnailButton; + this.outlineButton = elements.outlineButton; + this.attachmentsButton = elements.attachmentsButton; - this.thumbnailView = options.thumbnailView; - this.outlineView = options.outlineView; - this.attachmentsView = options.attachmentsView; - - this.disableNotification = options.disableNotification || false; + this.thumbnailView = elements.thumbnailView; + this.outlineView = elements.outlineView; + this.attachmentsView = elements.attachmentsView; this.eventBus = eventBus; this.l10n = l10n; + this._disableNotification = disableNotification; this._addEventListeners(); } @@ -305,7 +310,7 @@ class PDFSidebar { * @private */ _showUINotification(view) { - if (this.disableNotification) { + if (this._disableNotification) { return; } @@ -339,7 +344,7 @@ class PDFSidebar { * @private */ _hideUINotification(view) { - if (this.disableNotification) { + if (this._disableNotification) { return; }