From dfb8e620791d146a0068f06ceafbfe10b53f16db Mon Sep 17 00:00:00 2001 From: Jonas Jenwald Date: Tue, 8 Oct 2013 20:11:04 +0200 Subject: [PATCH] Enabling clicking to close the context menu in Presentation Mode, without going to the next page --- web/presentation_mode.js | 40 ++++++++++++++++++++++++++++++++++++++++ web/viewer.js | 19 ++++++------------- 2 files changed, 46 insertions(+), 13 deletions(-) diff --git a/web/presentation_mode.js b/web/presentation_mode.js index 4573b14a9..2acafb968 100644 --- a/web/presentation_mode.js +++ b/web/presentation_mode.js @@ -24,9 +24,34 @@ var SELECTOR = 'presentationControls'; var PresentationMode = { active: false, args: null, + contextMenuOpen: false, initialize: function presentationModeInitialize(options) { this.container = options.container; + this.secondaryToolbar = options.secondaryToolbar; + + this.firstPage = options.firstPage; + this.lastPage = options.lastPage; + this.pageRotateCw = options.pageRotateCw; + this.pageRotateCcw = options.pageRotateCcw; + + this.firstPage.addEventListener('click', function() { + this.contextMenuOpen = false; + this.secondaryToolbar.firstPageClick(); + }.bind(this)); + this.lastPage.addEventListener('click', function() { + this.contextMenuOpen = false; + this.secondaryToolbar.lastPageClick(); + }.bind(this)); + + this.pageRotateCw.addEventListener('click', function() { + this.contextMenuOpen = false; + this.secondaryToolbar.pageRotateCwClick(); + }.bind(this)); + this.pageRotateCcw.addEventListener('click', function() { + this.contextMenuOpen = false; + this.secondaryToolbar.pageRotateCcwClick(); + }.bind(this)); }, get isFullscreen() { @@ -69,8 +94,10 @@ var PresentationMode = { window.addEventListener('mousemove', this.mouseMove, false); window.addEventListener('mousedown', this.mouseDown, false); + window.addEventListener('contextmenu', this.contextMenu, false); this.showControls(); + this.contextMenuOpen = false; this.container.setAttribute('contextmenu', 'viewerContextMenu'); }, @@ -83,11 +110,13 @@ var PresentationMode = { window.removeEventListener('mousemove', this.mouseMove, false); window.removeEventListener('mousedown', this.mouseDown, false); + window.removeEventListener('contextmenu', this.contextMenu, false); this.hideControls(); this.args = null; PDFView.clearMouseScrollState(); this.container.removeAttribute('contextmenu'); + this.contextMenuOpen = false; // Ensure that the thumbnail of the current page is visible // when exiting presentation mode. @@ -120,6 +149,13 @@ var PresentationMode = { }, mouseDown: function presentationModeMouseDown(evt) { + var self = PresentationMode; + if (self.contextMenuOpen) { + self.contextMenuOpen = false; + evt.preventDefault(); + return; + } + if (evt.button === 0) { // Enable clicking of links in presentation mode. Please note: // Only links pointing to destinations in the current PDF document work. @@ -131,6 +167,10 @@ var PresentationMode = { PDFView.page += (evt.shiftKey ? -1 : 1); } } + }, + + contextMenu: function presentationModeContextMenu(evt) { + PresentationMode.contextMenuOpen = true; } }; diff --git a/web/viewer.js b/web/viewer.js index 5cb315fde..bfffaae4a 100644 --- a/web/viewer.js +++ b/web/viewer.js @@ -148,7 +148,12 @@ var PDFView = { }); PresentationMode.initialize({ - container: container + container: container, + secondaryToolbar: SecondaryToolbar, + firstPage: document.getElementById('contextFirstPage'), + lastPage: document.getElementById('contextLastPage'), + pageRotateCw: document.getElementById('contextPageRotateCw'), + pageRotateCcw: document.getElementById('contextPageRotateCcw') }); this.initialized = true; @@ -1650,18 +1655,6 @@ document.addEventListener('DOMContentLoaded', function webViewerLoad(evt) { document.getElementById('download').addEventListener('click', SecondaryToolbar.downloadClick.bind(SecondaryToolbar)); - document.getElementById('contextFirstPage').addEventListener('click', - SecondaryToolbar.firstPageClick.bind(SecondaryToolbar)); - - document.getElementById('contextLastPage').addEventListener('click', - SecondaryToolbar.lastPageClick.bind(SecondaryToolbar)); - - document.getElementById('contextPageRotateCw').addEventListener('click', - SecondaryToolbar.pageRotateCwClick.bind(SecondaryToolbar)); - - document.getElementById('contextPageRotateCcw').addEventListener('click', - SecondaryToolbar.pageRotateCcwClick.bind(SecondaryToolbar)); - //#if (FIREFOX || MOZCENTRAL) //PDFView.setTitleUsingUrl(file); //PDFView.initPassiveLoading();