[api-minor] Deprecate getGlobalEventBus and update the "viewer components" examples accordingly

To avoid outright breaking third-party usages of the "viewer components" the `getGlobalEventBus` functionality is left intact, but a deprecation message is printed if the function is invoked.

The various examples are updated to *explicitly* initialize an `EventBus` instance, and provide that when initializing the relevant viewer components.
This commit is contained in:
Jonas Jenwald 2020-02-26 17:16:30 +01:00
parent 965ebe63fd
commit 9a437a158f
16 changed files with 68 additions and 34 deletions

View File

@ -23,6 +23,8 @@ var DEFAULT_SCALE = 1.0;
var container = document.getElementById("pageContainer"); var container = document.getElementById("pageContainer");
var eventBus = new pdfjsViewer.EventBus();
// Fetch the PDF document from the URL using promises. // Fetch the PDF document from the URL using promises.
var loadingTask = pdfjsLib.getDocument(DEFAULT_URL); var loadingTask = pdfjsLib.getDocument(DEFAULT_URL);
loadingTask.promise.then(function(doc) { loadingTask.promise.then(function(doc) {
@ -39,6 +41,7 @@ loadingTask.promise.then(function(doc) {
id: pageNum, id: pageNum,
scale: DEFAULT_SCALE, scale: DEFAULT_SCALE,
defaultViewport: pdfPage.getViewport({ scale: DEFAULT_SCALE }), defaultViewport: pdfPage.getViewport({ scale: DEFAULT_SCALE }),
eventBus: eventBus,
annotationLayerFactory: new pdfjsViewer.DefaultAnnotationLayerFactory(), annotationLayerFactory: new pdfjsViewer.DefaultAnnotationLayerFactory(),
renderInteractiveForms: true, renderInteractiveForms: true,
}); });

View File

@ -35,6 +35,8 @@ var SCALE = 1.0;
var container = document.getElementById("pageContainer"); var container = document.getElementById("pageContainer");
var eventBus = new pdfjsViewer.EventBus();
// Loading document. // Loading document.
var loadingTask = pdfjsLib.getDocument({ var loadingTask = pdfjsLib.getDocument({
url: DEFAULT_URL, url: DEFAULT_URL,
@ -50,6 +52,7 @@ loadingTask.promise.then(function(pdfDocument) {
id: PAGE_TO_VIEW, id: PAGE_TO_VIEW,
scale: SCALE, scale: SCALE,
defaultViewport: pdfPage.getViewport({ scale: SCALE }), defaultViewport: pdfPage.getViewport({ scale: SCALE }),
eventBus: eventBus,
// We can enable text/annotations layers, if needed // We can enable text/annotations layers, if needed
textLayerFactory: new pdfjsViewer.DefaultTextLayerFactory(), textLayerFactory: new pdfjsViewer.DefaultTextLayerFactory(),
annotationLayerFactory: new pdfjsViewer.DefaultAnnotationLayerFactory(), annotationLayerFactory: new pdfjsViewer.DefaultAnnotationLayerFactory(),

View File

@ -34,22 +34,28 @@ var SEARCH_FOR = ""; // try 'Mozilla';
var container = document.getElementById("viewerContainer"); var container = document.getElementById("viewerContainer");
var eventBus = new pdfjsViewer.EventBus();
// (Optionally) enable hyperlinks within PDF files. // (Optionally) enable hyperlinks within PDF files.
var pdfLinkService = new pdfjsViewer.PDFLinkService(); var pdfLinkService = new pdfjsViewer.PDFLinkService({
eventBus: eventBus,
});
// (Optionally) enable find controller. // (Optionally) enable find controller.
var pdfFindController = new pdfjsViewer.PDFFindController({ var pdfFindController = new pdfjsViewer.PDFFindController({
eventBus: eventBus,
linkService: pdfLinkService, linkService: pdfLinkService,
}); });
var pdfViewer = new pdfjsViewer.PDFViewer({ var pdfViewer = new pdfjsViewer.PDFViewer({
container: container, container: container,
eventBus: eventBus,
linkService: pdfLinkService, linkService: pdfLinkService,
findController: pdfFindController, findController: pdfFindController,
}); });
pdfLinkService.setViewer(pdfViewer); pdfLinkService.setViewer(pdfViewer);
document.addEventListener("pagesinit", function() { eventBus.on("pagesinit", function() {
// We can use pdfViewer now, e.g. let's change default scale. // We can use pdfViewer now, e.g. let's change default scale.
pdfViewer.currentScaleValue = "page-width"; pdfViewer.currentScaleValue = "page-width";

View File

@ -34,22 +34,28 @@ var SEARCH_FOR = ""; // try 'Mozilla';
var container = document.getElementById("viewerContainer"); var container = document.getElementById("viewerContainer");
var eventBus = new pdfjsViewer.EventBus();
// (Optionally) enable hyperlinks within PDF files. // (Optionally) enable hyperlinks within PDF files.
var pdfLinkService = new pdfjsViewer.PDFLinkService(); var pdfLinkService = new pdfjsViewer.PDFLinkService({
eventBus: eventBus,
});
// (Optionally) enable find controller. // (Optionally) enable find controller.
var pdfFindController = new pdfjsViewer.PDFFindController({ var pdfFindController = new pdfjsViewer.PDFFindController({
eventBus: eventBus,
linkService: pdfLinkService, linkService: pdfLinkService,
}); });
var pdfSinglePageViewer = new pdfjsViewer.PDFSinglePageViewer({ var pdfSinglePageViewer = new pdfjsViewer.PDFSinglePageViewer({
container: container, container: container,
eventBus: eventBus,
linkService: pdfLinkService, linkService: pdfLinkService,
findController: pdfFindController, findController: pdfFindController,
}); });
pdfLinkService.setViewer(pdfSinglePageViewer); pdfLinkService.setViewer(pdfSinglePageViewer);
document.addEventListener("pagesinit", function() { eventBus.on("pagesinit", function() {
// We can use pdfSinglePageViewer now, e.g. let's change default scale. // We can use pdfSinglePageViewer now, e.g. let's change default scale.
pdfSinglePageViewer.currentScaleValue = "page-width"; pdfSinglePageViewer.currentScaleValue = "page-width";

View File

@ -40,6 +40,7 @@ var PDFViewerApplication = {
pdfViewer: null, pdfViewer: null,
pdfHistory: null, pdfHistory: null,
pdfLinkService: null, pdfLinkService: null,
eventBus: null,
/** /**
* Opens PDF document specified by URL. * Opens PDF document specified by URL.
@ -340,7 +341,12 @@ var PDFViewerApplication = {
}, },
initUI: function pdfViewInitUI() { initUI: function pdfViewInitUI() {
var linkService = new pdfjsViewer.PDFLinkService(); var eventBus = new pdfjsViewer.EventBus();
this.eventBus = eventBus;
var linkService = new pdfjsViewer.PDFLinkService({
eventBus: eventBus,
});
this.pdfLinkService = linkService; this.pdfLinkService = linkService;
this.l10n = pdfjsViewer.NullL10n; this.l10n = pdfjsViewer.NullL10n;
@ -348,6 +354,7 @@ var PDFViewerApplication = {
var container = document.getElementById("viewerContainer"); var container = document.getElementById("viewerContainer");
var pdfViewer = new pdfjsViewer.PDFViewer({ var pdfViewer = new pdfjsViewer.PDFViewer({
container: container, container: container,
eventBus: eventBus,
linkService: linkService, linkService: linkService,
l10n: this.l10n, l10n: this.l10n,
useOnlyCssZoom: USE_ONLY_CSS_ZOOM, useOnlyCssZoom: USE_ONLY_CSS_ZOOM,
@ -357,6 +364,7 @@ var PDFViewerApplication = {
linkService.setViewer(pdfViewer); linkService.setViewer(pdfViewer);
this.pdfHistory = new pdfjsViewer.PDFHistory({ this.pdfHistory = new pdfjsViewer.PDFHistory({
eventBus: eventBus,
linkService: linkService, linkService: linkService,
}); });
linkService.setHistory(this.pdfHistory); linkService.setHistory(this.pdfHistory);
@ -394,15 +402,15 @@ var PDFViewerApplication = {
} }
}); });
document.addEventListener("pagesinit", function() { eventBus.on("pagesinit", function() {
// We can use pdfViewer now, e.g. let's change default scale. // We can use pdfViewer now, e.g. let's change default scale.
pdfViewer.currentScaleValue = DEFAULT_SCALE_VALUE; pdfViewer.currentScaleValue = DEFAULT_SCALE_VALUE;
}); });
document.addEventListener( eventBus.on(
"pagechanging", "pagechanging",
function(evt) { function(evt) {
var page = evt.detail.pageNumber; var page = evt.pageNumber;
var numPages = PDFViewerApplication.pagesCount; var numPages = PDFViewerApplication.pagesCount;
document.getElementById("pageNumber").value = page; document.getElementById("pageNumber").value = page;

View File

@ -33,18 +33,23 @@ var DEFAULT_URL = "../../web/compressed.tracemonkey-pldi-09.pdf";
var container = document.getElementById("viewerContainer"); var container = document.getElementById("viewerContainer");
var eventBus = new pdfjsViewer.EventBus();
// (Optionally) enable hyperlinks within PDF files. // (Optionally) enable hyperlinks within PDF files.
var pdfLinkService = new pdfjsViewer.PDFLinkService(); var pdfLinkService = new pdfjsViewer.PDFLinkService({
eventBus: eventBus,
});
var pdfViewer = new pdfjsViewer.PDFViewer({ var pdfViewer = new pdfjsViewer.PDFViewer({
container: container, container: container,
eventBus: eventBus,
linkService: pdfLinkService, linkService: pdfLinkService,
renderer: "svg", renderer: "svg",
textLayerMode: 0, textLayerMode: 0,
}); });
pdfLinkService.setViewer(pdfViewer); pdfLinkService.setViewer(pdfViewer);
document.addEventListener("pagesinit", function() { eventBus.on("pagesinit", function() {
// We can use pdfViewer now, e.g. let's change default scale. // We can use pdfViewer now, e.g. let's change default scale.
pdfViewer.currentScaleValue = "page-width"; pdfViewer.currentScaleValue = "page-width";
}); });

View File

@ -18,7 +18,7 @@ import {
animationStarted, animationStarted,
AutoPrintRegExp, AutoPrintRegExp,
DEFAULT_SCALE_VALUE, DEFAULT_SCALE_VALUE,
getGlobalEventBus, EventBus,
getPDFFileNameFromURL, getPDFFileNameFromURL,
isValidRotation, isValidRotation,
isValidScrollMode, isValidScrollMode,
@ -343,7 +343,7 @@ const PDFViewerApplication = {
const eventBus = const eventBus =
appConfig.eventBus || appConfig.eventBus ||
getGlobalEventBus(AppOptions.get("eventBusDispatchToDOM")); new EventBus({ dispatchToDOM: AppOptions.get("eventBusDispatchToDOM") });
this.eventBus = eventBus; this.eventBus = eventBus;
const pdfRenderingQueue = new PDFRenderingQueue(); const pdfRenderingQueue = new PDFRenderingQueue();

View File

@ -1088,17 +1088,20 @@ class BaseViewer {
* @param {HTMLDivElement} textLayerDiv * @param {HTMLDivElement} textLayerDiv
* @param {number} pageIndex * @param {number} pageIndex
* @param {PageViewport} viewport * @param {PageViewport} viewport
* @param {boolean} enhanceTextSelection
* @param {EventBus} eventBus
* @returns {TextLayerBuilder} * @returns {TextLayerBuilder}
*/ */
createTextLayerBuilder( createTextLayerBuilder(
textLayerDiv, textLayerDiv,
pageIndex, pageIndex,
viewport, viewport,
enhanceTextSelection = false enhanceTextSelection = false,
eventBus
) { ) {
return new TextLayerBuilder({ return new TextLayerBuilder({
textLayerDiv, textLayerDiv,
eventBus: this.eventBus, eventBus,
pageIndex, pageIndex,
viewport, viewport,
findController: this.isInPresentationMode ? null : this.findController, findController: this.isInPresentationMode ? null : this.findController,

View File

@ -146,13 +146,15 @@ class IPDFTextLayerFactory {
* @param {number} pageIndex * @param {number} pageIndex
* @param {PageViewport} viewport * @param {PageViewport} viewport
* @param {boolean} enhanceTextSelection * @param {boolean} enhanceTextSelection
* @param {EventBus} eventBus
* @returns {TextLayerBuilder} * @returns {TextLayerBuilder}
*/ */
createTextLayerBuilder( createTextLayerBuilder(
textLayerDiv, textLayerDiv,
pageIndex, pageIndex,
viewport, viewport,
enhanceTextSelection = false enhanceTextSelection = false,
eventBus
) {} ) {}
} }

View File

@ -25,7 +25,7 @@ const MATCHES_COUNT_LIMIT = 1000;
* is done by PDFFindController. * is done by PDFFindController.
*/ */
class PDFFindBar { class PDFFindBar {
constructor(options, eventBus = getGlobalEventBus(), l10n = NullL10n) { constructor(options, eventBus, l10n = NullL10n) {
this.opened = false; this.opened = false;
this.bar = options.bar || null; this.bar = options.bar || null;
@ -38,7 +38,7 @@ class PDFFindBar {
this.findResultsCount = options.findResultsCount || null; this.findResultsCount = options.findResultsCount || null;
this.findPreviousButton = options.findPreviousButton || null; this.findPreviousButton = options.findPreviousButton || null;
this.findNextButton = options.findNextButton || null; this.findNextButton = options.findNextButton || null;
this.eventBus = eventBus; this.eventBus = eventBus || getGlobalEventBus();
this.l10n = l10n; this.l10n = l10n;
// Add event listeners to the DOM elements. // Add event listeners to the DOM elements.

View File

@ -67,9 +67,9 @@ class PDFFindController {
/** /**
* @param {PDFFindControllerOptions} options * @param {PDFFindControllerOptions} options
*/ */
constructor({ linkService, eventBus = getGlobalEventBus() }) { constructor({ linkService, eventBus }) {
this._linkService = linkService; this._linkService = linkService;
this._eventBus = eventBus; this._eventBus = eventBus || getGlobalEventBus();
this._reset(); this._reset();
eventBus.on("findbarclose", this._onFindBarClose.bind(this)); eventBus.on("findbarclose", this._onFindBarClose.bind(this));

View File

@ -444,7 +444,8 @@ class PDFPageView {
textLayerDiv, textLayerDiv,
this.id - 1, this.id - 1,
this.viewport, this.viewport,
this.textLayerMode === TextLayerMode.ENABLE_ENHANCE this.textLayerMode === TextLayerMode.ENABLE_ENHANCE,
this.eventBus
); );
} }
this.textLayer = textLayer; this.textLayer = textLayer;

View File

@ -21,12 +21,7 @@ import {
DefaultTextLayerFactory, DefaultTextLayerFactory,
TextLayerBuilder, TextLayerBuilder,
} from "./text_layer_builder.js"; } from "./text_layer_builder.js";
import { import { EventBus, NullL10n, ProgressBar } from "./ui_utils.js";
EventBus,
getGlobalEventBus,
NullL10n,
ProgressBar,
} from "./ui_utils.js";
import { PDFLinkService, SimpleLinkService } from "./pdf_link_service.js"; import { PDFLinkService, SimpleLinkService } from "./pdf_link_service.js";
import { DownloadManager } from "./download_manager.js"; import { DownloadManager } from "./download_manager.js";
import { GenericL10n } from "./genericl10n.js"; import { GenericL10n } from "./genericl10n.js";
@ -41,9 +36,6 @@ const pdfjsVersion = PDFJSDev.eval("BUNDLE_VERSION");
// eslint-disable-next-line no-unused-vars // eslint-disable-next-line no-unused-vars
const pdfjsBuild = PDFJSDev.eval("BUNDLE_BUILD"); const pdfjsBuild = PDFJSDev.eval("BUNDLE_BUILD");
// For backwards compatibility, ensure that events are re-dispatched to the DOM.
getGlobalEventBus(/* dispatchToDOM = */ true);
export { export {
PDFViewer, PDFViewer,
PDFSinglePageViewer, PDFSinglePageViewer,

View File

@ -444,19 +444,22 @@ class DefaultTextLayerFactory {
* @param {number} pageIndex * @param {number} pageIndex
* @param {PageViewport} viewport * @param {PageViewport} viewport
* @param {boolean} enhanceTextSelection * @param {boolean} enhanceTextSelection
* @param {EventBus} eventBus
* @returns {TextLayerBuilder} * @returns {TextLayerBuilder}
*/ */
createTextLayerBuilder( createTextLayerBuilder(
textLayerDiv, textLayerDiv,
pageIndex, pageIndex,
viewport, viewport,
enhanceTextSelection = false enhanceTextSelection = false,
eventBus
) { ) {
return new TextLayerBuilder({ return new TextLayerBuilder({
textLayerDiv, textLayerDiv,
pageIndex, pageIndex,
viewport, viewport,
enhanceTextSelection, enhanceTextSelection,
eventBus,
}); });
} }
} }

View File

@ -757,9 +757,8 @@ const animationStarted = new Promise(function(resolve) {
}); });
/** /**
* Simple event bus for an application. Listeners are attached using the * Simple event bus for an application. Listeners are attached using the `on`
* `on` and `off` methods. To raise an event, the `dispatch` method shall be * and `off` methods. To raise an event, the `dispatch` method shall be used.
* used.
*/ */
class EventBus { class EventBus {
constructor({ dispatchToDOM = false } = {}) { constructor({ dispatchToDOM = false } = {}) {
@ -832,6 +831,9 @@ class EventBus {
let globalEventBus = null; let globalEventBus = null;
function getGlobalEventBus(dispatchToDOM = false) { function getGlobalEventBus(dispatchToDOM = false) {
console.error(
"getGlobalEventBus is deprecated, use a manually created EventBus instance instead."
);
if (!globalEventBus) { if (!globalEventBus) {
globalEventBus = new EventBus({ dispatchToDOM }); globalEventBus = new EventBus({ dispatchToDOM });
} }

View File

@ -60,7 +60,7 @@ function getViewerConfiguration() {
appContainer: document.body, appContainer: document.body,
mainContainer: document.getElementById("viewerContainer"), mainContainer: document.getElementById("viewerContainer"),
viewerContainer: document.getElementById("viewer"), viewerContainer: document.getElementById("viewer"),
eventBus: null, // Using global event bus with (optional) DOM events. eventBus: null,
toolbar: { toolbar: {
container: document.getElementById("toolbarViewer"), container: document.getElementById("toolbarViewer"),
numPages: document.getElementById("numPages"), numPages: document.getElementById("numPages"),