2016-07-28 00:21:47 +09:00
|
|
|
/* Copyright 2016 Mozilla Foundation
|
2015-03-15 04:07:17 +09:00
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
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
|
|
|
"use strict";
|
2015-03-15 04:07:17 +09:00
|
|
|
|
2018-03-16 05:49:28 +09:00
|
|
|
if (!pdfjsLib.getDocument || !pdfjsViewer.PDFViewer) {
|
2021-01-23 01:38:26 +09:00
|
|
|
// eslint-disable-next-line no-alert
|
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
|
|
|
alert("Please build the pdfjs-dist library using\n `gulp dist-install`");
|
2016-07-28 00:21:47 +09:00
|
|
|
}
|
|
|
|
|
2021-03-13 01:08:17 +09:00
|
|
|
const USE_ONLY_CSS_ZOOM = true;
|
|
|
|
const TEXT_LAYER_MODE = 0; // DISABLE
|
|
|
|
const MAX_IMAGE_SIZE = 1024 * 1024;
|
|
|
|
const CMAP_URL = "../../node_modules/pdfjs-dist/cmaps/";
|
|
|
|
const CMAP_PACKED = true;
|
2015-03-15 04:07:17 +09:00
|
|
|
|
2018-03-16 05:49:28 +09:00
|
|
|
pdfjsLib.GlobalWorkerOptions.workerSrc =
|
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
|
|
|
"../../node_modules/pdfjs-dist/build/pdf.worker.js";
|
2018-02-14 22:49:24 +09:00
|
|
|
|
2021-03-13 01:08:17 +09:00
|
|
|
const DEFAULT_URL = "../../web/compressed.tracemonkey-pldi-09.pdf";
|
|
|
|
const DEFAULT_SCALE_DELTA = 1.1;
|
|
|
|
const MIN_SCALE = 0.25;
|
|
|
|
const MAX_SCALE = 10.0;
|
|
|
|
const DEFAULT_SCALE_VALUE = "auto";
|
2015-03-15 04:07:17 +09:00
|
|
|
|
2021-03-13 01:12:41 +09:00
|
|
|
const PDFViewerApplication = {
|
2016-08-27 19:46:05 +09:00
|
|
|
pdfLoadingTask: null,
|
2015-03-15 04:07:17 +09:00
|
|
|
pdfDocument: null,
|
|
|
|
pdfViewer: null,
|
|
|
|
pdfHistory: null,
|
|
|
|
pdfLinkService: null,
|
2020-02-27 01:16:30 +09:00
|
|
|
eventBus: null,
|
2015-03-15 04:07:17 +09:00
|
|
|
|
2016-08-27 19:46:05 +09:00
|
|
|
/**
|
|
|
|
* Opens PDF document specified by URL.
|
|
|
|
* @returns {Promise} - Returns the promise, which is resolved when document
|
|
|
|
* is opened.
|
|
|
|
*/
|
2021-01-23 01:38:26 +09:00
|
|
|
open(params) {
|
2016-08-27 19:46:05 +09:00
|
|
|
if (this.pdfLoadingTask) {
|
|
|
|
// We need to destroy already opened document
|
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.close().then(
|
2020-04-14 19:28:14 +09:00
|
|
|
function () {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
// ... and repeat the open() call.
|
|
|
|
return this.open(params);
|
|
|
|
}.bind(this)
|
|
|
|
);
|
2016-08-27 19:46:05 +09:00
|
|
|
}
|
|
|
|
|
2021-03-13 01:08:17 +09:00
|
|
|
const url = params.url;
|
|
|
|
const self = this;
|
2016-07-28 00:21:47 +09:00
|
|
|
this.setTitleUsingUrl(url);
|
2015-03-15 04:07:17 +09:00
|
|
|
|
|
|
|
// Loading document.
|
2021-03-13 01:08:17 +09:00
|
|
|
const loadingTask = pdfjsLib.getDocument({
|
2021-01-23 01:38:26 +09:00
|
|
|
url,
|
2018-02-18 00:13:33 +09:00
|
|
|
maxImageSize: MAX_IMAGE_SIZE,
|
2018-02-18 00:57:24 +09:00
|
|
|
cMapUrl: CMAP_URL,
|
|
|
|
cMapPacked: CMAP_PACKED,
|
2018-02-18 00:13:33 +09:00
|
|
|
});
|
2016-08-27 19:46:05 +09:00
|
|
|
this.pdfLoadingTask = loadingTask;
|
|
|
|
|
2020-04-14 19:28:14 +09:00
|
|
|
loadingTask.onProgress = function (progressData) {
|
2015-03-15 04:07:17 +09:00
|
|
|
self.progress(progressData.loaded / progressData.total);
|
|
|
|
};
|
2016-08-27 19:46:05 +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 loadingTask.promise.then(
|
2020-04-14 19:28:14 +09:00
|
|
|
function (pdfDocument) {
|
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
|
|
|
// Document loaded, specifying document for the viewer.
|
|
|
|
self.pdfDocument = pdfDocument;
|
|
|
|
self.pdfViewer.setDocument(pdfDocument);
|
|
|
|
self.pdfLinkService.setDocument(pdfDocument);
|
2022-05-14 20:10:13 +09:00
|
|
|
self.pdfHistory.initialize({
|
|
|
|
fingerprint: pdfDocument.fingerprints[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
|
|
|
|
|
|
|
self.loadingBar.hide();
|
|
|
|
self.setTitleUsingMetadata(pdfDocument);
|
|
|
|
},
|
2020-04-14 19:28:14 +09:00
|
|
|
function (exception) {
|
2021-03-13 01:08:17 +09:00
|
|
|
const message = exception && exception.message;
|
|
|
|
const l10n = self.l10n;
|
|
|
|
let loadingErrorMessage;
|
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 (exception instanceof pdfjsLib.InvalidPDFException) {
|
|
|
|
// change error message also for other builds
|
|
|
|
loadingErrorMessage = l10n.get(
|
|
|
|
"invalid_file_error",
|
|
|
|
null,
|
|
|
|
"Invalid or corrupted PDF file."
|
|
|
|
);
|
|
|
|
} else if (exception instanceof pdfjsLib.MissingPDFException) {
|
|
|
|
// special message for missing PDFs
|
|
|
|
loadingErrorMessage = l10n.get(
|
|
|
|
"missing_file_error",
|
|
|
|
null,
|
|
|
|
"Missing PDF file."
|
|
|
|
);
|
|
|
|
} else if (exception instanceof pdfjsLib.UnexpectedResponseException) {
|
|
|
|
loadingErrorMessage = l10n.get(
|
|
|
|
"unexpected_response_error",
|
|
|
|
null,
|
|
|
|
"Unexpected server response."
|
|
|
|
);
|
|
|
|
} else {
|
|
|
|
loadingErrorMessage = l10n.get(
|
|
|
|
"loading_error",
|
|
|
|
null,
|
|
|
|
"An error occurred while loading the PDF."
|
|
|
|
);
|
|
|
|
}
|
2015-03-15 04:07:17 +09:00
|
|
|
|
2020-04-14 19:28:14 +09:00
|
|
|
loadingErrorMessage.then(function (msg) {
|
2021-01-23 01:38:26 +09:00
|
|
|
self.error(msg, { message });
|
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
|
|
|
});
|
|
|
|
self.loadingBar.hide();
|
|
|
|
}
|
|
|
|
);
|
2015-03-15 04:07:17 +09:00
|
|
|
},
|
|
|
|
|
2016-08-27 19:46:05 +09:00
|
|
|
/**
|
|
|
|
* Closes opened PDF document.
|
|
|
|
* @returns {Promise} - Returns the promise, which is resolved when all
|
|
|
|
* destruction is completed.
|
|
|
|
*/
|
2021-01-23 01:38:26 +09:00
|
|
|
close() {
|
2021-03-13 01:08:17 +09:00
|
|
|
const errorWrapper = document.getElementById("errorWrapper");
|
2021-02-08 08:21:49 +09:00
|
|
|
errorWrapper.hidden = true;
|
2016-08-27 19:46:05 +09:00
|
|
|
|
|
|
|
if (!this.pdfLoadingTask) {
|
|
|
|
return Promise.resolve();
|
|
|
|
}
|
|
|
|
|
2021-03-13 01:08:17 +09:00
|
|
|
const promise = this.pdfLoadingTask.destroy();
|
2016-08-27 19:46:05 +09:00
|
|
|
this.pdfLoadingTask = null;
|
|
|
|
|
|
|
|
if (this.pdfDocument) {
|
|
|
|
this.pdfDocument = null;
|
|
|
|
|
|
|
|
this.pdfViewer.setDocument(null);
|
|
|
|
this.pdfLinkService.setDocument(null, null);
|
2019-12-03 20:04:49 +09:00
|
|
|
|
|
|
|
if (this.pdfHistory) {
|
|
|
|
this.pdfHistory.reset();
|
|
|
|
}
|
2016-08-27 19:46:05 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
return promise;
|
|
|
|
},
|
|
|
|
|
2015-03-15 04:07:17 +09:00
|
|
|
get loadingBar() {
|
2022-07-01 17:14:57 +09:00
|
|
|
const bar = new pdfjsViewer.ProgressBar("loadingBar");
|
2015-03-15 04:07:17 +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 pdfjsLib.shadow(this, "loadingBar", bar);
|
2015-03-15 04:07:17 +09:00
|
|
|
},
|
|
|
|
|
|
|
|
setTitleUsingUrl: function pdfViewSetTitleUsingUrl(url) {
|
|
|
|
this.url = url;
|
2021-03-13 01:08:17 +09:00
|
|
|
let title = pdfjsLib.getFilenameFromUrl(url) || url;
|
2015-03-15 04:07:17 +09:00
|
|
|
try {
|
|
|
|
title = decodeURIComponent(title);
|
|
|
|
} catch (e) {
|
|
|
|
// decodeURIComponent may throw URIError,
|
|
|
|
// fall back to using the unprocessed url in that case
|
|
|
|
}
|
|
|
|
this.setTitle(title);
|
|
|
|
},
|
|
|
|
|
2021-01-23 01:38:26 +09:00
|
|
|
setTitleUsingMetadata(pdfDocument) {
|
2021-03-13 01:08:17 +09:00
|
|
|
const self = this;
|
2020-04-14 19:28:14 +09:00
|
|
|
pdfDocument.getMetadata().then(function (data) {
|
2021-03-13 01:08:17 +09:00
|
|
|
const info = data.info,
|
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
|
|
|
metadata = data.metadata;
|
2015-03-15 04:07:17 +09:00
|
|
|
self.documentInfo = info;
|
|
|
|
self.metadata = metadata;
|
|
|
|
|
|
|
|
// Provides some basic debug information
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
console.log(
|
|
|
|
"PDF " +
|
2022-05-14 20:10:13 +09:00
|
|
|
pdfDocument.fingerprints[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
|
|
|
" [" +
|
|
|
|
info.PDFFormatVersion +
|
|
|
|
" " +
|
|
|
|
(info.Producer || "-").trim() +
|
|
|
|
" / " +
|
|
|
|
(info.Creator || "-").trim() +
|
|
|
|
"]" +
|
|
|
|
" (PDF.js: " +
|
|
|
|
(pdfjsLib.version || "-") +
|
|
|
|
")"
|
|
|
|
);
|
2015-03-15 04:07:17 +09:00
|
|
|
|
2021-03-13 01:08:17 +09:00
|
|
|
let pdfTitle;
|
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 (metadata && metadata.has("dc:title")) {
|
2021-03-13 01:08:17 +09:00
|
|
|
const title = metadata.get("dc:title");
|
2015-03-15 04:07:17 +09:00
|
|
|
// Ghostscript sometimes returns 'Untitled', so prevent setting the
|
|
|
|
// title to 'Untitled.
|
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 (title !== "Untitled") {
|
2015-03-15 04:07:17 +09:00
|
|
|
pdfTitle = title;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-04-17 19:06:27 +09:00
|
|
|
if (!pdfTitle && info && info.Title) {
|
|
|
|
pdfTitle = info.Title;
|
2015-03-15 04:07:17 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
if (pdfTitle) {
|
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
|
|
|
self.setTitle(pdfTitle + " - " + document.title);
|
2015-03-15 04:07:17 +09:00
|
|
|
}
|
|
|
|
});
|
|
|
|
},
|
|
|
|
|
|
|
|
setTitle: function pdfViewSetTitle(title) {
|
|
|
|
document.title = title;
|
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
|
|
|
document.getElementById("title").textContent = title;
|
2015-03-15 04:07:17 +09:00
|
|
|
},
|
|
|
|
|
|
|
|
error: function pdfViewError(message, moreInfo) {
|
2021-03-13 01:08:17 +09:00
|
|
|
const l10n = this.l10n;
|
|
|
|
const moreInfoText = [
|
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
|
|
|
l10n.get(
|
|
|
|
"error_version_info",
|
|
|
|
{ version: pdfjsLib.version || "?", build: pdfjsLib.build || "?" },
|
|
|
|
"PDF.js v{{version}} (build: {{build}})"
|
|
|
|
),
|
|
|
|
];
|
2015-03-15 04:07:17 +09:00
|
|
|
|
|
|
|
if (moreInfo) {
|
2017-05-04 10:05:53 +09:00
|
|
|
moreInfoText.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
|
|
|
l10n.get(
|
|
|
|
"error_message",
|
|
|
|
{ message: moreInfo.message },
|
|
|
|
"Message: {{message}}"
|
|
|
|
)
|
|
|
|
);
|
2015-03-15 04:07:17 +09:00
|
|
|
if (moreInfo.stack) {
|
2017-05-04 10:05:53 +09:00
|
|
|
moreInfoText.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
|
|
|
l10n.get("error_stack", { stack: moreInfo.stack }, "Stack: {{stack}}")
|
|
|
|
);
|
2015-03-15 04:07:17 +09:00
|
|
|
} else {
|
|
|
|
if (moreInfo.filename) {
|
2017-05-04 10:05:53 +09:00
|
|
|
moreInfoText.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
|
|
|
l10n.get(
|
|
|
|
"error_file",
|
|
|
|
{ file: moreInfo.filename },
|
|
|
|
"File: {{file}}"
|
|
|
|
)
|
|
|
|
);
|
2015-03-15 04:07:17 +09:00
|
|
|
}
|
|
|
|
if (moreInfo.lineNumber) {
|
2017-05-04 10:05:53 +09:00
|
|
|
moreInfoText.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
|
|
|
l10n.get(
|
|
|
|
"error_line",
|
|
|
|
{ line: moreInfo.lineNumber },
|
|
|
|
"Line: {{line}}"
|
|
|
|
)
|
|
|
|
);
|
2015-03-15 04:07:17 +09:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-03-13 01:08:17 +09:00
|
|
|
const errorWrapper = document.getElementById("errorWrapper");
|
2021-02-08 08:21:49 +09:00
|
|
|
errorWrapper.hidden = false;
|
2015-03-15 04:07:17 +09:00
|
|
|
|
2021-03-13 01:08:17 +09:00
|
|
|
const errorMessage = document.getElementById("errorMessage");
|
2015-03-15 04:07:17 +09:00
|
|
|
errorMessage.textContent = message;
|
|
|
|
|
2021-03-13 01:08:17 +09:00
|
|
|
const closeButton = document.getElementById("errorClose");
|
2020-04-14 19:28:14 +09:00
|
|
|
closeButton.onclick = function () {
|
2021-02-08 08:21:49 +09:00
|
|
|
errorWrapper.hidden = true;
|
2015-03-15 04:07:17 +09:00
|
|
|
};
|
|
|
|
|
2021-03-13 01:08:17 +09:00
|
|
|
const errorMoreInfo = document.getElementById("errorMoreInfo");
|
|
|
|
const moreInfoButton = document.getElementById("errorShowMore");
|
|
|
|
const lessInfoButton = document.getElementById("errorShowLess");
|
2020-04-14 19:28:14 +09:00
|
|
|
moreInfoButton.onclick = function () {
|
2021-02-08 08:21:49 +09:00
|
|
|
errorMoreInfo.hidden = false;
|
|
|
|
moreInfoButton.hidden = true;
|
|
|
|
lessInfoButton.hidden = false;
|
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
|
|
|
errorMoreInfo.style.height = errorMoreInfo.scrollHeight + "px";
|
2015-03-15 04:07:17 +09:00
|
|
|
};
|
2020-04-14 19:28:14 +09:00
|
|
|
lessInfoButton.onclick = function () {
|
2021-02-08 08:21:49 +09:00
|
|
|
errorMoreInfo.hidden = true;
|
|
|
|
moreInfoButton.hidden = false;
|
|
|
|
lessInfoButton.hidden = true;
|
2015-03-15 04:07:17 +09:00
|
|
|
};
|
2021-02-08 08:21:49 +09:00
|
|
|
moreInfoButton.hidden = false;
|
|
|
|
lessInfoButton.hidden = true;
|
2020-04-14 19:28:14 +09:00
|
|
|
Promise.all(moreInfoText).then(function (parts) {
|
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
|
|
|
errorMoreInfo.value = parts.join("\n");
|
2017-05-04 10:05:53 +09:00
|
|
|
});
|
2015-03-15 04:07:17 +09:00
|
|
|
},
|
|
|
|
|
|
|
|
progress: function pdfViewProgress(level) {
|
2021-03-13 01:08:17 +09:00
|
|
|
const percent = Math.round(level * 100);
|
2015-03-15 04:07:17 +09:00
|
|
|
// Updating the bar if value increases.
|
|
|
|
if (percent > this.loadingBar.percent || isNaN(percent)) {
|
|
|
|
this.loadingBar.percent = percent;
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
get pagesCount() {
|
|
|
|
return this.pdfDocument.numPages;
|
|
|
|
},
|
|
|
|
|
|
|
|
get page() {
|
|
|
|
return this.pdfViewer.currentPageNumber;
|
|
|
|
},
|
|
|
|
|
2020-05-07 18:43:19 +09:00
|
|
|
set page(val) {
|
|
|
|
this.pdfViewer.currentPageNumber = val;
|
|
|
|
},
|
|
|
|
|
2015-03-15 04:07:17 +09:00
|
|
|
zoomIn: function pdfViewZoomIn(ticks) {
|
2021-03-13 01:08:17 +09:00
|
|
|
let newScale = this.pdfViewer.currentScale;
|
2015-03-15 04:07:17 +09:00
|
|
|
do {
|
|
|
|
newScale = (newScale * DEFAULT_SCALE_DELTA).toFixed(2);
|
|
|
|
newScale = Math.ceil(newScale * 10) / 10;
|
|
|
|
newScale = Math.min(MAX_SCALE, newScale);
|
|
|
|
} while (--ticks && newScale < MAX_SCALE);
|
|
|
|
this.pdfViewer.currentScaleValue = newScale;
|
|
|
|
},
|
|
|
|
|
|
|
|
zoomOut: function pdfViewZoomOut(ticks) {
|
2021-03-13 01:08:17 +09:00
|
|
|
let newScale = this.pdfViewer.currentScale;
|
2015-03-15 04:07:17 +09:00
|
|
|
do {
|
|
|
|
newScale = (newScale / DEFAULT_SCALE_DELTA).toFixed(2);
|
|
|
|
newScale = Math.floor(newScale * 10) / 10;
|
|
|
|
newScale = Math.max(MIN_SCALE, newScale);
|
|
|
|
} while (--ticks && newScale > MIN_SCALE);
|
|
|
|
this.pdfViewer.currentScaleValue = newScale;
|
|
|
|
},
|
|
|
|
|
|
|
|
initUI: function pdfViewInitUI() {
|
2021-03-13 01:08:17 +09:00
|
|
|
const eventBus = new pdfjsViewer.EventBus();
|
2020-02-27 01:16:30 +09:00
|
|
|
this.eventBus = eventBus;
|
|
|
|
|
2021-03-13 01:08:17 +09:00
|
|
|
const linkService = new pdfjsViewer.PDFLinkService({
|
2021-01-23 01:38:26 +09:00
|
|
|
eventBus,
|
2020-02-27 01:16:30 +09:00
|
|
|
});
|
2015-03-15 04:07:17 +09:00
|
|
|
this.pdfLinkService = linkService;
|
|
|
|
|
2018-03-16 05:49:28 +09:00
|
|
|
this.l10n = pdfjsViewer.NullL10n;
|
2017-05-04 10:05:53 +09:00
|
|
|
|
2021-03-13 01:08:17 +09:00
|
|
|
const container = document.getElementById("viewerContainer");
|
|
|
|
const pdfViewer = new pdfjsViewer.PDFViewer({
|
2021-01-23 01:38:26 +09:00
|
|
|
container,
|
|
|
|
eventBus,
|
|
|
|
linkService,
|
2017-05-04 10:05:53 +09:00
|
|
|
l10n: this.l10n,
|
2018-02-13 20:52:42 +09:00
|
|
|
useOnlyCssZoom: USE_ONLY_CSS_ZOOM,
|
2018-02-13 23:01:55 +09:00
|
|
|
textLayerMode: TEXT_LAYER_MODE,
|
2015-03-15 04:07:17 +09:00
|
|
|
});
|
|
|
|
this.pdfViewer = pdfViewer;
|
|
|
|
linkService.setViewer(pdfViewer);
|
|
|
|
|
2018-03-16 05:49:28 +09:00
|
|
|
this.pdfHistory = new pdfjsViewer.PDFHistory({
|
2021-01-23 01:38:26 +09:00
|
|
|
eventBus,
|
|
|
|
linkService,
|
2015-03-15 04:07:17 +09:00
|
|
|
});
|
|
|
|
linkService.setHistory(this.pdfHistory);
|
|
|
|
|
2020-04-14 19:28:14 +09:00
|
|
|
document.getElementById("previous").addEventListener("click", function () {
|
2015-03-15 04:07:17 +09:00
|
|
|
PDFViewerApplication.page--;
|
|
|
|
});
|
|
|
|
|
2020-04-14 19:28:14 +09:00
|
|
|
document.getElementById("next").addEventListener("click", function () {
|
2015-03-15 04:07:17 +09:00
|
|
|
PDFViewerApplication.page++;
|
|
|
|
});
|
|
|
|
|
2020-04-14 19:28:14 +09:00
|
|
|
document.getElementById("zoomIn").addEventListener("click", function () {
|
2015-03-15 04:07:17 +09:00
|
|
|
PDFViewerApplication.zoomIn();
|
|
|
|
});
|
|
|
|
|
2020-04-14 19:28:14 +09:00
|
|
|
document.getElementById("zoomOut").addEventListener("click", function () {
|
2015-03-15 04:07:17 +09:00
|
|
|
PDFViewerApplication.zoomOut();
|
|
|
|
});
|
|
|
|
|
2020-04-14 19:28:14 +09:00
|
|
|
document
|
|
|
|
.getElementById("pageNumber")
|
|
|
|
.addEventListener("click", function () {
|
|
|
|
this.select();
|
|
|
|
});
|
2015-03-15 04:07:17 +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
|
|
|
document
|
|
|
|
.getElementById("pageNumber")
|
2020-04-14 19:28:14 +09:00
|
|
|
.addEventListener("change", function () {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
PDFViewerApplication.page = this.value | 0;
|
2015-03-15 04:07:17 +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
|
|
|
// Ensure that the page number input displays the correct value,
|
|
|
|
// even if the value entered by the user was invalid
|
|
|
|
// (e.g. a floating point number).
|
|
|
|
if (this.value !== PDFViewerApplication.page.toString()) {
|
|
|
|
this.value = PDFViewerApplication.page;
|
|
|
|
}
|
|
|
|
});
|
2015-03-15 04:07:17 +09:00
|
|
|
|
2020-04-14 19:28:14 +09:00
|
|
|
eventBus.on("pagesinit", function () {
|
2015-03-15 04:07:17 +09:00
|
|
|
// We can use pdfViewer now, e.g. let's change default scale.
|
|
|
|
pdfViewer.currentScaleValue = DEFAULT_SCALE_VALUE;
|
|
|
|
});
|
|
|
|
|
2020-02-27 01:16:30 +09:00
|
|
|
eventBus.on(
|
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
|
|
|
"pagechanging",
|
2020-04-14 19:28:14 +09:00
|
|
|
function (evt) {
|
2021-03-13 01:08:17 +09:00
|
|
|
const page = evt.pageNumber;
|
|
|
|
const numPages = PDFViewerApplication.pagesCount;
|
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
|
|
|
|
|
|
|
document.getElementById("pageNumber").value = page;
|
|
|
|
document.getElementById("previous").disabled = page <= 1;
|
|
|
|
document.getElementById("next").disabled = page >= numPages;
|
|
|
|
},
|
|
|
|
true
|
|
|
|
);
|
2018-12-06 21:55:15 +09:00
|
|
|
},
|
2015-03-15 04:07:17 +09:00
|
|
|
};
|
|
|
|
|
2021-03-13 01:12:41 +09:00
|
|
|
window.PDFViewerApplication = PDFViewerApplication;
|
|
|
|
|
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
|
|
|
document.addEventListener(
|
|
|
|
"DOMContentLoaded",
|
2020-04-14 19:28:14 +09:00
|
|
|
function () {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
PDFViewerApplication.initUI();
|
|
|
|
},
|
|
|
|
true
|
|
|
|
);
|
2015-03-15 04:07:17 +09:00
|
|
|
|
2021-03-13 01:19:58 +09:00
|
|
|
// The offsetParent is not set until the PDF.js iframe or object is visible;
|
|
|
|
// waiting for first animation.
|
|
|
|
const animationStarted = new Promise(function (resolve) {
|
|
|
|
window.requestAnimationFrame(resolve);
|
|
|
|
});
|
2015-03-15 04:07:17 +09:00
|
|
|
|
2016-07-28 00:21:47 +09:00
|
|
|
// We need to delay opening until all HTML is loaded.
|
2021-03-13 01:19:58 +09:00
|
|
|
animationStarted.then(function () {
|
2016-07-28 00:21:47 +09:00
|
|
|
PDFViewerApplication.open({
|
2018-12-06 21:55:15 +09:00
|
|
|
url: DEFAULT_URL,
|
2015-03-15 04:07:17 +09:00
|
|
|
});
|
|
|
|
});
|