2013-10-02 06:11:46 +09:00
|
|
|
/* Copyright 2012 Mozilla Foundation
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
|
2021-10-07 21:04:41 +09:00
|
|
|
import {
|
|
|
|
normalizeWheelEventDelta,
|
|
|
|
PresentationModeState,
|
|
|
|
ScrollMode,
|
|
|
|
SpreadMode,
|
|
|
|
} from "./ui_utils.js";
|
2022-07-01 23:09:10 +09:00
|
|
|
import { AnnotationEditorType } from "pdfjs-lib";
|
2016-04-09 02:34:27 +09:00
|
|
|
|
2017-04-24 04:13:59 +09:00
|
|
|
const DELAY_BEFORE_HIDING_CONTROLS = 3000; // in ms
|
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 ACTIVE_SELECTOR = "pdfPresentationMode";
|
|
|
|
const CONTROLS_SELECTOR = "pdfPresentationModeControls";
|
2017-04-24 04:13:59 +09:00
|
|
|
const MOUSE_SCROLL_COOLDOWN_TIME = 50; // in ms
|
|
|
|
const PAGE_SWITCH_THRESHOLD = 0.1;
|
|
|
|
|
|
|
|
// Number of CSS pixels for a movement to count as a swipe.
|
|
|
|
const SWIPE_MIN_DISTANCE_THRESHOLD = 50;
|
|
|
|
|
|
|
|
// Swipe angle deviation from the x or y axis before it is not
|
|
|
|
// considered a swipe in that direction any more.
|
|
|
|
const SWIPE_ANGLE_THRESHOLD = Math.PI / 6;
|
2013-10-07 03:05:13 +09:00
|
|
|
|
2015-02-02 06:53:59 +09:00
|
|
|
/**
|
|
|
|
* @typedef {Object} PDFPresentationModeOptions
|
|
|
|
* @property {HTMLDivElement} container - The container for the viewer element.
|
2015-07-06 16:45:40 +09:00
|
|
|
* @property {PDFViewer} pdfViewer - The document viewer.
|
2016-04-26 07:57:15 +09:00
|
|
|
* @property {EventBus} eventBus - The application event bus.
|
2015-02-02 06:53:59 +09:00
|
|
|
*/
|
|
|
|
|
2017-04-24 04:13:59 +09:00
|
|
|
class PDFPresentationMode {
|
2022-04-09 18:38:05 +09:00
|
|
|
#state = PresentationModeState.UNKNOWN;
|
|
|
|
|
2022-04-09 18:25:53 +09:00
|
|
|
#args = null;
|
|
|
|
|
2015-02-02 06:53:59 +09:00
|
|
|
/**
|
|
|
|
* @param {PDFPresentationModeOptions} options
|
|
|
|
*/
|
2021-02-09 22:24:55 +09:00
|
|
|
constructor({ container, pdfViewer, eventBus }) {
|
2017-06-30 19:55:22 +09:00
|
|
|
this.container = container;
|
|
|
|
this.pdfViewer = pdfViewer;
|
|
|
|
this.eventBus = eventBus;
|
2013-10-09 03:11:04 +09:00
|
|
|
|
2015-02-04 02:09:11 +09:00
|
|
|
this.contextMenuOpen = false;
|
|
|
|
this.mouseScrollTimeStamp = 0;
|
|
|
|
this.mouseScrollDelta = 0;
|
2016-09-21 22:44:56 +09:00
|
|
|
this.touchSwipeState = null;
|
2015-02-04 02:09:11 +09:00
|
|
|
}
|
2015-02-03 20:17:57 +09:00
|
|
|
|
2017-04-24 04:13:59 +09:00
|
|
|
/**
|
|
|
|
* Request the browser to enter fullscreen mode.
|
2022-04-09 18:25:53 +09:00
|
|
|
* @returns {Promise<boolean>} Indicating if the request was successful.
|
2017-04-24 04:13:59 +09:00
|
|
|
*/
|
2022-04-09 18:25:53 +09:00
|
|
|
async request() {
|
2022-04-09 18:38:05 +09:00
|
|
|
const { container, pdfViewer } = this;
|
|
|
|
|
|
|
|
if (this.active || !pdfViewer.pagesCount || !container.requestFullscreen) {
|
2017-04-24 04:13:59 +09:00
|
|
|
return false;
|
|
|
|
}
|
2022-02-25 22:49:12 +09:00
|
|
|
this.#addFullscreenChangeListeners();
|
2022-04-09 18:38:05 +09:00
|
|
|
this.#notifyStateChange(PresentationModeState.CHANGING);
|
2017-04-24 04:13:59 +09:00
|
|
|
|
2022-04-09 18:38:05 +09:00
|
|
|
const promise = container.requestFullscreen();
|
2014-01-11 20:57:33 +09:00
|
|
|
|
2022-04-09 18:25:53 +09:00
|
|
|
this.#args = {
|
2022-04-09 18:38:05 +09:00
|
|
|
pageNumber: pdfViewer.currentPageNumber,
|
|
|
|
scaleValue: pdfViewer.currentScaleValue,
|
|
|
|
scrollMode: pdfViewer.scrollMode,
|
2022-05-05 18:15:45 +09:00
|
|
|
spreadMode: null,
|
2022-07-01 23:09:10 +09:00
|
|
|
annotationEditorMode: null,
|
2017-04-24 04:13:59 +09:00
|
|
|
};
|
2022-04-09 18:25:53 +09:00
|
|
|
|
2022-05-05 18:15:45 +09:00
|
|
|
if (
|
|
|
|
pdfViewer.spreadMode !== SpreadMode.NONE &&
|
|
|
|
!(pdfViewer.pageViewsReady && pdfViewer.hasEqualPageSizes)
|
|
|
|
) {
|
|
|
|
console.warn(
|
|
|
|
"Ignoring Spread modes when entering PresentationMode, " +
|
|
|
|
"since the document may contain varying page sizes."
|
|
|
|
);
|
|
|
|
this.#args.spreadMode = pdfViewer.spreadMode;
|
|
|
|
}
|
2022-07-01 23:09:10 +09:00
|
|
|
if (pdfViewer.annotationEditorMode !== AnnotationEditorType.DISABLE) {
|
|
|
|
this.#args.annotationEditorMode = pdfViewer.annotationEditorMode;
|
|
|
|
}
|
2022-05-05 18:15:45 +09:00
|
|
|
|
2022-04-09 18:25:53 +09:00
|
|
|
try {
|
|
|
|
await promise;
|
|
|
|
return true;
|
|
|
|
} catch (reason) {
|
|
|
|
this.#removeFullscreenChangeListeners();
|
2022-04-09 18:38:05 +09:00
|
|
|
this.#notifyStateChange(PresentationModeState.NORMAL);
|
2022-04-09 18:25:53 +09:00
|
|
|
}
|
|
|
|
return false;
|
2017-04-24 04:13:59 +09:00
|
|
|
}
|
2015-02-04 02:09:11 +09:00
|
|
|
|
2022-04-09 18:38:05 +09:00
|
|
|
get active() {
|
|
|
|
return (
|
|
|
|
this.#state === PresentationModeState.CHANGING ||
|
|
|
|
this.#state === PresentationModeState.FULLSCREEN
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2022-02-25 22:49:12 +09:00
|
|
|
#mouseWheel(evt) {
|
2017-04-24 04:13:59 +09:00
|
|
|
if (!this.active) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
evt.preventDefault();
|
|
|
|
|
2019-12-27 08:22:32 +09:00
|
|
|
const delta = normalizeWheelEventDelta(evt);
|
2021-02-12 07:00:42 +09:00
|
|
|
const currentTime = Date.now();
|
2019-12-27 08:22:32 +09:00
|
|
|
const storedTime = this.mouseScrollTimeStamp;
|
2017-04-24 04:13:59 +09:00
|
|
|
|
|
|
|
// If we've already switched page, avoid accidentally switching again.
|
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 (
|
|
|
|
currentTime > storedTime &&
|
|
|
|
currentTime - storedTime < MOUSE_SCROLL_COOLDOWN_TIME
|
|
|
|
) {
|
2017-04-24 04:13:59 +09:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
// If the scroll direction changed, reset the accumulated scroll delta.
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
if (
|
|
|
|
(this.mouseScrollDelta > 0 && delta < 0) ||
|
|
|
|
(this.mouseScrollDelta < 0 && delta > 0)
|
|
|
|
) {
|
2022-02-25 22:49:12 +09:00
|
|
|
this.#resetMouseScrollState();
|
2017-04-24 04:13:59 +09:00
|
|
|
}
|
|
|
|
this.mouseScrollDelta += delta;
|
|
|
|
|
|
|
|
if (Math.abs(this.mouseScrollDelta) >= PAGE_SWITCH_THRESHOLD) {
|
2019-12-27 08:22:32 +09:00
|
|
|
const totalDelta = this.mouseScrollDelta;
|
2022-02-25 22:49:12 +09:00
|
|
|
this.#resetMouseScrollState();
|
2019-12-27 08:22:32 +09:00
|
|
|
const success =
|
Add previous/next-page functionality that takes scroll/spread-modes into account (issue 11946)
- For wrapped scrolling, we unfortunately need to do a fair bit of parsing of the *current* page layout. Compared to e.g. the spread-modes, where we can easily tell how the pages are laid out, with wrapped scrolling we cannot tell without actually checking. In particular documents with varying page sizes require some care, since we need to check all pages on the "row" of the current page are visible and that there aren't any "holes" present. Otherwise, in the general case, there's a risk that we'd skip over pages if we'd simply always advance to the previous/next "row" in wrapped scrolling.
- For horizontal scrolling, this patch simply maintains the current behaviour of advancing *one* page at a time. The reason for this is to prevent inconsistent behaviour for the next and previous cases, since those cannot be handled identically. For the next-case, it'd obviously be simple to advance to the first not completely visible page. However for the previous-case, we'd only be able to go back *one* page since it's not possible to (easily) determine the page layout of non-visible pages (documents with varying page sizes being a particular issue).
- For vertical scrolling, this patch maintains the current behaviour by default. When spread-modes are being used, we'll now attempt to advance to the next *spread*, rather than just the next page, whenever possible. To prevent skipping over a page, this two-page advance will only apply when both pages of the current spread are visible (to avoid breaking documents with varying page sizes) and when the second page in the current spread is fully visible *horizontally* (to handle larger zoom values).
In order to reduce the performance impact of these changes, note that the previous/next-functionality will only call `getVisibleElements` for the scroll/spread-modes where that's necessary and that "normal" vertical scrolling is thus unaffected by these changes.
To support these changes, the `getVisibleElements` helper function will now also include the `widthPercent` in addition to the existing `percent` property.
The `PDFViewer._updateHelper` method is changed slightly w.r.t. updating the `currentPageNumber` for the non-vertical/spread modes, i.e. won't affect "normal" vertical scrolling, since that helped simplify the overall calculation of the page advance.
Finally, these new `BaseViewer` methods also allow (some) simplification of previous/next-page functionality in various viewer components.
*Please note:* There's one thing that this patch does not attempt to change, namely disabling of the previous/next toolbarButtons respectively the firstPage/lastPage secondaryToolbarButtons. The reason for this is that doing so would add quite a bit of complexity in general, and if for some reason `BaseViewer._getPageAdvance` would get things wrong we could end up incorrectly disabling the buttons. Hence it seemed overall safer to *not* touch this, and accept that the buttons won't be `disabled` despite in some edge-cases no further scrolling being possible.
2021-01-16 02:45:12 +09:00
|
|
|
totalDelta > 0
|
|
|
|
? this.pdfViewer.previousPage()
|
|
|
|
: this.pdfViewer.nextPage();
|
2017-04-24 04:13:59 +09:00
|
|
|
if (success) {
|
|
|
|
this.mouseScrollTimeStamp = currentTime;
|
2015-02-04 02:09:11 +09:00
|
|
|
}
|
2017-04-24 04:13:59 +09:00
|
|
|
}
|
|
|
|
}
|
2016-09-28 05:27:42 +09:00
|
|
|
|
2022-04-09 18:38:05 +09:00
|
|
|
#notifyStateChange(state) {
|
|
|
|
this.#state = state;
|
2014-09-16 02:37:03 +09:00
|
|
|
|
2022-04-09 18:38:05 +09:00
|
|
|
this.eventBus.dispatch("presentationmodechanged", { source: this, state });
|
2017-04-24 04:13:59 +09:00
|
|
|
}
|
2015-02-04 02:09:11 +09:00
|
|
|
|
2022-02-25 22:49:12 +09:00
|
|
|
#enter() {
|
2022-04-09 18:38:05 +09:00
|
|
|
this.#notifyStateChange(PresentationModeState.FULLSCREEN);
|
2017-04-24 04:13:59 +09:00
|
|
|
this.container.classList.add(ACTIVE_SELECTOR);
|
|
|
|
|
|
|
|
// Ensure that the correct page is scrolled into view when entering
|
|
|
|
// Presentation Mode, by waiting until fullscreen mode in enabled.
|
|
|
|
setTimeout(() => {
|
2021-10-07 21:04:41 +09:00
|
|
|
this.pdfViewer.scrollMode = ScrollMode.PAGE;
|
2022-05-05 18:15:45 +09:00
|
|
|
if (this.#args.spreadMode !== null) {
|
|
|
|
this.pdfViewer.spreadMode = SpreadMode.NONE;
|
|
|
|
}
|
2022-04-09 18:25:53 +09:00
|
|
|
this.pdfViewer.currentPageNumber = this.#args.pageNumber;
|
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.pdfViewer.currentScaleValue = "page-fit";
|
2022-07-01 23:09:10 +09:00
|
|
|
|
|
|
|
if (this.#args.annotationEditorMode !== null) {
|
|
|
|
this.pdfViewer.annotationEditorMode = AnnotationEditorType.NONE;
|
|
|
|
}
|
2017-04-24 04:13:59 +09:00
|
|
|
}, 0);
|
|
|
|
|
2022-02-25 22:49:12 +09:00
|
|
|
this.#addWindowListeners();
|
|
|
|
this.#showControls();
|
2017-04-24 04:13:59 +09:00
|
|
|
this.contextMenuOpen = false;
|
2015-02-04 02:09:11 +09:00
|
|
|
|
2017-04-24 04:13:59 +09:00
|
|
|
// Text selection is disabled in Presentation Mode, thus it's not possible
|
|
|
|
// for the user to deselect text that is selected (e.g. with "Select all")
|
|
|
|
// when entering Presentation Mode, hence we remove any active selection.
|
|
|
|
window.getSelection().removeAllRanges();
|
|
|
|
}
|
|
|
|
|
2022-02-25 22:49:12 +09:00
|
|
|
#exit() {
|
2021-10-07 21:04:41 +09:00
|
|
|
const pageNumber = this.pdfViewer.currentPageNumber;
|
2017-04-24 04:13:59 +09:00
|
|
|
this.container.classList.remove(ACTIVE_SELECTOR);
|
|
|
|
|
|
|
|
// Ensure that the correct page is scrolled into view when exiting
|
|
|
|
// Presentation Mode, by waiting until fullscreen mode is disabled.
|
|
|
|
setTimeout(() => {
|
2022-02-25 22:49:12 +09:00
|
|
|
this.#removeFullscreenChangeListeners();
|
2022-04-09 18:38:05 +09:00
|
|
|
this.#notifyStateChange(PresentationModeState.NORMAL);
|
2017-04-24 04:13:59 +09:00
|
|
|
|
2022-04-09 18:25:53 +09:00
|
|
|
this.pdfViewer.scrollMode = this.#args.scrollMode;
|
2022-05-05 18:15:45 +09:00
|
|
|
if (this.#args.spreadMode !== null) {
|
|
|
|
this.pdfViewer.spreadMode = this.#args.spreadMode;
|
|
|
|
}
|
2022-04-09 18:25:53 +09:00
|
|
|
this.pdfViewer.currentScaleValue = this.#args.scaleValue;
|
2021-10-07 21:04:41 +09:00
|
|
|
this.pdfViewer.currentPageNumber = pageNumber;
|
2022-07-01 23:09:10 +09:00
|
|
|
|
|
|
|
if (this.#args.annotationEditorMode !== null) {
|
|
|
|
this.pdfViewer.annotationEditorMode = this.#args.annotationEditorMode;
|
|
|
|
}
|
2022-04-09 18:25:53 +09:00
|
|
|
this.#args = null;
|
2017-04-24 04:13:59 +09:00
|
|
|
}, 0);
|
|
|
|
|
2022-02-25 22:49:12 +09:00
|
|
|
this.#removeWindowListeners();
|
|
|
|
this.#hideControls();
|
|
|
|
this.#resetMouseScrollState();
|
2017-04-24 04:13:59 +09:00
|
|
|
this.contextMenuOpen = false;
|
|
|
|
}
|
|
|
|
|
2022-02-25 22:49:12 +09:00
|
|
|
#mouseDown(evt) {
|
2017-04-24 04:13:59 +09:00
|
|
|
if (this.contextMenuOpen) {
|
|
|
|
this.contextMenuOpen = false;
|
|
|
|
evt.preventDefault();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (evt.button === 0) {
|
|
|
|
// Enable clicking of links in presentation mode. Note: only links
|
|
|
|
// pointing to destinations in the current PDF document work.
|
2019-12-27 08:22:32 +09:00
|
|
|
const isInternalLink =
|
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
|
|
|
evt.target.href && evt.target.classList.contains("internalLink");
|
2017-04-24 04:13:59 +09:00
|
|
|
if (!isInternalLink) {
|
|
|
|
// Unless an internal link was clicked, advance one page.
|
2013-10-07 03:05:13 +09:00
|
|
|
evt.preventDefault();
|
2017-06-08 00:10:45 +09:00
|
|
|
|
|
|
|
if (evt.shiftKey) {
|
Add previous/next-page functionality that takes scroll/spread-modes into account (issue 11946)
- For wrapped scrolling, we unfortunately need to do a fair bit of parsing of the *current* page layout. Compared to e.g. the spread-modes, where we can easily tell how the pages are laid out, with wrapped scrolling we cannot tell without actually checking. In particular documents with varying page sizes require some care, since we need to check all pages on the "row" of the current page are visible and that there aren't any "holes" present. Otherwise, in the general case, there's a risk that we'd skip over pages if we'd simply always advance to the previous/next "row" in wrapped scrolling.
- For horizontal scrolling, this patch simply maintains the current behaviour of advancing *one* page at a time. The reason for this is to prevent inconsistent behaviour for the next and previous cases, since those cannot be handled identically. For the next-case, it'd obviously be simple to advance to the first not completely visible page. However for the previous-case, we'd only be able to go back *one* page since it's not possible to (easily) determine the page layout of non-visible pages (documents with varying page sizes being a particular issue).
- For vertical scrolling, this patch maintains the current behaviour by default. When spread-modes are being used, we'll now attempt to advance to the next *spread*, rather than just the next page, whenever possible. To prevent skipping over a page, this two-page advance will only apply when both pages of the current spread are visible (to avoid breaking documents with varying page sizes) and when the second page in the current spread is fully visible *horizontally* (to handle larger zoom values).
In order to reduce the performance impact of these changes, note that the previous/next-functionality will only call `getVisibleElements` for the scroll/spread-modes where that's necessary and that "normal" vertical scrolling is thus unaffected by these changes.
To support these changes, the `getVisibleElements` helper function will now also include the `widthPercent` in addition to the existing `percent` property.
The `PDFViewer._updateHelper` method is changed slightly w.r.t. updating the `currentPageNumber` for the non-vertical/spread modes, i.e. won't affect "normal" vertical scrolling, since that helped simplify the overall calculation of the page advance.
Finally, these new `BaseViewer` methods also allow (some) simplification of previous/next-page functionality in various viewer components.
*Please note:* There's one thing that this patch does not attempt to change, namely disabling of the previous/next toolbarButtons respectively the firstPage/lastPage secondaryToolbarButtons. The reason for this is that doing so would add quite a bit of complexity in general, and if for some reason `BaseViewer._getPageAdvance` would get things wrong we could end up incorrectly disabling the buttons. Hence it seemed overall safer to *not* touch this, and accept that the buttons won't be `disabled` despite in some edge-cases no further scrolling being possible.
2021-01-16 02:45:12 +09:00
|
|
|
this.pdfViewer.previousPage();
|
2017-06-08 00:10:45 +09:00
|
|
|
} else {
|
Add previous/next-page functionality that takes scroll/spread-modes into account (issue 11946)
- For wrapped scrolling, we unfortunately need to do a fair bit of parsing of the *current* page layout. Compared to e.g. the spread-modes, where we can easily tell how the pages are laid out, with wrapped scrolling we cannot tell without actually checking. In particular documents with varying page sizes require some care, since we need to check all pages on the "row" of the current page are visible and that there aren't any "holes" present. Otherwise, in the general case, there's a risk that we'd skip over pages if we'd simply always advance to the previous/next "row" in wrapped scrolling.
- For horizontal scrolling, this patch simply maintains the current behaviour of advancing *one* page at a time. The reason for this is to prevent inconsistent behaviour for the next and previous cases, since those cannot be handled identically. For the next-case, it'd obviously be simple to advance to the first not completely visible page. However for the previous-case, we'd only be able to go back *one* page since it's not possible to (easily) determine the page layout of non-visible pages (documents with varying page sizes being a particular issue).
- For vertical scrolling, this patch maintains the current behaviour by default. When spread-modes are being used, we'll now attempt to advance to the next *spread*, rather than just the next page, whenever possible. To prevent skipping over a page, this two-page advance will only apply when both pages of the current spread are visible (to avoid breaking documents with varying page sizes) and when the second page in the current spread is fully visible *horizontally* (to handle larger zoom values).
In order to reduce the performance impact of these changes, note that the previous/next-functionality will only call `getVisibleElements` for the scroll/spread-modes where that's necessary and that "normal" vertical scrolling is thus unaffected by these changes.
To support these changes, the `getVisibleElements` helper function will now also include the `widthPercent` in addition to the existing `percent` property.
The `PDFViewer._updateHelper` method is changed slightly w.r.t. updating the `currentPageNumber` for the non-vertical/spread modes, i.e. won't affect "normal" vertical scrolling, since that helped simplify the overall calculation of the page advance.
Finally, these new `BaseViewer` methods also allow (some) simplification of previous/next-page functionality in various viewer components.
*Please note:* There's one thing that this patch does not attempt to change, namely disabling of the previous/next toolbarButtons respectively the firstPage/lastPage secondaryToolbarButtons. The reason for this is that doing so would add quite a bit of complexity in general, and if for some reason `BaseViewer._getPageAdvance` would get things wrong we could end up incorrectly disabling the buttons. Hence it seemed overall safer to *not* touch this, and accept that the buttons won't be `disabled` despite in some edge-cases no further scrolling being possible.
2021-01-16 02:45:12 +09:00
|
|
|
this.pdfViewer.nextPage();
|
2017-06-08 00:10:45 +09:00
|
|
|
}
|
2015-02-04 02:09:11 +09:00
|
|
|
}
|
2017-04-24 04:13:59 +09:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-02-25 22:49:12 +09:00
|
|
|
#contextMenu() {
|
2017-04-24 04:13:59 +09:00
|
|
|
this.contextMenuOpen = true;
|
|
|
|
}
|
|
|
|
|
2022-02-25 22:49:12 +09:00
|
|
|
#showControls() {
|
2017-04-24 04:13:59 +09:00
|
|
|
if (this.controlsTimeout) {
|
2015-02-04 02:09:11 +09:00
|
|
|
clearTimeout(this.controlsTimeout);
|
2017-04-24 04:13:59 +09:00
|
|
|
} else {
|
|
|
|
this.container.classList.add(CONTROLS_SELECTOR);
|
|
|
|
}
|
|
|
|
this.controlsTimeout = setTimeout(() => {
|
2015-02-04 22:10:45 +09:00
|
|
|
this.container.classList.remove(CONTROLS_SELECTOR);
|
2015-02-04 02:09:11 +09:00
|
|
|
delete this.controlsTimeout;
|
2017-04-24 04:13:59 +09:00
|
|
|
}, DELAY_BEFORE_HIDING_CONTROLS);
|
|
|
|
}
|
2016-09-21 22:44:56 +09:00
|
|
|
|
2022-02-25 22:49:12 +09:00
|
|
|
#hideControls() {
|
2017-04-24 04:13:59 +09:00
|
|
|
if (!this.controlsTimeout) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
clearTimeout(this.controlsTimeout);
|
|
|
|
this.container.classList.remove(CONTROLS_SELECTOR);
|
|
|
|
delete this.controlsTimeout;
|
|
|
|
}
|
2016-09-21 22:44:56 +09:00
|
|
|
|
2017-04-24 04:13:59 +09:00
|
|
|
/**
|
|
|
|
* Resets the properties used for tracking mouse scrolling events.
|
|
|
|
*/
|
2022-02-25 22:49:12 +09:00
|
|
|
#resetMouseScrollState() {
|
2017-04-24 04:13:59 +09:00
|
|
|
this.mouseScrollTimeStamp = 0;
|
|
|
|
this.mouseScrollDelta = 0;
|
|
|
|
}
|
2015-02-01 00:46:23 +09:00
|
|
|
|
2022-02-25 22:49:12 +09:00
|
|
|
#touchSwipe(evt) {
|
2017-04-24 04:13:59 +09:00
|
|
|
if (!this.active) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (evt.touches.length > 1) {
|
|
|
|
// Multiple touch points detected; cancel the swipe.
|
|
|
|
this.touchSwipeState = null;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
switch (evt.type) {
|
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 "touchstart":
|
2017-04-24 04:13:59 +09:00
|
|
|
this.touchSwipeState = {
|
|
|
|
startX: evt.touches[0].pageX,
|
|
|
|
startY: evt.touches[0].pageY,
|
|
|
|
endX: evt.touches[0].pageX,
|
|
|
|
endY: evt.touches[0].pageY,
|
|
|
|
};
|
|
|
|
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 "touchmove":
|
2017-04-24 04:13:59 +09:00
|
|
|
if (this.touchSwipeState === null) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
this.touchSwipeState.endX = evt.touches[0].pageX;
|
|
|
|
this.touchSwipeState.endY = evt.touches[0].pageY;
|
|
|
|
// Avoid the swipe from triggering browser gestures (Chrome in
|
|
|
|
// particular has some sort of swipe gesture in fullscreen mode).
|
|
|
|
evt.preventDefault();
|
|
|
|
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 "touchend":
|
2017-04-24 04:13:59 +09:00
|
|
|
if (this.touchSwipeState === null) {
|
|
|
|
return;
|
|
|
|
}
|
2017-06-30 19:55:22 +09:00
|
|
|
let delta = 0;
|
2019-12-27 08:22:32 +09:00
|
|
|
const dx = this.touchSwipeState.endX - this.touchSwipeState.startX;
|
|
|
|
const dy = this.touchSwipeState.endY - this.touchSwipeState.startY;
|
|
|
|
const absAngle = Math.abs(Math.atan2(dy, dx));
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
if (
|
|
|
|
Math.abs(dx) > SWIPE_MIN_DISTANCE_THRESHOLD &&
|
|
|
|
(absAngle <= SWIPE_ANGLE_THRESHOLD ||
|
|
|
|
absAngle >= Math.PI - SWIPE_ANGLE_THRESHOLD)
|
|
|
|
) {
|
2017-04-24 04:13:59 +09:00
|
|
|
// Horizontal swipe.
|
|
|
|
delta = dx;
|
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 (
|
|
|
|
Math.abs(dy) > SWIPE_MIN_DISTANCE_THRESHOLD &&
|
|
|
|
Math.abs(absAngle - Math.PI / 2) <= SWIPE_ANGLE_THRESHOLD
|
|
|
|
) {
|
2017-04-24 04:13:59 +09:00
|
|
|
// Vertical swipe.
|
|
|
|
delta = dy;
|
|
|
|
}
|
|
|
|
if (delta > 0) {
|
Add previous/next-page functionality that takes scroll/spread-modes into account (issue 11946)
- For wrapped scrolling, we unfortunately need to do a fair bit of parsing of the *current* page layout. Compared to e.g. the spread-modes, where we can easily tell how the pages are laid out, with wrapped scrolling we cannot tell without actually checking. In particular documents with varying page sizes require some care, since we need to check all pages on the "row" of the current page are visible and that there aren't any "holes" present. Otherwise, in the general case, there's a risk that we'd skip over pages if we'd simply always advance to the previous/next "row" in wrapped scrolling.
- For horizontal scrolling, this patch simply maintains the current behaviour of advancing *one* page at a time. The reason for this is to prevent inconsistent behaviour for the next and previous cases, since those cannot be handled identically. For the next-case, it'd obviously be simple to advance to the first not completely visible page. However for the previous-case, we'd only be able to go back *one* page since it's not possible to (easily) determine the page layout of non-visible pages (documents with varying page sizes being a particular issue).
- For vertical scrolling, this patch maintains the current behaviour by default. When spread-modes are being used, we'll now attempt to advance to the next *spread*, rather than just the next page, whenever possible. To prevent skipping over a page, this two-page advance will only apply when both pages of the current spread are visible (to avoid breaking documents with varying page sizes) and when the second page in the current spread is fully visible *horizontally* (to handle larger zoom values).
In order to reduce the performance impact of these changes, note that the previous/next-functionality will only call `getVisibleElements` for the scroll/spread-modes where that's necessary and that "normal" vertical scrolling is thus unaffected by these changes.
To support these changes, the `getVisibleElements` helper function will now also include the `widthPercent` in addition to the existing `percent` property.
The `PDFViewer._updateHelper` method is changed slightly w.r.t. updating the `currentPageNumber` for the non-vertical/spread modes, i.e. won't affect "normal" vertical scrolling, since that helped simplify the overall calculation of the page advance.
Finally, these new `BaseViewer` methods also allow (some) simplification of previous/next-page functionality in various viewer components.
*Please note:* There's one thing that this patch does not attempt to change, namely disabling of the previous/next toolbarButtons respectively the firstPage/lastPage secondaryToolbarButtons. The reason for this is that doing so would add quite a bit of complexity in general, and if for some reason `BaseViewer._getPageAdvance` would get things wrong we could end up incorrectly disabling the buttons. Hence it seemed overall safer to *not* touch this, and accept that the buttons won't be `disabled` despite in some edge-cases no further scrolling being possible.
2021-01-16 02:45:12 +09:00
|
|
|
this.pdfViewer.previousPage();
|
2017-04-24 04:13:59 +09:00
|
|
|
} else if (delta < 0) {
|
Add previous/next-page functionality that takes scroll/spread-modes into account (issue 11946)
- For wrapped scrolling, we unfortunately need to do a fair bit of parsing of the *current* page layout. Compared to e.g. the spread-modes, where we can easily tell how the pages are laid out, with wrapped scrolling we cannot tell without actually checking. In particular documents with varying page sizes require some care, since we need to check all pages on the "row" of the current page are visible and that there aren't any "holes" present. Otherwise, in the general case, there's a risk that we'd skip over pages if we'd simply always advance to the previous/next "row" in wrapped scrolling.
- For horizontal scrolling, this patch simply maintains the current behaviour of advancing *one* page at a time. The reason for this is to prevent inconsistent behaviour for the next and previous cases, since those cannot be handled identically. For the next-case, it'd obviously be simple to advance to the first not completely visible page. However for the previous-case, we'd only be able to go back *one* page since it's not possible to (easily) determine the page layout of non-visible pages (documents with varying page sizes being a particular issue).
- For vertical scrolling, this patch maintains the current behaviour by default. When spread-modes are being used, we'll now attempt to advance to the next *spread*, rather than just the next page, whenever possible. To prevent skipping over a page, this two-page advance will only apply when both pages of the current spread are visible (to avoid breaking documents with varying page sizes) and when the second page in the current spread is fully visible *horizontally* (to handle larger zoom values).
In order to reduce the performance impact of these changes, note that the previous/next-functionality will only call `getVisibleElements` for the scroll/spread-modes where that's necessary and that "normal" vertical scrolling is thus unaffected by these changes.
To support these changes, the `getVisibleElements` helper function will now also include the `widthPercent` in addition to the existing `percent` property.
The `PDFViewer._updateHelper` method is changed slightly w.r.t. updating the `currentPageNumber` for the non-vertical/spread modes, i.e. won't affect "normal" vertical scrolling, since that helped simplify the overall calculation of the page advance.
Finally, these new `BaseViewer` methods also allow (some) simplification of previous/next-page functionality in various viewer components.
*Please note:* There's one thing that this patch does not attempt to change, namely disabling of the previous/next toolbarButtons respectively the firstPage/lastPage secondaryToolbarButtons. The reason for this is that doing so would add quite a bit of complexity in general, and if for some reason `BaseViewer._getPageAdvance` would get things wrong we could end up incorrectly disabling the buttons. Hence it seemed overall safer to *not* touch this, and accept that the buttons won't be `disabled` despite in some edge-cases no further scrolling being possible.
2021-01-16 02:45:12 +09:00
|
|
|
this.pdfViewer.nextPage();
|
2017-04-24 04:13:59 +09:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-02-25 22:49:12 +09:00
|
|
|
#addWindowListeners() {
|
|
|
|
this.showControlsBind = this.#showControls.bind(this);
|
|
|
|
this.mouseDownBind = this.#mouseDown.bind(this);
|
|
|
|
this.mouseWheelBind = this.#mouseWheel.bind(this);
|
|
|
|
this.resetMouseScrollStateBind = this.#resetMouseScrollState.bind(this);
|
|
|
|
this.contextMenuBind = this.#contextMenu.bind(this);
|
|
|
|
this.touchSwipeBind = this.#touchSwipe.bind(this);
|
2017-04-24 04:13:59 +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
|
|
|
window.addEventListener("mousemove", this.showControlsBind);
|
|
|
|
window.addEventListener("mousedown", this.mouseDownBind);
|
2020-03-24 01:07:32 +09:00
|
|
|
window.addEventListener("wheel", this.mouseWheelBind, { passive: 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
|
|
|
window.addEventListener("keydown", this.resetMouseScrollStateBind);
|
|
|
|
window.addEventListener("contextmenu", this.contextMenuBind);
|
|
|
|
window.addEventListener("touchstart", this.touchSwipeBind);
|
|
|
|
window.addEventListener("touchmove", this.touchSwipeBind);
|
|
|
|
window.addEventListener("touchend", this.touchSwipeBind);
|
2017-04-24 04:13:59 +09:00
|
|
|
}
|
|
|
|
|
2022-02-25 22:49:12 +09:00
|
|
|
#removeWindowListeners() {
|
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
|
|
|
window.removeEventListener("mousemove", this.showControlsBind);
|
|
|
|
window.removeEventListener("mousedown", this.mouseDownBind);
|
2020-03-25 22:53:08 +09:00
|
|
|
window.removeEventListener("wheel", this.mouseWheelBind, {
|
|
|
|
passive: 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
|
|
|
window.removeEventListener("keydown", this.resetMouseScrollStateBind);
|
|
|
|
window.removeEventListener("contextmenu", this.contextMenuBind);
|
|
|
|
window.removeEventListener("touchstart", this.touchSwipeBind);
|
|
|
|
window.removeEventListener("touchmove", this.touchSwipeBind);
|
|
|
|
window.removeEventListener("touchend", this.touchSwipeBind);
|
2017-04-24 04:13:59 +09:00
|
|
|
|
|
|
|
delete this.showControlsBind;
|
|
|
|
delete this.mouseDownBind;
|
|
|
|
delete this.mouseWheelBind;
|
|
|
|
delete this.resetMouseScrollStateBind;
|
|
|
|
delete this.contextMenuBind;
|
|
|
|
delete this.touchSwipeBind;
|
|
|
|
}
|
|
|
|
|
2022-02-25 22:49:12 +09:00
|
|
|
#fullscreenChange() {
|
Only support the standard, unprefixed, Fullscreen API in the default viewer
At this point in time, after recent rounds of clean-up, the `webkit`-prefixed Fullscreen API is the only remaining *browser-specific* compatibility hack in the `web/`-folder JavaScript code.
The standard, and thus unprefixed, Fullscreen API has been supported for *over three years* in both Mozilla Firefox and Google Chrome. [According to MDN](https://developer.mozilla.org/en-US/docs/Web/API/Fullscreen_API#browser_compatibility), the unprefixed Fullscreen API has been available since:
- Mozilla Firefox 64, released on 2018-12-11; see https://wiki.mozilla.org/Release_Management/Calendar#Past_branch_dates
- Google Chrome 71, released on 2018-12-04; see https://en.wikipedia.org/wiki/Google_Chrome_version_history
Hence *only* Safari now requires using a prefixed Fullscreen API, and it's thus (significantly) lagging behind other browsers in this regard.
Considering that the default viewer is written *specifically* to be the UI for the Firefox PDF Viewer, and that we ask users to not just use it as-is[1], I think that we should only support the standard Fullscreen API now.
Furthermore, note also that the FAQ already lists Safari as "Mostly" supported; see https://github.com/mozilla/pdf.js/wiki/Frequently-Asked-Questions#faq-support
---
[1] Note e.g. http://mozilla.github.io/pdf.js/getting_started/#introduction
> The viewer is built on the display layer and is the UI for PDF viewer in Firefox and the other browser extensions within the project. It can be a good starting point for building your own viewer. *However, we do ask if you plan to embed the viewer in your own site, that it not just be an unmodified version. Please re-skin it or build upon it.*
2022-02-25 23:36:45 +09:00
|
|
|
if (/* isFullscreen = */ document.fullscreenElement) {
|
2022-02-25 22:49:12 +09:00
|
|
|
this.#enter();
|
2017-04-24 04:13:59 +09:00
|
|
|
} else {
|
2022-02-25 22:49:12 +09:00
|
|
|
this.#exit();
|
2017-04-24 04:13:59 +09:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-02-25 22:49:12 +09:00
|
|
|
#addFullscreenChangeListeners() {
|
|
|
|
this.fullscreenChangeBind = this.#fullscreenChange.bind(this);
|
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
|
|
|
window.addEventListener("fullscreenchange", this.fullscreenChangeBind);
|
2017-04-24 04:13:59 +09:00
|
|
|
}
|
2015-02-01 00:46:23 +09:00
|
|
|
|
2022-02-25 22:49:12 +09:00
|
|
|
#removeFullscreenChangeListeners() {
|
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
|
|
|
window.removeEventListener("fullscreenchange", this.fullscreenChangeBind);
|
2017-04-24 04:13:59 +09:00
|
|
|
delete this.fullscreenChangeBind;
|
|
|
|
}
|
|
|
|
}
|
2016-04-09 02:34:27 +09:00
|
|
|
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
export { PDFPresentationMode };
|