diff --git a/web/app.js b/web/app.js index 1d442f0a189aa7..4bef0b9b67a782 100644 --- a/web/app.js +++ b/web/app.js @@ -189,6 +189,8 @@ const PDFViewerApplication = { externalServices: DefaultExternalServices, _boundEvents: {}, contentDispositionFilename: null, + _hasInteracted: false, + _delayedFallbackFeatureIds: [], // Called once when the document is loaded. async initialize(appConfig) { @@ -867,11 +869,20 @@ const PDFViewerApplication = { typeof PDFJSDev === "undefined" || PDFJSDev.test("MOZCENTRAL || GENERIC") ) { + // For PDFs that contain script and form errors, we should only trigger + // the fallback once the user has interacted with the page. + if (this._delayedFallbackFeatureIds.length === 2 && this._hasInteracted) { + featureId = this._delayedFallbackFeatureIds[0]; + // Reset to prevent all click events from showing fallback bar. + this._delayedFallbackFeatureIds = []; + } + // Only trigger the fallback once so we don't spam the user with messages // for one PDF. if (this.fellback) { return; } + this.fellback = true; this.externalServices.fallback( { @@ -1235,7 +1246,7 @@ const PDFViewerApplication = { return false; } console.warn("Warning: JavaScript is not supported"); - this.fallback(UNSUPPORTED_FEATURES.javaScript); + this._delayedFallbackFeatureIds.push(UNSUPPORTED_FEATURES.javaScript); return true; }); @@ -1317,7 +1328,7 @@ const PDFViewerApplication = { if (info.IsAcroFormPresent) { console.warn("Warning: AcroForm/XFA is not supported"); - this.fallback(UNSUPPORTED_FEATURES.forms); + this._delayedFallbackFeatureIds.push(UNSUPPORTED_FEATURES.forms); } if ( @@ -2473,6 +2484,17 @@ function webViewerWheel(evt) { } function webViewerClick(evt) { + PDFViewerApplication._hasInteracted = true; + + // Avoid triggering the fallback bar when the user clicks on the + // toolbar or sidebar. + if ( + PDFViewerApplication._delayedFallbackFeatureIds.length === 2 && + PDFViewerApplication.pdfViewer.containsElement(evt.target) + ) { + PDFViewerApplication.fallback(); + } + if (!PDFViewerApplication.secondaryToolbar.isOpen) { return; }