2013-09-20 16:25:41 +09:00
|
|
|
/* Copyright 2012 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.
|
|
|
|
*/
|
|
|
|
|
2021-12-15 07:59:17 +09:00
|
|
|
// eslint-disable-next-line max-len
|
|
|
|
/** @typedef {import("../src/display/display_utils").PageViewport} PageViewport */
|
|
|
|
// eslint-disable-next-line max-len
|
|
|
|
/** @typedef {import("../src/display/optional_content_config").OptionalContentConfig} OptionalContentConfig */
|
2021-12-15 21:54:29 +09:00
|
|
|
/** @typedef {import("./event_utils").EventBus} EventBus */
|
2021-12-15 07:59:17 +09:00
|
|
|
/** @typedef {import("./interfaces").IL10n} IL10n */
|
|
|
|
// eslint-disable-next-line max-len
|
|
|
|
/** @typedef {import("./interfaces").IPDFAnnotationLayerFactory} IPDFAnnotationLayerFactory */
|
|
|
|
// eslint-disable-next-line max-len
|
2022-06-01 17:38:08 +09:00
|
|
|
/** @typedef {import("./interfaces").IPDFAnnotationEditorLayerFactory} IPDFAnnotationEditorLayerFactory */
|
|
|
|
// eslint-disable-next-line max-len
|
2021-12-15 07:59:17 +09:00
|
|
|
/** @typedef {import("./interfaces").IPDFStructTreeLayerFactory} IPDFStructTreeLayerFactory */
|
|
|
|
// eslint-disable-next-line max-len
|
|
|
|
/** @typedef {import("./interfaces").IPDFTextLayerFactory} IPDFTextLayerFactory */
|
2022-06-22 18:06:11 +09:00
|
|
|
/** @typedef {import("./interfaces").IPDFXfaLayerFactory} IPDFXfaLayerFactory */
|
Fix Viewer API definitions and include in CI
The Viewer API definitions do not compile because of missing imports and
anonymous objects are typed as `Object`. These issues were not caught
during CI because the test project was not compiling anything from the
Viewer API.
As an example of the first problem:
```
/**
* @implements MyInterface
*/
export class MyClass {
...
}
```
will generate a broken definition that doesn’t import MyInterface:
```
/**
* @implements MyInterface
*/
export class MyClass implements MyInterface {
...
}
```
This can be fixed by adding a typedef jsdoc to specify the import:
```
/** @typedef {import("./otherFile").MyInterface} MyInterface */
```
See https://github.com/jsdoc/jsdoc/issues/1537 and
https://github.com/microsoft/TypeScript/issues/22160 for more details.
As an example of the second problem:
```
/**
* Gets the size of the specified page, converted from PDF units to inches.
* @param {Object} An Object containing the properties: {Array} `view`,
* {number} `userUnit`, and {number} `rotate`.
*/
function getPageSizeInches({ view, userUnit, rotate }) {
...
}
```
generates the broken definition:
```
function getPageSizeInches({ view, userUnit, rotate }: Object) {
...
}
```
The jsdoc should specify the type of each nested property:
```
/**
* Gets the size of the specified page, converted from PDF units to inches.
* @param {Object} options An object containing the properties: {Array} `view`,
* {number} `userUnit`, and {number} `rotate`.
* @param {number[]} options.view
* @param {number} options.userUnit
* @param {number} options.rotate
*/
```
2021-08-26 07:44:06 +09:00
|
|
|
/** @typedef {import("./interfaces").IRenderableView} IRenderableView */
|
2021-12-15 07:59:17 +09:00
|
|
|
// eslint-disable-next-line max-len
|
|
|
|
/** @typedef {import("./pdf_rendering_queue").PDFRenderingQueue} PDFRenderingQueue */
|
Fix Viewer API definitions and include in CI
The Viewer API definitions do not compile because of missing imports and
anonymous objects are typed as `Object`. These issues were not caught
during CI because the test project was not compiling anything from the
Viewer API.
As an example of the first problem:
```
/**
* @implements MyInterface
*/
export class MyClass {
...
}
```
will generate a broken definition that doesn’t import MyInterface:
```
/**
* @implements MyInterface
*/
export class MyClass implements MyInterface {
...
}
```
This can be fixed by adding a typedef jsdoc to specify the import:
```
/** @typedef {import("./otherFile").MyInterface} MyInterface */
```
See https://github.com/jsdoc/jsdoc/issues/1537 and
https://github.com/microsoft/TypeScript/issues/22160 for more details.
As an example of the second problem:
```
/**
* Gets the size of the specified page, converted from PDF units to inches.
* @param {Object} An Object containing the properties: {Array} `view`,
* {number} `userUnit`, and {number} `rotate`.
*/
function getPageSizeInches({ view, userUnit, rotate }) {
...
}
```
generates the broken definition:
```
function getPageSizeInches({ view, userUnit, rotate }: Object) {
...
}
```
The jsdoc should specify the type of each nested property:
```
/**
* Gets the size of the specified page, converted from PDF units to inches.
* @param {Object} options An object containing the properties: {Array} `view`,
* {number} `userUnit`, and {number} `rotate`.
* @param {number[]} options.view
* @param {number} options.userUnit
* @param {number} options.rotate
*/
```
2021-08-26 07:44:06 +09:00
|
|
|
|
[api-minor] Introduce a new `annotationMode`-option, in `PDFPageProxy.{render, getOperatorList}`
*This is a follow-up to PRs 13867 and 13899.*
This patch is tagged `api-minor` for the following reasons:
- It replaces the `renderInteractiveForms`/`includeAnnotationStorage`-options, in the `PDFPageProxy.render`-method, with the single `annotationMode`-option that controls which annotations are being rendered and how. Note that the old options were mutually exclusive, and setting both to `true` would result in undefined behaviour.
- For improved consistency in the API, the `annotationMode`-option will also work together with the `PDFPageProxy.getOperatorList`-method.
- It's now also possible to disable *all* annotation rendering in both the API and the Viewer, since the other changes meant that this could now be supported with a single added line on the worker-thread[1]; fixes 7282.
---
[1] Please note that in order to simplify the overall implementation, we'll purposely only support disabling of *all* annotations and that the option is being shared between the API and the Viewer. For any more "specialized" use-cases, where e.g. only some annotation-types are being rendered and/or the API and Viewer render different sets of annotations, that'll have to be handled in third-party implementations/forks of the PDF.js code-base.
2021-08-08 21:36:28 +09:00
|
|
|
import {
|
|
|
|
AnnotationMode,
|
|
|
|
createPromiseCapability,
|
2021-09-20 17:10:57 +09:00
|
|
|
PixelsPerInch,
|
[api-minor] Introduce a new `annotationMode`-option, in `PDFPageProxy.{render, getOperatorList}`
*This is a follow-up to PRs 13867 and 13899.*
This patch is tagged `api-minor` for the following reasons:
- It replaces the `renderInteractiveForms`/`includeAnnotationStorage`-options, in the `PDFPageProxy.render`-method, with the single `annotationMode`-option that controls which annotations are being rendered and how. Note that the old options were mutually exclusive, and setting both to `true` would result in undefined behaviour.
- For improved consistency in the API, the `annotationMode`-option will also work together with the `PDFPageProxy.getOperatorList`-method.
- It's now also possible to disable *all* annotation rendering in both the API and the Viewer, since the other changes meant that this could now be supported with a single added line on the worker-thread[1]; fixes 7282.
---
[1] Please note that in order to simplify the overall implementation, we'll purposely only support disabling of *all* annotations and that the option is being shared between the API and the Viewer. For any more "specialized" use-cases, where e.g. only some annotation-types are being rendered and/or the API and Viewer render different sets of annotations, that'll have to be handled in third-party implementations/forks of the PDF.js code-base.
2021-08-08 21:36:28 +09:00
|
|
|
RenderingCancelledException,
|
|
|
|
SVGGraphics,
|
|
|
|
} from "pdfjs-lib";
|
2017-03-28 08:07:27 +09:00
|
|
|
import {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
approximateFraction,
|
|
|
|
DEFAULT_SCALE,
|
2022-05-23 01:00:57 +09:00
|
|
|
docStyle,
|
2022-02-19 00:38:25 +09:00
|
|
|
OutputScale,
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
RendererType,
|
2021-12-15 21:54:29 +09:00
|
|
|
RenderingStates,
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
roundToDivide,
|
|
|
|
TextLayerMode,
|
2020-01-02 20:00:16 +09:00
|
|
|
} from "./ui_utils.js";
|
2021-07-27 19:23:33 +09:00
|
|
|
import { compatibilityParams } from "./app_options.js";
|
2021-02-22 20:43:16 +09:00
|
|
|
import { NullL10n } from "./l10n_utils.js";
|
2016-04-09 02:34:27 +09:00
|
|
|
|
2014-09-21 02:21:49 +09:00
|
|
|
/**
|
2014-09-28 03:03:28 +09:00
|
|
|
* @typedef {Object} PDFPageViewOptions
|
2021-10-28 18:57:27 +09:00
|
|
|
* @property {HTMLDivElement} [container] - The viewer element.
|
2016-04-26 07:57:15 +09:00
|
|
|
* @property {EventBus} eventBus - The application event bus.
|
2014-09-28 03:03:28 +09:00
|
|
|
* @property {number} id - The page unique ID (normally its number).
|
|
|
|
* @property {number} scale - The page scale display.
|
|
|
|
* @property {PageViewport} defaultViewport - The page viewport.
|
[api-minor] Add support for toggling of Optional Content in the viewer (issue 12096)
*Besides, obviously, adding viewer support:* This patch attempts to improve the general API for Optional Content Groups slightly, by adding a couple of new methods for interacting with the (more complex) data structures of `OptionalContentConfig`-instances. (Thus allowing us to mark some of the data as "private", given that it probably shouldn't be manipulated directly.)
By utilizing not just the "raw" Optional Content Groups, but the data from the `/Order` array when available, we can thus display the Layers in a proper tree-structure with collapsible headings for PDF documents that utilizes that feature.
Note that it's possible to reset all Optional Content Groups to their default visibility state, simply by double-clicking on the Layers-button in the sidebar.
(Currently that's indicated in the Layers-button tooltip, which is obviously easy to overlook, however it's probably the best we can do for now without adding more buttons, or even a dropdown-toolbar, to the sidebar.)
Also, the current Layers-button icons are a little rough around the edges, quite literally, but given that the viewer will soon have its UI modernized anyway they hopefully suffice in the meantime.
To give users *full* control of the visibility of the various Optional Content Groups, even those which according to the `/Order` array should not (by default) be toggleable in the UI, this patch will place those under a *custom* heading which:
- Is collapsed by default, and placed at the bottom of the Layers-tree, to be a bit less obtrusive.
- Uses a slightly different formatting, compared to the "regular" headings.
- Is localizable.
Finally, note that the thumbnails are *purposely* always rendered with all Optional Content Groups at their default visibility state, since that seems the most useful and it's also consistent with other viewers.
To ensure that this works as intended, we'll thus disable the `PDFThumbnailView.setImage` functionality when the Optional Content Groups have been changed in the viewer. (This obviously means that we'll re-render thumbnails instead of using the rendered pages. However, this situation ought to be rare enough for this to not really be a problem.)
2020-08-07 04:01:03 +09:00
|
|
|
* @property {Promise<OptionalContentConfig>} [optionalContentConfigPromise] -
|
|
|
|
* A promise that is resolved with an {@link OptionalContentConfig} instance.
|
|
|
|
* The default value is `null`.
|
2014-09-28 03:03:28 +09:00
|
|
|
* @property {PDFRenderingQueue} renderingQueue - The rendering queue object.
|
2014-09-28 23:35:33 +09:00
|
|
|
* @property {IPDFTextLayerFactory} textLayerFactory
|
2019-10-12 23:30:32 +09:00
|
|
|
* @property {number} [textLayerMode] - Controls if the text layer used for
|
|
|
|
* selection and searching is created, and if the improved text selection
|
2018-02-13 23:01:55 +09:00
|
|
|
* behaviour is enabled. The constants from {TextLayerMode} should be used.
|
|
|
|
* The default value is `TextLayerMode.ENABLE`.
|
[api-minor] Introduce a new `annotationMode`-option, in `PDFPageProxy.{render, getOperatorList}`
*This is a follow-up to PRs 13867 and 13899.*
This patch is tagged `api-minor` for the following reasons:
- It replaces the `renderInteractiveForms`/`includeAnnotationStorage`-options, in the `PDFPageProxy.render`-method, with the single `annotationMode`-option that controls which annotations are being rendered and how. Note that the old options were mutually exclusive, and setting both to `true` would result in undefined behaviour.
- For improved consistency in the API, the `annotationMode`-option will also work together with the `PDFPageProxy.getOperatorList`-method.
- It's now also possible to disable *all* annotation rendering in both the API and the Viewer, since the other changes meant that this could now be supported with a single added line on the worker-thread[1]; fixes 7282.
---
[1] Please note that in order to simplify the overall implementation, we'll purposely only support disabling of *all* annotations and that the option is being shared between the API and the Viewer. For any more "specialized" use-cases, where e.g. only some annotation-types are being rendered and/or the API and Viewer render different sets of annotations, that'll have to be handled in third-party implementations/forks of the PDF.js code-base.
2021-08-08 21:36:28 +09:00
|
|
|
* @property {number} [annotationMode] - Controls if the annotation layer is
|
|
|
|
* created, and if interactive form elements or `AnnotationStorage`-data are
|
|
|
|
* being rendered. The constants from {@link AnnotationMode} should be used;
|
|
|
|
* see also {@link RenderParameters} and {@link GetOperatorListParameters}.
|
|
|
|
* The default value is `AnnotationMode.ENABLE_FORMS`.
|
2015-12-17 20:54:53 +09:00
|
|
|
* @property {IPDFAnnotationLayerFactory} annotationLayerFactory
|
2022-06-01 17:38:08 +09:00
|
|
|
* @property {IPDFAnnotationEditorLayerFactory} annotationEditorLayerFactory
|
2021-03-19 18:11:40 +09:00
|
|
|
* @property {IPDFXfaLayerFactory} xfaLayerFactory
|
2021-04-01 07:07:02 +09:00
|
|
|
* @property {IPDFStructTreeLayerFactory} structTreeLayerFactory
|
Export the XFA/StructTree-layers in the viewer components
While e.g. the `simpleviewer` and `singlepageviewer` examples work, since they're based on the `BaseViewer`-class, the standalone `pageviewer` example currently doesn't support either XFA- or StructTree-layers. This seems like an obvious oversight, which can be easily addressed simply by exporting the necessary functionality through `pdf_viewer.component.js`, similar to the existing Text/Annotation-layers.
While working on, and testing, these changes I happened to notice a number of smaller things that's also fixed in this patch:
- Ensure that `XfaLayerBuilder.render` always have a *consistent* return type, to prevent possible run-time failures in `PDFPageView`; PR 13908 follow-up.
- Change the order of the options in the `XfaLayerBuilder`-constructor to agree with the parameter order in the `DefaultXfaLayerFactory.createXfaLayerBuilder`-method.
- Add a missing `textHighlighterFactory`-option, in the JSDocs for the `PDFPageView`-class.
- A couple of small tweaks in the `TextLayerBuilder.render`-method: Re-use an existing Array rather than creating a new one, and replace an `if` with optional chaining instead.
*Please note:* For now XFA-support is currently disabled by default, similar to the regular viewer.
2021-08-29 01:09:39 +09:00
|
|
|
* @property {Object} [textHighlighterFactory]
|
2019-10-12 23:30:32 +09:00
|
|
|
* @property {string} [imageResourcesPath] - Path for image resources, mainly
|
|
|
|
* for annotation icons. Include trailing slash.
|
2016-11-19 04:03:49 +09:00
|
|
|
* @property {string} renderer - 'canvas' or 'svg'. The default is 'canvas'.
|
2019-10-12 23:30:32 +09:00
|
|
|
* @property {boolean} [useOnlyCssZoom] - Enables CSS only zooming. The default
|
|
|
|
* value is `false`.
|
|
|
|
* @property {number} [maxCanvasPixels] - The maximum supported canvas size in
|
|
|
|
* total pixels, i.e. width * height. Use -1 for no limit. The default value
|
|
|
|
* is 4096 * 4096 (16 mega-pixels).
|
2022-05-04 22:37:13 +09:00
|
|
|
* @property {Object} [pageColors] - Overwrites background and foreground colors
|
|
|
|
* with user defined ones in order to improve readability in high contrast
|
|
|
|
* mode.
|
2017-05-04 10:05:53 +09:00
|
|
|
* @property {IL10n} l10n - Localization service.
|
2014-09-28 03:03:28 +09:00
|
|
|
*/
|
|
|
|
|
2021-07-27 19:23:33 +09:00
|
|
|
const MAX_CANVAS_PIXELS = compatibilityParams.maxCanvasPixels || 16777216;
|
2018-02-13 21:02:15 +09:00
|
|
|
|
2014-09-28 03:03:28 +09:00
|
|
|
/**
|
2014-09-21 02:21:49 +09:00
|
|
|
* @implements {IRenderableView}
|
|
|
|
*/
|
2017-05-29 05:44:00 +09:00
|
|
|
class PDFPageView {
|
2021-12-12 00:53:59 +09:00
|
|
|
#annotationMode = AnnotationMode.ENABLE_FORMS;
|
|
|
|
|
2014-09-28 03:03:28 +09:00
|
|
|
/**
|
|
|
|
* @param {PDFPageViewOptions} options
|
|
|
|
*/
|
2017-05-29 05:44:00 +09:00
|
|
|
constructor(options) {
|
2019-12-27 08:22:32 +09:00
|
|
|
const container = options.container;
|
|
|
|
const defaultViewport = options.defaultViewport;
|
2017-05-29 05:44:00 +09:00
|
|
|
|
|
|
|
this.id = options.id;
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
this.renderingId = "page" + this.id;
|
2014-09-28 03:03:28 +09:00
|
|
|
|
2017-08-04 07:24:19 +09:00
|
|
|
this.pdfPage = null;
|
2017-05-29 05:44:00 +09:00
|
|
|
this.pageLabel = null;
|
2014-09-28 03:03:28 +09:00
|
|
|
this.rotation = 0;
|
2017-05-29 05:44:00 +09:00
|
|
|
this.scale = options.scale || DEFAULT_SCALE;
|
2014-09-28 03:03:28 +09:00
|
|
|
this.viewport = defaultViewport;
|
|
|
|
this.pdfPageRotate = defaultViewport.rotation;
|
[api-minor] Add support for toggling of Optional Content in the viewer (issue 12096)
*Besides, obviously, adding viewer support:* This patch attempts to improve the general API for Optional Content Groups slightly, by adding a couple of new methods for interacting with the (more complex) data structures of `OptionalContentConfig`-instances. (Thus allowing us to mark some of the data as "private", given that it probably shouldn't be manipulated directly.)
By utilizing not just the "raw" Optional Content Groups, but the data from the `/Order` array when available, we can thus display the Layers in a proper tree-structure with collapsible headings for PDF documents that utilizes that feature.
Note that it's possible to reset all Optional Content Groups to their default visibility state, simply by double-clicking on the Layers-button in the sidebar.
(Currently that's indicated in the Layers-button tooltip, which is obviously easy to overlook, however it's probably the best we can do for now without adding more buttons, or even a dropdown-toolbar, to the sidebar.)
Also, the current Layers-button icons are a little rough around the edges, quite literally, but given that the viewer will soon have its UI modernized anyway they hopefully suffice in the meantime.
To give users *full* control of the visibility of the various Optional Content Groups, even those which according to the `/Order` array should not (by default) be toggleable in the UI, this patch will place those under a *custom* heading which:
- Is collapsed by default, and placed at the bottom of the Layers-tree, to be a bit less obtrusive.
- Uses a slightly different formatting, compared to the "regular" headings.
- Is localizable.
Finally, note that the thumbnails are *purposely* always rendered with all Optional Content Groups at their default visibility state, since that seems the most useful and it's also consistent with other viewers.
To ensure that this works as intended, we'll thus disable the `PDFThumbnailView.setImage` functionality when the Optional Content Groups have been changed in the viewer. (This obviously means that we'll re-render thumbnails instead of using the rendered pages. However, this situation ought to be rare enough for this to not really be a problem.)
2020-08-07 04:01:03 +09:00
|
|
|
this._optionalContentConfigPromise =
|
|
|
|
options.optionalContentConfigPromise || null;
|
2014-09-28 03:03:28 +09:00
|
|
|
this.hasRestrictedScaling = false;
|
[api-minor] Introduce a new `annotationMode`-option, in `PDFPageProxy.{render, getOperatorList}`
*This is a follow-up to PRs 13867 and 13899.*
This patch is tagged `api-minor` for the following reasons:
- It replaces the `renderInteractiveForms`/`includeAnnotationStorage`-options, in the `PDFPageProxy.render`-method, with the single `annotationMode`-option that controls which annotations are being rendered and how. Note that the old options were mutually exclusive, and setting both to `true` would result in undefined behaviour.
- For improved consistency in the API, the `annotationMode`-option will also work together with the `PDFPageProxy.getOperatorList`-method.
- It's now also possible to disable *all* annotation rendering in both the API and the Viewer, since the other changes meant that this could now be supported with a single added line on the worker-thread[1]; fixes 7282.
---
[1] Please note that in order to simplify the overall implementation, we'll purposely only support disabling of *all* annotations and that the option is being shared between the API and the Viewer. For any more "specialized" use-cases, where e.g. only some annotation-types are being rendered and/or the API and Viewer render different sets of annotations, that'll have to be handled in third-party implementations/forks of the PDF.js code-base.
2021-08-08 21:36:28 +09:00
|
|
|
this.textLayerMode = options.textLayerMode ?? TextLayerMode.ENABLE;
|
2021-12-12 00:53:59 +09:00
|
|
|
this.#annotationMode =
|
[api-minor] Introduce a new `annotationMode`-option, in `PDFPageProxy.{render, getOperatorList}`
*This is a follow-up to PRs 13867 and 13899.*
This patch is tagged `api-minor` for the following reasons:
- It replaces the `renderInteractiveForms`/`includeAnnotationStorage`-options, in the `PDFPageProxy.render`-method, with the single `annotationMode`-option that controls which annotations are being rendered and how. Note that the old options were mutually exclusive, and setting both to `true` would result in undefined behaviour.
- For improved consistency in the API, the `annotationMode`-option will also work together with the `PDFPageProxy.getOperatorList`-method.
- It's now also possible to disable *all* annotation rendering in both the API and the Viewer, since the other changes meant that this could now be supported with a single added line on the worker-thread[1]; fixes 7282.
---
[1] Please note that in order to simplify the overall implementation, we'll purposely only support disabling of *all* annotations and that the option is being shared between the API and the Viewer. For any more "specialized" use-cases, where e.g. only some annotation-types are being rendered and/or the API and Viewer render different sets of annotations, that'll have to be handled in third-party implementations/forks of the PDF.js code-base.
2021-08-08 21:36:28 +09:00
|
|
|
options.annotationMode ?? AnnotationMode.ENABLE_FORMS;
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
this.imageResourcesPath = options.imageResourcesPath || "";
|
2018-02-13 20:52:42 +09:00
|
|
|
this.useOnlyCssZoom = options.useOnlyCssZoom || false;
|
2018-02-13 21:02:15 +09:00
|
|
|
this.maxCanvasPixels = options.maxCanvasPixels || MAX_CANVAS_PIXELS;
|
2022-05-04 22:37:13 +09:00
|
|
|
this.pageColors = options.pageColors || null;
|
2014-09-28 03:03:28 +09:00
|
|
|
|
2020-02-27 23:02:03 +09:00
|
|
|
this.eventBus = options.eventBus;
|
2017-05-29 05:44:00 +09:00
|
|
|
this.renderingQueue = options.renderingQueue;
|
|
|
|
this.textLayerFactory = options.textLayerFactory;
|
|
|
|
this.annotationLayerFactory = options.annotationLayerFactory;
|
2022-06-01 17:38:08 +09:00
|
|
|
this.annotationEditorLayerFactory = options.annotationEditorLayerFactory;
|
2021-03-19 18:11:40 +09:00
|
|
|
this.xfaLayerFactory = options.xfaLayerFactory;
|
2021-08-19 09:02:29 +09:00
|
|
|
this.textHighlighter =
|
|
|
|
options.textHighlighterFactory?.createTextHighlighter(
|
|
|
|
this.id - 1,
|
|
|
|
this.eventBus
|
|
|
|
);
|
2021-04-01 07:07:02 +09:00
|
|
|
this.structTreeLayerFactory = options.structTreeLayerFactory;
|
2016-11-19 04:03:49 +09:00
|
|
|
this.renderer = options.renderer || RendererType.CANVAS;
|
2017-05-04 10:05:53 +09:00
|
|
|
this.l10n = options.l10n || NullL10n;
|
2014-09-28 03:03:28 +09:00
|
|
|
|
2016-10-19 23:16:57 +09:00
|
|
|
this.paintTask = null;
|
Ensure that we use the *correct* `paintedViewport` in `PDFPageView.cssTransform`, to avoid visual glitches on quick rotations (PR 7738 follow-up)
*This fixes a regression from commit https://github.com/mozilla/pdf.js/pull/7738/commits/c9a0955c9c7ed857c98696732c6edeb6f4901f43, i.e. PR 7738.*
Currently if you quickly rotate a document at least *twice*,[1] such that rendering of a page hasn't finished for the first rotation before the last rotation is triggered, the `cssTransform` method can fail to update the page correctly leading to it looking temporarily distorted.
The reason why things break is that previously we stored the `viewport` on the canvas DOM element, meaning that when it was accessed in `cssTransform` is was guaranteed to point to the `viewport` of the `zoomLayer` canvas.
Generally you want to avoid storing data on DOM elements this way, and during the `PDFPageView` refactoring needed to support SVG rendering, the previous `viewport` was instead stored directly on `PDFPageView`.
However, the problem is first of all that the `paintedViewport` only stores the *last* `viewport` computed, and second of all that there're no guarantees that it actually applies to the current `zoomLayer` canvas.
If a document is rotated slowly enough that rendering finishes *before* the next rotation then this problem doesn't exist, but for sufficiently quick rotations rendering will be cancelled at least once and the `paintedViewport` could thus be bogus.
The solution for the above problems is to ensure that we track the correct `viewport` for each DOM element (canvas or svg),[2] which seemed easist to do with a `WeakMap`.[3]
---
[1] I'm able to reproduce this using the `tracemonkey` file, but please note that for pages with few operations, i.e. that render very quickly, the effect may be hard to spot.
[2] One other possible solution that I briefly considered, was to wait until rendering finished before storing the current `viewport`. However, that would have caused issues with rotating a page before the *first* rendering operation had finished.
[3] This regression took me way longer to both figure out, and fix, than I'd like to admit :-)
2017-01-21 20:27:57 +09:00
|
|
|
this.paintedViewportMap = new WeakMap();
|
2014-09-28 03:03:28 +09:00
|
|
|
this.renderingState = RenderingStates.INITIAL;
|
|
|
|
this.resume = null;
|
2020-09-23 21:29:21 +09:00
|
|
|
this._renderError = null;
|
2021-08-05 18:32:45 +09:00
|
|
|
this._isStandalone = !this.renderingQueue?.hasViewer();
|
2014-09-28 03:03:28 +09:00
|
|
|
|
2021-11-07 02:36:49 +09:00
|
|
|
this._annotationCanvasMap = null;
|
|
|
|
|
2017-05-29 05:44:00 +09:00
|
|
|
this.annotationLayer = null;
|
2022-06-01 17:38:08 +09:00
|
|
|
this.annotationEditorLayer = null;
|
2014-09-28 03:03:28 +09:00
|
|
|
this.textLayer = null;
|
2013-10-03 01:05:46 +09:00
|
|
|
this.zoomLayer = null;
|
2021-03-19 18:11:40 +09:00
|
|
|
this.xfaLayer = null;
|
2021-04-01 07:07:02 +09:00
|
|
|
this.structTreeLayer = null;
|
2013-09-20 16:25:41 +09:00
|
|
|
|
2019-12-27 08:22:32 +09:00
|
|
|
const div = document.createElement("div");
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
div.className = "page";
|
|
|
|
div.style.width = Math.floor(this.viewport.width) + "px";
|
|
|
|
div.style.height = Math.floor(this.viewport.height) + "px";
|
|
|
|
div.setAttribute("data-page-number", this.id);
|
2021-03-19 08:10:54 +09:00
|
|
|
div.setAttribute("role", "region");
|
|
|
|
this.l10n.get("page_landmark", { page: this.id }).then(msg => {
|
|
|
|
div.setAttribute("aria-label", msg);
|
|
|
|
});
|
2014-09-28 03:03:28 +09:00
|
|
|
this.div = div;
|
|
|
|
|
2022-06-12 19:20:25 +09:00
|
|
|
container?.append(div);
|
2014-09-28 03:03:28 +09:00
|
|
|
}
|
|
|
|
|
2017-05-29 05:44:00 +09:00
|
|
|
setPdfPage(pdfPage) {
|
|
|
|
this.pdfPage = pdfPage;
|
|
|
|
this.pdfPageRotate = pdfPage.rotate;
|
2013-09-20 16:25:41 +09:00
|
|
|
|
2019-12-27 08:22:32 +09:00
|
|
|
const totalRotation = (this.rotation + this.pdfPageRotate) % 360;
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
this.viewport = pdfPage.getViewport({
|
2021-09-20 17:10:57 +09:00
|
|
|
scale: this.scale * PixelsPerInch.PDF_TO_CSS_UNITS,
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
rotation: totalRotation,
|
|
|
|
});
|
2017-05-29 05:44:00 +09:00
|
|
|
this.reset();
|
|
|
|
}
|
2014-09-28 03:03:28 +09:00
|
|
|
|
2017-05-29 05:44:00 +09:00
|
|
|
destroy() {
|
|
|
|
this.reset();
|
|
|
|
if (this.pdfPage) {
|
|
|
|
this.pdfPage.cleanup();
|
|
|
|
}
|
|
|
|
}
|
2013-09-20 16:25:41 +09:00
|
|
|
|
2020-08-18 05:19:03 +09:00
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
async _renderAnnotationLayer() {
|
|
|
|
let error = null;
|
|
|
|
try {
|
|
|
|
await this.annotationLayer.render(this.viewport, "display");
|
|
|
|
} catch (ex) {
|
|
|
|
error = ex;
|
|
|
|
} finally {
|
|
|
|
this.eventBus.dispatch("annotationlayerrendered", {
|
|
|
|
source: this,
|
|
|
|
pageNumber: this.id,
|
|
|
|
error,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-06-01 17:38:08 +09:00
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
async _renderAnnotationEditorLayer() {
|
|
|
|
let error = null;
|
|
|
|
try {
|
|
|
|
await this.annotationEditorLayer.render(this.viewport, "display");
|
|
|
|
} catch (ex) {
|
|
|
|
error = ex;
|
|
|
|
} finally {
|
|
|
|
this.eventBus.dispatch("annotationeditorlayerrendered", {
|
|
|
|
source: this,
|
|
|
|
pageNumber: this.id,
|
|
|
|
error,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-03-19 18:11:40 +09:00
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
async _renderXfaLayer() {
|
|
|
|
let error = null;
|
|
|
|
try {
|
2021-08-19 09:02:29 +09:00
|
|
|
const result = await this.xfaLayer.render(this.viewport, "display");
|
|
|
|
if (this.textHighlighter) {
|
|
|
|
this._buildXfaTextContentItems(result.textDivs);
|
|
|
|
}
|
2021-03-19 18:11:40 +09:00
|
|
|
} catch (ex) {
|
|
|
|
error = ex;
|
|
|
|
} finally {
|
|
|
|
this.eventBus.dispatch("xfalayerrendered", {
|
|
|
|
source: this,
|
|
|
|
pageNumber: this.id,
|
|
|
|
error,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-08-19 09:02:29 +09:00
|
|
|
async _buildXfaTextContentItems(textDivs) {
|
|
|
|
const text = await this.pdfPage.getTextContent();
|
|
|
|
const items = [];
|
|
|
|
for (const item of text.items) {
|
|
|
|
items.push(item.str);
|
|
|
|
}
|
|
|
|
this.textHighlighter.setTextMapping(textDivs, items);
|
|
|
|
this.textHighlighter.enable();
|
|
|
|
}
|
|
|
|
|
2017-05-29 05:44:00 +09:00
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
_resetZoomLayer(removeFromDOM = false) {
|
|
|
|
if (!this.zoomLayer) {
|
|
|
|
return;
|
|
|
|
}
|
2019-12-27 08:22:32 +09:00
|
|
|
const zoomLayerCanvas = this.zoomLayer.firstChild;
|
2017-05-29 05:44:00 +09:00
|
|
|
this.paintedViewportMap.delete(zoomLayerCanvas);
|
|
|
|
// Zeroing the width and height causes Firefox to release graphics
|
|
|
|
// resources immediately, which can greatly reduce memory consumption.
|
|
|
|
zoomLayerCanvas.width = 0;
|
|
|
|
zoomLayerCanvas.height = 0;
|
|
|
|
|
|
|
|
if (removeFromDOM) {
|
|
|
|
// Note: `ChildNode.remove` doesn't throw if the parent node is undefined.
|
|
|
|
this.zoomLayer.remove();
|
|
|
|
}
|
|
|
|
this.zoomLayer = null;
|
|
|
|
}
|
2013-10-03 01:05:46 +09:00
|
|
|
|
2021-07-23 18:37:38 +09:00
|
|
|
reset({
|
|
|
|
keepZoomLayer = false,
|
|
|
|
keepAnnotationLayer = false,
|
2022-06-01 17:38:08 +09:00
|
|
|
keepAnnotationEditorLayer = false,
|
2021-07-23 18:37:38 +09:00
|
|
|
keepXfaLayer = false,
|
|
|
|
} = {}) {
|
2022-06-01 17:38:08 +09:00
|
|
|
this.cancelRendering({
|
|
|
|
keepAnnotationLayer,
|
|
|
|
keepAnnotationEditorLayer,
|
|
|
|
keepXfaLayer,
|
|
|
|
});
|
2019-02-15 02:47:32 +09:00
|
|
|
this.renderingState = RenderingStates.INITIAL;
|
2013-10-03 01:05:46 +09:00
|
|
|
|
2019-12-27 08:22:32 +09:00
|
|
|
const div = this.div;
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
div.style.width = Math.floor(this.viewport.width) + "px";
|
|
|
|
div.style.height = Math.floor(this.viewport.height) + "px";
|
2013-10-03 01:05:46 +09:00
|
|
|
|
2021-07-23 18:37:38 +09:00
|
|
|
const childNodes = div.childNodes,
|
|
|
|
zoomLayerNode = (keepZoomLayer && this.zoomLayer) || null,
|
|
|
|
annotationLayerNode =
|
|
|
|
(keepAnnotationLayer && this.annotationLayer?.div) || null,
|
2022-06-01 17:38:08 +09:00
|
|
|
annotationEditorLayerNode =
|
|
|
|
(keepAnnotationEditorLayer && this.annotationEditorLayer?.div) || null,
|
2021-07-23 18:37:38 +09:00
|
|
|
xfaLayerNode = (keepXfaLayer && this.xfaLayer?.div) || null;
|
2017-05-29 05:44:00 +09:00
|
|
|
for (let i = childNodes.length - 1; i >= 0; i--) {
|
2019-12-27 08:22:32 +09:00
|
|
|
const node = childNodes[i];
|
2021-07-23 18:37:38 +09:00
|
|
|
switch (node) {
|
|
|
|
case zoomLayerNode:
|
|
|
|
case annotationLayerNode:
|
2022-06-01 17:38:08 +09:00
|
|
|
case annotationEditorLayerNode:
|
2021-07-23 18:37:38 +09:00
|
|
|
case xfaLayerNode:
|
|
|
|
continue;
|
2017-05-29 05:44:00 +09:00
|
|
|
}
|
2021-11-16 20:36:22 +09:00
|
|
|
node.remove();
|
2017-05-29 05:44:00 +09:00
|
|
|
}
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
div.removeAttribute("data-loaded");
|
2017-05-29 05:44:00 +09:00
|
|
|
|
2021-07-23 18:37:38 +09:00
|
|
|
if (annotationLayerNode) {
|
2017-05-29 05:44:00 +09:00
|
|
|
// Hide the annotation layer until all elements are resized
|
|
|
|
// so they are not displayed on the already resized page.
|
|
|
|
this.annotationLayer.hide();
|
|
|
|
}
|
2022-06-01 17:38:08 +09:00
|
|
|
|
|
|
|
if (annotationEditorLayerNode) {
|
|
|
|
this.annotationEditorLayer.hide();
|
|
|
|
} else {
|
|
|
|
this.annotationEditorLayer?.destroy();
|
|
|
|
}
|
2021-07-23 18:37:38 +09:00
|
|
|
if (xfaLayerNode) {
|
|
|
|
// Hide the XFA layer until all elements are resized
|
|
|
|
// so they are not displayed on the already resized page.
|
|
|
|
this.xfaLayer.hide();
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!zoomLayerNode) {
|
2017-05-29 05:44:00 +09:00
|
|
|
if (this.canvas) {
|
|
|
|
this.paintedViewportMap.delete(this.canvas);
|
|
|
|
// Zeroing the width and height causes Firefox to release graphics
|
|
|
|
// resources immediately, which can greatly reduce memory consumption.
|
|
|
|
this.canvas.width = 0;
|
|
|
|
this.canvas.height = 0;
|
|
|
|
delete this.canvas;
|
2014-05-24 10:43:43 +09:00
|
|
|
}
|
2017-05-29 05:44:00 +09:00
|
|
|
this._resetZoomLayer();
|
|
|
|
}
|
|
|
|
if (this.svg) {
|
|
|
|
this.paintedViewportMap.delete(this.svg);
|
|
|
|
delete this.svg;
|
|
|
|
}
|
|
|
|
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
this.loadingIconDiv = document.createElement("div");
|
2021-11-14 20:20:04 +09:00
|
|
|
this.loadingIconDiv.className = "loadingIcon notVisible";
|
|
|
|
if (this._isStandalone) {
|
|
|
|
this.toggleLoadingIconSpinner(/* viewVisible = */ true);
|
|
|
|
}
|
2021-03-19 08:10:54 +09:00
|
|
|
this.loadingIconDiv.setAttribute("role", "img");
|
|
|
|
this.l10n.get("loading").then(msg => {
|
|
|
|
this.loadingIconDiv?.setAttribute("aria-label", msg);
|
|
|
|
});
|
2022-06-12 19:20:25 +09:00
|
|
|
div.append(this.loadingIconDiv);
|
2017-05-29 05:44:00 +09:00
|
|
|
}
|
2013-10-03 01:05:46 +09:00
|
|
|
|
2021-09-01 00:08:43 +09:00
|
|
|
update({ scale = 0, rotation = null, optionalContentConfigPromise = null }) {
|
2017-05-29 05:44:00 +09:00
|
|
|
this.scale = scale || this.scale;
|
2021-09-01 00:08:43 +09:00
|
|
|
if (typeof rotation === "number") {
|
|
|
|
this.rotation = rotation; // The rotation may be zero.
|
2017-05-29 05:44:00 +09:00
|
|
|
}
|
[api-minor] Add support for toggling of Optional Content in the viewer (issue 12096)
*Besides, obviously, adding viewer support:* This patch attempts to improve the general API for Optional Content Groups slightly, by adding a couple of new methods for interacting with the (more complex) data structures of `OptionalContentConfig`-instances. (Thus allowing us to mark some of the data as "private", given that it probably shouldn't be manipulated directly.)
By utilizing not just the "raw" Optional Content Groups, but the data from the `/Order` array when available, we can thus display the Layers in a proper tree-structure with collapsible headings for PDF documents that utilizes that feature.
Note that it's possible to reset all Optional Content Groups to their default visibility state, simply by double-clicking on the Layers-button in the sidebar.
(Currently that's indicated in the Layers-button tooltip, which is obviously easy to overlook, however it's probably the best we can do for now without adding more buttons, or even a dropdown-toolbar, to the sidebar.)
Also, the current Layers-button icons are a little rough around the edges, quite literally, but given that the viewer will soon have its UI modernized anyway they hopefully suffice in the meantime.
To give users *full* control of the visibility of the various Optional Content Groups, even those which according to the `/Order` array should not (by default) be toggleable in the UI, this patch will place those under a *custom* heading which:
- Is collapsed by default, and placed at the bottom of the Layers-tree, to be a bit less obtrusive.
- Uses a slightly different formatting, compared to the "regular" headings.
- Is localizable.
Finally, note that the thumbnails are *purposely* always rendered with all Optional Content Groups at their default visibility state, since that seems the most useful and it's also consistent with other viewers.
To ensure that this works as intended, we'll thus disable the `PDFThumbnailView.setImage` functionality when the Optional Content Groups have been changed in the viewer. (This obviously means that we'll re-render thumbnails instead of using the rendered pages. However, this situation ought to be rare enough for this to not really be a problem.)
2020-08-07 04:01:03 +09:00
|
|
|
if (optionalContentConfigPromise instanceof Promise) {
|
|
|
|
this._optionalContentConfigPromise = optionalContentConfigPromise;
|
|
|
|
}
|
2017-05-29 05:44:00 +09:00
|
|
|
|
2019-12-27 08:22:32 +09:00
|
|
|
const totalRotation = (this.rotation + this.pdfPageRotate) % 360;
|
2017-05-29 05:44:00 +09:00
|
|
|
this.viewport = this.viewport.clone({
|
2022-04-14 19:43:44 +09:00
|
|
|
scale: this.scale * PixelsPerInch.PDF_TO_CSS_UNITS,
|
2017-05-29 05:44:00 +09:00
|
|
|
rotation: totalRotation,
|
|
|
|
});
|
|
|
|
|
2021-11-07 02:36:49 +09:00
|
|
|
if (this._isStandalone) {
|
2022-06-13 18:01:55 +09:00
|
|
|
docStyle.setProperty("--scale-factor", this.viewport.scale);
|
2021-11-07 02:36:49 +09:00
|
|
|
}
|
|
|
|
|
2017-05-29 05:44:00 +09:00
|
|
|
if (this.svg) {
|
2021-07-23 18:37:38 +09:00
|
|
|
this.cssTransform({
|
|
|
|
target: this.svg,
|
|
|
|
redrawAnnotationLayer: true,
|
2022-06-01 17:38:08 +09:00
|
|
|
redrawAnnotationEditorLayer: true,
|
2021-07-23 18:37:38 +09:00
|
|
|
redrawXfaLayer: true,
|
|
|
|
});
|
2017-05-29 05:44:00 +09:00
|
|
|
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
this.eventBus.dispatch("pagerendered", {
|
2017-05-29 05:44:00 +09:00
|
|
|
source: this,
|
|
|
|
pageNumber: this.id,
|
|
|
|
cssTransform: true,
|
2019-07-13 06:08:23 +09:00
|
|
|
timestamp: performance.now(),
|
2020-09-23 21:29:21 +09:00
|
|
|
error: this._renderError,
|
2014-09-28 03:03:28 +09:00
|
|
|
});
|
2017-05-29 05:44:00 +09:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
let isScalingRestricted = false;
|
2018-02-13 21:02:15 +09:00
|
|
|
if (this.canvas && this.maxCanvasPixels > 0) {
|
2019-12-27 08:22:32 +09:00
|
|
|
const outputScale = this.outputScale;
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
if (
|
|
|
|
((Math.floor(this.viewport.width) * outputScale.sx) | 0) *
|
2017-05-29 05:44:00 +09:00
|
|
|
((Math.floor(this.viewport.height) * outputScale.sy) | 0) >
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
this.maxCanvasPixels
|
|
|
|
) {
|
2017-05-29 05:44:00 +09:00
|
|
|
isScalingRestricted = true;
|
|
|
|
}
|
|
|
|
}
|
2014-09-28 03:03:28 +09:00
|
|
|
|
2017-05-29 05:44:00 +09:00
|
|
|
if (this.canvas) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
if (
|
|
|
|
this.useOnlyCssZoom ||
|
|
|
|
(this.hasRestrictedScaling && isScalingRestricted)
|
|
|
|
) {
|
2021-07-23 18:37:38 +09:00
|
|
|
this.cssTransform({
|
|
|
|
target: this.canvas,
|
|
|
|
redrawAnnotationLayer: true,
|
2022-06-01 17:38:08 +09:00
|
|
|
redrawAnnotationEditorLayer: true,
|
2021-07-23 18:37:38 +09:00
|
|
|
redrawXfaLayer: true,
|
|
|
|
});
|
2016-11-19 04:03:49 +09:00
|
|
|
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
this.eventBus.dispatch("pagerendered", {
|
2016-11-19 04:03:49 +09:00
|
|
|
source: this,
|
|
|
|
pageNumber: this.id,
|
|
|
|
cssTransform: true,
|
2019-07-13 06:08:23 +09:00
|
|
|
timestamp: performance.now(),
|
2020-09-23 21:29:21 +09:00
|
|
|
error: this._renderError,
|
2016-11-19 04:03:49 +09:00
|
|
|
});
|
|
|
|
return;
|
|
|
|
}
|
2021-02-08 08:21:49 +09:00
|
|
|
if (!this.zoomLayer && !this.canvas.hidden) {
|
2017-05-29 05:44:00 +09:00
|
|
|
this.zoomLayer = this.canvas.parentNode;
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
this.zoomLayer.style.position = "absolute";
|
2014-09-28 03:03:28 +09:00
|
|
|
}
|
2017-05-29 05:44:00 +09:00
|
|
|
}
|
|
|
|
if (this.zoomLayer) {
|
2021-07-23 18:37:38 +09:00
|
|
|
this.cssTransform({ target: this.zoomLayer.firstChild });
|
2017-05-29 05:44:00 +09:00
|
|
|
}
|
2021-07-23 18:37:38 +09:00
|
|
|
this.reset({
|
|
|
|
keepZoomLayer: true,
|
|
|
|
keepAnnotationLayer: true,
|
2022-06-01 17:38:08 +09:00
|
|
|
keepAnnotationEditorLayer: true,
|
2021-07-23 18:37:38 +09:00
|
|
|
keepXfaLayer: true,
|
|
|
|
});
|
2017-05-29 05:44:00 +09:00
|
|
|
}
|
2014-09-28 03:03:28 +09:00
|
|
|
|
2019-02-15 02:47:32 +09:00
|
|
|
/**
|
|
|
|
* PLEASE NOTE: Most likely you want to use the `this.reset()` method,
|
|
|
|
* rather than calling this one directly.
|
|
|
|
*/
|
2022-06-01 17:38:08 +09:00
|
|
|
cancelRendering({
|
|
|
|
keepAnnotationLayer = false,
|
|
|
|
keepAnnotationEditorLayer = false,
|
|
|
|
keepXfaLayer = false,
|
|
|
|
} = {}) {
|
2017-05-29 05:44:00 +09:00
|
|
|
if (this.paintTask) {
|
|
|
|
this.paintTask.cancel();
|
|
|
|
this.paintTask = null;
|
|
|
|
}
|
|
|
|
this.resume = null;
|
2014-09-28 03:03:28 +09:00
|
|
|
|
2017-05-29 05:44:00 +09:00
|
|
|
if (this.textLayer) {
|
|
|
|
this.textLayer.cancel();
|
|
|
|
this.textLayer = null;
|
|
|
|
}
|
2021-07-23 21:14:42 +09:00
|
|
|
if (
|
|
|
|
this.annotationLayer &&
|
|
|
|
(!keepAnnotationLayer || !this.annotationLayer.div)
|
|
|
|
) {
|
Prevent the `annotationLayer` from, in some cases, becoming duplicated on the first page when the document loads
I don't know if this is a regression, but I noticed earlier today that depending on the initial scale *and* sidebar state, the `annotationLayer` of the first rendered page may end up duplicated; please see screen-shot below.
[screen-shot]
I can reproduce this reliable with e.g. https://arxiv.org/pdf/1112.0542v1.pdf#zoom=page-width&pagemode=bookmarks.
When the document loads, rendering of the first page begins immediately. When the sidebar is then opened, that forces re-rendering which thus aborts rendering of the first page.
Note that calling `PDFPageView.draw()` will always, provided an `AnnotationLayerFactory` instance exists, call `AnnotationLayerBuilder.render()`. Hence the events described above will result in *two* such calls, where the actual annotation rendering/updating happens asynchronously.
For reasons that I don't (at all) understand, when multiple `pdfPage.getAnnotations()` promises are handled back-to-back (in `AnnotationLayerBuilder.render()`), the `this.div` property seems to not update in time for the subsequent calls.
This thus, at least in Firefox, result in double rendering of all annotations on the first page.
Obviously it'd be good to find out why it breaks, since it *really* shouldn't, but this patch at least provides a (hopefully) acceptable work-around by ignoring `getAnnotations()` calls for `AnnotationLayerBuilder` instances that we're destroying (in `PDFPageView.reset()`).
2017-10-07 00:26:54 +09:00
|
|
|
this.annotationLayer.cancel();
|
|
|
|
this.annotationLayer = null;
|
2021-11-07 02:36:49 +09:00
|
|
|
this._annotationCanvasMap = null;
|
Prevent the `annotationLayer` from, in some cases, becoming duplicated on the first page when the document loads
I don't know if this is a regression, but I noticed earlier today that depending on the initial scale *and* sidebar state, the `annotationLayer` of the first rendered page may end up duplicated; please see screen-shot below.
[screen-shot]
I can reproduce this reliable with e.g. https://arxiv.org/pdf/1112.0542v1.pdf#zoom=page-width&pagemode=bookmarks.
When the document loads, rendering of the first page begins immediately. When the sidebar is then opened, that forces re-rendering which thus aborts rendering of the first page.
Note that calling `PDFPageView.draw()` will always, provided an `AnnotationLayerFactory` instance exists, call `AnnotationLayerBuilder.render()`. Hence the events described above will result in *two* such calls, where the actual annotation rendering/updating happens asynchronously.
For reasons that I don't (at all) understand, when multiple `pdfPage.getAnnotations()` promises are handled back-to-back (in `AnnotationLayerBuilder.render()`), the `this.div` property seems to not update in time for the subsequent calls.
This thus, at least in Firefox, result in double rendering of all annotations on the first page.
Obviously it'd be good to find out why it breaks, since it *really* shouldn't, but this patch at least provides a (hopefully) acceptable work-around by ignoring `getAnnotations()` calls for `AnnotationLayerBuilder` instances that we're destroying (in `PDFPageView.reset()`).
2017-10-07 00:26:54 +09:00
|
|
|
}
|
2022-06-01 17:38:08 +09:00
|
|
|
if (
|
|
|
|
this.annotationEditorLayer &&
|
|
|
|
(!keepAnnotationEditorLayer || !this.annotationEditorLayer.div)
|
|
|
|
) {
|
|
|
|
this.annotationEditorLayer.cancel();
|
|
|
|
this.annotationEditorLayer = null;
|
|
|
|
}
|
2021-07-23 21:14:42 +09:00
|
|
|
if (this.xfaLayer && (!keepXfaLayer || !this.xfaLayer.div)) {
|
2021-07-23 18:37:38 +09:00
|
|
|
this.xfaLayer.cancel();
|
|
|
|
this.xfaLayer = null;
|
2021-08-19 09:02:29 +09:00
|
|
|
this.textHighlighter?.disable();
|
2021-07-23 18:37:38 +09:00
|
|
|
}
|
2021-04-01 07:07:02 +09:00
|
|
|
if (this._onTextLayerRendered) {
|
|
|
|
this.eventBus._off("textlayerrendered", this._onTextLayerRendered);
|
|
|
|
this._onTextLayerRendered = null;
|
|
|
|
}
|
2017-05-29 05:44:00 +09:00
|
|
|
}
|
2016-07-30 03:51:37 +09:00
|
|
|
|
2021-07-23 18:37:38 +09:00
|
|
|
cssTransform({
|
|
|
|
target,
|
|
|
|
redrawAnnotationLayer = false,
|
2022-06-01 17:38:08 +09:00
|
|
|
redrawAnnotationEditorLayer = false,
|
2021-07-23 18:37:38 +09:00
|
|
|
redrawXfaLayer = false,
|
|
|
|
}) {
|
2017-05-29 05:44:00 +09:00
|
|
|
// Scale target (canvas or svg), its wrapper and page container.
|
2019-12-27 08:22:32 +09:00
|
|
|
const width = this.viewport.width;
|
|
|
|
const height = this.viewport.height;
|
|
|
|
const div = this.div;
|
2021-05-16 17:58:34 +09:00
|
|
|
target.style.width =
|
|
|
|
target.parentNode.style.width =
|
|
|
|
div.style.width =
|
|
|
|
Math.floor(width) + "px";
|
|
|
|
target.style.height =
|
|
|
|
target.parentNode.style.height =
|
|
|
|
div.style.height =
|
|
|
|
Math.floor(height) + "px";
|
2017-05-29 05:44:00 +09:00
|
|
|
// The canvas may have been originally rotated; rotate relative to that.
|
2019-12-27 08:22:32 +09:00
|
|
|
const relativeRotation =
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
this.viewport.rotation - this.paintedViewportMap.get(target).rotation;
|
2019-12-27 08:22:32 +09:00
|
|
|
const absRotation = Math.abs(relativeRotation);
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
let scaleX = 1,
|
|
|
|
scaleY = 1;
|
2017-05-29 05:44:00 +09:00
|
|
|
if (absRotation === 90 || absRotation === 270) {
|
|
|
|
// Scale x and y because of the rotation.
|
|
|
|
scaleX = height / width;
|
|
|
|
scaleY = width / height;
|
|
|
|
}
|
2020-09-24 02:03:20 +09:00
|
|
|
target.style.transform = `rotate(${relativeRotation}deg) scale(${scaleX}, ${scaleY})`;
|
2017-05-29 05:44:00 +09:00
|
|
|
|
|
|
|
if (this.textLayer) {
|
|
|
|
// Rotating the text layer is more complicated since the divs inside the
|
|
|
|
// the text layer are rotated.
|
|
|
|
// TODO: This could probably be simplified by drawing the text layer in
|
|
|
|
// one orientation and then rotating overall.
|
2019-12-27 08:22:32 +09:00
|
|
|
const textLayerViewport = this.textLayer.viewport;
|
|
|
|
const textRelativeRotation =
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
this.viewport.rotation - textLayerViewport.rotation;
|
2019-12-27 08:22:32 +09:00
|
|
|
const textAbsRotation = Math.abs(textRelativeRotation);
|
2017-05-29 05:44:00 +09:00
|
|
|
let scale = width / textLayerViewport.width;
|
|
|
|
if (textAbsRotation === 90 || textAbsRotation === 270) {
|
|
|
|
scale = width / textLayerViewport.height;
|
2014-09-28 03:03:28 +09:00
|
|
|
}
|
2019-12-27 08:22:32 +09:00
|
|
|
const textLayerDiv = this.textLayer.textLayerDiv;
|
2017-05-29 05:44:00 +09:00
|
|
|
let transX, transY;
|
|
|
|
switch (textAbsRotation) {
|
|
|
|
case 0:
|
|
|
|
transX = transY = 0;
|
|
|
|
break;
|
|
|
|
case 90:
|
|
|
|
transX = 0;
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
transY = "-" + textLayerDiv.style.height;
|
2017-05-29 05:44:00 +09:00
|
|
|
break;
|
|
|
|
case 180:
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
transX = "-" + textLayerDiv.style.width;
|
|
|
|
transY = "-" + textLayerDiv.style.height;
|
2017-05-29 05:44:00 +09:00
|
|
|
break;
|
|
|
|
case 270:
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
transX = "-" + textLayerDiv.style.width;
|
2017-05-29 05:44:00 +09:00
|
|
|
transY = 0;
|
|
|
|
break;
|
|
|
|
default:
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
console.error("Bad rotation value.");
|
2017-05-29 05:44:00 +09:00
|
|
|
break;
|
2014-09-28 03:03:28 +09:00
|
|
|
}
|
2017-12-31 21:51:51 +09:00
|
|
|
|
|
|
|
textLayerDiv.style.transform =
|
2020-09-24 02:03:20 +09:00
|
|
|
`rotate(${textAbsRotation}deg) ` +
|
|
|
|
`scale(${scale}) ` +
|
|
|
|
`translate(${transX}, ${transY})`;
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
textLayerDiv.style.transformOrigin = "0% 0%";
|
2017-05-29 05:44:00 +09:00
|
|
|
}
|
|
|
|
|
2021-07-23 18:37:38 +09:00
|
|
|
if (redrawAnnotationLayer && this.annotationLayer) {
|
2020-08-18 05:19:03 +09:00
|
|
|
this._renderAnnotationLayer();
|
2017-05-29 05:44:00 +09:00
|
|
|
}
|
2022-06-01 17:38:08 +09:00
|
|
|
if (redrawAnnotationEditorLayer && this.annotationEditorLayer) {
|
|
|
|
this._renderAnnotationEditorLayer();
|
|
|
|
}
|
2021-07-23 18:37:38 +09:00
|
|
|
if (redrawXfaLayer && this.xfaLayer) {
|
2021-03-19 18:11:40 +09:00
|
|
|
this._renderXfaLayer();
|
|
|
|
}
|
2017-05-29 05:44:00 +09:00
|
|
|
}
|
2014-09-28 03:03:28 +09:00
|
|
|
|
2017-05-29 05:44:00 +09:00
|
|
|
get width() {
|
|
|
|
return this.viewport.width;
|
|
|
|
}
|
|
|
|
|
|
|
|
get height() {
|
|
|
|
return this.viewport.height;
|
|
|
|
}
|
2014-09-28 03:03:28 +09:00
|
|
|
|
2017-05-29 05:44:00 +09:00
|
|
|
getPagePoint(x, y) {
|
|
|
|
return this.viewport.convertToPdfPoint(x, y);
|
|
|
|
}
|
2014-09-28 03:03:28 +09:00
|
|
|
|
2021-11-14 20:20:04 +09:00
|
|
|
/**
|
|
|
|
* @ignore
|
|
|
|
*/
|
|
|
|
toggleLoadingIconSpinner(viewVisible = false) {
|
|
|
|
this.loadingIconDiv?.classList.toggle("notVisible", !viewVisible);
|
|
|
|
}
|
|
|
|
|
2017-05-29 05:44:00 +09:00
|
|
|
draw() {
|
|
|
|
if (this.renderingState !== RenderingStates.INITIAL) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
console.error("Must be in new state before drawing");
|
2017-05-29 05:44:00 +09:00
|
|
|
this.reset(); // Ensure that we reset all state to prevent issues.
|
|
|
|
}
|
2020-02-09 01:43:53 +09:00
|
|
|
const { div, pdfPage } = this;
|
2017-05-29 05:44:00 +09:00
|
|
|
|
2020-02-09 01:43:53 +09:00
|
|
|
if (!pdfPage) {
|
2017-08-04 07:24:19 +09:00
|
|
|
this.renderingState = RenderingStates.FINISHED;
|
2020-02-09 01:43:53 +09:00
|
|
|
|
|
|
|
if (this.loadingIconDiv) {
|
2021-11-16 20:36:22 +09:00
|
|
|
this.loadingIconDiv.remove();
|
2020-02-09 01:43:53 +09:00
|
|
|
delete this.loadingIconDiv;
|
|
|
|
}
|
|
|
|
return Promise.reject(new Error("pdfPage is not loaded"));
|
2017-08-04 07:24:19 +09:00
|
|
|
}
|
|
|
|
|
2017-05-29 05:44:00 +09:00
|
|
|
this.renderingState = RenderingStates.RUNNING;
|
|
|
|
|
|
|
|
// Wrap the canvas so that if it has a CSS transform for high DPI the
|
|
|
|
// overflow will be hidden in Firefox.
|
2019-12-27 08:22:32 +09:00
|
|
|
const canvasWrapper = document.createElement("div");
|
2017-05-29 05:44:00 +09:00
|
|
|
canvasWrapper.style.width = div.style.width;
|
|
|
|
canvasWrapper.style.height = div.style.height;
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
canvasWrapper.classList.add("canvasWrapper");
|
2017-05-29 05:44:00 +09:00
|
|
|
|
2022-06-01 17:38:08 +09:00
|
|
|
const lastDivBeforeTextDiv =
|
|
|
|
this.annotationLayer?.div || this.annotationEditorLayer?.div;
|
|
|
|
|
|
|
|
if (lastDivBeforeTextDiv) {
|
2017-05-29 05:44:00 +09:00
|
|
|
// The annotation layer needs to stay on top.
|
2022-06-13 00:19:32 +09:00
|
|
|
lastDivBeforeTextDiv.before(canvasWrapper);
|
2017-05-29 05:44:00 +09:00
|
|
|
} else {
|
2022-06-12 19:20:25 +09:00
|
|
|
div.append(canvasWrapper);
|
2017-05-29 05:44:00 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
let textLayer = null;
|
2018-02-13 23:01:55 +09:00
|
|
|
if (this.textLayerMode !== TextLayerMode.DISABLE && this.textLayerFactory) {
|
2019-12-27 08:22:32 +09:00
|
|
|
const textLayerDiv = document.createElement("div");
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
textLayerDiv.className = "textLayer";
|
2017-05-29 05:44:00 +09:00
|
|
|
textLayerDiv.style.width = canvasWrapper.style.width;
|
|
|
|
textLayerDiv.style.height = canvasWrapper.style.height;
|
2022-06-01 17:38:08 +09:00
|
|
|
if (lastDivBeforeTextDiv) {
|
2017-05-29 05:44:00 +09:00
|
|
|
// The annotation layer needs to stay on top.
|
2022-06-13 00:19:32 +09:00
|
|
|
lastDivBeforeTextDiv.before(textLayerDiv);
|
2014-04-01 20:45:00 +09:00
|
|
|
} else {
|
2022-06-12 19:20:25 +09:00
|
|
|
div.append(textLayerDiv);
|
2014-04-01 20:45:00 +09:00
|
|
|
}
|
2014-09-28 03:03:28 +09:00
|
|
|
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
textLayer = this.textLayerFactory.createTextLayerBuilder(
|
|
|
|
textLayerDiv,
|
|
|
|
this.id - 1,
|
|
|
|
this.viewport,
|
2020-02-27 01:16:30 +09:00
|
|
|
this.textLayerMode === TextLayerMode.ENABLE_ENHANCE,
|
2021-08-19 09:02:29 +09:00
|
|
|
this.eventBus,
|
|
|
|
this.textHighlighter
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
);
|
2017-05-29 05:44:00 +09:00
|
|
|
}
|
|
|
|
this.textLayer = textLayer;
|
|
|
|
|
2021-11-07 02:36:49 +09:00
|
|
|
if (
|
2021-12-12 00:53:59 +09:00
|
|
|
this.#annotationMode !== AnnotationMode.DISABLE &&
|
2021-11-07 02:36:49 +09:00
|
|
|
this.annotationLayerFactory
|
|
|
|
) {
|
|
|
|
this._annotationCanvasMap ||= new Map();
|
|
|
|
this.annotationLayer ||=
|
|
|
|
this.annotationLayerFactory.createAnnotationLayerBuilder(
|
|
|
|
div,
|
|
|
|
pdfPage,
|
|
|
|
/* annotationStorage = */ null,
|
|
|
|
this.imageResourcesPath,
|
2021-12-12 00:53:59 +09:00
|
|
|
this.#annotationMode === AnnotationMode.ENABLE_FORMS,
|
2021-11-07 02:36:49 +09:00
|
|
|
this.l10n,
|
|
|
|
/* enableScripting = */ null,
|
|
|
|
/* hasJSActionsPromise = */ null,
|
|
|
|
/* mouseState = */ null,
|
|
|
|
/* fieldObjectsPromise = */ null,
|
|
|
|
/* annotationCanvasMap */ this._annotationCanvasMap
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2021-07-10 03:58:19 +09:00
|
|
|
if (this.xfaLayer?.div) {
|
|
|
|
// The xfa layer needs to stay on top.
|
2022-06-12 19:20:25 +09:00
|
|
|
div.append(this.xfaLayer.div);
|
2021-07-10 03:58:19 +09:00
|
|
|
}
|
|
|
|
|
2017-05-29 05:44:00 +09:00
|
|
|
let renderContinueCallback = null;
|
|
|
|
if (this.renderingQueue) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
renderContinueCallback = cont => {
|
2017-05-29 05:44:00 +09:00
|
|
|
if (!this.renderingQueue.isHighestPriority(this)) {
|
|
|
|
this.renderingState = RenderingStates.PAUSED;
|
|
|
|
this.resume = () => {
|
|
|
|
this.renderingState = RenderingStates.RUNNING;
|
|
|
|
cont();
|
|
|
|
};
|
|
|
|
return;
|
2014-09-28 03:03:28 +09:00
|
|
|
}
|
2017-05-29 05:44:00 +09:00
|
|
|
cont();
|
|
|
|
};
|
|
|
|
}
|
2013-09-20 16:25:41 +09:00
|
|
|
|
2020-09-23 21:29:21 +09:00
|
|
|
const finishPaintTask = async (error = null) => {
|
2017-05-29 05:44:00 +09:00
|
|
|
// The paintTask may have been replaced by a new one, so only remove
|
|
|
|
// the reference to the paintTask if it matches the one that is
|
|
|
|
// triggering this callback.
|
|
|
|
if (paintTask === this.paintTask) {
|
|
|
|
this.paintTask = null;
|
2016-10-19 23:16:57 +09:00
|
|
|
}
|
2013-09-20 16:25:41 +09:00
|
|
|
|
2017-10-05 01:13:40 +09:00
|
|
|
if (error instanceof RenderingCancelledException) {
|
2020-09-23 21:29:21 +09:00
|
|
|
this._renderError = null;
|
2019-01-26 18:12:32 +09:00
|
|
|
return;
|
2017-05-29 05:44:00 +09:00
|
|
|
}
|
2020-09-23 21:29:21 +09:00
|
|
|
this._renderError = error;
|
2013-09-20 16:25:41 +09:00
|
|
|
|
2017-05-29 05:44:00 +09:00
|
|
|
this.renderingState = RenderingStates.FINISHED;
|
2016-10-19 23:16:57 +09:00
|
|
|
|
2017-05-29 05:44:00 +09:00
|
|
|
if (this.loadingIconDiv) {
|
2021-11-16 20:36:22 +09:00
|
|
|
this.loadingIconDiv.remove();
|
2017-05-29 05:44:00 +09:00
|
|
|
delete this.loadingIconDiv;
|
2014-09-28 03:03:28 +09:00
|
|
|
}
|
2017-05-29 05:44:00 +09:00
|
|
|
this._resetZoomLayer(/* removeFromDOM = */ true);
|
2013-09-20 16:25:41 +09:00
|
|
|
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
this.eventBus.dispatch("pagerendered", {
|
2017-05-29 05:44:00 +09:00
|
|
|
source: this,
|
|
|
|
pageNumber: this.id,
|
|
|
|
cssTransform: false,
|
2019-07-13 06:08:23 +09:00
|
|
|
timestamp: performance.now(),
|
2020-09-23 21:29:21 +09:00
|
|
|
error: this._renderError,
|
2017-05-29 05:44:00 +09:00
|
|
|
});
|
2016-10-19 23:16:57 +09:00
|
|
|
|
2017-05-29 05:44:00 +09:00
|
|
|
if (error) {
|
2019-01-26 18:12:32 +09:00
|
|
|
throw error;
|
2017-05-29 05:44:00 +09:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2019-12-27 08:22:32 +09:00
|
|
|
const paintTask =
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
this.renderer === RendererType.SVG
|
|
|
|
? this.paintOnSvg(canvasWrapper)
|
|
|
|
: this.paintOnCanvas(canvasWrapper);
|
2017-05-29 05:44:00 +09:00
|
|
|
paintTask.onRenderContinue = renderContinueCallback;
|
|
|
|
this.paintTask = paintTask;
|
|
|
|
|
2019-12-27 08:22:32 +09:00
|
|
|
const resultPromise = paintTask.promise.then(
|
2021-04-01 07:07:02 +09:00
|
|
|
() => {
|
|
|
|
return finishPaintTask(null).then(() => {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
if (textLayer) {
|
2019-12-27 08:22:32 +09:00
|
|
|
const readableStream = pdfPage.streamTextContent({
|
2021-04-01 07:07:02 +09:00
|
|
|
includeMarkedContent: true,
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
});
|
|
|
|
textLayer.setTextContentStream(readableStream);
|
|
|
|
textLayer.render();
|
|
|
|
}
|
2021-11-07 02:36:49 +09:00
|
|
|
|
|
|
|
if (this.annotationLayer) {
|
2022-06-01 17:38:08 +09:00
|
|
|
this._renderAnnotationLayer().then(() => {
|
|
|
|
if (this.annotationEditorLayerFactory) {
|
|
|
|
this.annotationEditorLayer ||=
|
|
|
|
this.annotationEditorLayerFactory.createAnnotationEditorLayerBuilder(
|
|
|
|
div,
|
|
|
|
pdfPage,
|
|
|
|
this.l10n,
|
|
|
|
/* annotationStorage = */ null
|
|
|
|
);
|
|
|
|
this._renderAnnotationEditorLayer();
|
|
|
|
}
|
|
|
|
});
|
2021-11-07 02:36:49 +09:00
|
|
|
}
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
});
|
|
|
|
},
|
2020-04-14 19:28:14 +09:00
|
|
|
function (reason) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
return finishPaintTask(reason);
|
|
|
|
}
|
|
|
|
);
|
2017-05-29 05:44:00 +09:00
|
|
|
|
2021-03-19 18:11:40 +09:00
|
|
|
if (this.xfaLayerFactory) {
|
|
|
|
if (!this.xfaLayer) {
|
|
|
|
this.xfaLayer = this.xfaLayerFactory.createXfaLayerBuilder(
|
|
|
|
div,
|
2021-05-24 20:42:42 +09:00
|
|
|
pdfPage,
|
|
|
|
/* annotationStorage = */ null
|
2021-03-19 18:11:40 +09:00
|
|
|
);
|
|
|
|
}
|
|
|
|
this._renderXfaLayer();
|
|
|
|
}
|
|
|
|
|
2021-04-01 07:07:02 +09:00
|
|
|
// The structure tree is currently only supported when the text layer is
|
|
|
|
// enabled and a canvas is used for rendering.
|
|
|
|
if (this.structTreeLayerFactory && this.textLayer && this.canvas) {
|
|
|
|
// The structure tree must be generated after the text layer for the
|
|
|
|
// aria-owns to work.
|
|
|
|
this._onTextLayerRendered = event => {
|
|
|
|
if (event.pageNumber !== this.id) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
this.eventBus._off("textlayerrendered", this._onTextLayerRendered);
|
|
|
|
this._onTextLayerRendered = null;
|
2021-04-28 21:27:03 +09:00
|
|
|
|
|
|
|
if (!this.canvas) {
|
|
|
|
return; // The canvas was removed, prevent errors below.
|
|
|
|
}
|
2021-04-01 07:07:02 +09:00
|
|
|
this.pdfPage.getStructTree().then(tree => {
|
2021-04-11 19:04:29 +09:00
|
|
|
if (!tree) {
|
|
|
|
return;
|
|
|
|
}
|
2021-04-28 21:27:03 +09:00
|
|
|
if (!this.canvas) {
|
|
|
|
return; // The canvas was removed, prevent errors below.
|
|
|
|
}
|
2021-04-01 07:07:02 +09:00
|
|
|
const treeDom = this.structTreeLayer.render(tree);
|
|
|
|
treeDom.classList.add("structTree");
|
2022-06-12 19:20:25 +09:00
|
|
|
this.canvas.append(treeDom);
|
2021-04-01 07:07:02 +09:00
|
|
|
});
|
|
|
|
};
|
|
|
|
this.eventBus._on("textlayerrendered", this._onTextLayerRendered);
|
2021-05-16 17:58:34 +09:00
|
|
|
this.structTreeLayer =
|
|
|
|
this.structTreeLayerFactory.createStructTreeLayerBuilder(pdfPage);
|
2021-04-01 07:07:02 +09:00
|
|
|
}
|
|
|
|
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
div.setAttribute("data-loaded", true);
|
2017-05-29 05:44:00 +09:00
|
|
|
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
this.eventBus.dispatch("pagerender", {
|
2019-07-19 19:40:49 +09:00
|
|
|
source: this,
|
|
|
|
pageNumber: this.id,
|
|
|
|
});
|
2017-05-29 05:44:00 +09:00
|
|
|
return resultPromise;
|
|
|
|
}
|
2014-12-18 05:47:14 +09:00
|
|
|
|
2017-05-29 05:44:00 +09:00
|
|
|
paintOnCanvas(canvasWrapper) {
|
2019-12-27 08:22:32 +09:00
|
|
|
const renderCapability = createPromiseCapability();
|
|
|
|
const result = {
|
2017-05-29 05:44:00 +09:00
|
|
|
promise: renderCapability.promise,
|
|
|
|
onRenderContinue(cont) {
|
|
|
|
cont();
|
|
|
|
},
|
|
|
|
cancel() {
|
|
|
|
renderTask.cancel();
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
2019-12-27 08:22:32 +09:00
|
|
|
const viewport = this.viewport;
|
|
|
|
const canvas = document.createElement("canvas");
|
2022-06-08 01:56:30 +09:00
|
|
|
canvas.setAttribute("role", "presentation");
|
2017-05-29 05:44:00 +09:00
|
|
|
|
|
|
|
// Keep the canvas hidden until the first draw callback, or until drawing
|
|
|
|
// is complete when `!this.renderingQueue`, to prevent black flickering.
|
2021-02-08 08:21:49 +09:00
|
|
|
canvas.hidden = true;
|
2017-05-29 05:44:00 +09:00
|
|
|
let isCanvasHidden = true;
|
2020-04-14 19:28:14 +09:00
|
|
|
const showCanvas = function () {
|
2017-05-29 05:44:00 +09:00
|
|
|
if (isCanvasHidden) {
|
2021-02-08 08:21:49 +09:00
|
|
|
canvas.hidden = false;
|
2017-05-29 05:44:00 +09:00
|
|
|
isCanvasHidden = false;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2022-06-12 19:20:25 +09:00
|
|
|
canvasWrapper.append(canvas);
|
2017-05-29 05:44:00 +09:00
|
|
|
this.canvas = canvas;
|
|
|
|
|
2019-12-27 08:22:32 +09:00
|
|
|
const ctx = canvas.getContext("2d", { alpha: false });
|
2022-02-19 00:38:25 +09:00
|
|
|
const outputScale = (this.outputScale = new OutputScale());
|
2017-05-29 05:44:00 +09:00
|
|
|
|
2018-02-13 20:52:42 +09:00
|
|
|
if (this.useOnlyCssZoom) {
|
2021-09-20 17:10:57 +09:00
|
|
|
const actualSizeViewport = viewport.clone({
|
|
|
|
scale: PixelsPerInch.PDF_TO_CSS_UNITS,
|
|
|
|
});
|
2017-05-29 05:44:00 +09:00
|
|
|
// Use a scale that makes the canvas have the originally intended size
|
|
|
|
// of the page.
|
|
|
|
outputScale.sx *= actualSizeViewport.width / viewport.width;
|
|
|
|
outputScale.sy *= actualSizeViewport.height / viewport.height;
|
|
|
|
}
|
|
|
|
|
2018-02-13 21:02:15 +09:00
|
|
|
if (this.maxCanvasPixels > 0) {
|
2019-12-27 08:22:32 +09:00
|
|
|
const pixelsInViewport = viewport.width * viewport.height;
|
|
|
|
const maxScale = Math.sqrt(this.maxCanvasPixels / pixelsInViewport);
|
2017-05-29 05:44:00 +09:00
|
|
|
if (outputScale.sx > maxScale || outputScale.sy > maxScale) {
|
|
|
|
outputScale.sx = maxScale;
|
|
|
|
outputScale.sy = maxScale;
|
|
|
|
this.hasRestrictedScaling = true;
|
|
|
|
} else {
|
|
|
|
this.hasRestrictedScaling = false;
|
2016-10-19 23:16:57 +09:00
|
|
|
}
|
2017-05-29 05:44:00 +09:00
|
|
|
}
|
|
|
|
|
2019-12-27 08:22:32 +09:00
|
|
|
const sfx = approximateFraction(outputScale.sx);
|
|
|
|
const sfy = approximateFraction(outputScale.sy);
|
2017-05-29 05:44:00 +09:00
|
|
|
canvas.width = roundToDivide(viewport.width * outputScale.sx, sfx[0]);
|
|
|
|
canvas.height = roundToDivide(viewport.height * outputScale.sy, sfy[0]);
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
canvas.style.width = roundToDivide(viewport.width, sfx[1]) + "px";
|
|
|
|
canvas.style.height = roundToDivide(viewport.height, sfy[1]) + "px";
|
2021-11-07 02:36:49 +09:00
|
|
|
|
2017-05-29 05:44:00 +09:00
|
|
|
// Add the viewport so it's known what it was originally drawn with.
|
|
|
|
this.paintedViewportMap.set(canvas, viewport);
|
|
|
|
|
|
|
|
// Rendering area
|
2022-02-18 06:21:59 +09:00
|
|
|
const transform = outputScale.scaled
|
|
|
|
? [outputScale.sx, 0, 0, outputScale.sy, 0, 0]
|
|
|
|
: null;
|
2019-12-27 08:22:32 +09:00
|
|
|
const renderContext = {
|
2017-05-29 05:44:00 +09:00
|
|
|
canvasContext: ctx,
|
|
|
|
transform,
|
|
|
|
viewport: this.viewport,
|
2021-12-12 00:53:59 +09:00
|
|
|
annotationMode: this.#annotationMode,
|
[api-minor] Add support for toggling of Optional Content in the viewer (issue 12096)
*Besides, obviously, adding viewer support:* This patch attempts to improve the general API for Optional Content Groups slightly, by adding a couple of new methods for interacting with the (more complex) data structures of `OptionalContentConfig`-instances. (Thus allowing us to mark some of the data as "private", given that it probably shouldn't be manipulated directly.)
By utilizing not just the "raw" Optional Content Groups, but the data from the `/Order` array when available, we can thus display the Layers in a proper tree-structure with collapsible headings for PDF documents that utilizes that feature.
Note that it's possible to reset all Optional Content Groups to their default visibility state, simply by double-clicking on the Layers-button in the sidebar.
(Currently that's indicated in the Layers-button tooltip, which is obviously easy to overlook, however it's probably the best we can do for now without adding more buttons, or even a dropdown-toolbar, to the sidebar.)
Also, the current Layers-button icons are a little rough around the edges, quite literally, but given that the viewer will soon have its UI modernized anyway they hopefully suffice in the meantime.
To give users *full* control of the visibility of the various Optional Content Groups, even those which according to the `/Order` array should not (by default) be toggleable in the UI, this patch will place those under a *custom* heading which:
- Is collapsed by default, and placed at the bottom of the Layers-tree, to be a bit less obtrusive.
- Uses a slightly different formatting, compared to the "regular" headings.
- Is localizable.
Finally, note that the thumbnails are *purposely* always rendered with all Optional Content Groups at their default visibility state, since that seems the most useful and it's also consistent with other viewers.
To ensure that this works as intended, we'll thus disable the `PDFThumbnailView.setImage` functionality when the Optional Content Groups have been changed in the viewer. (This obviously means that we'll re-render thumbnails instead of using the rendered pages. However, this situation ought to be rare enough for this to not really be a problem.)
2020-08-07 04:01:03 +09:00
|
|
|
optionalContentConfigPromise: this._optionalContentConfigPromise,
|
2021-11-07 02:36:49 +09:00
|
|
|
annotationCanvasMap: this._annotationCanvasMap,
|
2022-05-04 22:37:13 +09:00
|
|
|
pageColors: this.pageColors,
|
2017-05-29 05:44:00 +09:00
|
|
|
};
|
2019-12-27 08:22:32 +09:00
|
|
|
const renderTask = this.pdfPage.render(renderContext);
|
2020-04-14 19:28:14 +09:00
|
|
|
renderTask.onContinue = function (cont) {
|
2017-05-29 05:44:00 +09:00
|
|
|
showCanvas();
|
|
|
|
if (result.onRenderContinue) {
|
|
|
|
result.onRenderContinue(cont);
|
|
|
|
} else {
|
|
|
|
cont();
|
2016-10-19 23:16:57 +09:00
|
|
|
}
|
2017-05-29 05:44:00 +09:00
|
|
|
};
|
|
|
|
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
renderTask.promise.then(
|
2020-04-14 19:28:14 +09:00
|
|
|
function () {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
showCanvas();
|
2021-10-03 22:32:33 +09:00
|
|
|
renderCapability.resolve();
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
},
|
2020-04-14 19:28:14 +09:00
|
|
|
function (error) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
showCanvas();
|
|
|
|
renderCapability.reject(error);
|
|
|
|
}
|
|
|
|
);
|
2017-05-29 05:44:00 +09:00
|
|
|
return result;
|
|
|
|
}
|
2016-10-19 23:16:57 +09:00
|
|
|
|
2017-05-29 05:44:00 +09:00
|
|
|
paintOnSvg(wrapper) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
if (
|
2022-06-16 23:11:47 +09:00
|
|
|
!(
|
|
|
|
typeof PDFJSDev === "undefined" ||
|
|
|
|
PDFJSDev.test("!PRODUCTION || GENERIC")
|
|
|
|
)
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
) {
|
2022-06-16 23:11:47 +09:00
|
|
|
throw new Error("Not implemented: paintOnSvg");
|
2017-05-29 05:44:00 +09:00
|
|
|
}
|
|
|
|
let cancelled = false;
|
2019-12-27 08:22:32 +09:00
|
|
|
const ensureNotCancelled = () => {
|
2017-05-29 05:44:00 +09:00
|
|
|
if (cancelled) {
|
2017-10-05 01:13:40 +09:00
|
|
|
throw new RenderingCancelledException(
|
2020-03-19 23:36:09 +09:00
|
|
|
`Rendering cancelled, page ${this.id}`,
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
"svg"
|
|
|
|
);
|
2017-01-10 10:13:36 +09:00
|
|
|
}
|
2017-05-29 05:44:00 +09:00
|
|
|
};
|
|
|
|
|
2019-12-27 08:22:32 +09:00
|
|
|
const pdfPage = this.pdfPage;
|
2021-09-20 17:10:57 +09:00
|
|
|
const actualSizeViewport = this.viewport.clone({
|
|
|
|
scale: PixelsPerInch.PDF_TO_CSS_UNITS,
|
|
|
|
});
|
[api-minor] Introduce a new `annotationMode`-option, in `PDFPageProxy.{render, getOperatorList}`
*This is a follow-up to PRs 13867 and 13899.*
This patch is tagged `api-minor` for the following reasons:
- It replaces the `renderInteractiveForms`/`includeAnnotationStorage`-options, in the `PDFPageProxy.render`-method, with the single `annotationMode`-option that controls which annotations are being rendered and how. Note that the old options were mutually exclusive, and setting both to `true` would result in undefined behaviour.
- For improved consistency in the API, the `annotationMode`-option will also work together with the `PDFPageProxy.getOperatorList`-method.
- It's now also possible to disable *all* annotation rendering in both the API and the Viewer, since the other changes meant that this could now be supported with a single added line on the worker-thread[1]; fixes 7282.
---
[1] Please note that in order to simplify the overall implementation, we'll purposely only support disabling of *all* annotations and that the option is being shared between the API and the Viewer. For any more "specialized" use-cases, where e.g. only some annotation-types are being rendered and/or the API and Viewer render different sets of annotations, that'll have to be handled in third-party implementations/forks of the PDF.js code-base.
2021-08-08 21:36:28 +09:00
|
|
|
const promise = pdfPage
|
|
|
|
.getOperatorList({
|
2021-12-12 00:53:59 +09:00
|
|
|
annotationMode: this.#annotationMode,
|
[api-minor] Introduce a new `annotationMode`-option, in `PDFPageProxy.{render, getOperatorList}`
*This is a follow-up to PRs 13867 and 13899.*
This patch is tagged `api-minor` for the following reasons:
- It replaces the `renderInteractiveForms`/`includeAnnotationStorage`-options, in the `PDFPageProxy.render`-method, with the single `annotationMode`-option that controls which annotations are being rendered and how. Note that the old options were mutually exclusive, and setting both to `true` would result in undefined behaviour.
- For improved consistency in the API, the `annotationMode`-option will also work together with the `PDFPageProxy.getOperatorList`-method.
- It's now also possible to disable *all* annotation rendering in both the API and the Viewer, since the other changes meant that this could now be supported with a single added line on the worker-thread[1]; fixes 7282.
---
[1] Please note that in order to simplify the overall implementation, we'll purposely only support disabling of *all* annotations and that the option is being shared between the API and the Viewer. For any more "specialized" use-cases, where e.g. only some annotation-types are being rendered and/or the API and Viewer render different sets of annotations, that'll have to be handled in third-party implementations/forks of the PDF.js code-base.
2021-08-08 21:36:28 +09:00
|
|
|
})
|
|
|
|
.then(opList => {
|
2017-01-10 10:13:36 +09:00
|
|
|
ensureNotCancelled();
|
[api-minor] Remove support for browsers/environments without fully working `URL.createObjectURL` implementations
This `disableCreateObjectURL` option was originally introduced all the way back in PR 4103 (eight years ago), in order to work-around `URL.createObjectURL()`-bugs specific to Internet Explorer.
In PR 8081 (five years ago) the `disableCreateObjectURL` option was extended to cover Google Chrome on iOS-devices as well, since that configuration apparently also suffered from `URL.createObjectURL()`-bugs.[1]
At this point in time, I thus think that it makes sense to re-evaluate if we should still keep the `disableCreateObjectURL` option.
- For Internet Explorer, support was explicitly removed in PDF.js version `2.7.570` which was released one year ago and all IE-specific compatibility code (and polyfills) have since been removed.
- For Google Chrome on iOS-devices, while we still "support" such configurations, it's *not* the focus of any development and platform-specific bugs are thus often closed as WONTFIX.
Note here that at this point in time, the `disableCreateObjectURL` option is *only* being used in the viewer and any `URL.createObjectURL()`-bugs browser/platform bugs will thus not affect the main PDF.js library. Furthermore, given where the `disableCreateObjectURL` option is being used in the viewer the basic functionality should also remain unaffected by these changes.[2]
Furthermore, it's also possible that the `URL.createObjectURL()`-bugs have been fixed in *browser* itself since PR 8081 was submitted.[3]
Obviously you could argue that this isn't a lot of code, w.r.t. number of lines, and you'd be technically correct. However, it does add additional complexity in a few different viewer components which thus add overhead when reading and working with this code.
Finally, assuming the `URL.createObjectURL()`-bugs are still present in Google Chrome on iOS-devices, I think that we should ask ourselves if it's reasonable for the PDF.js project (and its contributors) to keep attempting to support a configuration if the *browser* developers still haven't fixed these kind of bugs!?
---
[1] According to https://groups.google.com/a/chromium.org/forum/#!topic/chromium-html5/RKQ0ZJIj7c4, which is linked in PR 8081, that bug was mentioned/reported as early as the 2014 (eight years ago).
[2] Viewer functionality such as e.g. downloading and printing may be affected.
[3] I don't have access to any iOS-devices to test with.
2022-01-02 21:18:18 +09:00
|
|
|
const svgGfx = new SVGGraphics(pdfPage.commonObjs, pdfPage.objs);
|
[api-minor] Introduce a new `annotationMode`-option, in `PDFPageProxy.{render, getOperatorList}`
*This is a follow-up to PRs 13867 and 13899.*
This patch is tagged `api-minor` for the following reasons:
- It replaces the `renderInteractiveForms`/`includeAnnotationStorage`-options, in the `PDFPageProxy.render`-method, with the single `annotationMode`-option that controls which annotations are being rendered and how. Note that the old options were mutually exclusive, and setting both to `true` would result in undefined behaviour.
- For improved consistency in the API, the `annotationMode`-option will also work together with the `PDFPageProxy.getOperatorList`-method.
- It's now also possible to disable *all* annotation rendering in both the API and the Viewer, since the other changes meant that this could now be supported with a single added line on the worker-thread[1]; fixes 7282.
---
[1] Please note that in order to simplify the overall implementation, we'll purposely only support disabling of *all* annotations and that the option is being shared between the API and the Viewer. For any more "specialized" use-cases, where e.g. only some annotation-types are being rendered and/or the API and Viewer render different sets of annotations, that'll have to be handled in third-party implementations/forks of the PDF.js code-base.
2021-08-08 21:36:28 +09:00
|
|
|
return svgGfx.getSVG(opList, actualSizeViewport).then(svg => {
|
|
|
|
ensureNotCancelled();
|
|
|
|
this.svg = svg;
|
|
|
|
this.paintedViewportMap.set(svg, actualSizeViewport);
|
|
|
|
|
|
|
|
svg.style.width = wrapper.style.width;
|
|
|
|
svg.style.height = wrapper.style.height;
|
|
|
|
this.renderingState = RenderingStates.FINISHED;
|
2022-06-12 19:20:25 +09:00
|
|
|
wrapper.append(svg);
|
[api-minor] Introduce a new `annotationMode`-option, in `PDFPageProxy.{render, getOperatorList}`
*This is a follow-up to PRs 13867 and 13899.*
This patch is tagged `api-minor` for the following reasons:
- It replaces the `renderInteractiveForms`/`includeAnnotationStorage`-options, in the `PDFPageProxy.render`-method, with the single `annotationMode`-option that controls which annotations are being rendered and how. Note that the old options were mutually exclusive, and setting both to `true` would result in undefined behaviour.
- For improved consistency in the API, the `annotationMode`-option will also work together with the `PDFPageProxy.getOperatorList`-method.
- It's now also possible to disable *all* annotation rendering in both the API and the Viewer, since the other changes meant that this could now be supported with a single added line on the worker-thread[1]; fixes 7282.
---
[1] Please note that in order to simplify the overall implementation, we'll purposely only support disabling of *all* annotations and that the option is being shared between the API and the Viewer. For any more "specialized" use-cases, where e.g. only some annotation-types are being rendered and/or the API and Viewer render different sets of annotations, that'll have to be handled in third-party implementations/forks of the PDF.js code-base.
2021-08-08 21:36:28 +09:00
|
|
|
});
|
2017-05-29 05:44:00 +09:00
|
|
|
});
|
|
|
|
|
|
|
|
return {
|
|
|
|
promise,
|
|
|
|
onRenderContinue(cont) {
|
|
|
|
cont();
|
|
|
|
},
|
|
|
|
cancel() {
|
|
|
|
cancelled = true;
|
|
|
|
},
|
|
|
|
};
|
|
|
|
}
|
2014-09-28 03:03:28 +09:00
|
|
|
|
2017-05-29 05:44:00 +09:00
|
|
|
/**
|
|
|
|
* @param {string|null} label
|
|
|
|
*/
|
|
|
|
setPageLabel(label) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
this.pageLabel = typeof label === "string" ? label : null;
|
2017-05-29 05:44:00 +09:00
|
|
|
|
|
|
|
if (this.pageLabel !== null) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
this.div.setAttribute("data-page-label", this.pageLabel);
|
2017-05-29 05:44:00 +09:00
|
|
|
} else {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
this.div.removeAttribute("data-page-label");
|
2017-05-29 05:44:00 +09:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2016-04-09 02:34:27 +09:00
|
|
|
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
export { PDFPageView };
|