diff --git a/web/default_preferences.js b/web/default_preferences.js index 10474144a..ea2d4ae22 100644 --- a/web/default_preferences.js +++ b/web/default_preferences.js @@ -32,5 +32,6 @@ var DEFAULT_PREFERENCES = { disableAutoFetch: false, disableFontFace: false, disableTextLayer: false, - useOnlyCssZoom: false + useOnlyCssZoom: false, + externalLinkTarget: 0, }; diff --git a/web/viewer.js b/web/viewer.js index 514e0c394..4b25ffe3c 100644 --- a/web/viewer.js +++ b/web/viewer.js @@ -288,12 +288,24 @@ var PDFViewerApplication = { }), Preferences.get('useOnlyCssZoom').then(function resolved(value) { PDFJS.useOnlyCssZoom = value; - }) + }), + Preferences.get('externalLinkTarget').then(function resolved(value) { + if (PDFJS.isExternalLinkTargetSet()) { + return; + } + PDFJS.externalLinkTarget = value; + }), // TODO move more preferences and other async stuff here ]).catch(function (reason) { }); return initializedPromise.then(function () { - PDFViewerApplication.initialized = true; + if (self.isViewerEmbedded && !PDFJS.isExternalLinkTargetSet()) { + // Prevent external links from "replacing" the viewer, + // when it's embedded in e.g. an iframe or an object. + PDFJS.externalLinkTarget = PDFJS.LinkTarget.TOP; + } + + self.initialized = true; }); },