2013-03-21 17:04:44 +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.
|
|
|
|
*/
|
|
|
|
|
2017-04-02 23:14:30 +09:00
|
|
|
import {
|
2020-10-01 03:58:45 +09:00
|
|
|
AnnotationActionEventType,
|
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
|
|
|
AnnotationBorderStyleType,
|
|
|
|
AnnotationFieldFlag,
|
|
|
|
AnnotationFlag,
|
|
|
|
AnnotationReplyType,
|
|
|
|
AnnotationType,
|
|
|
|
assert,
|
2020-08-05 21:40:31 +09:00
|
|
|
escapeString,
|
2020-08-04 02:44:04 +09:00
|
|
|
getModificationDate,
|
2020-08-27 23:04:17 +09:00
|
|
|
isAscii,
|
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
|
|
|
OPS,
|
2021-11-07 02:36:49 +09:00
|
|
|
RenderingIntentFlag,
|
2020-10-22 00:21:33 +09:00
|
|
|
shadow,
|
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
|
|
|
stringToPDFString,
|
2020-08-27 23:04:17 +09:00
|
|
|
stringToUTF16BEString,
|
2020-09-12 23:52:38 +09:00
|
|
|
unreachable,
|
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
|
|
|
Util,
|
|
|
|
warn,
|
2020-01-02 20:00:16 +09:00
|
|
|
} from "../shared/util.js";
|
2020-12-08 03:22:14 +09:00
|
|
|
import { collectActions, getInheritableProperty } from "./core_utils.js";
|
2021-01-22 04:15:31 +09:00
|
|
|
import {
|
|
|
|
createDefaultAppearance,
|
|
|
|
parseDefaultAppearance,
|
|
|
|
} from "./default_appearance.js";
|
2022-02-21 20:44:56 +09:00
|
|
|
import { Dict, isName, Name, Ref, RefSet } from "./primitives.js";
|
2022-02-17 21:45:42 +09:00
|
|
|
import { BaseStream } from "./base_stream.js";
|
2021-09-25 00:30:56 +09:00
|
|
|
import { bidi } from "./bidi.js";
|
2021-04-14 01:26:23 +09:00
|
|
|
import { Catalog } from "./catalog.js";
|
2020-01-02 20:00:16 +09:00
|
|
|
import { ColorSpace } from "./colorspace.js";
|
2021-04-14 01:25:48 +09:00
|
|
|
import { FileSpec } from "./file_spec.js";
|
2021-04-14 01:25:34 +09:00
|
|
|
import { ObjectLoader } from "./object_loader.js";
|
2020-01-02 20:00:16 +09:00
|
|
|
import { OperatorList } from "./operator_list.js";
|
2020-08-05 21:40:31 +09:00
|
|
|
import { StringStream } from "./stream.js";
|
2020-08-04 02:44:04 +09:00
|
|
|
import { writeDict } from "./writer.js";
|
2021-10-25 00:29:30 +09:00
|
|
|
import { XFAFactory } from "./xfa/factory.js";
|
2015-11-22 01:32:47 +09:00
|
|
|
|
2022-03-27 06:45:50 +09:00
|
|
|
// Represent the percentage of the height of a single-line field over
|
|
|
|
// the font size.
|
|
|
|
// Acrobat seems to use this value.
|
|
|
|
const LINE_FACTOR = 1.35;
|
|
|
|
|
2017-08-27 06:49:11 +09:00
|
|
|
class AnnotationFactory {
|
2015-07-26 23:47:28 +09:00
|
|
|
/**
|
2018-03-21 09:43:40 +09:00
|
|
|
* Create an `Annotation` object of the correct type for the given reference
|
|
|
|
* to an annotation dictionary. This yields a promise that is resolved when
|
|
|
|
* the `Annotation` object is constructed.
|
|
|
|
*
|
2015-07-26 23:47:28 +09:00
|
|
|
* @param {XRef} xref
|
|
|
|
* @param {Object} ref
|
2016-10-01 19:05:07 +09:00
|
|
|
* @param {PDFManager} pdfManager
|
2017-01-09 00:51:30 +09:00
|
|
|
* @param {Object} idFactory
|
2021-03-31 00:50:35 +09:00
|
|
|
* @param {boolean} collectFields
|
2019-10-13 01:14:29 +09:00
|
|
|
* @returns {Promise} A promise that is resolved with an {Annotation}
|
|
|
|
* instance.
|
2015-07-26 23:47:28 +09:00
|
|
|
*/
|
2021-03-31 00:50:35 +09:00
|
|
|
static create(xref, ref, pdfManager, idFactory, collectFields) {
|
2021-04-30 23:43:27 +09:00
|
|
|
return Promise.all([
|
|
|
|
pdfManager.ensureCatalog("acroForm"),
|
2022-04-19 23:53:44 +09:00
|
|
|
// Only necessary to prevent the `pdfManager.docBaseUrl`-getter, used
|
|
|
|
// with certain Annotations, from throwing and thus breaking parsing:
|
|
|
|
pdfManager.ensureCatalog("baseUrl"),
|
2022-04-01 02:18:30 +09:00
|
|
|
pdfManager.ensureDoc("xfaDatasets"),
|
2021-04-30 23:43:27 +09:00
|
|
|
collectFields ? this._getPageIndex(xref, ref, pdfManager) : -1,
|
2022-04-19 23:53:44 +09:00
|
|
|
]).then(([acroForm, baseUrl, xfaDatasets, pageIndex]) =>
|
2021-04-30 23:43:27 +09:00
|
|
|
pdfManager.ensure(this, "_create", [
|
2020-07-23 00:10:59 +09:00
|
|
|
xref,
|
|
|
|
ref,
|
|
|
|
pdfManager,
|
|
|
|
idFactory,
|
|
|
|
acroForm,
|
2022-04-01 02:18:30 +09:00
|
|
|
xfaDatasets,
|
2021-03-31 00:50:35 +09:00
|
|
|
collectFields,
|
2021-04-30 23:43:27 +09:00
|
|
|
pageIndex,
|
|
|
|
])
|
|
|
|
);
|
2018-03-21 09:43:40 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
2021-04-30 23:43:27 +09:00
|
|
|
static _create(
|
|
|
|
xref,
|
|
|
|
ref,
|
|
|
|
pdfManager,
|
|
|
|
idFactory,
|
|
|
|
acroForm,
|
2022-04-01 02:18:30 +09:00
|
|
|
xfaDatasets,
|
2021-04-30 23:43:27 +09:00
|
|
|
collectFields,
|
|
|
|
pageIndex = -1
|
|
|
|
) {
|
2019-09-01 00:07:29 +09:00
|
|
|
const dict = xref.fetchIfRef(ref);
|
2022-02-21 20:44:56 +09:00
|
|
|
if (!(dict instanceof Dict)) {
|
2019-05-10 19:54:06 +09:00
|
|
|
return undefined;
|
2015-07-26 23:47:28 +09:00
|
|
|
}
|
2020-08-04 02:44:04 +09:00
|
|
|
|
2022-02-18 20:11:45 +09:00
|
|
|
const id =
|
|
|
|
ref instanceof Ref ? ref.toString() : `annot_${idFactory.createObjId()}`;
|
2015-07-26 23:47:28 +09:00
|
|
|
|
|
|
|
// Determine the annotation's subtype.
|
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 subtype = dict.get("Subtype");
|
2022-02-21 20:45:00 +09:00
|
|
|
subtype = subtype instanceof Name ? subtype.name : null;
|
2015-07-26 23:47:28 +09:00
|
|
|
|
|
|
|
// Return the right annotation object based on the subtype and field type.
|
2019-09-01 00:07:29 +09:00
|
|
|
const parameters = {
|
2017-04-27 19:58:44 +09:00
|
|
|
xref,
|
2020-08-04 02:44:04 +09:00
|
|
|
ref,
|
2017-04-27 19:58:44 +09:00
|
|
|
dict,
|
|
|
|
subtype,
|
|
|
|
id,
|
|
|
|
pdfManager,
|
2020-07-23 00:10:59 +09:00
|
|
|
acroForm: acroForm instanceof Dict ? acroForm : Dict.empty,
|
2022-04-01 02:18:30 +09:00
|
|
|
xfaDatasets,
|
2021-03-31 00:50:35 +09:00
|
|
|
collectFields,
|
2021-04-30 23:43:27 +09:00
|
|
|
pageIndex,
|
2015-07-26 23:47:28 +09:00
|
|
|
};
|
|
|
|
|
|
|
|
switch (subtype) {
|
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
|
|
|
case "Link":
|
2015-07-26 23:47:28 +09:00
|
|
|
return new LinkAnnotation(parameters);
|
|
|
|
|
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
|
|
|
case "Text":
|
2015-07-26 23:47:28 +09:00
|
|
|
return new TextAnnotation(parameters);
|
|
|
|
|
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
|
|
|
case "Widget":
|
|
|
|
let fieldType = getInheritableProperty({ dict, key: "FT" });
|
2022-02-21 20:45:00 +09:00
|
|
|
fieldType = fieldType instanceof Name ? fieldType.name : null;
|
2016-09-06 06:46:52 +09:00
|
|
|
|
|
|
|
switch (fieldType) {
|
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
|
|
|
case "Tx":
|
2016-09-06 06:46:52 +09:00
|
|
|
return new TextWidgetAnnotation(parameters);
|
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
|
|
|
case "Btn":
|
2016-11-04 21:01:42 +09:00
|
|
|
return new ButtonWidgetAnnotation(parameters);
|
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
|
|
|
case "Ch":
|
2016-09-25 08:45:49 +09:00
|
|
|
return new ChoiceWidgetAnnotation(parameters);
|
2021-04-10 23:53:17 +09:00
|
|
|
case "Sig":
|
|
|
|
return new SignatureWidgetAnnotation(parameters);
|
2015-07-26 23:47: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
|
|
|
warn(
|
2021-03-31 21:40:21 +09:00
|
|
|
`Unimplemented widget field type "${fieldType}", ` +
|
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
|
|
|
"falling back to base field type."
|
|
|
|
);
|
2015-07-26 23:47:28 +09:00
|
|
|
return new WidgetAnnotation(parameters);
|
|
|
|
|
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
|
|
|
case "Popup":
|
2015-12-23 05:31:56 +09:00
|
|
|
return new PopupAnnotation(parameters);
|
|
|
|
|
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
|
|
|
case "FreeText":
|
2019-04-14 01:45:22 +09:00
|
|
|
return new FreeTextAnnotation(parameters);
|
|
|
|
|
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
|
|
|
case "Line":
|
2017-04-03 03:50:17 +09:00
|
|
|
return new LineAnnotation(parameters);
|
|
|
|
|
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
|
|
|
case "Square":
|
2017-07-24 07:11:27 +09:00
|
|
|
return new SquareAnnotation(parameters);
|
|
|
|
|
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
|
|
|
case "Circle":
|
2017-07-24 07:30:58 +09:00
|
|
|
return new CircleAnnotation(parameters);
|
|
|
|
|
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
|
|
|
case "PolyLine":
|
2017-09-18 03:18:22 +09:00
|
|
|
return new PolylineAnnotation(parameters);
|
|
|
|
|
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
|
|
|
case "Polygon":
|
2017-09-23 23:50:49 +09:00
|
|
|
return new PolygonAnnotation(parameters);
|
|
|
|
|
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
|
|
|
case "Caret":
|
2019-04-10 06:35:32 +09:00
|
|
|
return new CaretAnnotation(parameters);
|
|
|
|
|
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
|
|
|
case "Ink":
|
2018-09-30 23:29:16 +09:00
|
|
|
return new InkAnnotation(parameters);
|
|
|
|
|
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
|
|
|
case "Highlight":
|
2016-01-01 23:31:46 +09:00
|
|
|
return new HighlightAnnotation(parameters);
|
|
|
|
|
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
|
|
|
case "Underline":
|
2015-12-28 08:33:41 +09:00
|
|
|
return new UnderlineAnnotation(parameters);
|
|
|
|
|
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
|
|
|
case "Squiggly":
|
2015-12-30 23:28:26 +09:00
|
|
|
return new SquigglyAnnotation(parameters);
|
|
|
|
|
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
|
|
|
case "StrikeOut":
|
2015-12-29 23:09:28 +09:00
|
|
|
return new StrikeOutAnnotation(parameters);
|
|
|
|
|
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
|
|
|
case "Stamp":
|
2017-09-16 23:37:50 +09:00
|
|
|
return new StampAnnotation(parameters);
|
|
|
|
|
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
|
|
|
case "FileAttachment":
|
2016-02-15 04:44:00 +09:00
|
|
|
return new FileAttachmentAnnotation(parameters);
|
|
|
|
|
2015-07-26 23:47:28 +09:00
|
|
|
default:
|
2021-03-31 00:50:35 +09:00
|
|
|
if (!collectFields) {
|
|
|
|
if (!subtype) {
|
|
|
|
warn("Annotation is missing the required /Subtype.");
|
|
|
|
} else {
|
|
|
|
warn(
|
2021-03-31 21:40:21 +09:00
|
|
|
`Unimplemented annotation type "${subtype}", ` +
|
2021-03-31 00:50:35 +09:00
|
|
|
"falling back to base annotation."
|
|
|
|
);
|
|
|
|
}
|
2016-07-24 21:32:48 +09:00
|
|
|
}
|
2015-07-26 23:47:28 +09:00
|
|
|
return new Annotation(parameters);
|
|
|
|
}
|
2017-08-27 06:49:11 +09:00
|
|
|
}
|
2021-04-30 23:43:27 +09:00
|
|
|
|
|
|
|
static async _getPageIndex(xref, ref, pdfManager) {
|
|
|
|
try {
|
|
|
|
const annotDict = await xref.fetchIfRefAsync(ref);
|
2022-02-21 20:44:56 +09:00
|
|
|
if (!(annotDict instanceof Dict)) {
|
2021-04-30 23:43:27 +09:00
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
const pageRef = annotDict.getRaw("P");
|
2022-02-18 20:11:45 +09:00
|
|
|
if (!(pageRef instanceof Ref)) {
|
2021-04-30 23:43:27 +09:00
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
const pageIndex = await pdfManager.ensureCatalog("getPageIndex", [
|
|
|
|
pageRef,
|
|
|
|
]);
|
|
|
|
return pageIndex;
|
|
|
|
} catch (ex) {
|
|
|
|
warn(`_getPageIndex: "${ex}".`);
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
}
|
2017-08-27 06:49:11 +09:00
|
|
|
}
|
2014-03-07 23:48:42 +09:00
|
|
|
|
2021-09-19 03:22:29 +09:00
|
|
|
function getRgbColor(color, defaultColor = new Uint8ClampedArray(3)) {
|
2021-02-22 01:10:35 +09:00
|
|
|
if (!Array.isArray(color)) {
|
2021-09-19 03:22:29 +09:00
|
|
|
return defaultColor;
|
2021-02-22 01:10:35 +09:00
|
|
|
}
|
|
|
|
|
2021-09-19 03:22:29 +09:00
|
|
|
const rgbColor = defaultColor || new Uint8ClampedArray(3);
|
2021-02-22 01:10:35 +09:00
|
|
|
switch (color.length) {
|
|
|
|
case 0: // Transparent, which we indicate with a null value
|
|
|
|
return null;
|
|
|
|
|
|
|
|
case 1: // Convert grayscale to RGB
|
|
|
|
ColorSpace.singletons.gray.getRgbItem(color, 0, rgbColor, 0);
|
|
|
|
return rgbColor;
|
|
|
|
|
|
|
|
case 3: // Convert RGB percentages to RGB
|
|
|
|
ColorSpace.singletons.rgb.getRgbItem(color, 0, rgbColor, 0);
|
|
|
|
return rgbColor;
|
|
|
|
|
|
|
|
case 4: // Convert CMYK to RGB
|
|
|
|
ColorSpace.singletons.cmyk.getRgbItem(color, 0, rgbColor, 0);
|
|
|
|
return rgbColor;
|
|
|
|
|
|
|
|
default:
|
2021-09-19 03:22:29 +09:00
|
|
|
return defaultColor;
|
2021-02-22 01:10:35 +09:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-07-28 03:57:52 +09:00
|
|
|
function getQuadPoints(dict, rect) {
|
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 (!dict.has("QuadPoints")) {
|
2019-07-28 03:57:52 +09:00
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
// The region is described as a number of quadrilaterals.
|
|
|
|
// Each quadrilateral must consist of eight coordinates.
|
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
|
|
|
const quadPoints = dict.getArray("QuadPoints");
|
2020-10-21 19:00:34 +09:00
|
|
|
if (
|
|
|
|
!Array.isArray(quadPoints) ||
|
|
|
|
quadPoints.length === 0 ||
|
|
|
|
quadPoints.length % 8 > 0
|
|
|
|
) {
|
2019-07-28 03:57:52 +09:00
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
const quadPointsLists = [];
|
|
|
|
for (let i = 0, ii = quadPoints.length / 8; i < ii; i++) {
|
|
|
|
// Each series of eight numbers represents the coordinates for one
|
|
|
|
// quadrilateral in the order [x1, y1, x2, y2, x3, y3, x4, y4].
|
|
|
|
// Convert this to an array of objects with x and y coordinates.
|
|
|
|
quadPointsLists.push([]);
|
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
|
|
|
for (let j = i * 8, jj = i * 8 + 8; j < jj; j += 2) {
|
2019-07-28 03:57:52 +09:00
|
|
|
const x = quadPoints[j];
|
|
|
|
const y = quadPoints[j + 1];
|
|
|
|
|
|
|
|
// The quadpoints should be ignored if any coordinate in the array
|
2020-08-08 03:46:41 +09:00
|
|
|
// lies outside the region specified by the rectangle. The rectangle
|
|
|
|
// can be `null` for markup annotations since their rectangle may be
|
|
|
|
// incorrect (fixes bug 1538111).
|
|
|
|
if (
|
|
|
|
rect !== null &&
|
|
|
|
(x < rect[0] || x > rect[2] || y < rect[1] || y > rect[3])
|
|
|
|
) {
|
2019-07-28 03:57:52 +09:00
|
|
|
return 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
|
|
|
quadPointsLists[i].push({ x, y });
|
2019-07-28 03:57:52 +09:00
|
|
|
}
|
|
|
|
}
|
2020-12-06 05:27:38 +09:00
|
|
|
|
|
|
|
// The PDF specification states in section 12.5.6.10 (figure 64) that the
|
|
|
|
// order of the quadpoints should be bottom left, bottom right, top right
|
|
|
|
// and top left. However, in practice PDF files use a different order,
|
|
|
|
// namely bottom left, bottom right, top left and top right (this is also
|
|
|
|
// mentioned on https://github.com/highkite/pdfAnnotate#QuadPoints), so
|
|
|
|
// this is the actual order we should work with. However, the situation is
|
|
|
|
// even worse since Adobe's own applications and other applications violate
|
|
|
|
// the specification and create annotations with other orders, namely top
|
|
|
|
// left, top right, bottom left and bottom right or even top left, top right,
|
|
|
|
// bottom right and bottom left. To avoid inconsistency and broken rendering,
|
|
|
|
// we normalize all lists to put the quadpoints in the same standard order
|
|
|
|
// (see https://stackoverflow.com/a/10729881).
|
|
|
|
return quadPointsLists.map(quadPointsList => {
|
|
|
|
const [minX, maxX, minY, maxY] = quadPointsList.reduce(
|
|
|
|
([mX, MX, mY, MY], quadPoint) => [
|
|
|
|
Math.min(mX, quadPoint.x),
|
|
|
|
Math.max(MX, quadPoint.x),
|
|
|
|
Math.min(mY, quadPoint.y),
|
|
|
|
Math.max(MY, quadPoint.y),
|
|
|
|
],
|
|
|
|
[Number.MAX_VALUE, Number.MIN_VALUE, Number.MAX_VALUE, Number.MIN_VALUE]
|
|
|
|
);
|
|
|
|
return [
|
|
|
|
{ x: minX, y: maxY },
|
|
|
|
{ x: maxX, y: maxY },
|
|
|
|
{ x: minX, y: minY },
|
|
|
|
{ x: maxX, y: minY },
|
|
|
|
];
|
|
|
|
});
|
2019-07-28 03:57:52 +09:00
|
|
|
}
|
|
|
|
|
2017-08-27 06:49:11 +09:00
|
|
|
function getTransformMatrix(rect, bbox, matrix) {
|
2013-03-21 17:04:44 +09:00
|
|
|
// 12.5.5: Algorithm: Appearance streams
|
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
|
|
|
const [minX, minY, maxX, maxY] = Util.getAxialAlignedBoundingBox(
|
|
|
|
bbox,
|
|
|
|
matrix
|
|
|
|
);
|
2017-08-27 06:49:11 +09:00
|
|
|
if (minX === maxX || minY === maxY) {
|
|
|
|
// From real-life file, bbox was [0, 0, 0, 0]. In this case,
|
|
|
|
// just apply the transform for rect
|
|
|
|
return [1, 0, 0, 1, rect[0], rect[1]];
|
2013-03-21 17:04:44 +09:00
|
|
|
}
|
|
|
|
|
2019-09-01 00:07:29 +09:00
|
|
|
const xRatio = (rect[2] - rect[0]) / (maxX - minX);
|
|
|
|
const yRatio = (rect[3] - rect[1]) / (maxY - minY);
|
2017-08-27 06:49:11 +09:00
|
|
|
return [
|
|
|
|
xRatio,
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
yRatio,
|
|
|
|
rect[0] - minX * xRatio,
|
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
|
|
|
rect[1] - minY * yRatio,
|
2017-08-27 06:49:11 +09:00
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
class Annotation {
|
|
|
|
constructor(params) {
|
2019-05-18 22:52:17 +09:00
|
|
|
const dict = params.dict;
|
2015-11-22 07:25:17 +09:00
|
|
|
|
2021-09-25 00:30:56 +09:00
|
|
|
this.setTitle(dict.get("T"));
|
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.setContents(dict.get("Contents"));
|
|
|
|
this.setModificationDate(dict.get("M"));
|
|
|
|
this.setFlags(dict.get("F"));
|
|
|
|
this.setRectangle(dict.getArray("Rect"));
|
|
|
|
this.setColor(dict.getArray("C"));
|
2014-12-26 04:44:16 +09:00
|
|
|
this.setBorderStyle(dict);
|
2017-02-13 07:05:10 +09:00
|
|
|
this.setAppearance(dict);
|
2021-09-19 03:22:29 +09:00
|
|
|
this.setBorderAndBackgroundColors(dict.get("MK"));
|
2015-11-29 00:08:34 +09:00
|
|
|
|
2020-09-12 23:52:38 +09:00
|
|
|
this._streams = [];
|
|
|
|
if (this.appearance) {
|
|
|
|
this._streams.push(this.appearance);
|
|
|
|
}
|
|
|
|
|
2015-11-29 00:08:34 +09:00
|
|
|
// Expose public properties using a data object.
|
2017-08-27 06:49:11 +09:00
|
|
|
this.data = {
|
|
|
|
annotationFlags: this.flags,
|
|
|
|
borderStyle: this.borderStyle,
|
|
|
|
color: this.color,
|
2021-09-19 03:22:29 +09:00
|
|
|
backgroundColor: this.backgroundColor,
|
|
|
|
borderColor: this.borderColor,
|
2021-09-25 00:30:56 +09:00
|
|
|
contentsObj: this._contents,
|
2017-08-27 06:49:11 +09:00
|
|
|
hasAppearance: !!this.appearance,
|
|
|
|
id: params.id,
|
2019-04-22 04:21:01 +09:00
|
|
|
modificationDate: this.modificationDate,
|
2017-08-27 06:49:11 +09:00
|
|
|
rect: this.rectangle,
|
|
|
|
subtype: params.subtype,
|
2021-11-07 02:36:49 +09:00
|
|
|
hasOwnCanvas: false,
|
2017-08-27 06:49:11 +09:00
|
|
|
};
|
2020-10-22 00:21:33 +09:00
|
|
|
|
2021-03-31 00:50:35 +09:00
|
|
|
if (params.collectFields) {
|
|
|
|
// Fields can act as container for other fields and have
|
|
|
|
// some actions even if no Annotation inherit from them.
|
|
|
|
// Those fields can be referenced by CO (calculation order).
|
|
|
|
const kids = dict.get("Kids");
|
|
|
|
if (Array.isArray(kids)) {
|
|
|
|
const kidIds = [];
|
|
|
|
for (const kid of kids) {
|
2022-02-18 20:11:45 +09:00
|
|
|
if (kid instanceof Ref) {
|
2021-03-31 00:50:35 +09:00
|
|
|
kidIds.push(kid.toString());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (kidIds.length !== 0) {
|
|
|
|
this.data.kidIds = kidIds;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
this.data.actions = collectActions(
|
|
|
|
params.xref,
|
|
|
|
dict,
|
|
|
|
AnnotationActionEventType
|
|
|
|
);
|
|
|
|
this.data.fieldName = this._constructFieldName(dict);
|
2021-04-30 23:43:27 +09:00
|
|
|
this.data.pageIndex = params.pageIndex;
|
2021-03-31 00:50:35 +09:00
|
|
|
}
|
|
|
|
|
2020-10-22 00:21:33 +09:00
|
|
|
this._fallbackFontDict = null;
|
2013-03-21 17:04:44 +09:00
|
|
|
}
|
|
|
|
|
2017-08-27 06:49:11 +09:00
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
_hasFlag(flags, flag) {
|
|
|
|
return !!(flags & flag);
|
|
|
|
}
|
2015-07-15 23:59:25 +09:00
|
|
|
|
2017-08-27 06:49:11 +09:00
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
_isViewable(flags) {
|
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 (
|
|
|
|
!this._hasFlag(flags, AnnotationFlag.INVISIBLE) &&
|
|
|
|
!this._hasFlag(flags, AnnotationFlag.NOVIEW)
|
|
|
|
);
|
2017-08-27 06:49:11 +09:00
|
|
|
}
|
2015-07-15 23:59:25 +09:00
|
|
|
|
2017-08-27 06:49:11 +09:00
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
_isPrintable(flags) {
|
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 (
|
|
|
|
this._hasFlag(flags, AnnotationFlag.PRINT) &&
|
2020-11-04 00:04:08 +09:00
|
|
|
!this._hasFlag(flags, AnnotationFlag.INVISIBLE)
|
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-08-27 06:49:11 +09:00
|
|
|
}
|
2015-07-15 23:59:25 +09:00
|
|
|
|
2021-05-04 01:03:16 +09:00
|
|
|
/**
|
|
|
|
* Check if the annotation must be displayed by taking into account
|
|
|
|
* the value found in the annotationStorage which may have been set
|
|
|
|
* through JS.
|
|
|
|
*
|
|
|
|
* @public
|
|
|
|
* @memberof Annotation
|
|
|
|
* @param {AnnotationStorage} [annotationStorage] - Storage for annotation
|
|
|
|
*/
|
|
|
|
mustBeViewed(annotationStorage) {
|
2021-02-18 21:51:08 +09:00
|
|
|
const storageEntry =
|
|
|
|
annotationStorage && annotationStorage.get(this.data.id);
|
|
|
|
if (storageEntry && storageEntry.hidden !== undefined) {
|
2021-05-04 01:03:16 +09:00
|
|
|
return !storageEntry.hidden;
|
|
|
|
}
|
|
|
|
return this.viewable && !this._hasFlag(this.flags, AnnotationFlag.HIDDEN);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Check if the annotation must be printed by taking into account
|
|
|
|
* the value found in the annotationStorage which may have been set
|
|
|
|
* through JS.
|
|
|
|
*
|
|
|
|
* @public
|
|
|
|
* @memberof Annotation
|
|
|
|
* @param {AnnotationStorage} [annotationStorage] - Storage for annotation
|
|
|
|
*/
|
|
|
|
mustBePrinted(annotationStorage) {
|
|
|
|
const storageEntry =
|
|
|
|
annotationStorage && annotationStorage.get(this.data.id);
|
|
|
|
if (storageEntry && storageEntry.print !== undefined) {
|
|
|
|
return storageEntry.print;
|
2020-11-04 00:04:08 +09:00
|
|
|
}
|
2021-05-04 01:03:16 +09:00
|
|
|
return this.printable;
|
2020-11-04 00:04:08 +09:00
|
|
|
}
|
|
|
|
|
2017-08-27 06:49:11 +09:00
|
|
|
/**
|
2019-10-13 00:02:54 +09:00
|
|
|
* @type {boolean}
|
2017-08-27 06:49:11 +09:00
|
|
|
*/
|
|
|
|
get viewable() {
|
2020-10-21 19:00:34 +09:00
|
|
|
if (this.data.quadPoints === null) {
|
|
|
|
return false;
|
|
|
|
}
|
2017-08-27 06:49:11 +09:00
|
|
|
if (this.flags === 0) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return this._isViewable(this.flags);
|
|
|
|
}
|
2015-07-15 23:59:25 +09:00
|
|
|
|
2017-08-27 06:49:11 +09:00
|
|
|
/**
|
2019-10-13 00:02:54 +09:00
|
|
|
* @type {boolean}
|
2017-08-27 06:49:11 +09:00
|
|
|
*/
|
|
|
|
get printable() {
|
2020-10-21 19:00:34 +09:00
|
|
|
if (this.data.quadPoints === null) {
|
|
|
|
return false;
|
|
|
|
}
|
2017-08-27 06:49:11 +09:00
|
|
|
if (this.flags === 0) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
return this._isPrintable(this.flags);
|
|
|
|
}
|
2015-07-15 23:59:25 +09:00
|
|
|
|
2021-09-25 00:30:56 +09:00
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
_parseStringHelper(data) {
|
|
|
|
const str = typeof data === "string" ? stringToPDFString(data) : "";
|
|
|
|
const dir = str && bidi(str).dir === "rtl" ? "rtl" : "ltr";
|
|
|
|
|
|
|
|
return { str, dir };
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the title.
|
|
|
|
*
|
|
|
|
* @param {string} title - The title of the annotation, used e.g. with
|
|
|
|
* PopupAnnotations.
|
|
|
|
*/
|
|
|
|
setTitle(title) {
|
|
|
|
this._title = this._parseStringHelper(title);
|
|
|
|
}
|
|
|
|
|
2019-05-18 22:52:17 +09:00
|
|
|
/**
|
|
|
|
* Set the contents.
|
|
|
|
*
|
|
|
|
* @param {string} contents - Text to display for the annotation or, if the
|
|
|
|
* type of annotation does not display text, a
|
|
|
|
* description of the annotation's contents
|
|
|
|
*/
|
|
|
|
setContents(contents) {
|
2021-09-25 00:30:56 +09:00
|
|
|
this._contents = this._parseStringHelper(contents);
|
2019-05-18 22:52:17 +09:00
|
|
|
}
|
|
|
|
|
2019-04-22 04:21:01 +09:00
|
|
|
/**
|
|
|
|
* Set the modification date.
|
|
|
|
*
|
|
|
|
* @public
|
|
|
|
* @memberof Annotation
|
|
|
|
* @param {string} modificationDate - PDF date string that indicates when the
|
|
|
|
* annotation was last modified
|
|
|
|
*/
|
|
|
|
setModificationDate(modificationDate) {
|
2022-02-24 01:02:19 +09:00
|
|
|
this.modificationDate =
|
|
|
|
typeof modificationDate === "string" ? modificationDate : null;
|
2019-04-22 04:21:01 +09:00
|
|
|
}
|
|
|
|
|
2017-08-27 06:49:11 +09:00
|
|
|
/**
|
|
|
|
* Set the flags.
|
|
|
|
*
|
|
|
|
* @public
|
|
|
|
* @memberof Annotation
|
|
|
|
* @param {number} flags - Unsigned 32-bit integer specifying annotation
|
|
|
|
* characteristics
|
|
|
|
* @see {@link shared/util.js}
|
|
|
|
*/
|
|
|
|
setFlags(flags) {
|
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.flags = Number.isInteger(flags) && flags > 0 ? flags : 0;
|
2017-08-27 06:49:11 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Check if a provided flag is set.
|
|
|
|
*
|
|
|
|
* @public
|
|
|
|
* @memberof Annotation
|
|
|
|
* @param {number} flag - Hexadecimal representation for an annotation
|
|
|
|
* characteristic
|
2019-10-13 01:14:29 +09:00
|
|
|
* @returns {boolean}
|
2017-08-27 06:49:11 +09:00
|
|
|
* @see {@link shared/util.js}
|
|
|
|
*/
|
|
|
|
hasFlag(flag) {
|
|
|
|
return this._hasFlag(this.flags, flag);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the rectangle.
|
|
|
|
*
|
|
|
|
* @public
|
|
|
|
* @memberof Annotation
|
|
|
|
* @param {Array} rectangle - The rectangle array with exactly four entries
|
|
|
|
*/
|
|
|
|
setRectangle(rectangle) {
|
2017-09-02 03:27:13 +09:00
|
|
|
if (Array.isArray(rectangle) && rectangle.length === 4) {
|
2017-08-27 06:49:11 +09:00
|
|
|
this.rectangle = Util.normalizeRect(rectangle);
|
|
|
|
} else {
|
|
|
|
this.rectangle = [0, 0, 0, 0];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the color and take care of color space conversion.
|
2018-06-12 00:25:40 +09:00
|
|
|
* The default value is black, in RGB color space.
|
2017-08-27 06:49:11 +09:00
|
|
|
*
|
|
|
|
* @public
|
|
|
|
* @memberof Annotation
|
|
|
|
* @param {Array} color - The color array containing either 0
|
|
|
|
* (transparent), 1 (grayscale), 3 (RGB) or
|
|
|
|
* 4 (CMYK) elements
|
|
|
|
*/
|
|
|
|
setColor(color) {
|
2021-02-22 01:10:35 +09:00
|
|
|
this.color = getRgbColor(color);
|
2017-08-27 06:49:11 +09:00
|
|
|
}
|
|
|
|
|
2021-09-19 03:22:29 +09:00
|
|
|
/**
|
|
|
|
* Set the color for background and border if any.
|
|
|
|
* The default values are transparent.
|
|
|
|
*
|
|
|
|
* @public
|
|
|
|
* @memberof Annotation
|
|
|
|
* @param {Dict} mk - The MK dictionary
|
|
|
|
*/
|
|
|
|
setBorderAndBackgroundColors(mk) {
|
|
|
|
if (mk instanceof Dict) {
|
|
|
|
this.borderColor = getRgbColor(mk.getArray("BC"), null);
|
|
|
|
this.backgroundColor = getRgbColor(mk.getArray("BG"), null);
|
|
|
|
} else {
|
|
|
|
this.borderColor = this.backgroundColor = null;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-08-27 06:49:11 +09:00
|
|
|
/**
|
|
|
|
* Set the border style (as AnnotationBorderStyle object).
|
|
|
|
*
|
|
|
|
* @public
|
|
|
|
* @memberof Annotation
|
|
|
|
* @param {Dict} borderStyle - The border style dictionary
|
|
|
|
*/
|
|
|
|
setBorderStyle(borderStyle) {
|
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 (
|
|
|
|
typeof PDFJSDev === "undefined" ||
|
|
|
|
PDFJSDev.test("!PRODUCTION || TESTING")
|
|
|
|
) {
|
|
|
|
assert(this.rectangle, "setRectangle must have been called previously.");
|
2019-06-01 03:44:24 +09:00
|
|
|
}
|
|
|
|
|
2017-08-27 06:49:11 +09:00
|
|
|
this.borderStyle = new AnnotationBorderStyle();
|
2022-02-21 20:44:56 +09:00
|
|
|
if (!(borderStyle instanceof Dict)) {
|
2017-08-27 06:49:11 +09:00
|
|
|
return;
|
|
|
|
}
|
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 (borderStyle.has("BS")) {
|
|
|
|
const dict = borderStyle.get("BS");
|
|
|
|
const dictType = dict.get("Type");
|
|
|
|
|
|
|
|
if (!dictType || isName(dictType, "Border")) {
|
|
|
|
this.borderStyle.setWidth(dict.get("W"), this.rectangle);
|
|
|
|
this.borderStyle.setStyle(dict.get("S"));
|
|
|
|
this.borderStyle.setDashArray(dict.getArray("D"));
|
2017-08-27 06:49:11 +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
|
|
|
} else if (borderStyle.has("Border")) {
|
|
|
|
const array = borderStyle.getArray("Border");
|
2017-09-02 03:27:13 +09:00
|
|
|
if (Array.isArray(array) && array.length >= 3) {
|
2017-08-27 06:49:11 +09:00
|
|
|
this.borderStyle.setHorizontalCornerRadius(array[0]);
|
|
|
|
this.borderStyle.setVerticalCornerRadius(array[1]);
|
2019-06-01 03:44:24 +09:00
|
|
|
this.borderStyle.setWidth(array[2], this.rectangle);
|
2017-08-27 06:49:11 +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
|
|
|
if (array.length === 4) {
|
|
|
|
// Dash array available
|
2021-10-27 19:55:56 +09:00
|
|
|
this.borderStyle.setDashArray(array[3], /* forceStyle = */ true);
|
2014-12-26 04:24:28 +09:00
|
|
|
}
|
2017-02-13 07:05:10 +09:00
|
|
|
}
|
2017-08-27 06:49:11 +09:00
|
|
|
} else {
|
|
|
|
// There are no border entries in the dictionary. According to the
|
|
|
|
// specification, we should draw a solid border of width 1 in that
|
|
|
|
// case, but Adobe Reader did not implement that part of the
|
|
|
|
// specification and instead draws no border at all, so we do the same.
|
|
|
|
// See also https://github.com/mozilla/pdf.js/issues/6179.
|
|
|
|
this.borderStyle.setWidth(0);
|
|
|
|
}
|
|
|
|
}
|
2017-02-13 07:05:10 +09:00
|
|
|
|
2017-08-27 06:49:11 +09:00
|
|
|
/**
|
|
|
|
* Set the (normal) appearance.
|
|
|
|
*
|
|
|
|
* @public
|
|
|
|
* @memberof Annotation
|
|
|
|
* @param {Dict} dict - The annotation's data dictionary
|
|
|
|
*/
|
|
|
|
setAppearance(dict) {
|
|
|
|
this.appearance = null;
|
2017-02-13 07:05:10 +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
|
|
|
const appearanceStates = dict.get("AP");
|
2022-02-21 20:44:56 +09:00
|
|
|
if (!(appearanceStates instanceof Dict)) {
|
2017-08-27 06:49:11 +09:00
|
|
|
return;
|
|
|
|
}
|
2016-02-23 08:21:28 +09:00
|
|
|
|
2017-08-27 06:49:11 +09:00
|
|
|
// In case the normal appearance is a stream, then it is used directly.
|
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
|
|
|
const normalAppearanceState = appearanceStates.get("N");
|
2022-02-17 21:45:42 +09:00
|
|
|
if (normalAppearanceState instanceof BaseStream) {
|
2017-08-27 06:49:11 +09:00
|
|
|
this.appearance = normalAppearanceState;
|
|
|
|
return;
|
|
|
|
}
|
2022-02-21 20:44:56 +09:00
|
|
|
if (!(normalAppearanceState instanceof Dict)) {
|
2017-08-27 06:49:11 +09:00
|
|
|
return;
|
|
|
|
}
|
2016-02-23 08:21:28 +09:00
|
|
|
|
2017-08-27 06:49:11 +09:00
|
|
|
// In case the normal appearance is a dictionary, the `AS` entry provides
|
|
|
|
// the key of the stream in this dictionary.
|
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
|
|
|
const as = dict.get("AS");
|
2022-02-21 20:45:00 +09:00
|
|
|
if (!(as instanceof Name) || !normalAppearanceState.has(as.name)) {
|
2017-08-27 06:49:11 +09:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
this.appearance = normalAppearanceState.get(as.name);
|
|
|
|
}
|
2017-06-13 17:22:11 +09:00
|
|
|
|
2021-11-07 02:36:49 +09:00
|
|
|
loadResources(keys, appearance) {
|
|
|
|
return appearance.dict.getAsync("Resources").then(resources => {
|
2017-08-27 06:49:11 +09:00
|
|
|
if (!resources) {
|
2019-05-10 19:54:06 +09:00
|
|
|
return undefined;
|
2013-03-21 17:04:44 +09:00
|
|
|
}
|
|
|
|
|
2019-09-01 00:07:29 +09:00
|
|
|
const objectLoader = new ObjectLoader(resources, keys, resources.xref);
|
2020-04-14 19:28:14 +09:00
|
|
|
return objectLoader.load().then(function () {
|
2017-08-27 06:49:11 +09:00
|
|
|
return resources;
|
[api-minor] Always allow e.g. rendering to continue even if there are errors, and add a `stopAtErrors` parameter to `getDocument` to opt-out of this behaviour (issue 6342, issue 3795, bug 1130815)
Other PDF readers, e.g. Adobe Reader and PDFium (in Chrome), will attempt to render as much of a page as possible even if there are errors present.
Currently we just bail as soon the first error is hit, which means that we'll usually not render anything in these cases and just display a blank page instead.
NOTE: This patch changes the default behaviour of the PDF.js API to always attempt to recover as much data as possible, even when encountering errors during e.g. `getOperatorList`/`getTextContent`, which thus improve our handling of corrupt PDF files and allow the default viewer to handle errors slightly more gracefully.
In the event that an API consumer wishes to use the old behaviour, where we stop parsing as soon as an error is encountered, the `stopAtErrors` parameter can be set at `getDocument`.
Fixes, inasmuch it's possible since the PDF files are corrupt, e.g. issue 6342, issue 3795, and [bug 1130815](https://bugzilla.mozilla.org/show_bug.cgi?id=1130815) (and probably others too).
2017-02-19 22:03:08 +09:00
|
|
|
});
|
2017-08-27 06:49:11 +09:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2021-11-07 02:36:49 +09:00
|
|
|
getOperatorList(evaluator, task, intent, renderForms, annotationStorage) {
|
|
|
|
const data = this.data;
|
|
|
|
let appearance = this.appearance;
|
|
|
|
const isUsingOwnCanvas =
|
|
|
|
data.hasOwnCanvas && intent & RenderingIntentFlag.DISPLAY;
|
|
|
|
if (!appearance) {
|
|
|
|
if (!isUsingOwnCanvas) {
|
|
|
|
return Promise.resolve(new OperatorList());
|
|
|
|
}
|
|
|
|
appearance = new StringStream("");
|
|
|
|
appearance.dict = new Dict();
|
2017-08-27 06:49:11 +09:00
|
|
|
}
|
2013-03-21 17:04:44 +09:00
|
|
|
|
2020-07-23 00:10:59 +09:00
|
|
|
const appearanceDict = appearance.dict;
|
2021-11-07 02:36:49 +09:00
|
|
|
const resourcesPromise = this.loadResources(
|
|
|
|
["ExtGState", "ColorSpace", "Pattern", "Shading", "XObject", "Font"],
|
|
|
|
appearance
|
|
|
|
);
|
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
|
|
|
const bbox = appearanceDict.getArray("BBox") || [0, 0, 1, 1];
|
|
|
|
const matrix = appearanceDict.getArray("Matrix") || [1, 0, 0, 1, 0, 0];
|
2019-09-01 00:07:29 +09:00
|
|
|
const transform = getTransformMatrix(data.rect, bbox, matrix);
|
2017-08-27 06:49:11 +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
|
|
|
return resourcesPromise.then(resources => {
|
2019-09-01 00:07:29 +09:00
|
|
|
const opList = new OperatorList();
|
[api-minor] Add `intent` support to the `PDFPageProxy.getOperatorList` method (issue 13704)
With this patch, the `PDFPageProxy.getOperatorList` method will now return `PDFOperatorList`-instances that also include Annotation-operatorLists (when those exist). Hence this closes a small, but potentially confusing, gap between the `render` and `getOperatorList` methods.
Previously we've been somewhat reluctant to do this, as explained below, but given that there's actual use-cases where it's required probably means that we'll *have* to implement it now.
Since we still need the ability to separate "normal" rendering operations from direct `getOperatorList` calls in the worker-thread, this API-change unfortunately causes the *internal* renderingIntent to become a bit "messy" which is indeed unfortunate (note the `"oplist-"` strings in various spots). As-is I suppose that it's not all that bad, but we may want to consider changing the *internal* renderingIntent to e.g. a bitfield in the future.
Besides fixing issue 13704, this patch would also be necessary if someone ever tries to implement e.g. issue 10165 (since currently `PDFPageProxy.getOperatorList` doesn't include Annotation-operatorLists).
*Please note:* This patch is *also* tagged "api-minor" for a second reason, which is that we're now including the Annotation-id in the `beginAnnotation` argument. The reason for this is to allow correlating the Annotation-data returned by `PDFPageProxy.getAnnotations`, with its corresponding operatorList-data (for those Annotations that have it).
2021-07-10 23:47:39 +09:00
|
|
|
opList.addOp(OPS.beginAnnotation, [
|
|
|
|
data.id,
|
|
|
|
data.rect,
|
|
|
|
transform,
|
|
|
|
matrix,
|
2021-11-07 02:36:49 +09:00
|
|
|
isUsingOwnCanvas,
|
[api-minor] Add `intent` support to the `PDFPageProxy.getOperatorList` method (issue 13704)
With this patch, the `PDFPageProxy.getOperatorList` method will now return `PDFOperatorList`-instances that also include Annotation-operatorLists (when those exist). Hence this closes a small, but potentially confusing, gap between the `render` and `getOperatorList` methods.
Previously we've been somewhat reluctant to do this, as explained below, but given that there's actual use-cases where it's required probably means that we'll *have* to implement it now.
Since we still need the ability to separate "normal" rendering operations from direct `getOperatorList` calls in the worker-thread, this API-change unfortunately causes the *internal* renderingIntent to become a bit "messy" which is indeed unfortunate (note the `"oplist-"` strings in various spots). As-is I suppose that it's not all that bad, but we may want to consider changing the *internal* renderingIntent to e.g. a bitfield in the future.
Besides fixing issue 13704, this patch would also be necessary if someone ever tries to implement e.g. issue 10165 (since currently `PDFPageProxy.getOperatorList` doesn't include Annotation-operatorLists).
*Please note:* This patch is *also* tagged "api-minor" for a second reason, which is that we're now including the Annotation-id in the `beginAnnotation` argument. The reason for this is to allow correlating the Annotation-data returned by `PDFPageProxy.getAnnotations`, with its corresponding operatorList-data (for those Annotations that have it).
2021-07-10 23:47:39 +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
|
|
|
return evaluator
|
|
|
|
.getOperatorList({
|
2020-07-23 00:10:59 +09:00
|
|
|
stream: appearance,
|
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
|
|
|
task,
|
|
|
|
resources,
|
|
|
|
operatorList: opList,
|
2020-10-22 00:21:33 +09:00
|
|
|
fallbackFontDict: this._fallbackFontDict,
|
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
|
|
|
})
|
|
|
|
.then(() => {
|
|
|
|
opList.addOp(OPS.endAnnotation, []);
|
2020-09-12 23:52:38 +09:00
|
|
|
this.reset();
|
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 opList;
|
|
|
|
});
|
2017-08-27 06:49:11 +09:00
|
|
|
});
|
|
|
|
}
|
2020-08-04 02:44:04 +09:00
|
|
|
|
|
|
|
async save(evaluator, task, annotationStorage) {
|
|
|
|
return null;
|
|
|
|
}
|
2020-09-12 23:52:38 +09:00
|
|
|
|
2020-10-01 03:58:45 +09:00
|
|
|
/**
|
|
|
|
* Get field data for usage in JS sandbox.
|
|
|
|
*
|
|
|
|
* Field object is defined here:
|
|
|
|
* https://www.adobe.com/content/dam/acom/en/devnet/acrobat/pdfs/js_api_reference.pdf#page=16
|
|
|
|
*
|
|
|
|
* @public
|
|
|
|
* @memberof Annotation
|
|
|
|
* @returns {Object | null}
|
|
|
|
*/
|
|
|
|
getFieldObject() {
|
2021-03-31 00:50:35 +09:00
|
|
|
if (this.data.kidIds) {
|
|
|
|
return {
|
|
|
|
id: this.data.id,
|
|
|
|
actions: this.data.actions,
|
|
|
|
name: this.data.fieldName,
|
2021-09-19 03:22:29 +09:00
|
|
|
strokeColor: this.data.borderColor,
|
|
|
|
fillColor: this.data.backgroundColor,
|
2021-03-31 00:50:35 +09:00
|
|
|
type: "",
|
|
|
|
kidIds: this.data.kidIds,
|
2021-04-30 23:43:27 +09:00
|
|
|
page: this.data.pageIndex,
|
2021-03-31 00:50:35 +09:00
|
|
|
};
|
|
|
|
}
|
2020-10-01 03:58:45 +09:00
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2020-09-12 23:52:38 +09:00
|
|
|
/**
|
|
|
|
* Reset the annotation.
|
|
|
|
*
|
|
|
|
* This involves resetting the various streams that are either cached on the
|
|
|
|
* annotation instance or created during its construction.
|
|
|
|
*
|
|
|
|
* @public
|
|
|
|
* @memberof Annotation
|
|
|
|
*/
|
|
|
|
reset() {
|
|
|
|
if (
|
|
|
|
(typeof PDFJSDev === "undefined" ||
|
|
|
|
PDFJSDev.test("!PRODUCTION || TESTING")) &&
|
|
|
|
this.appearance &&
|
|
|
|
!this._streams.includes(this.appearance)
|
|
|
|
) {
|
|
|
|
unreachable("The appearance stream should always be reset.");
|
|
|
|
}
|
|
|
|
|
|
|
|
for (const stream of this._streams) {
|
|
|
|
stream.reset();
|
|
|
|
}
|
|
|
|
}
|
2021-03-31 00:50:35 +09:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Construct the (fully qualified) field name from the (partial) field
|
|
|
|
* names of the field and its ancestors.
|
|
|
|
*
|
|
|
|
* @private
|
|
|
|
* @memberof Annotation
|
|
|
|
* @param {Dict} dict - Complete widget annotation dictionary
|
|
|
|
* @returns {string}
|
|
|
|
*/
|
|
|
|
_constructFieldName(dict) {
|
|
|
|
// Both the `Parent` and `T` fields are optional. While at least one of
|
|
|
|
// them should be provided, bad PDF generators may fail to do so.
|
|
|
|
if (!dict.has("T") && !dict.has("Parent")) {
|
|
|
|
warn("Unknown field name, falling back to empty field name.");
|
|
|
|
return "";
|
|
|
|
}
|
|
|
|
|
|
|
|
// If no parent exists, the partial and fully qualified names are equal.
|
|
|
|
if (!dict.has("Parent")) {
|
|
|
|
return stringToPDFString(dict.get("T"));
|
|
|
|
}
|
|
|
|
|
|
|
|
// Form the fully qualified field name by appending the partial name to
|
|
|
|
// the parent's fully qualified name, separated by a period.
|
|
|
|
const fieldName = [];
|
|
|
|
if (dict.has("T")) {
|
|
|
|
fieldName.unshift(stringToPDFString(dict.get("T")));
|
|
|
|
}
|
|
|
|
|
|
|
|
let loopDict = dict;
|
|
|
|
const visited = new RefSet();
|
|
|
|
if (dict.objId) {
|
|
|
|
visited.put(dict.objId);
|
|
|
|
}
|
|
|
|
while (loopDict.has("Parent")) {
|
|
|
|
loopDict = loopDict.get("Parent");
|
|
|
|
if (
|
|
|
|
!(loopDict instanceof Dict) ||
|
|
|
|
(loopDict.objId && visited.has(loopDict.objId))
|
|
|
|
) {
|
|
|
|
// Even though it is not allowed according to the PDF specification,
|
|
|
|
// bad PDF generators may provide a `Parent` entry that is not a
|
|
|
|
// dictionary, but `null` for example (issue 8143).
|
|
|
|
//
|
|
|
|
// If parent has been already visited, it means that we're
|
|
|
|
// in an infinite loop.
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
if (loopDict.objId) {
|
|
|
|
visited.put(loopDict.objId);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (loopDict.has("T")) {
|
|
|
|
fieldName.unshift(stringToPDFString(loopDict.get("T")));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return fieldName.join(".");
|
|
|
|
}
|
2017-08-27 06:49:11 +09:00
|
|
|
}
|
2013-03-21 17:04:44 +09:00
|
|
|
|
2014-12-26 04:11:23 +09:00
|
|
|
/**
|
|
|
|
* Contains all data regarding an annotation's border style.
|
|
|
|
*/
|
2017-08-27 06:49:11 +09:00
|
|
|
class AnnotationBorderStyle {
|
|
|
|
constructor() {
|
2014-12-26 04:11:23 +09:00
|
|
|
this.width = 1;
|
|
|
|
this.style = AnnotationBorderStyleType.SOLID;
|
|
|
|
this.dashArray = [3];
|
|
|
|
this.horizontalCornerRadius = 0;
|
|
|
|
this.verticalCornerRadius = 0;
|
|
|
|
}
|
|
|
|
|
2017-08-27 06:49:11 +09:00
|
|
|
/**
|
|
|
|
* Set the width.
|
|
|
|
*
|
|
|
|
* @public
|
|
|
|
* @memberof AnnotationBorderStyle
|
2019-10-12 22:54:17 +09:00
|
|
|
* @param {number} width - The width.
|
2019-06-01 03:44:24 +09:00
|
|
|
* @param {Array} rect - The annotation `Rect` entry.
|
2017-08-27 06:49:11 +09:00
|
|
|
*/
|
2019-06-01 03:44:24 +09:00
|
|
|
setWidth(width, rect = [0, 0, 0, 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
|
|
|
if (
|
|
|
|
typeof PDFJSDev === "undefined" ||
|
|
|
|
PDFJSDev.test("!PRODUCTION || TESTING")
|
|
|
|
) {
|
|
|
|
assert(
|
|
|
|
Array.isArray(rect) && rect.length === 4,
|
|
|
|
"A valid `rect` parameter must be provided."
|
|
|
|
);
|
2019-06-01 03:44:24 +09:00
|
|
|
}
|
|
|
|
|
2018-12-31 20:21:28 +09:00
|
|
|
// Some corrupt PDF generators may provide the width as a `Name`,
|
|
|
|
// rather than as a number (fixes issue 10385).
|
2022-02-21 20:45:00 +09:00
|
|
|
if (width instanceof Name) {
|
2019-01-04 18:33:15 +09:00
|
|
|
this.width = 0; // This is consistent with the behaviour in Adobe Reader.
|
|
|
|
return;
|
2018-12-31 20:21:28 +09:00
|
|
|
}
|
2021-12-24 22:10:19 +09:00
|
|
|
if (typeof width === "number") {
|
2019-06-01 03:44:24 +09:00
|
|
|
if (width > 0) {
|
|
|
|
const maxWidth = (rect[2] - rect[0]) / 2;
|
|
|
|
const maxHeight = (rect[3] - rect[1]) / 2;
|
|
|
|
|
|
|
|
// Ignore large `width`s, since they lead to the Annotation overflowing
|
|
|
|
// the size set by the `Rect` entry thus causing the `annotationLayer`
|
|
|
|
// to render it over the surrounding document (fixes bug1552113.pdf).
|
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 (
|
|
|
|
maxWidth > 0 &&
|
|
|
|
maxHeight > 0 &&
|
|
|
|
(width > maxWidth || width > maxHeight)
|
|
|
|
) {
|
2019-06-01 03:44:24 +09:00
|
|
|
warn(`AnnotationBorderStyle.setWidth - ignoring width: ${width}`);
|
|
|
|
width = 1;
|
|
|
|
}
|
|
|
|
}
|
2017-08-27 06:49:11 +09:00
|
|
|
this.width = width;
|
|
|
|
}
|
|
|
|
}
|
2014-12-26 04:11:23 +09:00
|
|
|
|
2017-08-27 06:49:11 +09:00
|
|
|
/**
|
|
|
|
* Set the style.
|
|
|
|
*
|
|
|
|
* @public
|
|
|
|
* @memberof AnnotationBorderStyle
|
2018-12-31 20:14:33 +09:00
|
|
|
* @param {Name} style - The annotation style.
|
2017-08-27 06:49:11 +09:00
|
|
|
* @see {@link shared/util.js}
|
|
|
|
*/
|
|
|
|
setStyle(style) {
|
2022-02-21 20:45:00 +09:00
|
|
|
if (!(style instanceof Name)) {
|
2017-08-27 06:49:11 +09:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
switch (style.name) {
|
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
|
|
|
case "S":
|
2017-08-27 06:49:11 +09:00
|
|
|
this.style = AnnotationBorderStyleType.SOLID;
|
|
|
|
break;
|
2014-12-26 04:11:23 +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
|
|
|
case "D":
|
2017-08-27 06:49:11 +09:00
|
|
|
this.style = AnnotationBorderStyleType.DASHED;
|
|
|
|
break;
|
2014-12-26 04:11:23 +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
|
|
|
case "B":
|
2017-08-27 06:49:11 +09:00
|
|
|
this.style = AnnotationBorderStyleType.BEVELED;
|
|
|
|
break;
|
2014-12-26 04:11:23 +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
|
|
|
case "I":
|
2017-08-27 06:49:11 +09:00
|
|
|
this.style = AnnotationBorderStyleType.INSET;
|
|
|
|
break;
|
|
|
|
|
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
|
|
|
case "U":
|
2017-08-27 06:49:11 +09:00
|
|
|
this.style = AnnotationBorderStyleType.UNDERLINE;
|
|
|
|
break;
|
2014-12-26 04:11:23 +09:00
|
|
|
|
2017-08-27 06:49:11 +09:00
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the dash array.
|
|
|
|
*
|
|
|
|
* @public
|
|
|
|
* @memberof AnnotationBorderStyle
|
|
|
|
* @param {Array} dashArray - The dash array with at least one element
|
2021-10-27 19:55:56 +09:00
|
|
|
* @param {boolean} [forceStyle]
|
2017-08-27 06:49:11 +09:00
|
|
|
*/
|
2021-10-27 19:55:56 +09:00
|
|
|
setDashArray(dashArray, forceStyle = false) {
|
2017-08-27 06:49:11 +09:00
|
|
|
// We validate the dash array, but we do not use it because CSS does not
|
|
|
|
// allow us to change spacing of dashes. For more information, visit
|
|
|
|
// http://www.w3.org/TR/css3-background/#the-border-style.
|
2017-09-02 03:27:13 +09:00
|
|
|
if (Array.isArray(dashArray) && dashArray.length > 0) {
|
2017-08-27 06:49:11 +09:00
|
|
|
// According to the PDF specification: the elements in `dashArray`
|
|
|
|
// shall be numbers that are nonnegative and not all equal to zero.
|
|
|
|
let isValid = true;
|
|
|
|
let allZeros = true;
|
2019-09-01 00:07:29 +09:00
|
|
|
for (const element of dashArray) {
|
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
|
|
|
const validNumber = +element >= 0;
|
2017-08-27 06:49:11 +09:00
|
|
|
if (!validNumber) {
|
|
|
|
isValid = false;
|
2014-12-26 04:11:23 +09:00
|
|
|
break;
|
2017-08-27 06:49:11 +09:00
|
|
|
} else if (element > 0) {
|
|
|
|
allZeros = false;
|
2014-12-26 04:11:23 +09:00
|
|
|
}
|
|
|
|
}
|
2017-08-27 06:49:11 +09:00
|
|
|
if (isValid && !allZeros) {
|
|
|
|
this.dashArray = dashArray;
|
2021-10-27 19:55:56 +09:00
|
|
|
|
|
|
|
if (forceStyle) {
|
|
|
|
// Even though we cannot use the dash array in the display layer,
|
|
|
|
// at least ensure that we use the correct border-style.
|
|
|
|
this.setStyle(Name.get("D"));
|
|
|
|
}
|
2017-08-27 06:49:11 +09:00
|
|
|
} else {
|
|
|
|
this.width = 0; // Adobe behavior when the array is invalid.
|
2014-12-26 04:11:23 +09:00
|
|
|
}
|
2017-08-27 06:49:11 +09:00
|
|
|
} else if (dashArray) {
|
|
|
|
this.width = 0; // Adobe behavior when the array is invalid.
|
|
|
|
}
|
|
|
|
}
|
2014-12-26 04:11:23 +09:00
|
|
|
|
2017-08-27 06:49:11 +09:00
|
|
|
/**
|
|
|
|
* Set the horizontal corner radius (from a Border dictionary).
|
|
|
|
*
|
|
|
|
* @public
|
|
|
|
* @memberof AnnotationBorderStyle
|
2019-10-12 22:54:17 +09:00
|
|
|
* @param {number} radius - The horizontal corner radius.
|
2017-08-27 06:49:11 +09:00
|
|
|
*/
|
|
|
|
setHorizontalCornerRadius(radius) {
|
2017-09-03 19:50:16 +09:00
|
|
|
if (Number.isInteger(radius)) {
|
2017-08-27 06:49:11 +09:00
|
|
|
this.horizontalCornerRadius = radius;
|
|
|
|
}
|
|
|
|
}
|
2014-12-26 04:11:23 +09:00
|
|
|
|
2017-08-27 06:49:11 +09:00
|
|
|
/**
|
|
|
|
* Set the vertical corner radius (from a Border dictionary).
|
|
|
|
*
|
|
|
|
* @public
|
|
|
|
* @memberof AnnotationBorderStyle
|
2019-10-12 22:54:17 +09:00
|
|
|
* @param {number} radius - The vertical corner radius.
|
2017-08-27 06:49:11 +09:00
|
|
|
*/
|
|
|
|
setVerticalCornerRadius(radius) {
|
2017-09-03 19:50:16 +09:00
|
|
|
if (Number.isInteger(radius)) {
|
2017-08-27 06:49:11 +09:00
|
|
|
this.verticalCornerRadius = radius;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-04-11 20:55:58 +09:00
|
|
|
class MarkupAnnotation extends Annotation {
|
|
|
|
constructor(parameters) {
|
|
|
|
super(parameters);
|
|
|
|
|
2019-05-25 22:25:52 +09:00
|
|
|
const dict = parameters.dict;
|
2019-05-15 04:14:35 +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
|
|
|
if (dict.has("IRT")) {
|
|
|
|
const rawIRT = dict.getRaw("IRT");
|
2022-02-18 20:11:45 +09:00
|
|
|
this.data.inReplyTo = rawIRT instanceof Ref ? rawIRT.toString() : null;
|
2019-05-15 04:14:35 +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
|
|
|
const rt = dict.get("RT");
|
2022-02-21 20:45:00 +09:00
|
|
|
this.data.replyType =
|
|
|
|
rt instanceof Name ? rt.name : AnnotationReplyType.REPLY;
|
2019-04-11 20:55:58 +09:00
|
|
|
}
|
|
|
|
|
2019-05-15 04:14:35 +09:00
|
|
|
if (this.data.replyType === AnnotationReplyType.GROUP) {
|
|
|
|
// Subordinate annotations in a group should inherit
|
|
|
|
// the group attributes from the primary annotation.
|
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
|
|
|
const parent = dict.get("IRT");
|
2019-05-15 04:14:35 +09:00
|
|
|
|
2021-09-25 00:30:56 +09:00
|
|
|
this.setTitle(parent.get("T"));
|
|
|
|
this.data.titleObj = this._title;
|
2019-05-15 04:14:35 +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.setContents(parent.get("Contents"));
|
2021-09-25 00:30:56 +09:00
|
|
|
this.data.contentsObj = this._contents;
|
2019-05-15 04:14:35 +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
|
|
|
if (!parent.has("CreationDate")) {
|
2019-05-15 04:14:35 +09:00
|
|
|
this.data.creationDate = null;
|
|
|
|
} 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.setCreationDate(parent.get("CreationDate"));
|
2019-05-15 04:14:35 +09:00
|
|
|
this.data.creationDate = this.creationDate;
|
|
|
|
}
|
|
|
|
|
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 (!parent.has("M")) {
|
2019-05-15 04:14:35 +09:00
|
|
|
this.data.modificationDate = null;
|
|
|
|
} 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.setModificationDate(parent.get("M"));
|
2019-05-15 04:14:35 +09:00
|
|
|
this.data.modificationDate = this.modificationDate;
|
|
|
|
}
|
|
|
|
|
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.data.hasPopup = parent.has("Popup");
|
2019-05-15 04:14:35 +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
|
|
|
if (!parent.has("C")) {
|
2019-05-15 04:14:35 +09:00
|
|
|
// Fall back to the default background color.
|
|
|
|
this.data.color = null;
|
|
|
|
} 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.setColor(parent.getArray("C"));
|
2019-05-15 04:14:35 +09:00
|
|
|
this.data.color = this.color;
|
|
|
|
}
|
|
|
|
} else {
|
2021-09-25 00:30:56 +09:00
|
|
|
this.data.titleObj = this._title;
|
2019-05-15 04:14:35 +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.setCreationDate(dict.get("CreationDate"));
|
2019-05-15 04:14:35 +09:00
|
|
|
this.data.creationDate = this.creationDate;
|
|
|
|
|
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.data.hasPopup = dict.has("Popup");
|
2019-05-25 22:25:52 +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
|
|
|
if (!dict.has("C")) {
|
2019-05-15 04:14:35 +09:00
|
|
|
// Fall back to the default background color.
|
|
|
|
this.data.color = null;
|
|
|
|
}
|
|
|
|
}
|
2021-10-25 00:29:30 +09:00
|
|
|
|
|
|
|
if (dict.has("RC")) {
|
|
|
|
this.data.richText = XFAFactory.getRichTextAsHtml(dict.get("RC"));
|
|
|
|
}
|
2019-04-11 20:55:58 +09:00
|
|
|
}
|
2019-05-25 22:25:52 +09:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the creation date.
|
|
|
|
*
|
|
|
|
* @public
|
|
|
|
* @memberof MarkupAnnotation
|
|
|
|
* @param {string} creationDate - PDF date string that indicates when the
|
|
|
|
* annotation was originally created
|
|
|
|
*/
|
|
|
|
setCreationDate(creationDate) {
|
2022-02-24 01:02:19 +09:00
|
|
|
this.creationDate = typeof creationDate === "string" ? creationDate : null;
|
2019-05-25 22:25:52 +09:00
|
|
|
}
|
2020-08-08 03:46:41 +09:00
|
|
|
|
|
|
|
_setDefaultAppearance({
|
|
|
|
xref,
|
|
|
|
extra,
|
|
|
|
strokeColor,
|
|
|
|
fillColor,
|
|
|
|
blendMode,
|
2021-05-27 17:06:13 +09:00
|
|
|
strokeAlpha,
|
|
|
|
fillAlpha,
|
2020-08-08 03:46:41 +09:00
|
|
|
pointsCallback,
|
|
|
|
}) {
|
|
|
|
let minX = Number.MAX_VALUE;
|
|
|
|
let minY = Number.MAX_VALUE;
|
|
|
|
let maxX = Number.MIN_VALUE;
|
|
|
|
let maxY = Number.MIN_VALUE;
|
|
|
|
|
|
|
|
const buffer = ["q"];
|
|
|
|
if (extra) {
|
|
|
|
buffer.push(extra);
|
|
|
|
}
|
|
|
|
if (strokeColor) {
|
|
|
|
buffer.push(`${strokeColor[0]} ${strokeColor[1]} ${strokeColor[2]} RG`);
|
|
|
|
}
|
|
|
|
if (fillColor) {
|
|
|
|
buffer.push(`${fillColor[0]} ${fillColor[1]} ${fillColor[2]} rg`);
|
|
|
|
}
|
|
|
|
|
2021-02-22 01:10:35 +09:00
|
|
|
let pointsArray = this.data.quadPoints;
|
|
|
|
if (!pointsArray) {
|
|
|
|
// If there are no quadpoints, the rectangle should be used instead.
|
|
|
|
// Convert the rectangle definition to a points array similar to how the
|
|
|
|
// quadpoints are defined.
|
|
|
|
pointsArray = [
|
|
|
|
[
|
|
|
|
{ x: this.rectangle[0], y: this.rectangle[3] },
|
|
|
|
{ x: this.rectangle[2], y: this.rectangle[3] },
|
|
|
|
{ x: this.rectangle[0], y: this.rectangle[1] },
|
|
|
|
{ x: this.rectangle[2], y: this.rectangle[1] },
|
|
|
|
],
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
for (const points of pointsArray) {
|
2020-08-08 03:46:41 +09:00
|
|
|
const [mX, MX, mY, MY] = pointsCallback(buffer, points);
|
|
|
|
minX = Math.min(minX, mX);
|
|
|
|
maxX = Math.max(maxX, MX);
|
|
|
|
minY = Math.min(minY, mY);
|
|
|
|
maxY = Math.max(maxY, MY);
|
|
|
|
}
|
|
|
|
buffer.push("Q");
|
|
|
|
|
|
|
|
const formDict = new Dict(xref);
|
|
|
|
const appearanceStreamDict = new Dict(xref);
|
|
|
|
appearanceStreamDict.set("Subtype", Name.get("Form"));
|
|
|
|
|
|
|
|
const appearanceStream = new StringStream(buffer.join(" "));
|
|
|
|
appearanceStream.dict = appearanceStreamDict;
|
|
|
|
formDict.set("Fm0", appearanceStream);
|
|
|
|
|
|
|
|
const gsDict = new Dict(xref);
|
|
|
|
if (blendMode) {
|
|
|
|
gsDict.set("BM", Name.get(blendMode));
|
|
|
|
}
|
2021-05-27 17:06:13 +09:00
|
|
|
if (typeof strokeAlpha === "number") {
|
|
|
|
gsDict.set("CA", strokeAlpha);
|
|
|
|
}
|
|
|
|
if (typeof fillAlpha === "number") {
|
|
|
|
gsDict.set("ca", fillAlpha);
|
|
|
|
}
|
2020-08-08 03:46:41 +09:00
|
|
|
|
|
|
|
const stateDict = new Dict(xref);
|
|
|
|
stateDict.set("GS0", gsDict);
|
|
|
|
|
|
|
|
const resources = new Dict(xref);
|
|
|
|
resources.set("ExtGState", stateDict);
|
|
|
|
resources.set("XObject", formDict);
|
|
|
|
|
|
|
|
const appearanceDict = new Dict(xref);
|
|
|
|
appearanceDict.set("Resources", resources);
|
|
|
|
const bbox = (this.data.rect = [minX, minY, maxX, maxY]);
|
|
|
|
appearanceDict.set("BBox", bbox);
|
|
|
|
|
|
|
|
this.appearance = new StringStream("/GS0 gs /Fm0 Do");
|
|
|
|
this.appearance.dict = appearanceDict;
|
2020-09-12 23:52:38 +09:00
|
|
|
|
|
|
|
// This method is only called if there is no appearance for the annotation,
|
|
|
|
// so `this.appearance` is not pushed yet in the `Annotation` constructor.
|
|
|
|
this._streams.push(this.appearance, appearanceStream);
|
2020-08-08 03:46:41 +09:00
|
|
|
}
|
2019-04-11 20:55:58 +09:00
|
|
|
}
|
|
|
|
|
2017-08-27 06:49:11 +09:00
|
|
|
class WidgetAnnotation extends Annotation {
|
|
|
|
constructor(params) {
|
|
|
|
super(params);
|
2013-03-21 17:04:44 +09:00
|
|
|
|
2019-09-01 00:07:29 +09:00
|
|
|
const dict = params.dict;
|
|
|
|
const data = this.data;
|
2020-08-04 02:44:04 +09:00
|
|
|
this.ref = params.ref;
|
2013-03-21 17:04:44 +09:00
|
|
|
|
2015-12-15 22:52:17 +09:00
|
|
|
data.annotationType = AnnotationType.WIDGET;
|
2021-03-31 00:50:35 +09:00
|
|
|
if (data.fieldName === undefined) {
|
|
|
|
data.fieldName = this._constructFieldName(dict);
|
|
|
|
}
|
|
|
|
if (data.actions === undefined) {
|
|
|
|
data.actions = collectActions(
|
|
|
|
params.xref,
|
|
|
|
dict,
|
|
|
|
AnnotationActionEventType
|
|
|
|
);
|
|
|
|
}
|
2020-08-22 22:02:29 +09:00
|
|
|
|
2022-04-01 02:18:30 +09:00
|
|
|
let fieldValue = getInheritableProperty({
|
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
|
|
|
dict,
|
|
|
|
key: "V",
|
|
|
|
getArray: true,
|
|
|
|
});
|
2020-08-22 22:02:29 +09:00
|
|
|
data.fieldValue = this._decodeFormValue(fieldValue);
|
|
|
|
|
2020-11-04 00:53:21 +09:00
|
|
|
const defaultFieldValue = getInheritableProperty({
|
|
|
|
dict,
|
|
|
|
key: "DV",
|
|
|
|
getArray: true,
|
|
|
|
});
|
|
|
|
data.defaultFieldValue = this._decodeFormValue(defaultFieldValue);
|
|
|
|
|
2022-04-01 02:18:30 +09:00
|
|
|
if (fieldValue === undefined && params.xfaDatasets) {
|
|
|
|
// Try to figure out if we have something in the xfa dataset.
|
|
|
|
const path = this._title.str;
|
|
|
|
if (path) {
|
|
|
|
this._hasValueFromXFA = true;
|
|
|
|
data.fieldValue = fieldValue = params.xfaDatasets.getValue(path);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-07-30 23:15:41 +09:00
|
|
|
// When no "V" entry exists, let the fieldValue fallback to the "DV" entry
|
|
|
|
// (fixes issue13823.pdf).
|
|
|
|
if (fieldValue === undefined && data.defaultFieldValue !== null) {
|
|
|
|
data.fieldValue = data.defaultFieldValue;
|
|
|
|
}
|
|
|
|
|
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
|
|
|
data.alternativeText = stringToPDFString(dict.get("TU") || "");
|
2021-03-31 21:48:28 +09:00
|
|
|
|
2020-12-18 21:17:23 +09:00
|
|
|
const defaultAppearance =
|
2021-03-31 21:48:28 +09:00
|
|
|
getInheritableProperty({ dict, key: "DA" }) || params.acroForm.get("DA");
|
2022-02-24 01:02:19 +09:00
|
|
|
this._defaultAppearance =
|
|
|
|
typeof defaultAppearance === "string" ? defaultAppearance : "";
|
2021-03-31 21:48:28 +09:00
|
|
|
data.defaultAppearanceData = parseDefaultAppearance(
|
|
|
|
this._defaultAppearance
|
|
|
|
);
|
2021-01-22 04:15:31 +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
|
|
|
const fieldType = getInheritableProperty({ dict, key: "FT" });
|
2022-02-21 20:45:00 +09:00
|
|
|
data.fieldType = fieldType instanceof Name ? fieldType.name : null;
|
Ensure that all necessary /Font resources are included when saving a `WidgetAnnotation`-instance (issue 12294)
This patch contains a possible approach for fixing issue 12294, which compared to other PRs is purposely limited to the affected `WidgetAnnotation` code.
As mentioned elsewhere, considering that we're (at least for now) trying to fix *one specific* case, I think that we should avoid modifying the `Dict` primitive[1] and/or avoid a solution that (indirectly) modifies an existing `Dict`-instance[2].
This patch simply fixes the issue at hand, since that seems easiest for now, and I'd suggest that we worry about a more general approach if/when that actually becomes necessary.
Hence the solution implemented here, for `WidgetAnnotation`, is to simply use a combination of the local *and* AcroForm /DR resources during OperatorList-parsing to ensure that things work correctly regardless of where a particular /Font resource is found.
For saving of form-data, on the other hand, we want to avoid increasing the file-size unnecessarily and need to be smarter than just merging all of the available resources. To achive this, a new `WidgetAnnotation._getSaveFieldResources` method will when necessary produce a combined resources `Dict` with only the minimum amount of data from the AcroForm /DR resources included.
---
[1] You want to avoid anything that could cause the general `Dict` implementation to become slower, or more complex, just for handling an edge-case in my opinion.
[2] If an existing `Dict`-instance is modified unexpectedly, that could very easily lead to problems elsewhere since e.g. `Dict`-instances created during parsing are not expected to be changed.
2020-09-10 17:21:34 +09:00
|
|
|
|
|
|
|
const localResources = getInheritableProperty({ dict, key: "DR" });
|
|
|
|
const acroFormResources = params.acroForm.get("DR");
|
2020-09-20 00:11:04 +09:00
|
|
|
const appearanceResources =
|
|
|
|
this.appearance && this.appearance.dict.get("Resources");
|
|
|
|
|
Ensure that all necessary /Font resources are included when saving a `WidgetAnnotation`-instance (issue 12294)
This patch contains a possible approach for fixing issue 12294, which compared to other PRs is purposely limited to the affected `WidgetAnnotation` code.
As mentioned elsewhere, considering that we're (at least for now) trying to fix *one specific* case, I think that we should avoid modifying the `Dict` primitive[1] and/or avoid a solution that (indirectly) modifies an existing `Dict`-instance[2].
This patch simply fixes the issue at hand, since that seems easiest for now, and I'd suggest that we worry about a more general approach if/when that actually becomes necessary.
Hence the solution implemented here, for `WidgetAnnotation`, is to simply use a combination of the local *and* AcroForm /DR resources during OperatorList-parsing to ensure that things work correctly regardless of where a particular /Font resource is found.
For saving of form-data, on the other hand, we want to avoid increasing the file-size unnecessarily and need to be smarter than just merging all of the available resources. To achive this, a new `WidgetAnnotation._getSaveFieldResources` method will when necessary produce a combined resources `Dict` with only the minimum amount of data from the AcroForm /DR resources included.
---
[1] You want to avoid anything that could cause the general `Dict` implementation to become slower, or more complex, just for handling an edge-case in my opinion.
[2] If an existing `Dict`-instance is modified unexpectedly, that could very easily lead to problems elsewhere since e.g. `Dict`-instances created during parsing are not expected to be changed.
2020-09-10 17:21:34 +09:00
|
|
|
this._fieldResources = {
|
|
|
|
localResources,
|
|
|
|
acroFormResources,
|
2020-09-20 00:11:04 +09:00
|
|
|
appearanceResources,
|
Ensure that all necessary /Font resources are included when saving a `WidgetAnnotation`-instance (issue 12294)
This patch contains a possible approach for fixing issue 12294, which compared to other PRs is purposely limited to the affected `WidgetAnnotation` code.
As mentioned elsewhere, considering that we're (at least for now) trying to fix *one specific* case, I think that we should avoid modifying the `Dict` primitive[1] and/or avoid a solution that (indirectly) modifies an existing `Dict`-instance[2].
This patch simply fixes the issue at hand, since that seems easiest for now, and I'd suggest that we worry about a more general approach if/when that actually becomes necessary.
Hence the solution implemented here, for `WidgetAnnotation`, is to simply use a combination of the local *and* AcroForm /DR resources during OperatorList-parsing to ensure that things work correctly regardless of where a particular /Font resource is found.
For saving of form-data, on the other hand, we want to avoid increasing the file-size unnecessarily and need to be smarter than just merging all of the available resources. To achive this, a new `WidgetAnnotation._getSaveFieldResources` method will when necessary produce a combined resources `Dict` with only the minimum amount of data from the AcroForm /DR resources included.
---
[1] You want to avoid anything that could cause the general `Dict` implementation to become slower, or more complex, just for handling an edge-case in my opinion.
[2] If an existing `Dict`-instance is modified unexpectedly, that could very easily lead to problems elsewhere since e.g. `Dict`-instances created during parsing are not expected to be changed.
2020-09-10 17:21:34 +09:00
|
|
|
mergedResources: Dict.merge({
|
|
|
|
xref: params.xref,
|
2020-09-20 00:11:04 +09:00
|
|
|
dictArray: [localResources, appearanceResources, acroFormResources],
|
Ensure that all necessary /Font resources are included when saving a `WidgetAnnotation`-instance (issue 12294)
This patch contains a possible approach for fixing issue 12294, which compared to other PRs is purposely limited to the affected `WidgetAnnotation` code.
As mentioned elsewhere, considering that we're (at least for now) trying to fix *one specific* case, I think that we should avoid modifying the `Dict` primitive[1] and/or avoid a solution that (indirectly) modifies an existing `Dict`-instance[2].
This patch simply fixes the issue at hand, since that seems easiest for now, and I'd suggest that we worry about a more general approach if/when that actually becomes necessary.
Hence the solution implemented here, for `WidgetAnnotation`, is to simply use a combination of the local *and* AcroForm /DR resources during OperatorList-parsing to ensure that things work correctly regardless of where a particular /Font resource is found.
For saving of form-data, on the other hand, we want to avoid increasing the file-size unnecessarily and need to be smarter than just merging all of the available resources. To achive this, a new `WidgetAnnotation._getSaveFieldResources` method will when necessary produce a combined resources `Dict` with only the minimum amount of data from the AcroForm /DR resources included.
---
[1] You want to avoid anything that could cause the general `Dict` implementation to become slower, or more complex, just for handling an edge-case in my opinion.
[2] If an existing `Dict`-instance is modified unexpectedly, that could very easily lead to problems elsewhere since e.g. `Dict`-instances created during parsing are not expected to be changed.
2020-09-10 17:21:34 +09:00
|
|
|
mergeSubDicts: true,
|
|
|
|
}),
|
|
|
|
};
|
2013-03-21 17:04:44 +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
|
|
|
data.fieldFlags = getInheritableProperty({ dict, key: "Ff" });
|
2017-09-01 23:52:50 +09:00
|
|
|
if (!Number.isInteger(data.fieldFlags) || data.fieldFlags < 0) {
|
2016-09-14 23:32:51 +09:00
|
|
|
data.fieldFlags = 0;
|
|
|
|
}
|
|
|
|
|
2016-09-25 08:45:49 +09:00
|
|
|
data.readOnly = this.hasFieldFlag(AnnotationFieldFlag.READONLY);
|
2020-11-04 00:04:08 +09:00
|
|
|
data.hidden = this._hasFlag(data.annotationFlags, AnnotationFlag.HIDDEN);
|
2016-11-02 08:07:31 +09:00
|
|
|
}
|
2015-11-22 07:25:17 +09:00
|
|
|
|
2020-08-22 22:02:29 +09:00
|
|
|
/**
|
|
|
|
* Decode the given form value.
|
|
|
|
*
|
|
|
|
* @private
|
|
|
|
* @memberof WidgetAnnotation
|
|
|
|
* @param {Array<string>|Name|string} formValue - The (possibly encoded)
|
|
|
|
* form value.
|
|
|
|
* @returns {Array<string>|string|null}
|
|
|
|
*/
|
|
|
|
_decodeFormValue(formValue) {
|
|
|
|
if (Array.isArray(formValue)) {
|
|
|
|
return formValue
|
2022-02-24 01:02:19 +09:00
|
|
|
.filter(item => typeof item === "string")
|
2020-08-22 22:02:29 +09:00
|
|
|
.map(item => stringToPDFString(item));
|
2022-02-21 20:45:00 +09:00
|
|
|
} else if (formValue instanceof Name) {
|
2020-08-22 22:02:29 +09:00
|
|
|
return stringToPDFString(formValue.name);
|
2022-02-24 01:02:19 +09:00
|
|
|
} else if (typeof formValue === "string") {
|
2020-08-22 22:02:29 +09:00
|
|
|
return stringToPDFString(formValue);
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2017-08-27 06:49:11 +09:00
|
|
|
/**
|
|
|
|
* Check if a provided field flag is set.
|
|
|
|
*
|
|
|
|
* @public
|
|
|
|
* @memberof WidgetAnnotation
|
|
|
|
* @param {number} flag - Hexadecimal representation for an annotation
|
|
|
|
* field characteristic
|
2019-10-13 01:14:29 +09:00
|
|
|
* @returns {boolean}
|
2017-08-27 06:49:11 +09:00
|
|
|
* @see {@link shared/util.js}
|
|
|
|
*/
|
|
|
|
hasFieldFlag(flag) {
|
|
|
|
return !!(this.data.fieldFlags & flag);
|
|
|
|
}
|
2017-08-27 07:48:02 +09:00
|
|
|
|
2021-11-07 02:36:49 +09:00
|
|
|
getOperatorList(evaluator, task, intent, renderForms, annotationStorage) {
|
2017-08-27 07:48:02 +09:00
|
|
|
// Do not render form elements on the canvas when interactive forms are
|
|
|
|
// enabled. The display layer is responsible for rendering them instead.
|
2021-04-10 23:53:17 +09:00
|
|
|
if (renderForms && !(this instanceof SignatureWidgetAnnotation)) {
|
2017-08-27 07:48:02 +09:00
|
|
|
return Promise.resolve(new OperatorList());
|
|
|
|
}
|
2020-08-05 21:40:31 +09:00
|
|
|
|
|
|
|
if (!this._hasText) {
|
|
|
|
return super.getOperatorList(
|
|
|
|
evaluator,
|
|
|
|
task,
|
2021-11-07 02:36:49 +09:00
|
|
|
intent,
|
2020-08-05 21:40:31 +09:00
|
|
|
renderForms,
|
|
|
|
annotationStorage
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return this._getAppearance(evaluator, task, annotationStorage).then(
|
|
|
|
content => {
|
|
|
|
if (this.appearance && content === null) {
|
|
|
|
return super.getOperatorList(
|
|
|
|
evaluator,
|
|
|
|
task,
|
2021-11-07 02:36:49 +09:00
|
|
|
intent,
|
2020-08-05 21:40:31 +09:00
|
|
|
renderForms,
|
|
|
|
annotationStorage
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
const operatorList = new OperatorList();
|
|
|
|
|
|
|
|
// Even if there is an appearance stream, ignore it. This is the
|
|
|
|
// behaviour used by Adobe Reader.
|
2021-03-31 21:48:28 +09:00
|
|
|
if (!this._defaultAppearance || content === null) {
|
2020-08-05 21:40:31 +09:00
|
|
|
return operatorList;
|
|
|
|
}
|
|
|
|
|
|
|
|
const matrix = [1, 0, 0, 1, 0, 0];
|
|
|
|
const bbox = [
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
this.data.rect[2] - this.data.rect[0],
|
|
|
|
this.data.rect[3] - this.data.rect[1],
|
|
|
|
];
|
|
|
|
|
|
|
|
const transform = getTransformMatrix(this.data.rect, bbox, matrix);
|
|
|
|
operatorList.addOp(OPS.beginAnnotation, [
|
[api-minor] Add `intent` support to the `PDFPageProxy.getOperatorList` method (issue 13704)
With this patch, the `PDFPageProxy.getOperatorList` method will now return `PDFOperatorList`-instances that also include Annotation-operatorLists (when those exist). Hence this closes a small, but potentially confusing, gap between the `render` and `getOperatorList` methods.
Previously we've been somewhat reluctant to do this, as explained below, but given that there's actual use-cases where it's required probably means that we'll *have* to implement it now.
Since we still need the ability to separate "normal" rendering operations from direct `getOperatorList` calls in the worker-thread, this API-change unfortunately causes the *internal* renderingIntent to become a bit "messy" which is indeed unfortunate (note the `"oplist-"` strings in various spots). As-is I suppose that it's not all that bad, but we may want to consider changing the *internal* renderingIntent to e.g. a bitfield in the future.
Besides fixing issue 13704, this patch would also be necessary if someone ever tries to implement e.g. issue 10165 (since currently `PDFPageProxy.getOperatorList` doesn't include Annotation-operatorLists).
*Please note:* This patch is *also* tagged "api-minor" for a second reason, which is that we're now including the Annotation-id in the `beginAnnotation` argument. The reason for this is to allow correlating the Annotation-data returned by `PDFPageProxy.getAnnotations`, with its corresponding operatorList-data (for those Annotations that have it).
2021-07-10 23:47:39 +09:00
|
|
|
this.data.id,
|
2020-08-05 21:40:31 +09:00
|
|
|
this.data.rect,
|
|
|
|
transform,
|
|
|
|
matrix,
|
|
|
|
]);
|
|
|
|
|
|
|
|
const stream = new StringStream(content);
|
|
|
|
return evaluator
|
|
|
|
.getOperatorList({
|
|
|
|
stream,
|
|
|
|
task,
|
Ensure that all necessary /Font resources are included when saving a `WidgetAnnotation`-instance (issue 12294)
This patch contains a possible approach for fixing issue 12294, which compared to other PRs is purposely limited to the affected `WidgetAnnotation` code.
As mentioned elsewhere, considering that we're (at least for now) trying to fix *one specific* case, I think that we should avoid modifying the `Dict` primitive[1] and/or avoid a solution that (indirectly) modifies an existing `Dict`-instance[2].
This patch simply fixes the issue at hand, since that seems easiest for now, and I'd suggest that we worry about a more general approach if/when that actually becomes necessary.
Hence the solution implemented here, for `WidgetAnnotation`, is to simply use a combination of the local *and* AcroForm /DR resources during OperatorList-parsing to ensure that things work correctly regardless of where a particular /Font resource is found.
For saving of form-data, on the other hand, we want to avoid increasing the file-size unnecessarily and need to be smarter than just merging all of the available resources. To achive this, a new `WidgetAnnotation._getSaveFieldResources` method will when necessary produce a combined resources `Dict` with only the minimum amount of data from the AcroForm /DR resources included.
---
[1] You want to avoid anything that could cause the general `Dict` implementation to become slower, or more complex, just for handling an edge-case in my opinion.
[2] If an existing `Dict`-instance is modified unexpectedly, that could very easily lead to problems elsewhere since e.g. `Dict`-instances created during parsing are not expected to be changed.
2020-09-10 17:21:34 +09:00
|
|
|
resources: this._fieldResources.mergedResources,
|
2020-08-05 21:40:31 +09:00
|
|
|
operatorList,
|
|
|
|
})
|
|
|
|
.then(function () {
|
|
|
|
operatorList.addOp(OPS.endAnnotation, []);
|
|
|
|
return operatorList;
|
|
|
|
});
|
|
|
|
}
|
2020-07-22 20:55:52 +09:00
|
|
|
);
|
2017-08-27 07:48:02 +09:00
|
|
|
}
|
2020-08-05 21:40:31 +09:00
|
|
|
|
2020-08-04 02:44:04 +09:00
|
|
|
async save(evaluator, task, annotationStorage) {
|
2022-04-01 02:18:30 +09:00
|
|
|
const storageEntry = annotationStorage
|
|
|
|
? annotationStorage.get(this.data.id)
|
|
|
|
: undefined;
|
|
|
|
let value = storageEntry && storageEntry.value;
|
2020-09-20 00:47:38 +09:00
|
|
|
if (value === this.data.fieldValue || value === undefined) {
|
2022-04-01 02:18:30 +09:00
|
|
|
if (!this._hasValueFromXFA) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
value = value || this.data.fieldValue;
|
2020-08-04 02:44:04 +09:00
|
|
|
}
|
|
|
|
|
2022-03-27 06:45:50 +09:00
|
|
|
// Value can be an array (with choice list and multiple selections)
|
|
|
|
if (
|
2022-04-01 02:18:30 +09:00
|
|
|
!this._hasValueFromXFA &&
|
2022-03-27 06:45:50 +09:00
|
|
|
Array.isArray(value) &&
|
|
|
|
Array.isArray(this.data.fieldValue) &&
|
|
|
|
value.length === this.data.fieldValue.length &&
|
|
|
|
value.every((x, i) => x === this.data.fieldValue[i])
|
|
|
|
) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2020-08-04 02:44:04 +09:00
|
|
|
let appearance = await this._getAppearance(
|
|
|
|
evaluator,
|
|
|
|
task,
|
|
|
|
annotationStorage
|
|
|
|
);
|
|
|
|
if (appearance === null) {
|
|
|
|
return null;
|
|
|
|
}
|
Ensure that all necessary /Font resources are included when saving a `WidgetAnnotation`-instance (issue 12294)
This patch contains a possible approach for fixing issue 12294, which compared to other PRs is purposely limited to the affected `WidgetAnnotation` code.
As mentioned elsewhere, considering that we're (at least for now) trying to fix *one specific* case, I think that we should avoid modifying the `Dict` primitive[1] and/or avoid a solution that (indirectly) modifies an existing `Dict`-instance[2].
This patch simply fixes the issue at hand, since that seems easiest for now, and I'd suggest that we worry about a more general approach if/when that actually becomes necessary.
Hence the solution implemented here, for `WidgetAnnotation`, is to simply use a combination of the local *and* AcroForm /DR resources during OperatorList-parsing to ensure that things work correctly regardless of where a particular /Font resource is found.
For saving of form-data, on the other hand, we want to avoid increasing the file-size unnecessarily and need to be smarter than just merging all of the available resources. To achive this, a new `WidgetAnnotation._getSaveFieldResources` method will when necessary produce a combined resources `Dict` with only the minimum amount of data from the AcroForm /DR resources included.
---
[1] You want to avoid anything that could cause the general `Dict` implementation to become slower, or more complex, just for handling an edge-case in my opinion.
[2] If an existing `Dict`-instance is modified unexpectedly, that could very easily lead to problems elsewhere since e.g. `Dict`-instances created during parsing are not expected to be changed.
2020-09-10 17:21:34 +09:00
|
|
|
const { xref } = evaluator;
|
2020-08-04 02:44:04 +09:00
|
|
|
|
Ensure that all necessary /Font resources are included when saving a `WidgetAnnotation`-instance (issue 12294)
This patch contains a possible approach for fixing issue 12294, which compared to other PRs is purposely limited to the affected `WidgetAnnotation` code.
As mentioned elsewhere, considering that we're (at least for now) trying to fix *one specific* case, I think that we should avoid modifying the `Dict` primitive[1] and/or avoid a solution that (indirectly) modifies an existing `Dict`-instance[2].
This patch simply fixes the issue at hand, since that seems easiest for now, and I'd suggest that we worry about a more general approach if/when that actually becomes necessary.
Hence the solution implemented here, for `WidgetAnnotation`, is to simply use a combination of the local *and* AcroForm /DR resources during OperatorList-parsing to ensure that things work correctly regardless of where a particular /Font resource is found.
For saving of form-data, on the other hand, we want to avoid increasing the file-size unnecessarily and need to be smarter than just merging all of the available resources. To achive this, a new `WidgetAnnotation._getSaveFieldResources` method will when necessary produce a combined resources `Dict` with only the minimum amount of data from the AcroForm /DR resources included.
---
[1] You want to avoid anything that could cause the general `Dict` implementation to become slower, or more complex, just for handling an edge-case in my opinion.
[2] If an existing `Dict`-instance is modified unexpectedly, that could very easily lead to problems elsewhere since e.g. `Dict`-instances created during parsing are not expected to be changed.
2020-09-10 17:21:34 +09:00
|
|
|
const dict = xref.fetchIfRef(this.ref);
|
2022-02-21 20:44:56 +09:00
|
|
|
if (!(dict instanceof Dict)) {
|
2020-08-04 02:44:04 +09:00
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
const bbox = [
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
this.data.rect[2] - this.data.rect[0],
|
|
|
|
this.data.rect[3] - this.data.rect[1],
|
|
|
|
];
|
|
|
|
|
2020-09-09 07:13:52 +09:00
|
|
|
const xfa = {
|
|
|
|
path: stringToPDFString(dict.get("T") || ""),
|
|
|
|
value,
|
|
|
|
};
|
|
|
|
|
Ensure that all necessary /Font resources are included when saving a `WidgetAnnotation`-instance (issue 12294)
This patch contains a possible approach for fixing issue 12294, which compared to other PRs is purposely limited to the affected `WidgetAnnotation` code.
As mentioned elsewhere, considering that we're (at least for now) trying to fix *one specific* case, I think that we should avoid modifying the `Dict` primitive[1] and/or avoid a solution that (indirectly) modifies an existing `Dict`-instance[2].
This patch simply fixes the issue at hand, since that seems easiest for now, and I'd suggest that we worry about a more general approach if/when that actually becomes necessary.
Hence the solution implemented here, for `WidgetAnnotation`, is to simply use a combination of the local *and* AcroForm /DR resources during OperatorList-parsing to ensure that things work correctly regardless of where a particular /Font resource is found.
For saving of form-data, on the other hand, we want to avoid increasing the file-size unnecessarily and need to be smarter than just merging all of the available resources. To achive this, a new `WidgetAnnotation._getSaveFieldResources` method will when necessary produce a combined resources `Dict` with only the minimum amount of data from the AcroForm /DR resources included.
---
[1] You want to avoid anything that could cause the general `Dict` implementation to become slower, or more complex, just for handling an edge-case in my opinion.
[2] If an existing `Dict`-instance is modified unexpectedly, that could very easily lead to problems elsewhere since e.g. `Dict`-instances created during parsing are not expected to be changed.
2020-09-10 17:21:34 +09:00
|
|
|
const newRef = xref.getNewRef();
|
|
|
|
const AP = new Dict(xref);
|
2020-08-04 02:44:04 +09:00
|
|
|
AP.set("N", newRef);
|
|
|
|
|
Ensure that all necessary /Font resources are included when saving a `WidgetAnnotation`-instance (issue 12294)
This patch contains a possible approach for fixing issue 12294, which compared to other PRs is purposely limited to the affected `WidgetAnnotation` code.
As mentioned elsewhere, considering that we're (at least for now) trying to fix *one specific* case, I think that we should avoid modifying the `Dict` primitive[1] and/or avoid a solution that (indirectly) modifies an existing `Dict`-instance[2].
This patch simply fixes the issue at hand, since that seems easiest for now, and I'd suggest that we worry about a more general approach if/when that actually becomes necessary.
Hence the solution implemented here, for `WidgetAnnotation`, is to simply use a combination of the local *and* AcroForm /DR resources during OperatorList-parsing to ensure that things work correctly regardless of where a particular /Font resource is found.
For saving of form-data, on the other hand, we want to avoid increasing the file-size unnecessarily and need to be smarter than just merging all of the available resources. To achive this, a new `WidgetAnnotation._getSaveFieldResources` method will when necessary produce a combined resources `Dict` with only the minimum amount of data from the AcroForm /DR resources included.
---
[1] You want to avoid anything that could cause the general `Dict` implementation to become slower, or more complex, just for handling an edge-case in my opinion.
[2] If an existing `Dict`-instance is modified unexpectedly, that could very easily lead to problems elsewhere since e.g. `Dict`-instances created during parsing are not expected to be changed.
2020-09-10 17:21:34 +09:00
|
|
|
const encrypt = xref.encrypt;
|
2020-08-04 02:44:04 +09:00
|
|
|
let originalTransform = null;
|
|
|
|
let newTransform = null;
|
|
|
|
if (encrypt) {
|
|
|
|
originalTransform = encrypt.createCipherTransform(
|
|
|
|
this.ref.num,
|
|
|
|
this.ref.gen
|
|
|
|
);
|
|
|
|
newTransform = encrypt.createCipherTransform(newRef.num, newRef.gen);
|
|
|
|
appearance = newTransform.encryptString(appearance);
|
|
|
|
}
|
|
|
|
|
2022-03-27 06:45:50 +09:00
|
|
|
const encoder = val => (isAscii(val) ? val : stringToUTF16BEString(val));
|
|
|
|
dict.set("V", Array.isArray(value) ? value.map(encoder) : encoder(value));
|
2020-08-04 02:44:04 +09:00
|
|
|
dict.set("AP", AP);
|
|
|
|
dict.set("M", `D:${getModificationDate()}`);
|
|
|
|
|
Ensure that all necessary /Font resources are included when saving a `WidgetAnnotation`-instance (issue 12294)
This patch contains a possible approach for fixing issue 12294, which compared to other PRs is purposely limited to the affected `WidgetAnnotation` code.
As mentioned elsewhere, considering that we're (at least for now) trying to fix *one specific* case, I think that we should avoid modifying the `Dict` primitive[1] and/or avoid a solution that (indirectly) modifies an existing `Dict`-instance[2].
This patch simply fixes the issue at hand, since that seems easiest for now, and I'd suggest that we worry about a more general approach if/when that actually becomes necessary.
Hence the solution implemented here, for `WidgetAnnotation`, is to simply use a combination of the local *and* AcroForm /DR resources during OperatorList-parsing to ensure that things work correctly regardless of where a particular /Font resource is found.
For saving of form-data, on the other hand, we want to avoid increasing the file-size unnecessarily and need to be smarter than just merging all of the available resources. To achive this, a new `WidgetAnnotation._getSaveFieldResources` method will when necessary produce a combined resources `Dict` with only the minimum amount of data from the AcroForm /DR resources included.
---
[1] You want to avoid anything that could cause the general `Dict` implementation to become slower, or more complex, just for handling an edge-case in my opinion.
[2] If an existing `Dict`-instance is modified unexpectedly, that could very easily lead to problems elsewhere since e.g. `Dict`-instances created during parsing are not expected to be changed.
2020-09-10 17:21:34 +09:00
|
|
|
const appearanceDict = new Dict(xref);
|
2020-08-04 02:44:04 +09:00
|
|
|
appearanceDict.set("Length", appearance.length);
|
|
|
|
appearanceDict.set("Subtype", Name.get("Form"));
|
Ensure that all necessary /Font resources are included when saving a `WidgetAnnotation`-instance (issue 12294)
This patch contains a possible approach for fixing issue 12294, which compared to other PRs is purposely limited to the affected `WidgetAnnotation` code.
As mentioned elsewhere, considering that we're (at least for now) trying to fix *one specific* case, I think that we should avoid modifying the `Dict` primitive[1] and/or avoid a solution that (indirectly) modifies an existing `Dict`-instance[2].
This patch simply fixes the issue at hand, since that seems easiest for now, and I'd suggest that we worry about a more general approach if/when that actually becomes necessary.
Hence the solution implemented here, for `WidgetAnnotation`, is to simply use a combination of the local *and* AcroForm /DR resources during OperatorList-parsing to ensure that things work correctly regardless of where a particular /Font resource is found.
For saving of form-data, on the other hand, we want to avoid increasing the file-size unnecessarily and need to be smarter than just merging all of the available resources. To achive this, a new `WidgetAnnotation._getSaveFieldResources` method will when necessary produce a combined resources `Dict` with only the minimum amount of data from the AcroForm /DR resources included.
---
[1] You want to avoid anything that could cause the general `Dict` implementation to become slower, or more complex, just for handling an edge-case in my opinion.
[2] If an existing `Dict`-instance is modified unexpectedly, that could very easily lead to problems elsewhere since e.g. `Dict`-instances created during parsing are not expected to be changed.
2020-09-10 17:21:34 +09:00
|
|
|
appearanceDict.set("Resources", this._getSaveFieldResources(xref));
|
2020-08-04 02:44:04 +09:00
|
|
|
appearanceDict.set("BBox", bbox);
|
|
|
|
|
|
|
|
const bufferOriginal = [`${this.ref.num} ${this.ref.gen} obj\n`];
|
|
|
|
writeDict(dict, bufferOriginal, originalTransform);
|
|
|
|
bufferOriginal.push("\nendobj\n");
|
|
|
|
|
|
|
|
const bufferNew = [`${newRef.num} ${newRef.gen} obj\n`];
|
|
|
|
writeDict(appearanceDict, bufferNew, newTransform);
|
2021-05-24 20:20:19 +09:00
|
|
|
bufferNew.push(" stream\n", appearance, "\nendstream\nendobj\n");
|
2020-08-04 02:44:04 +09:00
|
|
|
|
|
|
|
return [
|
|
|
|
// data for the original object
|
|
|
|
// V field changed + reference for new AP
|
2020-09-09 07:13:52 +09:00
|
|
|
{ ref: this.ref, data: bufferOriginal.join(""), xfa },
|
2020-08-04 02:44:04 +09:00
|
|
|
// data for the new AP
|
2020-09-09 07:13:52 +09:00
|
|
|
{ ref: newRef, data: bufferNew.join(""), xfa: null },
|
2020-08-04 02:44:04 +09:00
|
|
|
];
|
|
|
|
}
|
|
|
|
|
2020-08-05 21:40:31 +09:00
|
|
|
async _getAppearance(evaluator, task, annotationStorage) {
|
|
|
|
const isPassword = this.hasFieldFlag(AnnotationFieldFlag.PASSWORD);
|
2022-04-01 02:18:30 +09:00
|
|
|
if (isPassword) {
|
2020-08-05 21:40:31 +09:00
|
|
|
return null;
|
|
|
|
}
|
2022-04-01 02:18:30 +09:00
|
|
|
const storageEntry = annotationStorage
|
|
|
|
? annotationStorage.get(this.data.id)
|
|
|
|
: undefined;
|
2021-02-18 21:51:08 +09:00
|
|
|
let value = storageEntry && storageEntry.value;
|
2020-09-20 00:47:38 +09:00
|
|
|
if (value === undefined) {
|
2022-04-01 02:18:30 +09:00
|
|
|
if (!this._hasValueFromXFA || this.appearance) {
|
|
|
|
// The annotation hasn't been rendered so use the appearance.
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
// The annotation has its value in XFA datasets but not in the V field.
|
|
|
|
value = this.data.fieldValue;
|
|
|
|
if (!value) {
|
|
|
|
return "";
|
|
|
|
}
|
2020-09-20 00:47:38 +09:00
|
|
|
}
|
|
|
|
|
2020-12-20 02:12:44 +09:00
|
|
|
value = value.trim();
|
|
|
|
|
2020-08-05 21:40:31 +09:00
|
|
|
if (value === "") {
|
2020-09-20 00:47:38 +09:00
|
|
|
// the field is empty: nothing to render
|
2020-08-06 23:07:13 +09:00
|
|
|
return "";
|
2020-08-05 21:40:31 +09:00
|
|
|
}
|
|
|
|
|
2020-12-20 02:12:44 +09:00
|
|
|
let lineCount = -1;
|
|
|
|
if (this.data.multiLine) {
|
|
|
|
lineCount = value.split(/\r\n|\r|\n/).length;
|
|
|
|
}
|
|
|
|
|
2020-08-05 21:40:31 +09:00
|
|
|
const defaultPadding = 2;
|
|
|
|
const hPadding = defaultPadding;
|
|
|
|
const totalHeight = this.data.rect[3] - this.data.rect[1];
|
|
|
|
const totalWidth = this.data.rect[2] - this.data.rect[0];
|
|
|
|
|
2021-03-31 21:48:28 +09:00
|
|
|
if (!this._defaultAppearance) {
|
2020-12-18 21:17:23 +09:00
|
|
|
// The DA is required and must be a string.
|
|
|
|
// If there is no font named Helvetica in the resource dictionary,
|
|
|
|
// the evaluator will fall back to a default font.
|
|
|
|
// Doing so prevents exceptions and allows saving/printing
|
|
|
|
// the file as expected.
|
2021-01-22 06:33:43 +09:00
|
|
|
this.data.defaultAppearanceData = parseDefaultAppearance(
|
2021-03-31 21:48:28 +09:00
|
|
|
(this._defaultAppearance = "/Helvetica 0 Tf 0 g")
|
2021-01-22 04:15:31 +09:00
|
|
|
);
|
2020-12-18 21:17:23 +09:00
|
|
|
}
|
|
|
|
|
2022-01-28 06:51:30 +09:00
|
|
|
const font = await this._getFontData(evaluator, task);
|
2020-12-20 02:12:44 +09:00
|
|
|
const [defaultAppearance, fontSize] = this._computeFontSize(
|
2022-01-28 06:51:30 +09:00
|
|
|
totalHeight - defaultPadding,
|
|
|
|
totalWidth - 2 * hPadding,
|
|
|
|
value,
|
|
|
|
font,
|
2020-12-20 02:12:44 +09:00
|
|
|
lineCount
|
|
|
|
);
|
|
|
|
|
2020-08-05 21:40:31 +09:00
|
|
|
let descent = font.descent;
|
|
|
|
if (isNaN(descent)) {
|
|
|
|
descent = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
const vPadding = defaultPadding + Math.abs(descent) * fontSize;
|
|
|
|
const alignment = this.data.textAlignment;
|
2020-08-06 23:07:13 +09:00
|
|
|
|
2020-08-27 23:04:17 +09:00
|
|
|
if (this.data.multiLine) {
|
|
|
|
return this._getMultilineAppearance(
|
2020-08-06 23:45:17 +09:00
|
|
|
defaultAppearance,
|
|
|
|
value,
|
2020-08-27 23:04:17 +09:00
|
|
|
font,
|
|
|
|
fontSize,
|
2020-08-06 23:45:17 +09:00
|
|
|
totalWidth,
|
2020-08-27 23:04:17 +09:00
|
|
|
totalHeight,
|
|
|
|
alignment,
|
2020-08-06 23:45:17 +09:00
|
|
|
hPadding,
|
|
|
|
vPadding
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2020-08-27 23:04:17 +09:00
|
|
|
// TODO: need to handle chars which are not in the font.
|
|
|
|
const encodedString = font.encodeString(value).join("");
|
|
|
|
|
|
|
|
if (this.data.comb) {
|
|
|
|
return this._getCombAppearance(
|
2020-08-06 23:07:13 +09:00
|
|
|
defaultAppearance,
|
|
|
|
font,
|
2020-08-27 23:04:17 +09:00
|
|
|
encodedString,
|
2020-08-06 23:07:13 +09:00
|
|
|
totalWidth,
|
|
|
|
hPadding,
|
|
|
|
vPadding
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2020-08-05 21:40:31 +09:00
|
|
|
if (alignment === 0 || alignment > 2) {
|
|
|
|
// Left alignment: nothing to do
|
|
|
|
return (
|
|
|
|
"/Tx BMC q BT " +
|
|
|
|
defaultAppearance +
|
2020-08-27 23:04:17 +09:00
|
|
|
` 1 0 0 1 ${hPadding} ${vPadding} Tm (${escapeString(
|
|
|
|
encodedString
|
|
|
|
)}) Tj` +
|
2020-08-05 21:40:31 +09:00
|
|
|
" ET Q EMC"
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
const renderedText = this._renderText(
|
2020-08-27 23:04:17 +09:00
|
|
|
encodedString,
|
2020-08-05 21:40:31 +09:00
|
|
|
font,
|
|
|
|
fontSize,
|
|
|
|
totalWidth,
|
|
|
|
alignment,
|
|
|
|
hPadding,
|
|
|
|
vPadding
|
|
|
|
);
|
|
|
|
return (
|
|
|
|
"/Tx BMC q BT " +
|
|
|
|
defaultAppearance +
|
|
|
|
` 1 0 0 1 0 0 Tm ${renderedText}` +
|
|
|
|
" ET Q EMC"
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
async _getFontData(evaluator, task) {
|
|
|
|
const operatorList = new OperatorList();
|
|
|
|
const initialState = {
|
|
|
|
font: null,
|
|
|
|
clone() {
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
2021-01-22 06:33:43 +09:00
|
|
|
const { fontName, fontSize } = this.data.defaultAppearanceData;
|
2021-01-22 04:15:31 +09:00
|
|
|
await evaluator.handleSetFont(
|
|
|
|
this._fieldResources.mergedResources,
|
2021-04-01 22:19:45 +09:00
|
|
|
[fontName && Name.get(fontName), fontSize],
|
2021-01-22 04:15:31 +09:00
|
|
|
/* fontRef = */ null,
|
2020-08-05 21:40:31 +09:00
|
|
|
operatorList,
|
2021-01-22 04:15:31 +09:00
|
|
|
task,
|
2020-08-05 21:40:31 +09:00
|
|
|
initialState,
|
2021-01-22 04:15:31 +09:00
|
|
|
/* fallbackFontDict = */ null
|
|
|
|
);
|
2020-08-05 21:40:31 +09:00
|
|
|
|
2021-01-22 04:15:31 +09:00
|
|
|
return initialState.font;
|
2020-08-05 21:40:31 +09:00
|
|
|
}
|
|
|
|
|
2022-01-28 06:51:30 +09:00
|
|
|
_getTextWidth(text, font) {
|
|
|
|
return (
|
|
|
|
font
|
|
|
|
.charsToGlyphs(text)
|
|
|
|
.reduce((width, glyph) => width + glyph.width, 0) / 1000
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
_computeFontSize(height, width, text, font, lineCount) {
|
2020-12-20 02:12:44 +09:00
|
|
|
let { fontSize } = this.data.defaultAppearanceData;
|
2021-03-31 21:48:28 +09:00
|
|
|
if (!fontSize) {
|
2020-12-20 02:12:44 +09:00
|
|
|
// A zero value for size means that the font shall be auto-sized:
|
|
|
|
// its size shall be computed as a function of the height of the
|
|
|
|
// annotation rectangle (see 12.7.3.3).
|
|
|
|
|
2022-01-28 06:51:30 +09:00
|
|
|
const roundWithTwoDigits = x => Math.floor(x * 100) / 100;
|
|
|
|
|
2020-12-20 02:12:44 +09:00
|
|
|
if (lineCount === -1) {
|
2022-01-28 06:51:30 +09:00
|
|
|
const textWidth = this._getTextWidth(text, font);
|
|
|
|
fontSize = roundWithTwoDigits(
|
|
|
|
Math.min(height / LINE_FACTOR, width / textWidth)
|
|
|
|
);
|
2020-08-27 23:04:17 +09:00
|
|
|
} else {
|
2022-01-28 06:51:30 +09:00
|
|
|
const lines = text.split(/\r\n?|\n/);
|
|
|
|
const cachedLines = [];
|
|
|
|
for (const line of lines) {
|
|
|
|
const encoded = font.encodeString(line).join("");
|
|
|
|
const glyphs = font.charsToGlyphs(encoded);
|
|
|
|
const positions = font.getCharPositions(encoded);
|
|
|
|
cachedLines.push({
|
|
|
|
line: encoded,
|
|
|
|
glyphs,
|
|
|
|
positions,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
const isTooBig = fsize => {
|
|
|
|
// Return true when the text doesn't fit the given height.
|
|
|
|
let totalHeight = 0;
|
|
|
|
for (const cache of cachedLines) {
|
|
|
|
const chunks = this._splitLine(null, font, fsize, width, cache);
|
|
|
|
totalHeight += chunks.length * fsize;
|
|
|
|
if (totalHeight > height) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
};
|
|
|
|
|
2020-12-20 02:12:44 +09:00
|
|
|
// Hard to guess how many lines there are.
|
|
|
|
// The field may have been sized to have 10 lines
|
|
|
|
// and the user entered only 1 so if we get font size from
|
|
|
|
// height and number of lines then we'll get something too big.
|
|
|
|
// So we compute a fake number of lines based on height and
|
2022-01-28 06:51:30 +09:00
|
|
|
// a font size equal to 12 (this is the default font size in
|
|
|
|
// Acrobat).
|
2020-12-20 02:12:44 +09:00
|
|
|
// Then we'll adjust font size to what we have really.
|
2022-01-28 06:51:30 +09:00
|
|
|
fontSize = 12;
|
|
|
|
let lineHeight = fontSize * LINE_FACTOR;
|
2020-12-20 02:12:44 +09:00
|
|
|
let numberOfLines = Math.round(height / lineHeight);
|
|
|
|
numberOfLines = Math.max(numberOfLines, lineCount);
|
2022-01-28 06:51:30 +09:00
|
|
|
|
|
|
|
while (true) {
|
|
|
|
lineHeight = height / numberOfLines;
|
|
|
|
fontSize = roundWithTwoDigits(lineHeight / LINE_FACTOR);
|
|
|
|
|
|
|
|
if (isTooBig(fontSize)) {
|
|
|
|
numberOfLines++;
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
2020-08-27 23:04:17 +09:00
|
|
|
}
|
|
|
|
|
2020-12-20 02:12:44 +09:00
|
|
|
const { fontName, fontColor } = this.data.defaultAppearanceData;
|
2021-03-31 21:48:28 +09:00
|
|
|
this._defaultAppearance = createDefaultAppearance({
|
2021-01-22 04:15:31 +09:00
|
|
|
fontSize,
|
|
|
|
fontName,
|
|
|
|
fontColor,
|
|
|
|
});
|
2020-08-05 21:40:31 +09:00
|
|
|
}
|
2021-03-31 21:48:28 +09:00
|
|
|
return [this._defaultAppearance, fontSize];
|
2020-08-05 21:40:31 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
_renderText(text, font, fontSize, totalWidth, alignment, hPadding, vPadding) {
|
|
|
|
let shift;
|
|
|
|
if (alignment === 1) {
|
|
|
|
// Center
|
2022-03-27 06:45:50 +09:00
|
|
|
const width = this._getTextWidth(text, font) * fontSize;
|
2020-08-05 21:40:31 +09:00
|
|
|
shift = (totalWidth - width) / 2;
|
|
|
|
} else if (alignment === 2) {
|
|
|
|
// Right
|
2022-03-27 06:45:50 +09:00
|
|
|
const width = this._getTextWidth(text, font) * fontSize;
|
2020-08-05 21:40:31 +09:00
|
|
|
shift = totalWidth - width - hPadding;
|
|
|
|
} else {
|
|
|
|
shift = hPadding;
|
|
|
|
}
|
|
|
|
shift = shift.toFixed(2);
|
|
|
|
vPadding = vPadding.toFixed(2);
|
|
|
|
|
2020-08-06 23:07:13 +09:00
|
|
|
return `${shift} ${vPadding} Td (${escapeString(text)}) Tj`;
|
2020-08-05 21:40:31 +09:00
|
|
|
}
|
Ensure that all necessary /Font resources are included when saving a `WidgetAnnotation`-instance (issue 12294)
This patch contains a possible approach for fixing issue 12294, which compared to other PRs is purposely limited to the affected `WidgetAnnotation` code.
As mentioned elsewhere, considering that we're (at least for now) trying to fix *one specific* case, I think that we should avoid modifying the `Dict` primitive[1] and/or avoid a solution that (indirectly) modifies an existing `Dict`-instance[2].
This patch simply fixes the issue at hand, since that seems easiest for now, and I'd suggest that we worry about a more general approach if/when that actually becomes necessary.
Hence the solution implemented here, for `WidgetAnnotation`, is to simply use a combination of the local *and* AcroForm /DR resources during OperatorList-parsing to ensure that things work correctly regardless of where a particular /Font resource is found.
For saving of form-data, on the other hand, we want to avoid increasing the file-size unnecessarily and need to be smarter than just merging all of the available resources. To achive this, a new `WidgetAnnotation._getSaveFieldResources` method will when necessary produce a combined resources `Dict` with only the minimum amount of data from the AcroForm /DR resources included.
---
[1] You want to avoid anything that could cause the general `Dict` implementation to become slower, or more complex, just for handling an edge-case in my opinion.
[2] If an existing `Dict`-instance is modified unexpectedly, that could very easily lead to problems elsewhere since e.g. `Dict`-instances created during parsing are not expected to be changed.
2020-09-10 17:21:34 +09:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
_getSaveFieldResources(xref) {
|
|
|
|
if (
|
|
|
|
typeof PDFJSDev === "undefined" ||
|
|
|
|
PDFJSDev.test("!PRODUCTION || TESTING")
|
|
|
|
) {
|
|
|
|
assert(
|
2021-01-22 06:33:43 +09:00
|
|
|
this.data.defaultAppearanceData,
|
2021-01-22 21:09:15 +09:00
|
|
|
"Expected `_defaultAppearanceData` to have been set."
|
Ensure that all necessary /Font resources are included when saving a `WidgetAnnotation`-instance (issue 12294)
This patch contains a possible approach for fixing issue 12294, which compared to other PRs is purposely limited to the affected `WidgetAnnotation` code.
As mentioned elsewhere, considering that we're (at least for now) trying to fix *one specific* case, I think that we should avoid modifying the `Dict` primitive[1] and/or avoid a solution that (indirectly) modifies an existing `Dict`-instance[2].
This patch simply fixes the issue at hand, since that seems easiest for now, and I'd suggest that we worry about a more general approach if/when that actually becomes necessary.
Hence the solution implemented here, for `WidgetAnnotation`, is to simply use a combination of the local *and* AcroForm /DR resources during OperatorList-parsing to ensure that things work correctly regardless of where a particular /Font resource is found.
For saving of form-data, on the other hand, we want to avoid increasing the file-size unnecessarily and need to be smarter than just merging all of the available resources. To achive this, a new `WidgetAnnotation._getSaveFieldResources` method will when necessary produce a combined resources `Dict` with only the minimum amount of data from the AcroForm /DR resources included.
---
[1] You want to avoid anything that could cause the general `Dict` implementation to become slower, or more complex, just for handling an edge-case in my opinion.
[2] If an existing `Dict`-instance is modified unexpectedly, that could very easily lead to problems elsewhere since e.g. `Dict`-instances created during parsing are not expected to be changed.
2020-09-10 17:21:34 +09:00
|
|
|
);
|
|
|
|
}
|
2021-05-16 17:58:34 +09:00
|
|
|
const { localResources, appearanceResources, acroFormResources } =
|
|
|
|
this._fieldResources;
|
Ensure that all necessary /Font resources are included when saving a `WidgetAnnotation`-instance (issue 12294)
This patch contains a possible approach for fixing issue 12294, which compared to other PRs is purposely limited to the affected `WidgetAnnotation` code.
As mentioned elsewhere, considering that we're (at least for now) trying to fix *one specific* case, I think that we should avoid modifying the `Dict` primitive[1] and/or avoid a solution that (indirectly) modifies an existing `Dict`-instance[2].
This patch simply fixes the issue at hand, since that seems easiest for now, and I'd suggest that we worry about a more general approach if/when that actually becomes necessary.
Hence the solution implemented here, for `WidgetAnnotation`, is to simply use a combination of the local *and* AcroForm /DR resources during OperatorList-parsing to ensure that things work correctly regardless of where a particular /Font resource is found.
For saving of form-data, on the other hand, we want to avoid increasing the file-size unnecessarily and need to be smarter than just merging all of the available resources. To achive this, a new `WidgetAnnotation._getSaveFieldResources` method will when necessary produce a combined resources `Dict` with only the minimum amount of data from the AcroForm /DR resources included.
---
[1] You want to avoid anything that could cause the general `Dict` implementation to become slower, or more complex, just for handling an edge-case in my opinion.
[2] If an existing `Dict`-instance is modified unexpectedly, that could very easily lead to problems elsewhere since e.g. `Dict`-instances created during parsing are not expected to be changed.
2020-09-10 17:21:34 +09:00
|
|
|
|
2021-04-01 22:19:45 +09:00
|
|
|
const fontName =
|
2021-01-22 06:33:43 +09:00
|
|
|
this.data.defaultAppearanceData &&
|
2021-04-01 22:19:45 +09:00
|
|
|
this.data.defaultAppearanceData.fontName;
|
|
|
|
if (!fontName) {
|
Ensure that all necessary /Font resources are included when saving a `WidgetAnnotation`-instance (issue 12294)
This patch contains a possible approach for fixing issue 12294, which compared to other PRs is purposely limited to the affected `WidgetAnnotation` code.
As mentioned elsewhere, considering that we're (at least for now) trying to fix *one specific* case, I think that we should avoid modifying the `Dict` primitive[1] and/or avoid a solution that (indirectly) modifies an existing `Dict`-instance[2].
This patch simply fixes the issue at hand, since that seems easiest for now, and I'd suggest that we worry about a more general approach if/when that actually becomes necessary.
Hence the solution implemented here, for `WidgetAnnotation`, is to simply use a combination of the local *and* AcroForm /DR resources during OperatorList-parsing to ensure that things work correctly regardless of where a particular /Font resource is found.
For saving of form-data, on the other hand, we want to avoid increasing the file-size unnecessarily and need to be smarter than just merging all of the available resources. To achive this, a new `WidgetAnnotation._getSaveFieldResources` method will when necessary produce a combined resources `Dict` with only the minimum amount of data from the AcroForm /DR resources included.
---
[1] You want to avoid anything that could cause the general `Dict` implementation to become slower, or more complex, just for handling an edge-case in my opinion.
[2] If an existing `Dict`-instance is modified unexpectedly, that could very easily lead to problems elsewhere since e.g. `Dict`-instances created during parsing are not expected to be changed.
2020-09-10 17:21:34 +09:00
|
|
|
return localResources || Dict.empty;
|
|
|
|
}
|
2020-09-20 00:11:04 +09:00
|
|
|
|
|
|
|
for (const resources of [localResources, appearanceResources]) {
|
|
|
|
if (resources instanceof Dict) {
|
|
|
|
const localFont = resources.get("Font");
|
2021-04-01 22:19:45 +09:00
|
|
|
if (localFont instanceof Dict && localFont.has(fontName)) {
|
2020-09-20 00:11:04 +09:00
|
|
|
return resources;
|
|
|
|
}
|
Ensure that all necessary /Font resources are included when saving a `WidgetAnnotation`-instance (issue 12294)
This patch contains a possible approach for fixing issue 12294, which compared to other PRs is purposely limited to the affected `WidgetAnnotation` code.
As mentioned elsewhere, considering that we're (at least for now) trying to fix *one specific* case, I think that we should avoid modifying the `Dict` primitive[1] and/or avoid a solution that (indirectly) modifies an existing `Dict`-instance[2].
This patch simply fixes the issue at hand, since that seems easiest for now, and I'd suggest that we worry about a more general approach if/when that actually becomes necessary.
Hence the solution implemented here, for `WidgetAnnotation`, is to simply use a combination of the local *and* AcroForm /DR resources during OperatorList-parsing to ensure that things work correctly regardless of where a particular /Font resource is found.
For saving of form-data, on the other hand, we want to avoid increasing the file-size unnecessarily and need to be smarter than just merging all of the available resources. To achive this, a new `WidgetAnnotation._getSaveFieldResources` method will when necessary produce a combined resources `Dict` with only the minimum amount of data from the AcroForm /DR resources included.
---
[1] You want to avoid anything that could cause the general `Dict` implementation to become slower, or more complex, just for handling an edge-case in my opinion.
[2] If an existing `Dict`-instance is modified unexpectedly, that could very easily lead to problems elsewhere since e.g. `Dict`-instances created during parsing are not expected to be changed.
2020-09-10 17:21:34 +09:00
|
|
|
}
|
|
|
|
}
|
|
|
|
if (acroFormResources instanceof Dict) {
|
|
|
|
const acroFormFont = acroFormResources.get("Font");
|
2021-04-01 22:19:45 +09:00
|
|
|
if (acroFormFont instanceof Dict && acroFormFont.has(fontName)) {
|
Ensure that all necessary /Font resources are included when saving a `WidgetAnnotation`-instance (issue 12294)
This patch contains a possible approach for fixing issue 12294, which compared to other PRs is purposely limited to the affected `WidgetAnnotation` code.
As mentioned elsewhere, considering that we're (at least for now) trying to fix *one specific* case, I think that we should avoid modifying the `Dict` primitive[1] and/or avoid a solution that (indirectly) modifies an existing `Dict`-instance[2].
This patch simply fixes the issue at hand, since that seems easiest for now, and I'd suggest that we worry about a more general approach if/when that actually becomes necessary.
Hence the solution implemented here, for `WidgetAnnotation`, is to simply use a combination of the local *and* AcroForm /DR resources during OperatorList-parsing to ensure that things work correctly regardless of where a particular /Font resource is found.
For saving of form-data, on the other hand, we want to avoid increasing the file-size unnecessarily and need to be smarter than just merging all of the available resources. To achive this, a new `WidgetAnnotation._getSaveFieldResources` method will when necessary produce a combined resources `Dict` with only the minimum amount of data from the AcroForm /DR resources included.
---
[1] You want to avoid anything that could cause the general `Dict` implementation to become slower, or more complex, just for handling an edge-case in my opinion.
[2] If an existing `Dict`-instance is modified unexpectedly, that could very easily lead to problems elsewhere since e.g. `Dict`-instances created during parsing are not expected to be changed.
2020-09-10 17:21:34 +09:00
|
|
|
const subFontDict = new Dict(xref);
|
2021-04-01 22:19:45 +09:00
|
|
|
subFontDict.set(fontName, acroFormFont.getRaw(fontName));
|
Ensure that all necessary /Font resources are included when saving a `WidgetAnnotation`-instance (issue 12294)
This patch contains a possible approach for fixing issue 12294, which compared to other PRs is purposely limited to the affected `WidgetAnnotation` code.
As mentioned elsewhere, considering that we're (at least for now) trying to fix *one specific* case, I think that we should avoid modifying the `Dict` primitive[1] and/or avoid a solution that (indirectly) modifies an existing `Dict`-instance[2].
This patch simply fixes the issue at hand, since that seems easiest for now, and I'd suggest that we worry about a more general approach if/when that actually becomes necessary.
Hence the solution implemented here, for `WidgetAnnotation`, is to simply use a combination of the local *and* AcroForm /DR resources during OperatorList-parsing to ensure that things work correctly regardless of where a particular /Font resource is found.
For saving of form-data, on the other hand, we want to avoid increasing the file-size unnecessarily and need to be smarter than just merging all of the available resources. To achive this, a new `WidgetAnnotation._getSaveFieldResources` method will when necessary produce a combined resources `Dict` with only the minimum amount of data from the AcroForm /DR resources included.
---
[1] You want to avoid anything that could cause the general `Dict` implementation to become slower, or more complex, just for handling an edge-case in my opinion.
[2] If an existing `Dict`-instance is modified unexpectedly, that could very easily lead to problems elsewhere since e.g. `Dict`-instances created during parsing are not expected to be changed.
2020-09-10 17:21:34 +09:00
|
|
|
|
|
|
|
const subResourcesDict = new Dict(xref);
|
|
|
|
subResourcesDict.set("Font", subFontDict);
|
|
|
|
|
|
|
|
return Dict.merge({
|
|
|
|
xref,
|
|
|
|
dictArray: [subResourcesDict, localResources],
|
|
|
|
mergeSubDicts: true,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return localResources || Dict.empty;
|
|
|
|
}
|
2020-10-01 03:58:45 +09:00
|
|
|
|
|
|
|
getFieldObject() {
|
|
|
|
return null;
|
|
|
|
}
|
2017-08-27 06:49:11 +09:00
|
|
|
}
|
2016-11-02 08:07:31 +09:00
|
|
|
|
2017-08-27 06:49:11 +09:00
|
|
|
class TextWidgetAnnotation extends WidgetAnnotation {
|
|
|
|
constructor(params) {
|
|
|
|
super(params);
|
2013-03-26 07:32:47 +09:00
|
|
|
|
2020-08-05 21:40:31 +09:00
|
|
|
this._hasText = true;
|
|
|
|
|
2018-02-19 05:42:33 +09:00
|
|
|
const dict = params.dict;
|
|
|
|
|
2016-09-25 08:45:49 +09:00
|
|
|
// The field value is always a string.
|
2022-02-24 01:02:19 +09:00
|
|
|
if (typeof this.data.fieldValue !== "string") {
|
2020-08-22 22:02:29 +09:00
|
|
|
this.data.fieldValue = "";
|
|
|
|
}
|
2016-09-25 08:45:49 +09:00
|
|
|
|
2016-09-13 21:57:11 +09:00
|
|
|
// Determine the alignment of text in the field.
|
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 alignment = getInheritableProperty({ dict, key: "Q" });
|
2017-09-01 23:52:50 +09:00
|
|
|
if (!Number.isInteger(alignment) || alignment < 0 || alignment > 2) {
|
2016-09-13 21:57:11 +09:00
|
|
|
alignment = null;
|
|
|
|
}
|
|
|
|
this.data.textAlignment = alignment;
|
|
|
|
|
|
|
|
// Determine the maximum length of text in the field.
|
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 maximumLength = getInheritableProperty({ dict, key: "MaxLen" });
|
2017-09-01 23:52:50 +09:00
|
|
|
if (!Number.isInteger(maximumLength) || maximumLength < 0) {
|
2016-09-13 21:57:11 +09:00
|
|
|
maximumLength = null;
|
|
|
|
}
|
|
|
|
this.data.maxLen = maximumLength;
|
2016-09-14 23:32:51 +09:00
|
|
|
|
|
|
|
// Process field flags for the display layer.
|
|
|
|
this.data.multiLine = this.hasFieldFlag(AnnotationFieldFlag.MULTILINE);
|
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.data.comb =
|
|
|
|
this.hasFieldFlag(AnnotationFieldFlag.COMB) &&
|
|
|
|
!this.hasFieldFlag(AnnotationFieldFlag.MULTILINE) &&
|
|
|
|
!this.hasFieldFlag(AnnotationFieldFlag.PASSWORD) &&
|
|
|
|
!this.hasFieldFlag(AnnotationFieldFlag.FILESELECT) &&
|
|
|
|
this.data.maxLen !== null;
|
2013-03-26 07:32:47 +09:00
|
|
|
}
|
2020-08-06 23:07:13 +09:00
|
|
|
|
2020-08-27 23:04:17 +09:00
|
|
|
_getCombAppearance(defaultAppearance, font, text, width, hPadding, vPadding) {
|
2020-08-06 23:45:17 +09:00
|
|
|
const combWidth = (width / this.data.maxLen).toFixed(2);
|
|
|
|
const buf = [];
|
2020-08-27 23:04:17 +09:00
|
|
|
const positions = font.getCharPositions(text);
|
|
|
|
for (const [start, end] of positions) {
|
|
|
|
buf.push(`(${escapeString(text.substring(start, end))}) Tj`);
|
2020-08-06 23:45:17 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
const renderedComb = buf.join(` ${combWidth} 0 Td `);
|
|
|
|
return (
|
|
|
|
"/Tx BMC q BT " +
|
|
|
|
defaultAppearance +
|
|
|
|
` 1 0 0 1 ${hPadding} ${vPadding} Tm ${renderedComb}` +
|
|
|
|
" ET Q EMC"
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2020-08-06 23:07:13 +09:00
|
|
|
_getMultilineAppearance(
|
|
|
|
defaultAppearance,
|
|
|
|
text,
|
|
|
|
font,
|
|
|
|
fontSize,
|
|
|
|
width,
|
|
|
|
height,
|
|
|
|
alignment,
|
|
|
|
hPadding,
|
|
|
|
vPadding
|
|
|
|
) {
|
2022-01-28 06:51:30 +09:00
|
|
|
const lines = text.split(/\r\n?|\n/);
|
2020-08-06 23:07:13 +09:00
|
|
|
const buf = [];
|
|
|
|
const totalWidth = width - 2 * hPadding;
|
|
|
|
for (const line of lines) {
|
|
|
|
const chunks = this._splitLine(line, font, fontSize, totalWidth);
|
|
|
|
for (const chunk of chunks) {
|
|
|
|
const padding = buf.length === 0 ? hPadding : 0;
|
|
|
|
buf.push(
|
|
|
|
this._renderText(
|
|
|
|
chunk,
|
|
|
|
font,
|
|
|
|
fontSize,
|
|
|
|
width,
|
|
|
|
alignment,
|
|
|
|
padding,
|
|
|
|
-fontSize // <0 because a line is below the previous one
|
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
const renderedText = buf.join("\n");
|
|
|
|
return (
|
|
|
|
"/Tx BMC q BT " +
|
|
|
|
defaultAppearance +
|
|
|
|
` 1 0 0 1 0 ${height} Tm ${renderedText}` +
|
|
|
|
" ET Q EMC"
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2022-01-28 06:51:30 +09:00
|
|
|
_splitLine(line, font, fontSize, width, cache = {}) {
|
2020-08-27 23:04:17 +09:00
|
|
|
// TODO: need to handle chars which are not in the font.
|
2022-01-28 06:51:30 +09:00
|
|
|
line = cache.line || font.encodeString(line).join("");
|
2020-08-27 23:04:17 +09:00
|
|
|
|
2022-01-28 06:51:30 +09:00
|
|
|
const glyphs = cache.glyphs || font.charsToGlyphs(line);
|
2020-08-27 23:04:17 +09:00
|
|
|
|
|
|
|
if (glyphs.length <= 1) {
|
2020-08-06 23:07:13 +09:00
|
|
|
// Nothing to split
|
|
|
|
return [line];
|
|
|
|
}
|
|
|
|
|
2022-01-28 06:51:30 +09:00
|
|
|
const positions = cache.positions || font.getCharPositions(line);
|
2020-08-06 23:07:13 +09:00
|
|
|
const scale = fontSize / 1000;
|
|
|
|
const chunks = [];
|
|
|
|
|
2020-08-27 23:04:17 +09:00
|
|
|
let lastSpacePosInStringStart = -1,
|
|
|
|
lastSpacePosInStringEnd = -1,
|
|
|
|
lastSpacePos = -1,
|
2020-08-06 23:07:13 +09:00
|
|
|
startChunk = 0,
|
|
|
|
currentWidth = 0;
|
|
|
|
|
2020-08-27 23:04:17 +09:00
|
|
|
for (let i = 0, ii = glyphs.length; i < ii; i++) {
|
|
|
|
const [start, end] = positions[i];
|
|
|
|
const glyph = glyphs[i];
|
|
|
|
const glyphWidth = glyph.width * scale;
|
|
|
|
if (glyph.unicode === " ") {
|
|
|
|
if (currentWidth + glyphWidth > width) {
|
2020-08-06 23:07:13 +09:00
|
|
|
// We can break here
|
2020-08-27 23:04:17 +09:00
|
|
|
chunks.push(line.substring(startChunk, start));
|
|
|
|
startChunk = start;
|
|
|
|
currentWidth = glyphWidth;
|
|
|
|
lastSpacePosInStringStart = -1;
|
2020-08-06 23:07:13 +09:00
|
|
|
lastSpacePos = -1;
|
|
|
|
} else {
|
2020-08-27 23:04:17 +09:00
|
|
|
currentWidth += glyphWidth;
|
|
|
|
lastSpacePosInStringStart = start;
|
|
|
|
lastSpacePosInStringEnd = end;
|
2020-08-06 23:07:13 +09:00
|
|
|
lastSpacePos = i;
|
|
|
|
}
|
|
|
|
} else {
|
2020-08-27 23:04:17 +09:00
|
|
|
if (currentWidth + glyphWidth > width) {
|
2020-08-06 23:07:13 +09:00
|
|
|
// We must break to the last white position (if available)
|
2020-08-27 23:04:17 +09:00
|
|
|
if (lastSpacePosInStringStart !== -1) {
|
|
|
|
chunks.push(line.substring(startChunk, lastSpacePosInStringEnd));
|
|
|
|
startChunk = lastSpacePosInStringEnd;
|
|
|
|
i = lastSpacePos + 1;
|
|
|
|
lastSpacePosInStringStart = -1;
|
2020-08-06 23:07:13 +09:00
|
|
|
currentWidth = 0;
|
|
|
|
} else {
|
|
|
|
// Just break in the middle of the word
|
2020-08-27 23:04:17 +09:00
|
|
|
chunks.push(line.substring(startChunk, start));
|
|
|
|
startChunk = start;
|
|
|
|
currentWidth = glyphWidth;
|
2020-08-06 23:07:13 +09:00
|
|
|
}
|
|
|
|
} else {
|
2020-08-27 23:04:17 +09:00
|
|
|
currentWidth += glyphWidth;
|
2020-08-06 23:07:13 +09:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (startChunk < line.length) {
|
|
|
|
chunks.push(line.substring(startChunk, line.length));
|
|
|
|
}
|
|
|
|
|
|
|
|
return chunks;
|
|
|
|
}
|
2020-10-01 03:58:45 +09:00
|
|
|
|
|
|
|
getFieldObject() {
|
|
|
|
return {
|
|
|
|
id: this.data.id,
|
|
|
|
value: this.data.fieldValue,
|
2020-11-04 00:53:21 +09:00
|
|
|
defaultValue: this.data.defaultFieldValue,
|
2020-10-01 03:58:45 +09:00
|
|
|
multiline: this.data.multiLine,
|
|
|
|
password: this.hasFieldFlag(AnnotationFieldFlag.PASSWORD),
|
|
|
|
charLimit: this.data.maxLen,
|
|
|
|
comb: this.data.comb,
|
|
|
|
editable: !this.data.readOnly,
|
|
|
|
hidden: this.data.hidden,
|
|
|
|
name: this.data.fieldName,
|
|
|
|
rect: this.data.rect,
|
|
|
|
actions: this.data.actions,
|
2021-04-30 23:43:27 +09:00
|
|
|
page: this.data.pageIndex,
|
2021-09-19 03:22:29 +09:00
|
|
|
strokeColor: this.data.borderColor,
|
|
|
|
fillColor: this.data.backgroundColor,
|
2020-10-01 03:58:45 +09:00
|
|
|
type: "text",
|
|
|
|
};
|
|
|
|
}
|
2017-08-27 06:49:11 +09:00
|
|
|
}
|
2013-03-26 07:32:47 +09:00
|
|
|
|
2017-08-27 06:49:11 +09:00
|
|
|
class ButtonWidgetAnnotation extends WidgetAnnotation {
|
|
|
|
constructor(params) {
|
|
|
|
super(params);
|
2016-11-04 21:01:42 +09:00
|
|
|
|
2020-07-23 00:10:59 +09:00
|
|
|
this.checkedAppearance = null;
|
|
|
|
this.uncheckedAppearance = 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.data.checkBox =
|
|
|
|
!this.hasFieldFlag(AnnotationFieldFlag.RADIO) &&
|
|
|
|
!this.hasFieldFlag(AnnotationFieldFlag.PUSHBUTTON);
|
|
|
|
this.data.radioButton =
|
|
|
|
this.hasFieldFlag(AnnotationFieldFlag.RADIO) &&
|
|
|
|
!this.hasFieldFlag(AnnotationFieldFlag.PUSHBUTTON);
|
2017-11-21 07:00:19 +09:00
|
|
|
this.data.pushButton = this.hasFieldFlag(AnnotationFieldFlag.PUSHBUTTON);
|
2020-09-07 00:14:56 +09:00
|
|
|
this.data.isTooltipOnly = false;
|
2017-11-21 07:00:19 +09:00
|
|
|
|
2016-12-16 07:49:46 +09:00
|
|
|
if (this.data.checkBox) {
|
2018-07-07 09:51:10 +09:00
|
|
|
this._processCheckBox(params);
|
2017-11-21 07:00:19 +09:00
|
|
|
} else if (this.data.radioButton) {
|
|
|
|
this._processRadioButton(params);
|
|
|
|
} else if (this.data.pushButton) {
|
2021-11-07 02:36:49 +09:00
|
|
|
this.data.hasOwnCanvas = true;
|
2017-11-21 07:00:19 +09:00
|
|
|
this._processPushButton(params);
|
|
|
|
} 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
|
|
|
warn("Invalid field flags for button widget annotation");
|
2016-11-04 21:01:42 +09:00
|
|
|
}
|
2017-11-21 07:00:19 +09:00
|
|
|
}
|
2016-12-16 06:58:27 +09:00
|
|
|
|
2021-11-07 02:36:49 +09:00
|
|
|
async getOperatorList(
|
|
|
|
evaluator,
|
|
|
|
task,
|
|
|
|
intent,
|
|
|
|
renderForms,
|
|
|
|
annotationStorage
|
|
|
|
) {
|
2020-08-27 03:26:18 +09:00
|
|
|
if (this.data.pushButton) {
|
|
|
|
return super.getOperatorList(
|
|
|
|
evaluator,
|
|
|
|
task,
|
2021-11-07 02:36:49 +09:00
|
|
|
intent,
|
2020-08-27 03:26:18 +09:00
|
|
|
false, // we use normalAppearance to render the button
|
|
|
|
annotationStorage
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2021-09-17 22:31:22 +09:00
|
|
|
let value = null;
|
2020-07-23 00:10:59 +09:00
|
|
|
if (annotationStorage) {
|
2021-02-18 21:51:08 +09:00
|
|
|
const storageEntry = annotationStorage.get(this.data.id);
|
2021-09-17 22:31:22 +09:00
|
|
|
value = storageEntry ? storageEntry.value : null;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (value === null) {
|
|
|
|
// Nothing in the annotationStorage.
|
|
|
|
if (this.appearance) {
|
|
|
|
// But we've a default appearance so use it.
|
2020-09-20 00:47:38 +09:00
|
|
|
return super.getOperatorList(
|
|
|
|
evaluator,
|
|
|
|
task,
|
2021-11-07 02:36:49 +09:00
|
|
|
intent,
|
2020-09-20 00:47:38 +09:00
|
|
|
renderForms,
|
|
|
|
annotationStorage
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2021-09-17 22:31:22 +09:00
|
|
|
// There is no default appearance so use the one derived
|
|
|
|
// from the field value.
|
|
|
|
if (this.data.checkBox) {
|
|
|
|
value = this.data.fieldValue === this.data.exportValue;
|
2020-07-23 00:10:59 +09:00
|
|
|
} else {
|
2021-09-17 22:31:22 +09:00
|
|
|
value = this.data.fieldValue === this.data.buttonValue;
|
2020-07-23 00:10:59 +09:00
|
|
|
}
|
2021-09-17 22:31:22 +09:00
|
|
|
}
|
2020-07-23 00:10:59 +09:00
|
|
|
|
2021-09-17 22:31:22 +09:00
|
|
|
const appearance = value
|
|
|
|
? this.checkedAppearance
|
|
|
|
: this.uncheckedAppearance;
|
|
|
|
if (appearance) {
|
|
|
|
const savedAppearance = this.appearance;
|
|
|
|
this.appearance = appearance;
|
|
|
|
const operatorList = super.getOperatorList(
|
|
|
|
evaluator,
|
|
|
|
task,
|
2021-11-07 02:36:49 +09:00
|
|
|
intent,
|
2021-09-17 22:31:22 +09:00
|
|
|
renderForms,
|
|
|
|
annotationStorage
|
|
|
|
);
|
|
|
|
this.appearance = savedAppearance;
|
|
|
|
return operatorList;
|
2020-07-23 00:10:59 +09:00
|
|
|
}
|
2021-09-17 22:31:22 +09:00
|
|
|
|
|
|
|
// No appearance
|
|
|
|
return new OperatorList();
|
2020-07-23 00:10:59 +09:00
|
|
|
}
|
|
|
|
|
2020-08-04 02:44:04 +09:00
|
|
|
async save(evaluator, task, annotationStorage) {
|
|
|
|
if (this.data.checkBox) {
|
|
|
|
return this._saveCheckbox(evaluator, task, annotationStorage);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (this.data.radioButton) {
|
|
|
|
return this._saveRadioButton(evaluator, task, annotationStorage);
|
|
|
|
}
|
|
|
|
|
2020-09-09 02:07:10 +09:00
|
|
|
// Nothing to save
|
|
|
|
return null;
|
2020-08-04 02:44:04 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
async _saveCheckbox(evaluator, task, annotationStorage) {
|
2021-02-18 21:51:08 +09:00
|
|
|
if (!annotationStorage) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
const storageEntry = annotationStorage.get(this.data.id);
|
|
|
|
const value = storageEntry && storageEntry.value;
|
2020-09-20 00:47:38 +09:00
|
|
|
if (value === undefined) {
|
|
|
|
return null;
|
|
|
|
}
|
2020-08-04 02:44:04 +09:00
|
|
|
|
2021-09-17 22:31:22 +09:00
|
|
|
const defaultValue = this.data.fieldValue === this.data.exportValue;
|
2020-08-04 02:44:04 +09:00
|
|
|
if (defaultValue === value) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
const dict = evaluator.xref.fetchIfRef(this.ref);
|
2022-02-21 20:44:56 +09:00
|
|
|
if (!(dict instanceof Dict)) {
|
2020-08-04 02:44:04 +09:00
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2020-09-09 07:13:52 +09:00
|
|
|
const xfa = {
|
|
|
|
path: stringToPDFString(dict.get("T") || ""),
|
|
|
|
value: value ? this.data.exportValue : "",
|
|
|
|
};
|
|
|
|
|
2020-08-04 02:44:04 +09:00
|
|
|
const name = Name.get(value ? this.data.exportValue : "Off");
|
|
|
|
dict.set("V", name);
|
|
|
|
dict.set("AS", name);
|
|
|
|
dict.set("M", `D:${getModificationDate()}`);
|
|
|
|
|
|
|
|
const encrypt = evaluator.xref.encrypt;
|
|
|
|
let originalTransform = null;
|
|
|
|
if (encrypt) {
|
|
|
|
originalTransform = encrypt.createCipherTransform(
|
|
|
|
this.ref.num,
|
|
|
|
this.ref.gen
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
const buffer = [`${this.ref.num} ${this.ref.gen} obj\n`];
|
|
|
|
writeDict(dict, buffer, originalTransform);
|
|
|
|
buffer.push("\nendobj\n");
|
|
|
|
|
2020-09-09 07:13:52 +09:00
|
|
|
return [{ ref: this.ref, data: buffer.join(""), xfa }];
|
2020-08-04 02:44:04 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
async _saveRadioButton(evaluator, task, annotationStorage) {
|
2021-02-18 21:51:08 +09:00
|
|
|
if (!annotationStorage) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
const storageEntry = annotationStorage.get(this.data.id);
|
|
|
|
const value = storageEntry && storageEntry.value;
|
2020-09-20 00:47:38 +09:00
|
|
|
if (value === undefined) {
|
|
|
|
return null;
|
|
|
|
}
|
2020-08-04 02:44:04 +09:00
|
|
|
|
2020-09-20 00:47:38 +09:00
|
|
|
const defaultValue = this.data.fieldValue === this.data.buttonValue;
|
2020-08-04 02:44:04 +09:00
|
|
|
if (defaultValue === value) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
const dict = evaluator.xref.fetchIfRef(this.ref);
|
2022-02-21 20:44:56 +09:00
|
|
|
if (!(dict instanceof Dict)) {
|
2020-08-04 02:44:04 +09:00
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2020-09-09 07:13:52 +09:00
|
|
|
const xfa = {
|
|
|
|
path: stringToPDFString(dict.get("T") || ""),
|
|
|
|
value: value ? this.data.buttonValue : "",
|
|
|
|
};
|
|
|
|
|
2020-08-04 02:44:04 +09:00
|
|
|
const name = Name.get(value ? this.data.buttonValue : "Off");
|
|
|
|
let parentBuffer = null;
|
|
|
|
const encrypt = evaluator.xref.encrypt;
|
|
|
|
|
|
|
|
if (value) {
|
2022-02-18 20:11:45 +09:00
|
|
|
if (this.parent instanceof Ref) {
|
2020-08-04 02:44:04 +09:00
|
|
|
const parent = evaluator.xref.fetch(this.parent);
|
|
|
|
let parentTransform = null;
|
|
|
|
if (encrypt) {
|
|
|
|
parentTransform = encrypt.createCipherTransform(
|
|
|
|
this.parent.num,
|
|
|
|
this.parent.gen
|
|
|
|
);
|
|
|
|
}
|
|
|
|
parent.set("V", name);
|
|
|
|
parentBuffer = [`${this.parent.num} ${this.parent.gen} obj\n`];
|
|
|
|
writeDict(parent, parentBuffer, parentTransform);
|
|
|
|
parentBuffer.push("\nendobj\n");
|
2022-02-21 20:44:56 +09:00
|
|
|
} else if (this.parent instanceof Dict) {
|
2020-08-04 02:44:04 +09:00
|
|
|
this.parent.set("V", name);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
dict.set("AS", name);
|
|
|
|
dict.set("M", `D:${getModificationDate()}`);
|
|
|
|
|
|
|
|
let originalTransform = null;
|
|
|
|
if (encrypt) {
|
|
|
|
originalTransform = encrypt.createCipherTransform(
|
|
|
|
this.ref.num,
|
|
|
|
this.ref.gen
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
const buffer = [`${this.ref.num} ${this.ref.gen} obj\n`];
|
|
|
|
writeDict(dict, buffer, originalTransform);
|
|
|
|
buffer.push("\nendobj\n");
|
|
|
|
|
2020-09-09 07:13:52 +09:00
|
|
|
const newRefs = [{ ref: this.ref, data: buffer.join(""), xfa }];
|
2020-08-04 02:44:04 +09:00
|
|
|
if (parentBuffer !== null) {
|
2020-09-09 07:13:52 +09:00
|
|
|
newRefs.push({
|
|
|
|
ref: this.parent,
|
|
|
|
data: parentBuffer.join(""),
|
|
|
|
xfa: null,
|
|
|
|
});
|
2020-08-04 02:44:04 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
return newRefs;
|
|
|
|
}
|
|
|
|
|
2021-09-17 22:31:22 +09:00
|
|
|
_getDefaultCheckedAppearance(params, type) {
|
|
|
|
const width = this.data.rect[2] - this.data.rect[0];
|
|
|
|
const height = this.data.rect[3] - this.data.rect[1];
|
|
|
|
const bbox = [0, 0, width, height];
|
|
|
|
|
|
|
|
// Ratio used to have a mark slightly smaller than the bbox.
|
|
|
|
const FONT_RATIO = 0.8;
|
|
|
|
const fontSize = Math.min(width, height) * FONT_RATIO;
|
|
|
|
|
|
|
|
// Char Metrics
|
|
|
|
// Widths came from widths for ZapfDingbats.
|
|
|
|
// Heights are guessed with Fontforge and FoxitDingbats.pfb.
|
|
|
|
let metrics, char;
|
|
|
|
if (type === "check") {
|
|
|
|
// Char 33 (2713 in unicode)
|
|
|
|
metrics = {
|
|
|
|
width: 0.755 * fontSize,
|
|
|
|
height: 0.705 * fontSize,
|
|
|
|
};
|
|
|
|
char = "\x33";
|
|
|
|
} else if (type === "disc") {
|
|
|
|
// Char 6C (25CF in unicode)
|
|
|
|
metrics = {
|
|
|
|
width: 0.791 * fontSize,
|
|
|
|
height: 0.705 * fontSize,
|
|
|
|
};
|
|
|
|
char = "\x6C";
|
|
|
|
} else {
|
|
|
|
unreachable(`_getDefaultCheckedAppearance - unsupported type: ${type}`);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Values to center the glyph in the bbox.
|
|
|
|
const xShift = (width - metrics.width) / 2;
|
|
|
|
const yShift = (height - metrics.height) / 2;
|
|
|
|
|
|
|
|
const appearance = `q BT /PdfJsZaDb ${fontSize} Tf 0 g ${xShift} ${yShift} Td (${char}) Tj ET Q`;
|
|
|
|
|
|
|
|
const appearanceStreamDict = new Dict(params.xref);
|
|
|
|
appearanceStreamDict.set("FormType", 1);
|
|
|
|
appearanceStreamDict.set("Subtype", Name.get("Form"));
|
|
|
|
appearanceStreamDict.set("Type", Name.get("XObject"));
|
|
|
|
appearanceStreamDict.set("BBox", bbox);
|
|
|
|
appearanceStreamDict.set("Matrix", [1, 0, 0, 1, 0, 0]);
|
|
|
|
appearanceStreamDict.set("Length", appearance.length);
|
|
|
|
|
|
|
|
const resources = new Dict(params.xref);
|
|
|
|
const font = new Dict(params.xref);
|
|
|
|
font.set("PdfJsZaDb", this.fallbackFontDict);
|
|
|
|
resources.set("Font", font);
|
|
|
|
|
|
|
|
appearanceStreamDict.set("Resources", resources);
|
|
|
|
|
|
|
|
this.checkedAppearance = new StringStream(appearance);
|
|
|
|
this.checkedAppearance.dict = appearanceStreamDict;
|
|
|
|
|
|
|
|
this._streams.push(this.checkedAppearance);
|
|
|
|
}
|
|
|
|
|
2018-07-07 09:51:10 +09:00
|
|
|
_processCheckBox(params) {
|
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
|
|
|
const customAppearance = params.dict.get("AP");
|
2022-02-21 20:44:56 +09:00
|
|
|
if (!(customAppearance instanceof Dict)) {
|
2018-07-07 09:51:10 +09:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2020-08-22 22:45:33 +09:00
|
|
|
const normalAppearance = customAppearance.get("N");
|
2022-02-21 20:44:56 +09:00
|
|
|
if (!(normalAppearance instanceof Dict)) {
|
2017-11-21 07:00:19 +09:00
|
|
|
return;
|
|
|
|
}
|
2018-07-07 09:51:10 +09:00
|
|
|
|
2021-09-17 19:41:50 +09:00
|
|
|
// See https://bugzilla.mozilla.org/show_bug.cgi?id=1722036.
|
|
|
|
// If we've an AS and a V then take AS.
|
|
|
|
const asValue = this._decodeFormValue(params.dict.get("AS"));
|
|
|
|
if (typeof asValue === "string") {
|
|
|
|
this.data.fieldValue = asValue;
|
|
|
|
}
|
|
|
|
|
2021-09-17 22:31:22 +09:00
|
|
|
const yes =
|
|
|
|
this.data.fieldValue !== null && this.data.fieldValue !== "Off"
|
|
|
|
? this.data.fieldValue
|
|
|
|
: "Yes";
|
|
|
|
|
2020-08-22 22:45:33 +09:00
|
|
|
const exportValues = normalAppearance.getKeys();
|
2021-09-17 22:31:22 +09:00
|
|
|
if (exportValues.length === 0) {
|
|
|
|
exportValues.push("Off", yes);
|
|
|
|
} else if (exportValues.length === 1) {
|
|
|
|
if (exportValues[0] === "Off") {
|
|
|
|
exportValues.push(yes);
|
|
|
|
} else {
|
|
|
|
exportValues.unshift("Off");
|
|
|
|
}
|
|
|
|
} else if (exportValues.includes(yes)) {
|
|
|
|
exportValues.length = 0;
|
|
|
|
exportValues.push("Off", yes);
|
|
|
|
} else {
|
|
|
|
const otherYes = exportValues.find(v => v !== "Off");
|
|
|
|
exportValues.length = 0;
|
|
|
|
exportValues.push("Off", otherYes);
|
2020-08-22 22:45:33 +09:00
|
|
|
}
|
2021-09-17 22:31:22 +09:00
|
|
|
|
2021-07-15 02:31:09 +09:00
|
|
|
// Don't use a "V" entry pointing to a non-existent appearance state,
|
|
|
|
// see e.g. bug1720411.pdf where it's an *empty* Name-instance.
|
|
|
|
if (!exportValues.includes(this.data.fieldValue)) {
|
2021-09-17 22:31:22 +09:00
|
|
|
this.data.fieldValue = "Off";
|
2018-07-07 09:51:10 +09:00
|
|
|
}
|
|
|
|
|
2021-09-17 22:31:22 +09:00
|
|
|
this.data.exportValue = exportValues[1];
|
2020-07-23 00:10:59 +09:00
|
|
|
|
2021-09-17 22:31:22 +09:00
|
|
|
this.checkedAppearance =
|
|
|
|
normalAppearance.get(this.data.exportValue) || null;
|
2020-07-23 00:10:59 +09:00
|
|
|
this.uncheckedAppearance = normalAppearance.get("Off") || null;
|
2020-09-25 02:13:09 +09:00
|
|
|
|
2021-09-17 22:31:22 +09:00
|
|
|
if (this.checkedAppearance) {
|
|
|
|
this._streams.push(this.checkedAppearance);
|
|
|
|
} else {
|
|
|
|
this._getDefaultCheckedAppearance(params, "check");
|
|
|
|
}
|
2020-09-25 02:13:09 +09:00
|
|
|
if (this.uncheckedAppearance) {
|
|
|
|
this._streams.push(this.uncheckedAppearance);
|
|
|
|
}
|
2020-10-22 00:21:33 +09:00
|
|
|
this._fallbackFontDict = this.fallbackFontDict;
|
2017-11-21 07:00:19 +09:00
|
|
|
}
|
2016-12-16 06:58:27 +09:00
|
|
|
|
2017-11-21 07:00:19 +09:00
|
|
|
_processRadioButton(params) {
|
|
|
|
this.data.fieldValue = this.data.buttonValue = null;
|
|
|
|
|
|
|
|
// The parent field's `V` entry holds a `Name` object with the appearance
|
|
|
|
// state of whichever child field is currently in the "on" state.
|
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
|
|
|
const fieldParent = params.dict.get("Parent");
|
2022-02-21 20:44:56 +09:00
|
|
|
if (fieldParent instanceof Dict) {
|
2020-09-15 21:23:08 +09:00
|
|
|
this.parent = params.dict.getRaw("Parent");
|
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
|
|
|
const fieldParentValue = fieldParent.get("V");
|
2022-02-21 20:45:00 +09:00
|
|
|
if (fieldParentValue instanceof Name) {
|
2020-08-22 22:02:29 +09:00
|
|
|
this.data.fieldValue = this._decodeFormValue(fieldParentValue);
|
2016-12-16 06:58:27 +09:00
|
|
|
}
|
2017-11-21 07:00:19 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
// The button's value corresponds to its appearance state.
|
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
|
|
|
const appearanceStates = params.dict.get("AP");
|
2022-02-21 20:44:56 +09:00
|
|
|
if (!(appearanceStates instanceof Dict)) {
|
2017-11-21 07:00:19 +09:00
|
|
|
return;
|
|
|
|
}
|
2020-07-23 00:29:35 +09:00
|
|
|
const normalAppearance = appearanceStates.get("N");
|
2022-02-21 20:44:56 +09:00
|
|
|
if (!(normalAppearance instanceof Dict)) {
|
2017-11-21 07:00:19 +09:00
|
|
|
return;
|
|
|
|
}
|
2020-07-23 00:29:35 +09:00
|
|
|
for (const key of normalAppearance.getKeys()) {
|
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 (key !== "Off") {
|
2020-09-17 01:47:25 +09:00
|
|
|
this.data.buttonValue = this._decodeFormValue(key);
|
2017-11-21 07:00:19 +09:00
|
|
|
break;
|
2016-11-04 21:01:42 +09:00
|
|
|
}
|
|
|
|
}
|
2020-07-23 00:29:35 +09:00
|
|
|
|
2021-09-17 22:31:22 +09:00
|
|
|
this.checkedAppearance =
|
|
|
|
normalAppearance.get(this.data.buttonValue) || null;
|
2020-07-23 00:29:35 +09:00
|
|
|
this.uncheckedAppearance = normalAppearance.get("Off") || null;
|
2020-09-25 02:13:09 +09:00
|
|
|
|
2021-09-17 22:31:22 +09:00
|
|
|
if (this.checkedAppearance) {
|
|
|
|
this._streams.push(this.checkedAppearance);
|
|
|
|
} else {
|
|
|
|
this._getDefaultCheckedAppearance(params, "disc");
|
|
|
|
}
|
2020-09-25 02:13:09 +09:00
|
|
|
if (this.uncheckedAppearance) {
|
|
|
|
this._streams.push(this.uncheckedAppearance);
|
|
|
|
}
|
2020-10-22 00:21:33 +09:00
|
|
|
this._fallbackFontDict = this.fallbackFontDict;
|
2016-11-04 21:01:42 +09:00
|
|
|
}
|
2017-11-21 07:00:19 +09:00
|
|
|
|
|
|
|
_processPushButton(params) {
|
2020-10-16 02:42:36 +09:00
|
|
|
if (
|
|
|
|
!params.dict.has("A") &&
|
|
|
|
!params.dict.has("AA") &&
|
|
|
|
!this.data.alternativeText
|
|
|
|
) {
|
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
|
|
|
warn("Push buttons without action dictionaries are not supported");
|
2017-11-21 07:00:19 +09:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2020-10-16 02:42:36 +09:00
|
|
|
this.data.isTooltipOnly = !params.dict.has("A") && !params.dict.has("AA");
|
2020-09-07 00:14:56 +09:00
|
|
|
|
2017-11-21 07:00:19 +09:00
|
|
|
Catalog.parseDestDictionary({
|
|
|
|
destDict: params.dict,
|
|
|
|
resultObj: this.data,
|
|
|
|
docBaseUrl: params.pdfManager.docBaseUrl,
|
|
|
|
});
|
|
|
|
}
|
2020-10-01 03:58:45 +09:00
|
|
|
|
|
|
|
getFieldObject() {
|
|
|
|
let type = "button";
|
2020-11-19 02:54:26 +09:00
|
|
|
let exportValues;
|
2020-10-01 03:58:45 +09:00
|
|
|
if (this.data.checkBox) {
|
|
|
|
type = "checkbox";
|
2020-11-19 02:54:26 +09:00
|
|
|
exportValues = this.data.exportValue;
|
2020-10-01 03:58:45 +09:00
|
|
|
} else if (this.data.radioButton) {
|
|
|
|
type = "radiobutton";
|
2020-11-19 02:54:26 +09:00
|
|
|
exportValues = this.data.buttonValue;
|
2020-10-01 03:58:45 +09:00
|
|
|
}
|
|
|
|
return {
|
|
|
|
id: this.data.id,
|
2021-01-09 00:43:16 +09:00
|
|
|
value: this.data.fieldValue || "Off",
|
2020-11-04 00:53:21 +09:00
|
|
|
defaultValue: this.data.defaultFieldValue,
|
2020-11-19 02:54:26 +09:00
|
|
|
exportValues,
|
2020-10-01 03:58:45 +09:00
|
|
|
editable: !this.data.readOnly,
|
|
|
|
name: this.data.fieldName,
|
|
|
|
rect: this.data.rect,
|
|
|
|
hidden: this.data.hidden,
|
|
|
|
actions: this.data.actions,
|
2021-04-30 23:43:27 +09:00
|
|
|
page: this.data.pageIndex,
|
2021-09-19 03:22:29 +09:00
|
|
|
strokeColor: this.data.borderColor,
|
|
|
|
fillColor: this.data.backgroundColor,
|
2020-10-01 03:58:45 +09:00
|
|
|
type,
|
|
|
|
};
|
|
|
|
}
|
2020-10-22 00:21:33 +09:00
|
|
|
|
|
|
|
get fallbackFontDict() {
|
|
|
|
const dict = new Dict();
|
|
|
|
dict.set("BaseFont", Name.get("ZapfDingbats"));
|
|
|
|
dict.set("Type", Name.get("FallbackType"));
|
|
|
|
dict.set("Subtype", Name.get("FallbackType"));
|
|
|
|
dict.set("Encoding", Name.get("ZapfDingbatsEncoding"));
|
|
|
|
|
|
|
|
return shadow(this, "fallbackFontDict", dict);
|
|
|
|
}
|
2017-08-27 06:49:11 +09:00
|
|
|
}
|
2016-11-04 21:01:42 +09:00
|
|
|
|
2017-08-27 06:49:11 +09:00
|
|
|
class ChoiceWidgetAnnotation extends WidgetAnnotation {
|
|
|
|
constructor(params) {
|
|
|
|
super(params);
|
2016-09-25 08:45:49 +09:00
|
|
|
|
|
|
|
// Determine the options. The options array may consist of strings or
|
|
|
|
// arrays. If the array consists of arrays, then the first element of
|
|
|
|
// each array is the export value and the second element of each array is
|
|
|
|
// the display value. If the array consists of strings, then these
|
|
|
|
// represent both the export and display value. In this case, we convert
|
|
|
|
// it to an array of arrays as well for convenience in the display layer.
|
2017-02-26 07:34:26 +09:00
|
|
|
// Note that the specification does not state that the `Opt` field is
|
|
|
|
// inheritable, but in practice PDF generators do make annotations
|
|
|
|
// inherit the options from a parent annotation (issue 8094).
|
2016-09-25 08:45:49 +09:00
|
|
|
this.data.options = [];
|
|
|
|
|
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
|
|
|
const options = getInheritableProperty({ dict: params.dict, key: "Opt" });
|
2017-09-02 03:27:13 +09:00
|
|
|
if (Array.isArray(options)) {
|
2019-09-01 00:07:29 +09:00
|
|
|
const xref = params.xref;
|
2017-08-27 06:49:11 +09:00
|
|
|
for (let i = 0, ii = options.length; i < ii; i++) {
|
2020-01-24 17:48:21 +09:00
|
|
|
const option = xref.fetchIfRef(options[i]);
|
|
|
|
const isOptionArray = Array.isArray(option);
|
2016-09-25 08:45:49 +09:00
|
|
|
|
|
|
|
this.data.options[i] = {
|
2020-08-22 22:02:29 +09:00
|
|
|
exportValue: this._decodeFormValue(
|
|
|
|
isOptionArray ? xref.fetchIfRef(option[0]) : option
|
|
|
|
),
|
|
|
|
displayValue: this._decodeFormValue(
|
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
|
|
|
isOptionArray ? xref.fetchIfRef(option[1]) : option
|
|
|
|
),
|
2016-09-25 08:45:49 +09:00
|
|
|
};
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-08-19 06:04:56 +09:00
|
|
|
// The field value can be `null` if no item is selected, a string if one
|
|
|
|
// item is selected or an array of strings if multiple items are selected.
|
|
|
|
// For consistency in the API and convenience in the display layer, we
|
|
|
|
// always make the field value an array with zero, one or multiple items.
|
2022-02-24 01:02:19 +09:00
|
|
|
if (typeof this.data.fieldValue === "string") {
|
2016-09-25 08:45:49 +09:00
|
|
|
this.data.fieldValue = [this.data.fieldValue];
|
2020-08-19 06:04:56 +09:00
|
|
|
} else if (!this.data.fieldValue) {
|
|
|
|
this.data.fieldValue = [];
|
2016-09-25 08:45:49 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
// Process field flags for the display layer.
|
|
|
|
this.data.combo = this.hasFieldFlag(AnnotationFieldFlag.COMBO);
|
|
|
|
this.data.multiSelect = this.hasFieldFlag(AnnotationFieldFlag.MULTISELECT);
|
2020-08-05 21:40:31 +09:00
|
|
|
this._hasText = true;
|
2016-09-25 08:45:49 +09:00
|
|
|
}
|
2020-10-01 03:58:45 +09:00
|
|
|
|
|
|
|
getFieldObject() {
|
|
|
|
const type = this.data.combo ? "combobox" : "listbox";
|
|
|
|
const value =
|
|
|
|
this.data.fieldValue.length > 0 ? this.data.fieldValue[0] : null;
|
|
|
|
return {
|
|
|
|
id: this.data.id,
|
|
|
|
value,
|
2020-11-04 00:53:21 +09:00
|
|
|
defaultValue: this.data.defaultFieldValue,
|
2020-10-01 03:58:45 +09:00
|
|
|
editable: !this.data.readOnly,
|
|
|
|
name: this.data.fieldName,
|
|
|
|
rect: this.data.rect,
|
2020-11-19 02:54:26 +09:00
|
|
|
numItems: this.data.fieldValue.length,
|
2020-10-01 03:58:45 +09:00
|
|
|
multipleSelection: this.data.multiSelect,
|
|
|
|
hidden: this.data.hidden,
|
|
|
|
actions: this.data.actions,
|
2021-01-26 07:40:57 +09:00
|
|
|
items: this.data.options,
|
2021-04-30 23:43:27 +09:00
|
|
|
page: this.data.pageIndex,
|
2021-09-19 03:22:29 +09:00
|
|
|
strokeColor: this.data.borderColor,
|
|
|
|
fillColor: this.data.backgroundColor,
|
2020-10-01 03:58:45 +09:00
|
|
|
type,
|
|
|
|
};
|
|
|
|
}
|
2022-03-27 06:45:50 +09:00
|
|
|
|
|
|
|
async _getAppearance(evaluator, task, annotationStorage) {
|
|
|
|
if (this.data.combo) {
|
|
|
|
return super._getAppearance(evaluator, task, annotationStorage);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!annotationStorage) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
const storageEntry = annotationStorage.get(this.data.id);
|
|
|
|
let exportedValue = storageEntry && storageEntry.value;
|
|
|
|
if (exportedValue === undefined) {
|
|
|
|
// The annotation hasn't been rendered so use the appearance
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!Array.isArray(exportedValue)) {
|
|
|
|
exportedValue = [exportedValue];
|
|
|
|
}
|
|
|
|
|
|
|
|
const defaultPadding = 2;
|
|
|
|
const hPadding = defaultPadding;
|
|
|
|
const totalHeight = this.data.rect[3] - this.data.rect[1];
|
|
|
|
const totalWidth = this.data.rect[2] - this.data.rect[0];
|
|
|
|
const lineCount = this.data.options.length;
|
|
|
|
const valueIndices = [];
|
|
|
|
for (let i = 0; i < lineCount; i++) {
|
|
|
|
const { exportValue } = this.data.options[i];
|
|
|
|
if (exportedValue.includes(exportValue)) {
|
|
|
|
valueIndices.push(i);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!this._defaultAppearance) {
|
|
|
|
// The DA is required and must be a string.
|
|
|
|
// If there is no font named Helvetica in the resource dictionary,
|
|
|
|
// the evaluator will fall back to a default font.
|
|
|
|
// Doing so prevents exceptions and allows saving/printing
|
|
|
|
// the file as expected.
|
|
|
|
this.data.defaultAppearanceData = parseDefaultAppearance(
|
|
|
|
(this._defaultAppearance = "/Helvetica 0 Tf 0 g")
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
const font = await this._getFontData(evaluator, task);
|
|
|
|
|
|
|
|
let defaultAppearance;
|
|
|
|
let { fontSize } = this.data.defaultAppearanceData;
|
|
|
|
if (!fontSize) {
|
|
|
|
const lineHeight = (totalHeight - defaultPadding) / lineCount;
|
|
|
|
let lineWidth = -1;
|
|
|
|
let value;
|
|
|
|
for (const { displayValue } of this.data.options) {
|
|
|
|
const width = this._getTextWidth(displayValue);
|
|
|
|
if (width > lineWidth) {
|
|
|
|
lineWidth = width;
|
|
|
|
value = displayValue;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
[defaultAppearance, fontSize] = this._computeFontSize(
|
|
|
|
lineHeight,
|
|
|
|
totalWidth - 2 * hPadding,
|
|
|
|
value,
|
|
|
|
font,
|
|
|
|
-1
|
|
|
|
);
|
|
|
|
} else {
|
|
|
|
defaultAppearance = this._defaultAppearance;
|
|
|
|
}
|
|
|
|
|
|
|
|
const lineHeight = fontSize * LINE_FACTOR;
|
|
|
|
const vPadding = (lineHeight - fontSize) / 2;
|
|
|
|
const numberOfVisibleLines = Math.floor(totalHeight / lineHeight);
|
|
|
|
|
|
|
|
let firstIndex;
|
|
|
|
if (valueIndices.length === 1) {
|
|
|
|
const valuePosition = valueIndices[0];
|
|
|
|
const indexInPage = valuePosition % numberOfVisibleLines;
|
|
|
|
firstIndex = valuePosition - indexInPage;
|
|
|
|
} else {
|
|
|
|
// If nothing is selected (valueIndice.length === 0), we render
|
|
|
|
// from the first element.
|
|
|
|
firstIndex = valueIndices.length ? valueIndices[0] : 0;
|
|
|
|
}
|
|
|
|
const end = Math.min(firstIndex + numberOfVisibleLines + 1, lineCount);
|
|
|
|
|
|
|
|
const buf = ["/Tx BMC q", `1 1 ${totalWidth} ${totalHeight} re W n`];
|
|
|
|
|
|
|
|
if (valueIndices.length) {
|
|
|
|
// This value has been copied/pasted from annotation-choice-widget.pdf.
|
|
|
|
// It corresponds to rgb(153, 193, 218).
|
|
|
|
buf.push("0.600006 0.756866 0.854904 rg");
|
|
|
|
|
|
|
|
// Highlight the lines in filling a blue rectangle at the selected
|
|
|
|
// positions.
|
|
|
|
for (const index of valueIndices) {
|
|
|
|
if (firstIndex <= index && index < end) {
|
|
|
|
buf.push(
|
|
|
|
`1 ${
|
|
|
|
totalHeight - (index - firstIndex + 1) * lineHeight
|
|
|
|
} ${totalWidth} ${lineHeight} re f`
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
buf.push("BT", defaultAppearance, `1 0 0 1 0 ${totalHeight} Tm`);
|
|
|
|
|
|
|
|
for (let i = firstIndex; i < end; i++) {
|
|
|
|
const { displayValue } = this.data.options[i];
|
|
|
|
const hpadding = i === firstIndex ? hPadding : 0;
|
|
|
|
const vpadding = i === firstIndex ? vPadding : 0;
|
|
|
|
buf.push(
|
|
|
|
this._renderText(
|
|
|
|
displayValue,
|
|
|
|
font,
|
|
|
|
fontSize,
|
|
|
|
totalWidth,
|
|
|
|
0,
|
|
|
|
hpadding,
|
|
|
|
-lineHeight + vpadding
|
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
buf.push("ET Q EMC");
|
|
|
|
|
|
|
|
return buf.join("\n");
|
|
|
|
}
|
2017-08-27 06:49:11 +09:00
|
|
|
}
|
2016-09-25 08:45:49 +09:00
|
|
|
|
2021-04-10 23:53:17 +09:00
|
|
|
class SignatureWidgetAnnotation extends WidgetAnnotation {
|
|
|
|
constructor(params) {
|
|
|
|
super(params);
|
|
|
|
|
|
|
|
// Unset the fieldValue since it's (most likely) a `Dict` which is
|
|
|
|
// non-serializable and will thus cause errors when sending annotations
|
|
|
|
// to the main-thread (issue 10347).
|
|
|
|
this.data.fieldValue = null;
|
|
|
|
}
|
|
|
|
|
|
|
|
getFieldObject() {
|
|
|
|
return {
|
|
|
|
id: this.data.id,
|
|
|
|
value: null,
|
2021-04-30 23:43:27 +09:00
|
|
|
page: this.data.pageIndex,
|
2021-04-10 23:53:17 +09:00
|
|
|
type: "signature",
|
|
|
|
};
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-04-11 20:55:58 +09:00
|
|
|
class TextAnnotation extends MarkupAnnotation {
|
2017-08-27 06:49:11 +09:00
|
|
|
constructor(parameters) {
|
|
|
|
const DEFAULT_ICON_SIZE = 22; // px
|
2013-03-21 17:04:44 +09:00
|
|
|
|
2017-08-27 06:49:11 +09:00
|
|
|
super(parameters);
|
2013-03-21 17:04:44 +09:00
|
|
|
|
2019-05-15 04:14:35 +09:00
|
|
|
const dict = parameters.dict;
|
2015-12-23 05:31:56 +09:00
|
|
|
this.data.annotationType = AnnotationType.TEXT;
|
2013-03-21 17:04:44 +09:00
|
|
|
|
2015-12-23 05:31:56 +09:00
|
|
|
if (this.data.hasAppearance) {
|
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.data.name = "NoIcon";
|
2014-03-07 23:48:42 +09:00
|
|
|
} else {
|
2015-12-23 05:31:56 +09:00
|
|
|
this.data.rect[1] = this.data.rect[3] - DEFAULT_ICON_SIZE;
|
|
|
|
this.data.rect[2] = this.data.rect[0] + DEFAULT_ICON_SIZE;
|
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.data.name = dict.has("Name") ? dict.get("Name").name : "Note";
|
2015-12-23 05:31:56 +09:00
|
|
|
}
|
2019-04-11 20:55:58 +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
|
|
|
if (dict.has("State")) {
|
|
|
|
this.data.state = dict.get("State") || null;
|
|
|
|
this.data.stateModel = dict.get("StateModel") || null;
|
2019-05-15 04:14:35 +09:00
|
|
|
} else {
|
|
|
|
this.data.state = null;
|
|
|
|
this.data.stateModel = null;
|
|
|
|
}
|
2014-03-07 23:48:42 +09:00
|
|
|
}
|
2017-08-27 06:49:11 +09:00
|
|
|
}
|
2013-03-21 17:04:44 +09:00
|
|
|
|
2017-08-27 06:49:11 +09:00
|
|
|
class LinkAnnotation extends Annotation {
|
|
|
|
constructor(params) {
|
|
|
|
super(params);
|
2013-03-21 17:04:44 +09:00
|
|
|
|
2017-08-27 06:49:11 +09:00
|
|
|
this.data.annotationType = AnnotationType.LINK;
|
2013-03-21 17:04:44 +09:00
|
|
|
|
2019-07-28 03:57:52 +09:00
|
|
|
const quadPoints = getQuadPoints(params.dict, this.rectangle);
|
|
|
|
if (quadPoints) {
|
|
|
|
this.data.quadPoints = quadPoints;
|
|
|
|
}
|
|
|
|
|
2016-09-30 23:08:03 +09:00
|
|
|
Catalog.parseDestDictionary({
|
|
|
|
destDict: params.dict,
|
2017-08-27 06:49:11 +09:00
|
|
|
resultObj: this.data,
|
2016-10-01 19:05:07 +09:00
|
|
|
docBaseUrl: params.pdfManager.docBaseUrl,
|
2016-09-30 23:08:03 +09:00
|
|
|
});
|
2016-03-03 21:07:22 +09:00
|
|
|
}
|
2017-08-27 06:49:11 +09:00
|
|
|
}
|
2016-03-03 21:07:22 +09:00
|
|
|
|
2017-08-27 06:49:11 +09:00
|
|
|
class PopupAnnotation extends Annotation {
|
|
|
|
constructor(parameters) {
|
|
|
|
super(parameters);
|
2015-12-23 05:31:56 +09:00
|
|
|
|
|
|
|
this.data.annotationType = AnnotationType.POPUP;
|
|
|
|
|
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 parentItem = parameters.dict.get("Parent");
|
2015-12-23 05:31:56 +09:00
|
|
|
if (!parentItem) {
|
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
|
|
|
warn("Popup annotation has a missing or invalid parent annotation.");
|
2015-12-23 05:31:56 +09:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
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
|
|
|
const parentSubtype = parentItem.get("Subtype");
|
2022-02-21 20:45:00 +09:00
|
|
|
this.data.parentType =
|
|
|
|
parentSubtype instanceof Name ? parentSubtype.name : 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
|
|
|
const rawParent = parameters.dict.getRaw("Parent");
|
2022-02-18 20:11:45 +09:00
|
|
|
this.data.parentId = rawParent instanceof Ref ? rawParent.toString() : null;
|
2019-05-15 04:14:35 +09:00
|
|
|
|
2020-10-21 20:12:43 +09:00
|
|
|
const parentRect = parentItem.getArray("Rect");
|
|
|
|
if (Array.isArray(parentRect) && parentRect.length === 4) {
|
|
|
|
this.data.parentRect = Util.normalizeRect(parentRect);
|
|
|
|
} else {
|
|
|
|
this.data.parentRect = [0, 0, 0, 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
|
|
|
const rt = parentItem.get("RT");
|
2019-05-15 04:14:35 +09:00
|
|
|
if (isName(rt, AnnotationReplyType.GROUP)) {
|
|
|
|
// Subordinate annotations in a group should inherit
|
|
|
|
// the group attributes from the primary annotation.
|
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
|
|
|
parentItem = parentItem.get("IRT");
|
2019-05-15 04:14:35 +09:00
|
|
|
}
|
2015-12-23 05:31:56 +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
|
|
|
if (!parentItem.has("M")) {
|
2019-04-22 04:21:01 +09:00
|
|
|
this.data.modificationDate = null;
|
|
|
|
} 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.setModificationDate(parentItem.get("M"));
|
2019-04-22 04:21:01 +09:00
|
|
|
this.data.modificationDate = this.modificationDate;
|
|
|
|
}
|
|
|
|
|
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 (!parentItem.has("C")) {
|
2015-12-23 05:31:56 +09:00
|
|
|
// Fall back to the default background color.
|
|
|
|
this.data.color = null;
|
|
|
|
} 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.setColor(parentItem.getArray("C"));
|
2015-12-23 05:31:56 +09:00
|
|
|
this.data.color = this.color;
|
|
|
|
}
|
2016-05-25 00:35:45 +09:00
|
|
|
|
|
|
|
// If the Popup annotation is not viewable, but the parent annotation is,
|
|
|
|
// that is most likely a bug. Fallback to inherit the flags from the parent
|
|
|
|
// annotation (this is consistent with the behaviour in Adobe Reader).
|
|
|
|
if (!this.viewable) {
|
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
|
|
|
const parentFlags = parentItem.get("F");
|
2016-05-25 00:35:45 +09:00
|
|
|
if (this._isViewable(parentFlags)) {
|
|
|
|
this.setFlags(parentFlags);
|
|
|
|
}
|
|
|
|
}
|
2019-05-15 04:14:35 +09:00
|
|
|
|
2021-09-25 00:30:56 +09:00
|
|
|
this.setTitle(parentItem.get("T"));
|
|
|
|
this.data.titleObj = this._title;
|
|
|
|
|
|
|
|
this.setContents(parentItem.get("Contents"));
|
|
|
|
this.data.contentsObj = this._contents;
|
2021-10-25 00:29:30 +09:00
|
|
|
|
|
|
|
if (parentItem.has("RC")) {
|
|
|
|
this.data.richText = XFAFactory.getRichTextAsHtml(parentItem.get("RC"));
|
|
|
|
}
|
2015-12-23 05:31:56 +09:00
|
|
|
}
|
2017-08-27 06:49:11 +09:00
|
|
|
}
|
2015-12-23 05:31:56 +09:00
|
|
|
|
2019-04-14 01:45:22 +09:00
|
|
|
class FreeTextAnnotation extends MarkupAnnotation {
|
|
|
|
constructor(parameters) {
|
|
|
|
super(parameters);
|
|
|
|
|
|
|
|
this.data.annotationType = AnnotationType.FREETEXT;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-04-11 20:55:58 +09:00
|
|
|
class LineAnnotation extends MarkupAnnotation {
|
2017-08-27 06:49:11 +09:00
|
|
|
constructor(parameters) {
|
|
|
|
super(parameters);
|
2017-04-03 03:50:17 +09:00
|
|
|
|
|
|
|
this.data.annotationType = AnnotationType.LINE;
|
|
|
|
|
2021-03-01 02:51:37 +09:00
|
|
|
const lineCoordinates = parameters.dict.getArray("L");
|
|
|
|
this.data.lineCoordinates = Util.normalizeRect(lineCoordinates);
|
|
|
|
|
|
|
|
if (!this.appearance) {
|
|
|
|
// The default stroke color is black.
|
|
|
|
const strokeColor = this.color
|
|
|
|
? Array.from(this.color).map(c => c / 255)
|
|
|
|
: [0, 0, 0];
|
2021-05-27 17:06:13 +09:00
|
|
|
const strokeAlpha = parameters.dict.get("CA");
|
2021-03-01 02:51:37 +09:00
|
|
|
|
2021-05-27 17:06:13 +09:00
|
|
|
// The default fill color is transparent. Setting the fill colour is
|
|
|
|
// necessary if/when we want to add support for non-default line endings.
|
|
|
|
let fillColor = null,
|
|
|
|
interiorColor = parameters.dict.getArray("IC");
|
|
|
|
if (interiorColor) {
|
2021-09-19 03:22:29 +09:00
|
|
|
interiorColor = getRgbColor(interiorColor, null);
|
2021-05-27 17:06:13 +09:00
|
|
|
fillColor = interiorColor
|
|
|
|
? Array.from(interiorColor).map(c => c / 255)
|
|
|
|
: null;
|
|
|
|
}
|
|
|
|
const fillAlpha = fillColor ? strokeAlpha : null;
|
2021-03-01 02:51:37 +09:00
|
|
|
|
2021-05-27 20:13:10 +09:00
|
|
|
const borderWidth = this.borderStyle.width || 1,
|
|
|
|
borderAdjust = 2 * borderWidth;
|
2021-03-01 02:51:37 +09:00
|
|
|
|
2021-05-27 20:13:10 +09:00
|
|
|
// If the /Rect-entry is empty/wrong, create a fallback rectangle so that
|
|
|
|
// we get similar rendering/highlighting behaviour as in Adobe Reader.
|
|
|
|
const bbox = [
|
|
|
|
this.data.lineCoordinates[0] - borderAdjust,
|
|
|
|
this.data.lineCoordinates[1] - borderAdjust,
|
|
|
|
this.data.lineCoordinates[2] + borderAdjust,
|
|
|
|
this.data.lineCoordinates[3] + borderAdjust,
|
|
|
|
];
|
|
|
|
if (!Util.intersect(this.rectangle, bbox)) {
|
|
|
|
this.rectangle = bbox;
|
2021-03-16 00:16:49 +09:00
|
|
|
}
|
|
|
|
|
2021-03-01 02:51:37 +09:00
|
|
|
this._setDefaultAppearance({
|
|
|
|
xref: parameters.xref,
|
|
|
|
extra: `${borderWidth} w`,
|
|
|
|
strokeColor,
|
2021-05-27 17:06:13 +09:00
|
|
|
fillColor,
|
|
|
|
strokeAlpha,
|
|
|
|
fillAlpha,
|
2021-03-01 02:51:37 +09:00
|
|
|
pointsCallback: (buffer, points) => {
|
2021-05-24 20:20:19 +09:00
|
|
|
buffer.push(
|
|
|
|
`${lineCoordinates[0]} ${lineCoordinates[1]} m`,
|
|
|
|
`${lineCoordinates[2]} ${lineCoordinates[3]} l`,
|
|
|
|
"S"
|
|
|
|
);
|
2021-03-01 02:51:37 +09:00
|
|
|
return [
|
|
|
|
points[0].x - borderWidth,
|
|
|
|
points[1].x + borderWidth,
|
|
|
|
points[3].y - borderWidth,
|
|
|
|
points[1].y + borderWidth,
|
|
|
|
];
|
|
|
|
},
|
|
|
|
});
|
|
|
|
}
|
2017-04-03 03:50:17 +09:00
|
|
|
}
|
2017-08-27 06:49:11 +09:00
|
|
|
}
|
2017-04-03 03:50:17 +09:00
|
|
|
|
2019-04-11 20:55:58 +09:00
|
|
|
class SquareAnnotation extends MarkupAnnotation {
|
2017-07-24 07:11:27 +09:00
|
|
|
constructor(parameters) {
|
|
|
|
super(parameters);
|
|
|
|
|
|
|
|
this.data.annotationType = AnnotationType.SQUARE;
|
2021-02-22 01:10:35 +09:00
|
|
|
|
|
|
|
if (!this.appearance) {
|
|
|
|
// The default stroke color is black.
|
|
|
|
const strokeColor = this.color
|
|
|
|
? Array.from(this.color).map(c => c / 255)
|
|
|
|
: [0, 0, 0];
|
2021-05-27 17:06:13 +09:00
|
|
|
const strokeAlpha = parameters.dict.get("CA");
|
2021-02-22 01:10:35 +09:00
|
|
|
|
|
|
|
// The default fill color is transparent.
|
2021-05-27 17:06:13 +09:00
|
|
|
let fillColor = null,
|
|
|
|
interiorColor = parameters.dict.getArray("IC");
|
2021-02-22 01:10:35 +09:00
|
|
|
if (interiorColor) {
|
2021-09-19 03:22:29 +09:00
|
|
|
interiorColor = getRgbColor(interiorColor, null);
|
2021-02-22 01:10:35 +09:00
|
|
|
fillColor = interiorColor
|
|
|
|
? Array.from(interiorColor).map(c => c / 255)
|
|
|
|
: null;
|
|
|
|
}
|
2021-05-27 17:06:13 +09:00
|
|
|
const fillAlpha = fillColor ? strokeAlpha : null;
|
2021-02-22 01:10:35 +09:00
|
|
|
|
2021-10-19 22:13:04 +09:00
|
|
|
if (this.borderStyle.width === 0 && !fillColor) {
|
|
|
|
// Prevent rendering a "hairline" border (fixes issue14164.pdf).
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2021-02-22 01:10:35 +09:00
|
|
|
this._setDefaultAppearance({
|
|
|
|
xref: parameters.xref,
|
|
|
|
extra: `${this.borderStyle.width} w`,
|
|
|
|
strokeColor,
|
|
|
|
fillColor,
|
2021-05-27 17:06:13 +09:00
|
|
|
strokeAlpha,
|
|
|
|
fillAlpha,
|
2021-02-22 01:10:35 +09:00
|
|
|
pointsCallback: (buffer, points) => {
|
|
|
|
const x = points[2].x + this.borderStyle.width / 2;
|
|
|
|
const y = points[2].y + this.borderStyle.width / 2;
|
|
|
|
const width = points[3].x - points[2].x - this.borderStyle.width;
|
|
|
|
const height = points[1].y - points[3].y - this.borderStyle.width;
|
|
|
|
buffer.push(`${x} ${y} ${width} ${height} re`);
|
|
|
|
if (fillColor) {
|
|
|
|
buffer.push("B");
|
|
|
|
} else {
|
|
|
|
buffer.push("S");
|
|
|
|
}
|
|
|
|
return [points[0].x, points[1].x, points[3].y, points[1].y];
|
|
|
|
},
|
|
|
|
});
|
|
|
|
}
|
2017-07-24 07:11:27 +09:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-04-11 20:55:58 +09:00
|
|
|
class CircleAnnotation extends MarkupAnnotation {
|
2017-07-24 07:30:58 +09:00
|
|
|
constructor(parameters) {
|
|
|
|
super(parameters);
|
|
|
|
|
|
|
|
this.data.annotationType = AnnotationType.CIRCLE;
|
2021-02-22 01:10:35 +09:00
|
|
|
|
|
|
|
if (!this.appearance) {
|
|
|
|
// The default stroke color is black.
|
|
|
|
const strokeColor = this.color
|
|
|
|
? Array.from(this.color).map(c => c / 255)
|
|
|
|
: [0, 0, 0];
|
2021-05-27 17:06:13 +09:00
|
|
|
const strokeAlpha = parameters.dict.get("CA");
|
2021-02-22 01:10:35 +09:00
|
|
|
|
|
|
|
// The default fill color is transparent.
|
|
|
|
let fillColor = null;
|
|
|
|
let interiorColor = parameters.dict.getArray("IC");
|
|
|
|
if (interiorColor) {
|
2021-09-19 03:22:29 +09:00
|
|
|
interiorColor = getRgbColor(interiorColor, null);
|
2021-02-22 01:10:35 +09:00
|
|
|
fillColor = interiorColor
|
|
|
|
? Array.from(interiorColor).map(c => c / 255)
|
|
|
|
: null;
|
|
|
|
}
|
2021-05-27 17:06:13 +09:00
|
|
|
const fillAlpha = fillColor ? strokeAlpha : null;
|
2021-02-22 01:10:35 +09:00
|
|
|
|
2021-10-19 22:13:04 +09:00
|
|
|
if (this.borderStyle.width === 0 && !fillColor) {
|
|
|
|
// Prevent rendering a "hairline" border (fixes issue14164.pdf).
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2021-02-22 01:10:35 +09:00
|
|
|
// Circles are approximated by Bézier curves with four segments since
|
|
|
|
// there is no circle primitive in the PDF specification. For the control
|
|
|
|
// points distance, see https://stackoverflow.com/a/27863181.
|
|
|
|
const controlPointsDistance = (4 / 3) * Math.tan(Math.PI / (2 * 4));
|
|
|
|
|
|
|
|
this._setDefaultAppearance({
|
|
|
|
xref: parameters.xref,
|
|
|
|
extra: `${this.borderStyle.width} w`,
|
|
|
|
strokeColor,
|
|
|
|
fillColor,
|
2021-05-27 17:06:13 +09:00
|
|
|
strokeAlpha,
|
|
|
|
fillAlpha,
|
2021-02-22 01:10:35 +09:00
|
|
|
pointsCallback: (buffer, points) => {
|
|
|
|
const x0 = points[0].x + this.borderStyle.width / 2;
|
|
|
|
const y0 = points[0].y - this.borderStyle.width / 2;
|
|
|
|
const x1 = points[3].x - this.borderStyle.width / 2;
|
|
|
|
const y1 = points[3].y + this.borderStyle.width / 2;
|
|
|
|
const xMid = x0 + (x1 - x0) / 2;
|
|
|
|
const yMid = y0 + (y1 - y0) / 2;
|
|
|
|
const xOffset = ((x1 - x0) / 2) * controlPointsDistance;
|
|
|
|
const yOffset = ((y1 - y0) / 2) * controlPointsDistance;
|
|
|
|
|
|
|
|
buffer.push(
|
2021-05-24 20:20:19 +09:00
|
|
|
`${xMid} ${y1} m`,
|
|
|
|
`${xMid + xOffset} ${y1} ${x1} ${yMid + yOffset} ${x1} ${yMid} c`,
|
|
|
|
`${x1} ${yMid - yOffset} ${xMid + xOffset} ${y0} ${xMid} ${y0} c`,
|
|
|
|
`${xMid - xOffset} ${y0} ${x0} ${yMid - yOffset} ${x0} ${yMid} c`,
|
|
|
|
`${x0} ${yMid + yOffset} ${xMid - xOffset} ${y1} ${xMid} ${y1} c`,
|
|
|
|
"h"
|
2021-02-22 01:10:35 +09:00
|
|
|
);
|
|
|
|
if (fillColor) {
|
|
|
|
buffer.push("B");
|
|
|
|
} else {
|
|
|
|
buffer.push("S");
|
|
|
|
}
|
|
|
|
return [points[0].x, points[1].x, points[3].y, points[1].y];
|
|
|
|
},
|
|
|
|
});
|
|
|
|
}
|
2017-07-24 07:30:58 +09:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-04-11 20:55:58 +09:00
|
|
|
class PolylineAnnotation extends MarkupAnnotation {
|
2017-09-18 03:18:22 +09:00
|
|
|
constructor(parameters) {
|
|
|
|
super(parameters);
|
|
|
|
|
|
|
|
this.data.annotationType = AnnotationType.POLYLINE;
|
2020-09-19 22:29:55 +09:00
|
|
|
this.data.vertices = [];
|
2017-09-18 03:18:22 +09:00
|
|
|
|
|
|
|
// The vertices array is an array of numbers representing the alternating
|
|
|
|
// horizontal and vertical coordinates, respectively, of each vertex.
|
|
|
|
// Convert this to an array of objects with x and y coordinates.
|
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
|
|
|
const rawVertices = parameters.dict.getArray("Vertices");
|
2020-09-19 22:29:55 +09:00
|
|
|
if (!Array.isArray(rawVertices)) {
|
|
|
|
return;
|
|
|
|
}
|
2017-09-18 03:18:22 +09:00
|
|
|
for (let i = 0, ii = rawVertices.length; i < ii; i += 2) {
|
|
|
|
this.data.vertices.push({
|
|
|
|
x: rawVertices[i],
|
|
|
|
y: rawVertices[i + 1],
|
|
|
|
});
|
|
|
|
}
|
2021-04-28 02:02:20 +09:00
|
|
|
|
|
|
|
if (!this.appearance) {
|
|
|
|
// The default stroke color is black.
|
|
|
|
const strokeColor = this.color
|
|
|
|
? Array.from(this.color).map(c => c / 255)
|
|
|
|
: [0, 0, 0];
|
2021-05-27 17:06:13 +09:00
|
|
|
const strokeAlpha = parameters.dict.get("CA");
|
2021-04-28 02:02:20 +09:00
|
|
|
|
2021-05-27 20:13:10 +09:00
|
|
|
const borderWidth = this.borderStyle.width || 1,
|
|
|
|
borderAdjust = 2 * borderWidth;
|
|
|
|
|
|
|
|
// If the /Rect-entry is empty/wrong, create a fallback rectangle so that
|
|
|
|
// we get similar rendering/highlighting behaviour as in Adobe Reader.
|
|
|
|
const bbox = [Infinity, Infinity, -Infinity, -Infinity];
|
|
|
|
for (const vertex of this.data.vertices) {
|
|
|
|
bbox[0] = Math.min(bbox[0], vertex.x - borderAdjust);
|
|
|
|
bbox[1] = Math.min(bbox[1], vertex.y - borderAdjust);
|
|
|
|
bbox[2] = Math.max(bbox[2], vertex.x + borderAdjust);
|
|
|
|
bbox[3] = Math.max(bbox[3], vertex.y + borderAdjust);
|
|
|
|
}
|
|
|
|
if (!Util.intersect(this.rectangle, bbox)) {
|
|
|
|
this.rectangle = bbox;
|
|
|
|
}
|
2021-04-28 02:02:20 +09:00
|
|
|
|
|
|
|
this._setDefaultAppearance({
|
|
|
|
xref: parameters.xref,
|
|
|
|
extra: `${borderWidth} w`,
|
|
|
|
strokeColor,
|
2021-05-27 17:06:13 +09:00
|
|
|
strokeAlpha,
|
2021-04-28 02:02:20 +09:00
|
|
|
pointsCallback: (buffer, points) => {
|
|
|
|
const vertices = this.data.vertices;
|
|
|
|
for (let i = 0, ii = vertices.length; i < ii; i++) {
|
|
|
|
buffer.push(
|
|
|
|
`${vertices[i].x} ${vertices[i].y} ${i === 0 ? "m" : "l"}`
|
|
|
|
);
|
|
|
|
}
|
|
|
|
buffer.push("S");
|
|
|
|
return [points[0].x, points[1].x, points[3].y, points[1].y];
|
|
|
|
},
|
|
|
|
});
|
|
|
|
}
|
2017-09-18 03:18:22 +09:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-09-23 23:50:49 +09:00
|
|
|
class PolygonAnnotation extends PolylineAnnotation {
|
|
|
|
constructor(parameters) {
|
|
|
|
// Polygons are specific forms of polylines, so reuse their logic.
|
|
|
|
super(parameters);
|
|
|
|
|
|
|
|
this.data.annotationType = AnnotationType.POLYGON;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-04-11 20:55:58 +09:00
|
|
|
class CaretAnnotation extends MarkupAnnotation {
|
2019-04-10 06:35:32 +09:00
|
|
|
constructor(parameters) {
|
|
|
|
super(parameters);
|
|
|
|
|
|
|
|
this.data.annotationType = AnnotationType.CARET;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-04-11 20:55:58 +09:00
|
|
|
class InkAnnotation extends MarkupAnnotation {
|
2018-09-30 23:29:16 +09:00
|
|
|
constructor(parameters) {
|
|
|
|
super(parameters);
|
|
|
|
|
|
|
|
this.data.annotationType = AnnotationType.INK;
|
2020-09-19 22:29:55 +09:00
|
|
|
this.data.inkLists = [];
|
2018-09-30 23:29:16 +09:00
|
|
|
|
2020-09-19 22:29:55 +09:00
|
|
|
const rawInkLists = parameters.dict.getArray("InkList");
|
|
|
|
if (!Array.isArray(rawInkLists)) {
|
|
|
|
return;
|
|
|
|
}
|
2018-09-30 23:29:16 +09:00
|
|
|
const xref = parameters.xref;
|
2020-09-19 22:29:55 +09:00
|
|
|
for (let i = 0, ii = rawInkLists.length; i < ii; ++i) {
|
2018-09-30 23:29:16 +09:00
|
|
|
// The raw ink lists array contains arrays of numbers representing
|
|
|
|
// the alternating horizontal and vertical coordinates, respectively,
|
|
|
|
// of each vertex. Convert this to an array of objects with x and y
|
|
|
|
// coordinates.
|
|
|
|
this.data.inkLists.push([]);
|
2020-09-19 22:29:55 +09:00
|
|
|
for (let j = 0, jj = rawInkLists[i].length; j < jj; j += 2) {
|
2018-09-30 23:29:16 +09:00
|
|
|
this.data.inkLists[i].push({
|
2020-09-19 22:29:55 +09:00
|
|
|
x: xref.fetchIfRef(rawInkLists[i][j]),
|
|
|
|
y: xref.fetchIfRef(rawInkLists[i][j + 1]),
|
2018-09-30 23:29:16 +09:00
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
2021-04-27 18:49:03 +09:00
|
|
|
|
|
|
|
if (!this.appearance) {
|
|
|
|
// The default stroke color is black.
|
|
|
|
const strokeColor = this.color
|
|
|
|
? Array.from(this.color).map(c => c / 255)
|
|
|
|
: [0, 0, 0];
|
2021-05-27 17:06:13 +09:00
|
|
|
const strokeAlpha = parameters.dict.get("CA");
|
2021-04-27 18:49:03 +09:00
|
|
|
|
2021-05-27 20:13:10 +09:00
|
|
|
const borderWidth = this.borderStyle.width || 1,
|
|
|
|
borderAdjust = 2 * borderWidth;
|
|
|
|
|
|
|
|
// If the /Rect-entry is empty/wrong, create a fallback rectangle so that
|
|
|
|
// we get similar rendering/highlighting behaviour as in Adobe Reader.
|
|
|
|
const bbox = [Infinity, Infinity, -Infinity, -Infinity];
|
|
|
|
for (const inkLists of this.data.inkLists) {
|
|
|
|
for (const vertex of inkLists) {
|
|
|
|
bbox[0] = Math.min(bbox[0], vertex.x - borderAdjust);
|
|
|
|
bbox[1] = Math.min(bbox[1], vertex.y - borderAdjust);
|
|
|
|
bbox[2] = Math.max(bbox[2], vertex.x + borderAdjust);
|
|
|
|
bbox[3] = Math.max(bbox[3], vertex.y + borderAdjust);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (!Util.intersect(this.rectangle, bbox)) {
|
|
|
|
this.rectangle = bbox;
|
|
|
|
}
|
2021-04-27 18:49:03 +09:00
|
|
|
|
|
|
|
this._setDefaultAppearance({
|
|
|
|
xref: parameters.xref,
|
|
|
|
extra: `${borderWidth} w`,
|
|
|
|
strokeColor,
|
2021-05-27 17:06:13 +09:00
|
|
|
strokeAlpha,
|
2021-04-27 18:49:03 +09:00
|
|
|
pointsCallback: (buffer, points) => {
|
|
|
|
// According to the specification, see "12.5.6.13 Ink Annotations":
|
|
|
|
// When drawn, the points shall be connected by straight lines or
|
|
|
|
// curves in an implementation-dependent way.
|
|
|
|
// In order to simplify things, we utilize straight lines for now.
|
|
|
|
for (const inkList of this.data.inkLists) {
|
|
|
|
for (let i = 0, ii = inkList.length; i < ii; i++) {
|
|
|
|
buffer.push(
|
|
|
|
`${inkList[i].x} ${inkList[i].y} ${i === 0 ? "m" : "l"}`
|
|
|
|
);
|
|
|
|
}
|
|
|
|
buffer.push("S");
|
|
|
|
}
|
|
|
|
return [points[0].x, points[1].x, points[3].y, points[1].y];
|
|
|
|
},
|
|
|
|
});
|
|
|
|
}
|
2018-09-30 23:29:16 +09:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-04-11 20:55:58 +09:00
|
|
|
class HighlightAnnotation extends MarkupAnnotation {
|
2017-08-27 06:49:11 +09:00
|
|
|
constructor(parameters) {
|
|
|
|
super(parameters);
|
2016-01-01 23:31:46 +09:00
|
|
|
|
|
|
|
this.data.annotationType = AnnotationType.HIGHLIGHT;
|
2020-10-21 19:00:34 +09:00
|
|
|
const quadPoints = (this.data.quadPoints = getQuadPoints(
|
|
|
|
parameters.dict,
|
|
|
|
null
|
|
|
|
));
|
2019-07-28 03:57:52 +09:00
|
|
|
if (quadPoints) {
|
2021-05-28 20:30:18 +09:00
|
|
|
const resources =
|
|
|
|
this.appearance && this.appearance.dict.get("Resources");
|
|
|
|
|
|
|
|
if (!this.appearance || !(resources && resources.has("ExtGState"))) {
|
|
|
|
if (this.appearance) {
|
|
|
|
// Workaround for cases where there's no /ExtGState-entry directly
|
|
|
|
// available, e.g. when the appearance stream contains a /XObject of
|
|
|
|
// the /Form-type, since that causes the highlighting to completely
|
2022-04-09 09:43:18 +09:00
|
|
|
// obscure the PDF content below it (fixes issue13242.pdf).
|
2021-05-28 20:30:18 +09:00
|
|
|
warn("HighlightAnnotation - ignoring built-in appearance stream.");
|
|
|
|
}
|
2020-08-08 03:46:41 +09:00
|
|
|
// Default color is yellow in Acrobat Reader
|
|
|
|
const fillColor = this.color
|
|
|
|
? Array.from(this.color).map(c => c / 255)
|
|
|
|
: [1, 1, 0];
|
2021-05-27 17:06:13 +09:00
|
|
|
const fillAlpha = parameters.dict.get("CA");
|
|
|
|
|
2020-08-08 03:46:41 +09:00
|
|
|
this._setDefaultAppearance({
|
|
|
|
xref: parameters.xref,
|
|
|
|
fillColor,
|
|
|
|
blendMode: "Multiply",
|
2021-05-27 17:06:13 +09:00
|
|
|
fillAlpha,
|
2020-08-08 03:46:41 +09:00
|
|
|
pointsCallback: (buffer, points) => {
|
2021-05-24 20:20:19 +09:00
|
|
|
buffer.push(
|
|
|
|
`${points[0].x} ${points[0].y} m`,
|
|
|
|
`${points[1].x} ${points[1].y} l`,
|
|
|
|
`${points[3].x} ${points[3].y} l`,
|
|
|
|
`${points[2].x} ${points[2].y} l`,
|
|
|
|
"f"
|
|
|
|
);
|
2020-08-08 03:46:41 +09:00
|
|
|
return [points[0].x, points[1].x, points[3].y, points[1].y];
|
|
|
|
},
|
|
|
|
});
|
|
|
|
}
|
2020-10-21 19:00:34 +09:00
|
|
|
} else {
|
|
|
|
this.data.hasPopup = false;
|
2019-07-28 03:57:52 +09:00
|
|
|
}
|
2016-01-01 23:31:46 +09:00
|
|
|
}
|
2017-08-27 06:49:11 +09:00
|
|
|
}
|
2016-01-01 23:31:46 +09:00
|
|
|
|
2019-04-11 20:55:58 +09:00
|
|
|
class UnderlineAnnotation extends MarkupAnnotation {
|
2017-08-27 06:49:11 +09:00
|
|
|
constructor(parameters) {
|
|
|
|
super(parameters);
|
2015-12-28 08:33:41 +09:00
|
|
|
|
|
|
|
this.data.annotationType = AnnotationType.UNDERLINE;
|
2020-10-21 19:00:34 +09:00
|
|
|
const quadPoints = (this.data.quadPoints = getQuadPoints(
|
|
|
|
parameters.dict,
|
|
|
|
null
|
|
|
|
));
|
2019-07-28 03:57:52 +09:00
|
|
|
if (quadPoints) {
|
2020-08-08 03:46:41 +09:00
|
|
|
if (!this.appearance) {
|
|
|
|
// Default color is black
|
|
|
|
const strokeColor = this.color
|
|
|
|
? Array.from(this.color).map(c => c / 255)
|
|
|
|
: [0, 0, 0];
|
2021-05-27 17:06:13 +09:00
|
|
|
const strokeAlpha = parameters.dict.get("CA");
|
|
|
|
|
2020-08-08 03:46:41 +09:00
|
|
|
this._setDefaultAppearance({
|
|
|
|
xref: parameters.xref,
|
|
|
|
extra: "[] 0 d 1 w",
|
|
|
|
strokeColor,
|
2021-05-27 17:06:13 +09:00
|
|
|
strokeAlpha,
|
2020-08-08 03:46:41 +09:00
|
|
|
pointsCallback: (buffer, points) => {
|
2021-05-24 20:20:19 +09:00
|
|
|
buffer.push(
|
|
|
|
`${points[2].x} ${points[2].y} m`,
|
|
|
|
`${points[3].x} ${points[3].y} l`,
|
|
|
|
"S"
|
|
|
|
);
|
2020-08-08 03:46:41 +09:00
|
|
|
return [points[0].x, points[1].x, points[3].y, points[1].y];
|
|
|
|
},
|
|
|
|
});
|
|
|
|
}
|
2020-10-21 19:00:34 +09:00
|
|
|
} else {
|
|
|
|
this.data.hasPopup = false;
|
2019-07-28 03:57:52 +09:00
|
|
|
}
|
2015-12-28 08:33:41 +09:00
|
|
|
}
|
2017-08-27 06:49:11 +09:00
|
|
|
}
|
2015-12-28 08:33:41 +09:00
|
|
|
|
2019-04-11 20:55:58 +09:00
|
|
|
class SquigglyAnnotation extends MarkupAnnotation {
|
2017-08-27 06:49:11 +09:00
|
|
|
constructor(parameters) {
|
|
|
|
super(parameters);
|
2015-12-30 23:28:26 +09:00
|
|
|
|
|
|
|
this.data.annotationType = AnnotationType.SQUIGGLY;
|
2019-07-28 03:57:52 +09:00
|
|
|
|
2020-10-21 19:00:34 +09:00
|
|
|
const quadPoints = (this.data.quadPoints = getQuadPoints(
|
|
|
|
parameters.dict,
|
|
|
|
null
|
|
|
|
));
|
2019-07-28 03:57:52 +09:00
|
|
|
if (quadPoints) {
|
2020-08-08 03:46:41 +09:00
|
|
|
if (!this.appearance) {
|
|
|
|
// Default color is black
|
|
|
|
const strokeColor = this.color
|
|
|
|
? Array.from(this.color).map(c => c / 255)
|
|
|
|
: [0, 0, 0];
|
2021-05-27 17:06:13 +09:00
|
|
|
const strokeAlpha = parameters.dict.get("CA");
|
|
|
|
|
2020-08-08 03:46:41 +09:00
|
|
|
this._setDefaultAppearance({
|
|
|
|
xref: parameters.xref,
|
|
|
|
extra: "[] 0 d 1 w",
|
|
|
|
strokeColor,
|
2021-05-27 17:06:13 +09:00
|
|
|
strokeAlpha,
|
2020-08-08 03:46:41 +09:00
|
|
|
pointsCallback: (buffer, points) => {
|
|
|
|
const dy = (points[0].y - points[2].y) / 6;
|
|
|
|
let shift = dy;
|
|
|
|
let x = points[2].x;
|
|
|
|
const y = points[2].y;
|
|
|
|
const xEnd = points[3].x;
|
|
|
|
buffer.push(`${x} ${y + shift} m`);
|
|
|
|
do {
|
|
|
|
x += 2;
|
|
|
|
shift = shift === 0 ? dy : 0;
|
|
|
|
buffer.push(`${x} ${y + shift} l`);
|
|
|
|
} while (x < xEnd);
|
|
|
|
buffer.push("S");
|
|
|
|
return [points[2].x, xEnd, y - 2 * dy, y + 2 * dy];
|
|
|
|
},
|
|
|
|
});
|
|
|
|
}
|
2020-10-21 19:00:34 +09:00
|
|
|
} else {
|
|
|
|
this.data.hasPopup = false;
|
2019-07-28 03:57:52 +09:00
|
|
|
}
|
2015-12-30 23:28:26 +09:00
|
|
|
}
|
2017-08-27 06:49:11 +09:00
|
|
|
}
|
2015-12-30 23:28:26 +09:00
|
|
|
|
2019-04-11 20:55:58 +09:00
|
|
|
class StrikeOutAnnotation extends MarkupAnnotation {
|
2017-08-27 06:49:11 +09:00
|
|
|
constructor(parameters) {
|
|
|
|
super(parameters);
|
2015-12-29 23:09:28 +09:00
|
|
|
|
|
|
|
this.data.annotationType = AnnotationType.STRIKEOUT;
|
2019-07-28 03:57:52 +09:00
|
|
|
|
2020-10-21 19:00:34 +09:00
|
|
|
const quadPoints = (this.data.quadPoints = getQuadPoints(
|
|
|
|
parameters.dict,
|
|
|
|
null
|
|
|
|
));
|
2019-07-28 03:57:52 +09:00
|
|
|
if (quadPoints) {
|
2020-08-08 03:46:41 +09:00
|
|
|
if (!this.appearance) {
|
|
|
|
// Default color is black
|
|
|
|
const strokeColor = this.color
|
|
|
|
? Array.from(this.color).map(c => c / 255)
|
|
|
|
: [0, 0, 0];
|
2021-05-27 17:06:13 +09:00
|
|
|
const strokeAlpha = parameters.dict.get("CA");
|
|
|
|
|
2020-08-08 03:46:41 +09:00
|
|
|
this._setDefaultAppearance({
|
|
|
|
xref: parameters.xref,
|
|
|
|
extra: "[] 0 d 1 w",
|
|
|
|
strokeColor,
|
2021-05-27 17:06:13 +09:00
|
|
|
strokeAlpha,
|
2020-08-08 03:46:41 +09:00
|
|
|
pointsCallback: (buffer, points) => {
|
|
|
|
buffer.push(
|
2021-05-24 20:20:19 +09:00
|
|
|
`${(points[0].x + points[2].x) / 2} ` +
|
|
|
|
`${(points[0].y + points[2].y) / 2} m`,
|
|
|
|
`${(points[1].x + points[3].x) / 2} ` +
|
|
|
|
`${(points[1].y + points[3].y) / 2} l`,
|
|
|
|
"S"
|
2020-08-08 03:46:41 +09:00
|
|
|
);
|
|
|
|
return [points[0].x, points[1].x, points[3].y, points[1].y];
|
|
|
|
},
|
|
|
|
});
|
|
|
|
}
|
2020-10-21 19:00:34 +09:00
|
|
|
} else {
|
|
|
|
this.data.hasPopup = false;
|
2019-07-28 03:57:52 +09:00
|
|
|
}
|
2015-12-29 23:09:28 +09:00
|
|
|
}
|
2017-08-27 06:49:11 +09:00
|
|
|
}
|
2015-12-29 23:09:28 +09:00
|
|
|
|
2019-04-11 20:55:58 +09:00
|
|
|
class StampAnnotation extends MarkupAnnotation {
|
2017-09-16 23:37:50 +09:00
|
|
|
constructor(parameters) {
|
|
|
|
super(parameters);
|
|
|
|
|
|
|
|
this.data.annotationType = AnnotationType.STAMP;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-04-11 20:55:58 +09:00
|
|
|
class FileAttachmentAnnotation extends MarkupAnnotation {
|
2017-08-27 06:49:11 +09:00
|
|
|
constructor(parameters) {
|
|
|
|
super(parameters);
|
2015-12-29 23:09: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
|
|
|
const file = new FileSpec(parameters.dict.get("FS"), parameters.xref);
|
2016-02-15 04:44:00 +09:00
|
|
|
|
|
|
|
this.data.annotationType = AnnotationType.FILEATTACHMENT;
|
|
|
|
this.data.file = file.serializable;
|
|
|
|
}
|
2017-08-27 06:49:11 +09:00
|
|
|
}
|
2016-02-15 04:44:00 +09:00
|
|
|
|
2017-04-02 23:14:30 +09:00
|
|
|
export {
|
|
|
|
Annotation,
|
|
|
|
AnnotationBorderStyle,
|
|
|
|
AnnotationFactory,
|
2019-07-28 03:57:52 +09:00
|
|
|
getQuadPoints,
|
2021-01-09 23:37:44 +09:00
|
|
|
MarkupAnnotation,
|
2017-04-02 23:14:30 +09:00
|
|
|
};
|