Merge pull request #16592 from Snuffleupagus/rm-viewer-component-default-factory
[api-minor] Remove the default-factories from the viewer components (PR 15811 follow-up)
This commit is contained in:
commit
436699b0db
@ -52,20 +52,6 @@ const loadingTask = pdfjsLib.getDocument({
|
|||||||
// Document loaded, retrieving the page.
|
// Document loaded, retrieving the page.
|
||||||
const pdfPage = await pdfDocument.getPage(PAGE_TO_VIEW);
|
const pdfPage = await pdfDocument.getPage(PAGE_TO_VIEW);
|
||||||
|
|
||||||
const match = /^(\d+)\.(\d+)\.(\d+)$/.exec(pdfjsLib.version);
|
|
||||||
if (match && (match[1] | 0) >= 3 && (match[2] | 0) >= 2) {
|
|
||||||
// Creating the page view with default parameters.
|
|
||||||
const pdfPageView = new pdfjsViewer.PDFPageView({
|
|
||||||
container,
|
|
||||||
id: PAGE_TO_VIEW,
|
|
||||||
scale: SCALE,
|
|
||||||
defaultViewport: pdfPage.getViewport({ scale: SCALE }),
|
|
||||||
eventBus,
|
|
||||||
});
|
|
||||||
// Associate the actual page with the view, and draw it.
|
|
||||||
pdfPageView.setPdfPage(pdfPage);
|
|
||||||
return pdfPageView.draw();
|
|
||||||
}
|
|
||||||
// Creating the page view with default parameters.
|
// Creating the page view with default parameters.
|
||||||
const pdfPageView = new pdfjsViewer.PDFPageView({
|
const pdfPageView = new pdfjsViewer.PDFPageView({
|
||||||
container,
|
container,
|
||||||
@ -73,15 +59,6 @@ const loadingTask = pdfjsLib.getDocument({
|
|||||||
scale: SCALE,
|
scale: SCALE,
|
||||||
defaultViewport: pdfPage.getViewport({ scale: SCALE }),
|
defaultViewport: pdfPage.getViewport({ scale: SCALE }),
|
||||||
eventBus,
|
eventBus,
|
||||||
// We can enable text/annotation/xfa/struct-layers, as needed.
|
|
||||||
textLayerFactory: !pdfDocument.isPureXfa
|
|
||||||
? new pdfjsViewer.DefaultTextLayerFactory()
|
|
||||||
: null,
|
|
||||||
annotationLayerFactory: new pdfjsViewer.DefaultAnnotationLayerFactory(),
|
|
||||||
xfaLayerFactory: pdfDocument.isPureXfa
|
|
||||||
? new pdfjsViewer.DefaultXfaLayerFactory()
|
|
||||||
: null,
|
|
||||||
structTreeLayerFactory: new pdfjsViewer.DefaultStructTreeLayerFactory(),
|
|
||||||
});
|
});
|
||||||
// Associate the actual page with the view, and draw it.
|
// Associate the actual page with the view, and draw it.
|
||||||
pdfPageView.setPdfPage(pdfPage);
|
pdfPageView.setPdfPage(pdfPage);
|
||||||
|
@ -78,6 +78,7 @@ async function initializePDFJS(callback) {
|
|||||||
"pdfjs-test/unit/pdf_find_utils_spec.js",
|
"pdfjs-test/unit/pdf_find_utils_spec.js",
|
||||||
"pdfjs-test/unit/pdf_history_spec.js",
|
"pdfjs-test/unit/pdf_history_spec.js",
|
||||||
"pdfjs-test/unit/pdf_spec.js",
|
"pdfjs-test/unit/pdf_spec.js",
|
||||||
|
"pdfjs-test/unit/pdf_viewer.component_spec.js",
|
||||||
"pdfjs-test/unit/pdf_viewer_spec.js",
|
"pdfjs-test/unit/pdf_viewer_spec.js",
|
||||||
"pdfjs-test/unit/primitives_spec.js",
|
"pdfjs-test/unit/primitives_spec.js",
|
||||||
"pdfjs-test/unit/scripting_spec.js",
|
"pdfjs-test/unit/scripting_spec.js",
|
||||||
|
75
test/unit/pdf_viewer.component_spec.js
Normal file
75
test/unit/pdf_viewer.component_spec.js
Normal file
@ -0,0 +1,75 @@
|
|||||||
|
/* Copyright 2023 Mozilla Foundation
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import { FindState, PDFFindController } from "../../web/pdf_find_controller.js";
|
||||||
|
import {
|
||||||
|
LinkTarget,
|
||||||
|
PDFLinkService,
|
||||||
|
SimpleLinkService,
|
||||||
|
} from "../../web/pdf_link_service.js";
|
||||||
|
import {
|
||||||
|
parseQueryString,
|
||||||
|
ProgressBar,
|
||||||
|
RenderingStates,
|
||||||
|
ScrollMode,
|
||||||
|
SpreadMode,
|
||||||
|
} from "../../web/ui_utils.js";
|
||||||
|
import { AnnotationLayerBuilder } from "../../web/annotation_layer_builder.js";
|
||||||
|
import { DownloadManager } from "../../web/download_manager.js";
|
||||||
|
import { EventBus } from "../../web/event_utils.js";
|
||||||
|
import { GenericL10n } from "../../web/genericl10n.js";
|
||||||
|
import { NullL10n } from "../../web/l10n_utils.js";
|
||||||
|
import { PDFHistory } from "../../web/pdf_history.js";
|
||||||
|
import { PDFPageView } from "../../web/pdf_page_view.js";
|
||||||
|
import { PDFScriptingManager } from "../../web/pdf_scripting_manager.js";
|
||||||
|
import { PDFSinglePageViewer } from "../../web/pdf_single_page_viewer.js";
|
||||||
|
import { PDFViewer } from "../../web/pdf_viewer.js";
|
||||||
|
import { StructTreeLayerBuilder } from "../../web/struct_tree_layer_builder.js";
|
||||||
|
import { TextLayerBuilder } from "../../web/text_layer_builder.js";
|
||||||
|
import { XfaLayerBuilder } from "../../web/xfa_layer_builder.js";
|
||||||
|
|
||||||
|
describe("pdfviewer_api", function () {
|
||||||
|
it("checks that the *official* PDF.js-viewer API exposes the expected functionality", async function () {
|
||||||
|
const pdfviewerAPI = await import("../../web/pdf_viewer.component.js");
|
||||||
|
|
||||||
|
// The imported Object contains an (automatically) inserted Symbol,
|
||||||
|
// hence we copy the data to allow using a simple comparison below.
|
||||||
|
expect({ ...pdfviewerAPI }).toEqual({
|
||||||
|
AnnotationLayerBuilder,
|
||||||
|
DownloadManager,
|
||||||
|
EventBus,
|
||||||
|
FindState,
|
||||||
|
GenericL10n,
|
||||||
|
LinkTarget,
|
||||||
|
NullL10n,
|
||||||
|
parseQueryString,
|
||||||
|
PDFFindController,
|
||||||
|
PDFHistory,
|
||||||
|
PDFLinkService,
|
||||||
|
PDFPageView,
|
||||||
|
PDFScriptingManager,
|
||||||
|
PDFSinglePageViewer,
|
||||||
|
PDFViewer,
|
||||||
|
ProgressBar,
|
||||||
|
RenderingStates,
|
||||||
|
ScrollMode,
|
||||||
|
SimpleLinkService,
|
||||||
|
SpreadMode,
|
||||||
|
StructTreeLayerBuilder,
|
||||||
|
TextLayerBuilder,
|
||||||
|
XfaLayerBuilder,
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
@ -13,6 +13,7 @@
|
|||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
import { FindState, PDFFindController } from "./pdf_find_controller.js";
|
||||||
import {
|
import {
|
||||||
LinkTarget,
|
LinkTarget,
|
||||||
PDFLinkService,
|
PDFLinkService,
|
||||||
@ -30,7 +31,6 @@ import { DownloadManager } from "./download_manager.js";
|
|||||||
import { EventBus } from "./event_utils.js";
|
import { EventBus } from "./event_utils.js";
|
||||||
import { GenericL10n } from "./genericl10n.js";
|
import { GenericL10n } from "./genericl10n.js";
|
||||||
import { NullL10n } from "./l10n_utils.js";
|
import { NullL10n } from "./l10n_utils.js";
|
||||||
import { PDFFindController } from "./pdf_find_controller.js";
|
|
||||||
import { PDFHistory } from "./pdf_history.js";
|
import { PDFHistory } from "./pdf_history.js";
|
||||||
import { PDFPageView } from "./pdf_page_view.js";
|
import { PDFPageView } from "./pdf_page_view.js";
|
||||||
import { PDFScriptingManager } from "./pdf_scripting_manager.js";
|
import { PDFScriptingManager } from "./pdf_scripting_manager.js";
|
||||||
@ -40,58 +40,18 @@ import { StructTreeLayerBuilder } from "./struct_tree_layer_builder.js";
|
|||||||
import { TextLayerBuilder } from "./text_layer_builder.js";
|
import { TextLayerBuilder } from "./text_layer_builder.js";
|
||||||
import { XfaLayerBuilder } from "./xfa_layer_builder.js";
|
import { XfaLayerBuilder } from "./xfa_layer_builder.js";
|
||||||
|
|
||||||
// eslint-disable-next-line no-unused-vars
|
/* eslint-disable-next-line no-unused-vars */
|
||||||
const pdfjsVersion = PDFJSDev.eval("BUNDLE_VERSION");
|
const pdfjsVersion =
|
||||||
// eslint-disable-next-line no-unused-vars
|
typeof PDFJSDev !== "undefined" ? PDFJSDev.eval("BUNDLE_VERSION") : void 0;
|
||||||
const pdfjsBuild = PDFJSDev.eval("BUNDLE_BUILD");
|
/* eslint-disable-next-line no-unused-vars */
|
||||||
|
const pdfjsBuild =
|
||||||
class DefaultAnnotationLayerFactory {
|
typeof PDFJSDev !== "undefined" ? PDFJSDev.eval("BUNDLE_BUILD") : void 0;
|
||||||
constructor() {
|
|
||||||
throw new Error(
|
|
||||||
"The `DefaultAnnotationLayerFactory` has been removed, " +
|
|
||||||
"please use the `annotationMode` option when initializing " +
|
|
||||||
"the `PDFPageView`-instance to control AnnotationLayer rendering."
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class DefaultStructTreeLayerFactory {
|
|
||||||
constructor() {
|
|
||||||
throw new Error(
|
|
||||||
"The `DefaultStructTreeLayerFactory` has been removed, " +
|
|
||||||
"this functionality is automatically enabled when the TextLayer is used."
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class DefaultTextLayerFactory {
|
|
||||||
constructor() {
|
|
||||||
throw new Error(
|
|
||||||
"The `DefaultTextLayerFactory` has been removed, " +
|
|
||||||
"please use the `textLayerMode` option when initializing " +
|
|
||||||
"the `PDFPageView`-instance to control TextLayer rendering."
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class DefaultXfaLayerFactory {
|
|
||||||
constructor() {
|
|
||||||
throw new Error(
|
|
||||||
"The `DefaultXfaLayerFactory` has been removed, " +
|
|
||||||
"please use the `enableXfa` option when calling " +
|
|
||||||
"the `getDocument`-function to control XfaLayer rendering."
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export {
|
export {
|
||||||
AnnotationLayerBuilder,
|
AnnotationLayerBuilder,
|
||||||
DefaultAnnotationLayerFactory,
|
|
||||||
DefaultStructTreeLayerFactory,
|
|
||||||
DefaultTextLayerFactory,
|
|
||||||
DefaultXfaLayerFactory,
|
|
||||||
DownloadManager,
|
DownloadManager,
|
||||||
EventBus,
|
EventBus,
|
||||||
|
FindState,
|
||||||
GenericL10n,
|
GenericL10n,
|
||||||
LinkTarget,
|
LinkTarget,
|
||||||
NullL10n,
|
NullL10n,
|
||||||
|
Loading…
Reference in New Issue
Block a user