/* Copyright 2022 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. */ /** @typedef {import("../src/display/api").PDFPageProxy} PDFPageProxy */ // eslint-disable-next-line max-len /** @typedef {import("../src/display/display_utils").PageViewport} PageViewport */ /** @typedef {import("./interfaces").IPDFLinkService} IPDFLinkService */ // eslint-disable-next-line max-len /** @typedef {import("../src/display/editor/tools.js").AnnotationEditorUIManager} AnnotationEditorUIManager */ // eslint-disable-next-line max-len /** @typedef {import("../annotation_storage.js").AnnotationStorage} AnnotationStorage */ /** @typedef {import("./interfaces").IL10n} IL10n */ import { AnnotationEditorLayer } from "pdfjs-lib"; import { NullL10n } from "./l10n_utils.js"; /** * @typedef {Object} AnnotationEditorLayerBuilderOptions * @property {number} mode - Editor mode * @property {HTMLDivElement} pageDiv * @property {PDFPageProxy} pdfPage * @property {AnnotationStorage} annotationStorage * @property {IL10n} l10n - Localization service. * @property {AnnotationEditorUIManager} uiManager */ class AnnotationEditorLayerBuilder { #uiManager; /** * @param {AnnotationEditorLayerBuilderOptions} options */ constructor(options) { this.pageDiv = options.pageDiv; this.pdfPage = options.pdfPage; this.annotationStorage = options.annotationStorage || null; this.l10n = options.l10n || NullL10n; this.annotationEditorLayer = null; this.div = null; this._cancelled = false; this.#uiManager = options.uiManager; } /** * @param {PageViewport} viewport * @param {string} intent (default value is 'display') */ async render(viewport, intent = "display") { if (intent !== "display") { return; } if (this._cancelled) { return; } const clonedViewport = viewport.clone({ dontFlip: true }); if (this.div) { this.annotationEditorLayer.update({ viewport: clonedViewport }); this.show(); return; } // Create an AnnotationEditor layer div this.div = document.createElement("div"); this.div.className = "annotationEditorLayer"; this.div.tabIndex = 0; this.annotationEditorLayer = new AnnotationEditorLayer({ uiManager: this.#uiManager, div: this.div, annotationStorage: this.annotationStorage, pageIndex: this.pdfPage._pageIndex, l10n: this.l10n, }); const parameters = { viewport: clonedViewport, div: this.div, annotations: null, intent, }; this.annotationEditorLayer.render(parameters); this.pageDiv.append(this.div); } cancel() { this._cancelled = true; } hide() { if (!this.div) { return; } this.div.hidden = true; } show() { if (!this.div) { return; } this.div.hidden = false; } destroy() { if (!this.div) { return; } this.pageDiv = null; this.div.remove(); this.annotationEditorLayer.destroy(); } } export { AnnotationEditorLayerBuilder };