@internetarchive/bookreader 5.0.0-7 → 5.0.0-70
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.eslintrc.js +17 -15
- package/.github/workflows/node.js.yml +73 -10
- package/.github/workflows/npm-publish.yml +6 -20
- package/.testcaferc.js +10 -0
- package/BookReader/BookReader.css +396 -1129
- package/BookReader/BookReader.js +1 -1
- package/BookReader/BookReader.js.LICENSE.txt +20 -20
- package/BookReader/BookReader.js.map +1 -1
- package/BookReader/ia-bookreader-bundle.js +1509 -0
- package/BookReader/ia-bookreader-bundle.js.LICENSE.txt +19 -0
- package/BookReader/ia-bookreader-bundle.js.map +1 -0
- package/BookReader/icons/1up.svg +1 -1
- package/BookReader/icons/2up.svg +1 -1
- package/BookReader/icons/advance.svg +1 -1
- package/BookReader/icons/chevron-right.svg +1 -1
- package/BookReader/icons/close-circle-dark.svg +1 -1
- package/BookReader/icons/close-circle.svg +1 -1
- package/BookReader/icons/fullscreen.svg +1 -1
- package/BookReader/icons/fullscreen_exit.svg +1 -1
- package/BookReader/icons/hamburger.svg +1 -1
- package/BookReader/icons/left-arrow.svg +1 -1
- package/BookReader/icons/magnify-minus.svg +1 -1
- package/BookReader/icons/magnify-plus.svg +1 -1
- package/BookReader/icons/magnify.svg +1 -1
- package/BookReader/icons/pause.svg +1 -1
- package/BookReader/icons/play.svg +1 -1
- package/BookReader/icons/playback-speed.svg +1 -1
- package/BookReader/icons/read-aloud.svg +1 -1
- package/BookReader/icons/review.svg +1 -1
- package/BookReader/icons/thumbnails.svg +1 -1
- package/BookReader/icons/voice.svg +1 -0
- package/BookReader/icons/volume-full.svg +1 -1
- package/BookReader/images/BRicons.svg +3 -3
- package/BookReader/images/books_graphic.svg +1 -1
- package/BookReader/images/icon_book.svg +1 -1
- package/BookReader/images/icon_bookmark.svg +1 -1
- package/BookReader/images/icon_gear.svg +1 -1
- package/BookReader/images/icon_hamburger.svg +1 -1
- package/BookReader/images/icon_home.svg +1 -1
- package/BookReader/images/icon_info.svg +1 -1
- package/BookReader/images/icon_one_page.svg +1 -1
- package/BookReader/images/icon_pause.svg +1 -1
- package/BookReader/images/icon_play.svg +1 -1
- package/BookReader/images/icon_playback-rate.svg +1 -1
- package/BookReader/images/icon_search_button.svg +1 -1
- package/BookReader/images/icon_share.svg +1 -1
- package/BookReader/images/icon_skip-ahead.svg +1 -1
- package/BookReader/images/icon_skip-back.svg +1 -1
- package/BookReader/images/icon_speaker.svg +1 -1
- package/BookReader/images/icon_speaker_open.svg +1 -1
- package/BookReader/images/icon_thumbnails.svg +1 -1
- package/BookReader/images/icon_toc.svg +1 -1
- package/BookReader/images/icon_two_pages.svg +1 -1
- package/BookReader/images/marker_chap-off.svg +1 -1
- package/BookReader/images/marker_chap-on.svg +1 -1
- package/BookReader/images/marker_srch-on.svg +1 -1
- package/BookReader/jquery-3.js +2 -0
- package/BookReader/jquery-3.js.LICENSE.txt +24 -0
- package/BookReader/plugins/plugin.archive_analytics.js +1 -1
- package/BookReader/plugins/plugin.archive_analytics.js.map +1 -1
- package/BookReader/plugins/plugin.autoplay.js +1 -1
- package/BookReader/plugins/plugin.autoplay.js.map +1 -1
- package/BookReader/plugins/plugin.chapters.js +25 -1
- package/BookReader/plugins/plugin.chapters.js.LICENSE.txt +1 -0
- package/BookReader/plugins/plugin.chapters.js.map +1 -1
- package/BookReader/plugins/plugin.iframe.js +1 -1
- package/BookReader/plugins/plugin.iframe.js.map +1 -1
- package/BookReader/plugins/plugin.resume.js +1 -1
- package/BookReader/plugins/plugin.resume.js.map +1 -1
- package/BookReader/plugins/plugin.search.js +2 -1
- package/BookReader/plugins/plugin.search.js.LICENSE.txt +1 -0
- package/BookReader/plugins/plugin.search.js.map +1 -1
- package/BookReader/plugins/plugin.text_selection.js +2 -1
- package/BookReader/plugins/plugin.text_selection.js.LICENSE.txt +1 -0
- package/BookReader/plugins/plugin.text_selection.js.map +1 -1
- package/BookReader/plugins/plugin.tts.js +1 -1
- package/BookReader/plugins/plugin.tts.js.LICENSE.txt +2 -0
- package/BookReader/plugins/plugin.tts.js.map +1 -1
- package/BookReader/plugins/plugin.url.js +1 -1
- package/BookReader/plugins/plugin.url.js.map +1 -1
- package/BookReader/plugins/plugin.vendor-fullscreen.js +1 -1
- package/BookReader/plugins/plugin.vendor-fullscreen.js.map +1 -1
- package/BookReader/webcomponents-bundle.js +3 -0
- package/BookReader/webcomponents-bundle.js.LICENSE.txt +9 -0
- package/BookReader/webcomponents-bundle.js.map +1 -0
- package/BookReaderDemo/BookReaderDemo.css +16 -19
- package/BookReaderDemo/BookReaderJSAdvanced.js +0 -3
- package/BookReaderDemo/BookReaderJSAutoplay.js +4 -1
- package/BookReaderDemo/BookReaderJSSimple.js +1 -0
- package/BookReaderDemo/IADemoBr.js +147 -0
- package/BookReaderDemo/demo-advanced.html +2 -2
- package/BookReaderDemo/demo-autoplay.html +2 -3
- package/BookReaderDemo/demo-embed-iframe-src.html +2 -1
- package/BookReaderDemo/demo-fullscreen-mobile.html +3 -5
- package/BookReaderDemo/demo-fullscreen.html +2 -4
- package/BookReaderDemo/demo-iiif.html +2 -1
- package/BookReaderDemo/demo-iiif.js +0 -1
- package/BookReaderDemo/demo-internetarchive.html +213 -17
- package/BookReaderDemo/demo-multiple.html +2 -1
- package/BookReaderDemo/demo-preview-pages.html +2 -1
- package/BookReaderDemo/demo-simple.html +2 -1
- package/BookReaderDemo/demo-vendor-fullscreen.html +2 -4
- package/BookReaderDemo/ia-multiple-volumes-manifest.js +170 -0
- package/BookReaderDemo/immersion-1up.html +2 -2
- package/BookReaderDemo/immersion-mode.html +2 -4
- package/BookReaderDemo/toggle_controls.html +3 -2
- package/BookReaderDemo/view_mode.html +2 -1
- package/BookReaderDemo/viewmode-cycle.html +2 -3
- package/CHANGELOG.md +283 -0
- package/README.md +14 -1
- package/babel.config.js +20 -0
- package/codecov.yml +6 -0
- package/index.html +4 -1
- package/jsconfig.json +19 -0
- package/netlify.toml +9 -0
- package/package.json +71 -60
- package/renovate.json +52 -0
- package/scripts/preversion.js +4 -1
- package/src/BookNavigator/assets/bookmark-colors.js +1 -1
- package/src/BookNavigator/assets/button-base.js +4 -2
- package/src/BookNavigator/assets/ia-logo.js +17 -0
- package/src/BookNavigator/assets/icon_checkmark.js +1 -1
- package/src/BookNavigator/assets/icon_close.js +1 -1
- package/src/BookNavigator/assets/icon_sort_asc.js +5 -0
- package/src/BookNavigator/assets/icon_sort_desc.js +5 -0
- package/src/BookNavigator/assets/icon_sort_neutral.js +5 -0
- package/src/BookNavigator/assets/icon_volumes.js +11 -0
- package/src/BookNavigator/book-navigator.js +586 -0
- package/src/BookNavigator/bookmarks/bookmark-button.js +3 -2
- package/src/BookNavigator/bookmarks/bookmark-edit.js +3 -4
- package/src/BookNavigator/bookmarks/bookmarks-list.js +2 -3
- package/src/BookNavigator/bookmarks/bookmarks-loginCTA.js +3 -8
- package/src/BookNavigator/bookmarks/bookmarks-provider.js +27 -17
- package/src/BookNavigator/bookmarks/ia-bookmarks.js +116 -67
- package/src/BookNavigator/delete-modal-actions.js +1 -1
- package/src/BookNavigator/downloads/downloads-provider.js +36 -21
- package/src/BookNavigator/downloads/downloads.js +41 -25
- package/src/BookNavigator/search/search-provider.js +49 -27
- package/src/BookNavigator/search/search-results.js +23 -9
- package/src/BookNavigator/sharing.js +27 -0
- package/src/BookNavigator/visual-adjustments/visual-adjustments-provider.js +11 -10
- package/src/BookNavigator/visual-adjustments/visual-adjustments.js +3 -3
- package/src/BookNavigator/volumes/volumes-provider.js +111 -0
- package/src/BookNavigator/volumes/volumes.js +188 -0
- package/src/BookReader/BookModel.js +64 -34
- package/src/BookReader/DragScrollable.js +233 -0
- package/src/BookReader/Mode1Up.js +56 -351
- package/src/BookReader/Mode1UpLit.js +388 -0
- package/src/BookReader/Mode2Up.js +73 -1318
- package/src/BookReader/Mode2UpLit.js +776 -0
- package/src/BookReader/ModeCoordinateSpace.js +29 -0
- package/src/BookReader/ModeSmoothZoom.js +312 -0
- package/src/BookReader/ModeThumb.js +18 -12
- package/src/BookReader/Navbar/Navbar.js +12 -38
- package/src/BookReader/PageContainer.js +81 -6
- package/src/BookReader/ReduceSet.js +1 -1
- package/src/BookReader/Toolbar/Toolbar.js +10 -37
- package/src/BookReader/events.js +2 -3
- package/src/BookReader/options.js +24 -2
- package/src/BookReader/utils/HTMLDimensionsCacher.js +44 -0
- package/src/BookReader/utils/ScrollClassAdder.js +31 -0
- package/src/BookReader/utils/SelectionObserver.js +43 -0
- package/src/BookReader/utils.js +118 -13
- package/src/BookReader.js +427 -1061
- package/src/assets/icons/magnify-minus.svg +3 -7
- package/src/assets/icons/magnify-plus.svg +3 -7
- package/src/assets/icons/voice.svg +1 -0
- package/src/css/BookReader.scss +1 -5
- package/src/css/_BRBookmarks.scss +1 -1
- package/src/css/_BRComponent.scss +1 -1
- package/src/css/_BRmain.scss +16 -0
- package/src/css/_BRnav.scss +11 -38
- package/src/css/_BRpages.scss +149 -40
- package/src/css/_BRsearch.scss +67 -21
- package/src/css/_TextSelection.scss +87 -27
- package/src/css/_colorbox.scss +2 -2
- package/src/css/_controls.scss +20 -7
- package/src/css/_icons.scss +1 -1
- package/src/ia-bookreader/ia-bookreader.js +224 -0
- package/src/plugins/plugin.archive_analytics.js +3 -3
- package/src/plugins/plugin.autoplay.js +5 -11
- package/src/plugins/plugin.chapters.js +211 -186
- package/src/plugins/plugin.resume.js +3 -3
- package/src/plugins/plugin.text_selection.js +464 -134
- package/src/plugins/plugin.vendor-fullscreen.js +4 -4
- package/src/plugins/search/plugin.search.js +142 -125
- package/src/plugins/search/utils.js +43 -0
- package/src/plugins/search/view.js +33 -58
- package/src/plugins/tts/AbstractTTSEngine.js +68 -40
- package/src/plugins/tts/FestivalTTSEngine.js +13 -14
- package/src/plugins/tts/PageChunk.js +15 -21
- package/src/plugins/tts/PageChunkIterator.js +8 -12
- package/src/plugins/tts/WebTTSEngine.js +87 -71
- package/src/plugins/tts/plugin.tts.js +95 -126
- package/src/plugins/tts/utils.js +0 -25
- package/src/plugins/url/UrlPlugin.js +191 -0
- package/src/plugins/{plugin.url.js → url/plugin.url.js} +45 -16
- package/src/util/browserSniffing.js +22 -0
- package/src/util/docCookies.js +21 -2
- package/tests/e2e/README.md +37 -0
- package/tests/e2e/autoplay.test.js +2 -2
- package/tests/e2e/base.test.js +8 -16
- package/tests/e2e/helpers/base.js +53 -48
- package/tests/e2e/helpers/debug.js +1 -1
- package/tests/e2e/helpers/params.js +17 -0
- package/tests/e2e/helpers/rightToLeft.js +8 -14
- package/tests/e2e/helpers/search.js +73 -0
- package/tests/e2e/models/Navigation.js +20 -37
- package/tests/e2e/rightToLeft.test.js +4 -5
- package/tests/e2e/viewmode.test.js +40 -33
- package/tests/jest/BookNavigator/book-navigator.test.js +658 -0
- package/tests/jest/BookNavigator/bookmarks/bookmark-button.test.js +43 -0
- package/tests/{karma → jest}/BookNavigator/bookmarks/bookmark-edit.test.js +25 -26
- package/tests/{karma → jest}/BookNavigator/bookmarks/bookmarks-list.test.js +41 -42
- package/tests/jest/BookNavigator/bookmarks/ia-bookmarks.test.js +45 -0
- package/tests/jest/BookNavigator/downloads/downloads-provider.test.js +67 -0
- package/tests/jest/BookNavigator/downloads/downloads.test.js +53 -0
- package/tests/jest/BookNavigator/search/search-provider.test.js +167 -0
- package/tests/{karma → jest}/BookNavigator/search/search-results.test.js +109 -60
- package/tests/jest/BookNavigator/sharing/sharing-provider.test.js +49 -0
- package/tests/jest/BookNavigator/visual-adjustments.test.js +200 -0
- package/tests/jest/BookNavigator/volumes/volumes-provider.test.js +184 -0
- package/tests/jest/BookNavigator/volumes/volumes.test.js +97 -0
- package/tests/{BookReader → jest/BookReader}/BookModel.test.js +74 -14
- package/tests/jest/BookReader/BookReaderPublicFunctions.test.js +193 -0
- package/tests/{BookReader → jest/BookReader}/ImageCache.test.js +4 -4
- package/tests/jest/BookReader/Mode1UpLit.test.js +73 -0
- package/tests/jest/BookReader/Mode2Up.test.js +98 -0
- package/tests/jest/BookReader/Mode2UpLit.test.js +190 -0
- package/tests/jest/BookReader/ModeCoordinateSpace.test.js +16 -0
- package/tests/jest/BookReader/ModeSmoothZoom.test.js +218 -0
- package/tests/jest/BookReader/ModeThumb.test.js +71 -0
- package/tests/{BookReader → jest/BookReader}/Navbar/Navbar.test.js +10 -10
- package/tests/{BookReader → jest/BookReader}/PageContainer.test.js +88 -6
- package/tests/{BookReader → jest/BookReader}/ReduceSet.test.js +1 -1
- package/tests/{BookReader → jest/BookReader}/Toolbar/Toolbar.test.js +2 -2
- package/tests/jest/BookReader/utils/HTMLDimensionsCacher.test.js +59 -0
- package/tests/jest/BookReader/utils/ScrollClassAdder.test.js +49 -0
- package/tests/jest/BookReader/utils/SelectionObserver.test.js +43 -0
- package/tests/{BookReader → jest/BookReader}/utils/classes.test.js +1 -1
- package/tests/jest/BookReader/utils.test.js +229 -0
- package/tests/jest/BookReader.keyboard.test.js +190 -0
- package/tests/{BookReader.options.test.js → jest/BookReader.options.test.js} +9 -1
- package/tests/{BookReader.test.js → jest/BookReader.test.js} +26 -37
- package/tests/{plugins → jest/plugins}/plugin.archive_analytics.test.js +2 -2
- package/tests/{plugins → jest/plugins}/plugin.autoplay.test.js +4 -4
- package/tests/jest/plugins/plugin.chapters.test.js +145 -0
- package/tests/{plugins → jest/plugins}/plugin.iframe.test.js +2 -2
- package/tests/{plugins → jest/plugins}/plugin.resume.test.js +3 -3
- package/tests/jest/plugins/plugin.text_selection.test.js +317 -0
- package/tests/{plugins → jest/plugins}/plugin.vendor-fullscreen.test.js +2 -2
- package/tests/{plugins → jest/plugins}/search/plugin.search.test.js +25 -47
- package/tests/{plugins → jest/plugins}/search/plugin.search.view.test.js +39 -6
- package/tests/jest/plugins/search/utils.js +25 -0
- package/tests/jest/plugins/search/utils.test.js +29 -0
- package/tests/{plugins → jest/plugins}/tts/AbstractTTSEngine.test.js +29 -9
- package/tests/{plugins → jest/plugins}/tts/FestivalTTSEngine.test.js +4 -4
- package/tests/{plugins → jest/plugins}/tts/PageChunk.test.js +1 -1
- package/tests/{plugins → jest/plugins}/tts/PageChunkIterator.test.js +3 -3
- package/tests/{plugins → jest/plugins}/tts/WebTTSEngine.test.js +47 -1
- package/tests/{plugins → jest/plugins}/tts/utils.test.js +1 -60
- package/tests/jest/plugins/url/UrlPlugin.test.js +198 -0
- package/tests/{plugins → jest/plugins/url}/plugin.url.test.js +53 -14
- package/tests/jest/setup.js +3 -0
- package/tests/{util → jest/util}/browserSniffing.test.js +1 -1
- package/tests/jest/util/docCookies.test.js +24 -0
- package/tests/{util → jest/util}/strings.test.js +1 -1
- package/tests/{utils.js → jest/utils.js} +38 -0
- package/webpack.config.js +11 -6
- package/.babelrc +0 -12
- package/.dependabot/config.yml +0 -6
- package/.testcaferc.json +0 -5
- package/BookReader/bookreader-component-bundle.js +0 -1450
- package/BookReader/bookreader-component-bundle.js.LICENSE.txt +0 -38
- package/BookReader/bookreader-component-bundle.js.map +0 -1
- package/BookReader/jquery-1.10.1.js +0 -2
- package/BookReader/jquery-1.10.1.js.LICENSE.txt +0 -24
- package/BookReader/plugins/plugin.menu_toggle.js +0 -2
- package/BookReader/plugins/plugin.menu_toggle.js.map +0 -1
- package/BookReader/plugins/plugin.mobile_nav.js +0 -2
- package/BookReader/plugins/plugin.mobile_nav.js.map +0 -1
- package/BookReaderDemo/bookreader-template-bundle.js +0 -7178
- package/BookReaderDemo/demo-plugin-menu-toggle.html +0 -34
- package/karma.conf.js +0 -23
- package/src/BookNavigator/BookModel.js +0 -14
- package/src/BookNavigator/BookNavigator.js +0 -446
- package/src/BookNavigator/assets/book-loader.js +0 -27
- package/src/BookNavigator/br-fullscreen-mgr.js +0 -83
- package/src/BookNavigator/search/a-search-result.js +0 -55
- package/src/BookReader/DebugConsole.js +0 -54
- package/src/BookReaderComponent/BookReaderComponent.js +0 -112
- package/src/ItemNavigator/ItemNavigator.js +0 -376
- package/src/ItemNavigator/providers/sharing.js +0 -29
- package/src/css/_MobileNav.scss +0 -194
- package/src/dragscrollable-br.js +0 -261
- package/src/plugins/menu_toggle/plugin.menu_toggle.js +0 -324
- package/src/plugins/plugin.mobile_nav.js +0 -287
- package/tests/BookReader/BookReaderPublicFunctions.test.js +0 -171
- package/tests/BookReader/DebugConsole.test.js +0 -25
- package/tests/BookReader/Mode1Up.test.js +0 -164
- package/tests/BookReader/Mode2Up.test.js +0 -247
- package/tests/BookReader/utils.test.js +0 -109
- package/tests/e2e/helpers/desktopSearch.js +0 -72
- package/tests/e2e/helpers/mobileSearch.js +0 -85
- package/tests/e2e/ia-production/ia-prod-base.js +0 -17
- package/tests/karma/BookNavigator/book-navigator.test.js +0 -132
- package/tests/karma/BookNavigator/search/search-provider.test.js +0 -23
- package/tests/karma/BookNavigator/visual-adjustments.test.js +0 -201
- package/tests/plugins/menu_toggle/plugin.menu_toggle.test.js +0 -68
- package/tests/plugins/plugin.chapters.test.js +0 -130
- package/tests/plugins/plugin.mobile_nav.test.js +0 -66
- package/tests/plugins/plugin.text_selection.test.js +0 -203
- package/tests/util/docCookies.test.js +0 -15
|
@@ -23,42 +23,15 @@ export class BookModel {
|
|
|
23
23
|
this.br = br;
|
|
24
24
|
this.reduceSet = br.reduceSet;
|
|
25
25
|
this.ppi = br.options?.ppi ?? DEFAULT_OPTIONS.ppi;
|
|
26
|
+
/** @type {'lr' | 'rl'} Page progression */
|
|
27
|
+
this.pageProgression = br.options?.pageProgression ?? DEFAULT_OPTIONS.pageProgression;
|
|
26
28
|
|
|
27
29
|
/** @type {{width: number, height: number}} memoize storage */
|
|
28
30
|
this._medianPageSize = null;
|
|
29
|
-
/** @deprecated @type {{width: number, height: number}} memoize storage */
|
|
30
|
-
this._medianPageSizePixels = null;
|
|
31
31
|
/** @type {[PageData[], number]} */
|
|
32
32
|
this._getDataFlattenedCached = null;
|
|
33
33
|
}
|
|
34
34
|
|
|
35
|
-
/**
|
|
36
|
-
* @deprecated Use getMedianPageSizeInches
|
|
37
|
-
* Memoized
|
|
38
|
-
* @return {{width: number, height: number}}
|
|
39
|
-
*/
|
|
40
|
-
getMedianPageSize() {
|
|
41
|
-
if (this._medianPageSizePixels) {
|
|
42
|
-
return this._medianPageSizePixels;
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
// A little expensive but we just do it once
|
|
46
|
-
const widths = [];
|
|
47
|
-
const heights = [];
|
|
48
|
-
for (let i = 0; i < this.getNumLeafs(); i++) {
|
|
49
|
-
widths.push(this.getPageWidth(i));
|
|
50
|
-
heights.push(this.getPageHeight(i));
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
widths.sort();
|
|
54
|
-
heights.sort();
|
|
55
|
-
this._medianPageSizePixels = {
|
|
56
|
-
width: widths[Math.floor(widths.length / 2)],
|
|
57
|
-
height: heights[Math.floor(heights.length / 2)]
|
|
58
|
-
};
|
|
59
|
-
return this._medianPageSizePixels;
|
|
60
|
-
}
|
|
61
|
-
|
|
62
35
|
/** Get median width/height of page in inches. Memoized for performance. */
|
|
63
36
|
getMedianPageSizeInches() {
|
|
64
37
|
if (this._medianPageSize) {
|
|
@@ -72,8 +45,8 @@ export class BookModel {
|
|
|
72
45
|
heights.push(page.heightInches);
|
|
73
46
|
}
|
|
74
47
|
|
|
75
|
-
widths.sort();
|
|
76
|
-
heights.sort();
|
|
48
|
+
widths.sort((a, b) => a - b);
|
|
49
|
+
heights.sort((a, b) => a - b);
|
|
77
50
|
|
|
78
51
|
this._medianPageSize = {
|
|
79
52
|
width: widths[Math.floor(widths.length / 2)],
|
|
@@ -226,7 +199,7 @@ export class BookModel {
|
|
|
226
199
|
* @return {[PageIndex, PageIndex]} eg [0, 1]
|
|
227
200
|
*/
|
|
228
201
|
getSpreadIndices(pindex) {
|
|
229
|
-
if (this.
|
|
202
|
+
if (this.pageProgression == 'rl') {
|
|
230
203
|
return this.getPageSide(pindex) == 'R' ? [pindex + 1, pindex] : [pindex, pindex - 1];
|
|
231
204
|
} else {
|
|
232
205
|
return this.getPageSide(pindex) == 'L' ? [pindex, pindex + 1] : [pindex - 1, pindex];
|
|
@@ -379,8 +352,9 @@ export class PageModel {
|
|
|
379
352
|
* @param {PageIndex} index
|
|
380
353
|
*/
|
|
381
354
|
constructor(book, index) {
|
|
382
|
-
//
|
|
383
|
-
|
|
355
|
+
// Values less than 10 cause the UI to not work correctly
|
|
356
|
+
const pagePPI = book._getDataProp(index, 'ppi', book.ppi);
|
|
357
|
+
this.ppi = Math.max(pagePPI < 10 ? book.ppi : pagePPI, 10);
|
|
384
358
|
this.book = book;
|
|
385
359
|
this.index = index;
|
|
386
360
|
this.width = book.getPageWidth(index);
|
|
@@ -437,6 +411,42 @@ export class PageModel {
|
|
|
437
411
|
return this.findNext();
|
|
438
412
|
}
|
|
439
413
|
|
|
414
|
+
/** @type {PageModel | null} */
|
|
415
|
+
get left() {
|
|
416
|
+
return this.book.pageProgression === 'lr' ? this.prev : this.next;
|
|
417
|
+
}
|
|
418
|
+
|
|
419
|
+
/** @type {PageModel | null} */
|
|
420
|
+
get right() {
|
|
421
|
+
return this.book.pageProgression === 'lr' ? this.next : this.prev;
|
|
422
|
+
}
|
|
423
|
+
|
|
424
|
+
/**
|
|
425
|
+
* @type {{left: PageModel | null, right: PageModel | null}}
|
|
426
|
+
*/
|
|
427
|
+
get spread() {
|
|
428
|
+
return {
|
|
429
|
+
left: this.pageSide === 'L' ? this : this.left,
|
|
430
|
+
right: this.pageSide === 'R' ? this : this.right,
|
|
431
|
+
};
|
|
432
|
+
}
|
|
433
|
+
|
|
434
|
+
/**
|
|
435
|
+
* @param {number} pages
|
|
436
|
+
*/
|
|
437
|
+
goLeft(pages) {
|
|
438
|
+
const newIndex = this.book.pageProgression === 'lr' ? this.index - pages : this.index + pages;
|
|
439
|
+
return this.book.getPage(newIndex);
|
|
440
|
+
}
|
|
441
|
+
|
|
442
|
+
/**
|
|
443
|
+
* @param {number} pages
|
|
444
|
+
*/
|
|
445
|
+
goRight(pages) {
|
|
446
|
+
const newIndex = this.book.pageProgression === 'lr' ? this.index + pages : this.index - pages;
|
|
447
|
+
return this.book.getPage(newIndex);
|
|
448
|
+
}
|
|
449
|
+
|
|
440
450
|
/**
|
|
441
451
|
* @param {number} reduce
|
|
442
452
|
* @param {number} rotate
|
|
@@ -498,6 +508,26 @@ export class PageModel {
|
|
|
498
508
|
return new PageModel(this.book, this.index - 1);
|
|
499
509
|
}
|
|
500
510
|
}
|
|
511
|
+
|
|
512
|
+
/**
|
|
513
|
+
* @param {object} [arg0]
|
|
514
|
+
* @param {boolean} [arg0.combineConsecutiveUnviewables] Whether to only yield the first page
|
|
515
|
+
* of a series of unviewable pages instead of each page
|
|
516
|
+
* @return {PageModel|void}
|
|
517
|
+
*/
|
|
518
|
+
findLeft({ combineConsecutiveUnviewables = false } = {}) {
|
|
519
|
+
return this.book.pageProgression === 'lr' ? this.findPrev({ combineConsecutiveUnviewables }) : this.findNext({ combineConsecutiveUnviewables });
|
|
520
|
+
}
|
|
521
|
+
|
|
522
|
+
/**
|
|
523
|
+
* @param {object} [arg0]
|
|
524
|
+
* @param {boolean} [arg0.combineConsecutiveUnviewables] Whether to only yield the first page
|
|
525
|
+
* of a series of unviewable pages instead of each page
|
|
526
|
+
* @return {PageModel|void}
|
|
527
|
+
*/
|
|
528
|
+
findRight({ combineConsecutiveUnviewables = false } = {}) {
|
|
529
|
+
return this.book.pageProgression === 'lr' ? this.findNext({ combineConsecutiveUnviewables }) : this.findPrev({ combineConsecutiveUnviewables });
|
|
530
|
+
}
|
|
501
531
|
}
|
|
502
532
|
|
|
503
533
|
// There are a few main ways we can reference a specific page in a book:
|
|
@@ -0,0 +1,233 @@
|
|
|
1
|
+
// @ts-check
|
|
2
|
+
/*
|
|
3
|
+
* jQuery dragscrollable Plugin
|
|
4
|
+
* Based off version: 1.0 (25-Jun-2009)
|
|
5
|
+
* Copyright (c) 2009 Miquel Herrera
|
|
6
|
+
*
|
|
7
|
+
* Portions Copyright (c) 2010 Reg Braithwaite
|
|
8
|
+
* Copyright (c) 2010 Internet Archive / Michael Ang
|
|
9
|
+
* Copyright (c) 2016 Internet Archive / Richard Caceres
|
|
10
|
+
*
|
|
11
|
+
* Dual licensed under the MIT and GPL licenses:
|
|
12
|
+
* http://www.opensource.org/licenses/mit-license.php
|
|
13
|
+
* http://www.gnu.org/licenses/gpl.html
|
|
14
|
+
*/
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* @param {string} string_of_events
|
|
18
|
+
* @param {string} ns
|
|
19
|
+
* @returns
|
|
20
|
+
*/
|
|
21
|
+
function append_namespace(string_of_events, ns) {
|
|
22
|
+
return string_of_events
|
|
23
|
+
.split(' ')
|
|
24
|
+
.map(event_name => event_name + ns)
|
|
25
|
+
.join(' ');
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
function left_top(event) {
|
|
29
|
+
/** @type {number} */
|
|
30
|
+
let x;
|
|
31
|
+
/** @type {number} */
|
|
32
|
+
let y;
|
|
33
|
+
if (typeof(event.clientX) != 'undefined') {
|
|
34
|
+
x = event.clientX;
|
|
35
|
+
y = event.clientY;
|
|
36
|
+
}
|
|
37
|
+
else if (typeof(event.screenX) != 'undefined') {
|
|
38
|
+
x = event.screenX;
|
|
39
|
+
y = event.screenY;
|
|
40
|
+
}
|
|
41
|
+
else if (typeof(event.targetTouches) != 'undefined') {
|
|
42
|
+
x = event.targetTouches[0].pageX;
|
|
43
|
+
y = event.targetTouches[0].pageY;
|
|
44
|
+
}
|
|
45
|
+
else if (typeof(event.originalEvent) == 'undefined') {
|
|
46
|
+
console.error("don't understand x and y for " + event.type, event);
|
|
47
|
+
}
|
|
48
|
+
else if (typeof(event.originalEvent.clientX) != 'undefined') {
|
|
49
|
+
x = event.originalEvent.clientX;
|
|
50
|
+
y = event.originalEvent.clientY;
|
|
51
|
+
}
|
|
52
|
+
else if (typeof(event.originalEvent.screenX) != 'undefined') {
|
|
53
|
+
x = event.originalEvent.screenX;
|
|
54
|
+
y = event.originalEvent.screenY;
|
|
55
|
+
}
|
|
56
|
+
else if (typeof(event.originalEvent.targetTouches) != 'undefined') {
|
|
57
|
+
x = event.originalEvent.targetTouches[0].pageX;
|
|
58
|
+
y = event.originalEvent.targetTouches[0].pageY;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
return { left: x, top: y };
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
const DEFAULT_OPTIONS = {
|
|
65
|
+
/**
|
|
66
|
+
* @type {String|HTMLElement} jQuery selector to apply to each wrapped element to
|
|
67
|
+
* find which will be the dragging elements. Defaults to the first child of scrollable
|
|
68
|
+
* element
|
|
69
|
+
*/
|
|
70
|
+
dragSelector: '>:first',
|
|
71
|
+
|
|
72
|
+
/** Will the dragging element accept propagated events? default is yes, a propagated
|
|
73
|
+
* mouse event on a inner element will be accepted and processed. If set to false,
|
|
74
|
+
* only events originated on the draggable elements will be processed. */
|
|
75
|
+
acceptPropagatedEvent: true,
|
|
76
|
+
|
|
77
|
+
/**
|
|
78
|
+
* Prevents the event to propagate further effectively disabling other default actions
|
|
79
|
+
*/
|
|
80
|
+
preventDefault: true,
|
|
81
|
+
|
|
82
|
+
dragstart: 'mousedown touchstart',
|
|
83
|
+
dragcontinue: 'mousemove touchmove',
|
|
84
|
+
dragend: 'mouseup touchend', // mouseleave
|
|
85
|
+
dragMinDistance: 5,
|
|
86
|
+
namespace: '.ds',
|
|
87
|
+
|
|
88
|
+
/** Scroll the window rather than the element */
|
|
89
|
+
scrollWindow: false,
|
|
90
|
+
};
|
|
91
|
+
|
|
92
|
+
/**
|
|
93
|
+
* Adds the ability to manage elements scroll by dragging
|
|
94
|
+
* one or more of its descendant elements. Options parameter
|
|
95
|
+
* allow to specifically select which inner elements will
|
|
96
|
+
* respond to the drag events.
|
|
97
|
+
* usage examples:
|
|
98
|
+
*
|
|
99
|
+
* To add the scroll by drag to the element id=viewport when dragging its
|
|
100
|
+
* first child accepting any propagated events
|
|
101
|
+
* `new DragScrollable($('#viewport')[0]);`
|
|
102
|
+
*
|
|
103
|
+
* To add the scroll by drag ability to any element div of class viewport
|
|
104
|
+
* when dragging its first descendant of class dragMe responding only to
|
|
105
|
+
* evcents originated on the '.dragMe' elements.
|
|
106
|
+
* ```js
|
|
107
|
+
* new DragScrollable($('div.viewport')[0], {
|
|
108
|
+
* dragSelector: '.dragMe:first',
|
|
109
|
+
* acceptPropagatedEvent: false
|
|
110
|
+
* });
|
|
111
|
+
* ```
|
|
112
|
+
*
|
|
113
|
+
* Notice that some 'viewports' could be nested within others but events
|
|
114
|
+
* would not interfere as acceptPropagatedEvent is set to false.
|
|
115
|
+
*/
|
|
116
|
+
export class DragScrollable {
|
|
117
|
+
/**
|
|
118
|
+
* @param {HTMLElement} element
|
|
119
|
+
* @param {Partial<DEFAULT_OPTIONS>} options
|
|
120
|
+
*/
|
|
121
|
+
constructor(element, options = {}) {
|
|
122
|
+
this.handling_element = $(element);
|
|
123
|
+
/** @type {typeof DEFAULT_OPTIONS} */
|
|
124
|
+
this.settings = $.extend({}, DEFAULT_OPTIONS, options || {});
|
|
125
|
+
this.firstCoord = { left: 0, top: 0 };
|
|
126
|
+
this.lastCoord = { left: 0, top: 0 };
|
|
127
|
+
|
|
128
|
+
this.settings.dragstart = append_namespace(this.settings.dragstart, this.settings.namespace);
|
|
129
|
+
this.settings.dragcontinue = append_namespace(this.settings.dragcontinue, this.settings.namespace);
|
|
130
|
+
//settings.dragend = append_namespace(settings.dragend, settings.namespace);
|
|
131
|
+
|
|
132
|
+
// Set mouse initiating event on the desired descendant
|
|
133
|
+
this.handling_element.find(this.settings.dragSelector)
|
|
134
|
+
.on(this.settings.dragstart, this._dragStartHandler);
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
_shouldAbort() {
|
|
138
|
+
const isTouchDevice = !!('ontouchstart' in window) || !!('msmaxtouchpoints' in window.navigator);
|
|
139
|
+
return isTouchDevice;
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
/** @param {MouseEvent} event */
|
|
143
|
+
_dragStartHandler = (event) => {
|
|
144
|
+
if (this._shouldAbort()) { return true; }
|
|
145
|
+
|
|
146
|
+
// mousedown, left click, check propagation
|
|
147
|
+
if (event.which > 1 ||
|
|
148
|
+
(!this.settings.acceptPropagatedEvent && event.target != this.handling_element[0])) {
|
|
149
|
+
return false;
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
// Initial coordinates will be the last when dragging
|
|
153
|
+
this.lastCoord = this.firstCoord = left_top(event);
|
|
154
|
+
|
|
155
|
+
this.handling_element
|
|
156
|
+
.on(this.settings.dragcontinue, this._dragContinueHandler)
|
|
157
|
+
//.on(this.settings.dragend, this._dragEndHandler)
|
|
158
|
+
;
|
|
159
|
+
|
|
160
|
+
// Note, we bind using addEventListener so we can use "capture" binding
|
|
161
|
+
// instead of "bubble" binding
|
|
162
|
+
this.settings.dragend.split(' ').forEach(event_name => {
|
|
163
|
+
this.handling_element[0].addEventListener(event_name, this._dragEndHandler, true);
|
|
164
|
+
});
|
|
165
|
+
|
|
166
|
+
if (this.settings.preventDefault) {
|
|
167
|
+
event.preventDefault();
|
|
168
|
+
return false;
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
/** @param {MouseEvent} event */
|
|
173
|
+
_dragContinueHandler = (event) => { // User is dragging
|
|
174
|
+
// console.log('drag continue');
|
|
175
|
+
if (this._shouldAbort()) { return true; }
|
|
176
|
+
|
|
177
|
+
const lt = left_top(event);
|
|
178
|
+
|
|
179
|
+
// How much did the mouse move?
|
|
180
|
+
const delta = {
|
|
181
|
+
left: (lt.left - this.lastCoord.left),
|
|
182
|
+
top: (lt.top - this.lastCoord.top)
|
|
183
|
+
};
|
|
184
|
+
|
|
185
|
+
const scrollTarget = this.settings.scrollWindow ? $(window) : this.handling_element;
|
|
186
|
+
|
|
187
|
+
// Set the scroll position relative to what ever the scroll is now
|
|
188
|
+
scrollTarget.scrollLeft( scrollTarget.scrollLeft() - delta.left );
|
|
189
|
+
scrollTarget.scrollTop( scrollTarget.scrollTop() - delta.top );
|
|
190
|
+
|
|
191
|
+
// Save where the cursor is
|
|
192
|
+
this.lastCoord = lt;
|
|
193
|
+
|
|
194
|
+
if (this.settings.preventDefault) {
|
|
195
|
+
event.preventDefault();
|
|
196
|
+
return false;
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
|
|
200
|
+
/** @param {MouseEvent} event */
|
|
201
|
+
_dragEndHandler = (event) => { // Stop scrolling
|
|
202
|
+
//console.log('dragEndHandler');
|
|
203
|
+
|
|
204
|
+
if (this._shouldAbort()) { return true; }
|
|
205
|
+
|
|
206
|
+
this.handling_element
|
|
207
|
+
.off(this.settings.dragcontinue)
|
|
208
|
+
// Note, for some reason, even though I removeEventListener below,
|
|
209
|
+
// this call to unbind is still necessary. I don't know why.
|
|
210
|
+
.off(this.settings.dragend);
|
|
211
|
+
|
|
212
|
+
// Note, we bind using addEventListener so we can use "capture" binding
|
|
213
|
+
// instead of "bubble" binding
|
|
214
|
+
this.settings.dragend.split(' ').forEach(event_name => {
|
|
215
|
+
this.handling_element[0].removeEventListener(event_name, this._dragEndHandler, true);
|
|
216
|
+
});
|
|
217
|
+
|
|
218
|
+
// How much did the mouse move total?
|
|
219
|
+
const delta = {
|
|
220
|
+
left: Math.abs(this.lastCoord.left - this.firstCoord.left),
|
|
221
|
+
top: Math.abs(this.lastCoord.top - this.firstCoord.top)
|
|
222
|
+
};
|
|
223
|
+
const distance = Math.max(delta.left, delta.top);
|
|
224
|
+
|
|
225
|
+
// Allow event to propagate if min distance was not achieved
|
|
226
|
+
if (this.settings.preventDefault && distance > this.settings.dragMinDistance) {
|
|
227
|
+
event.preventDefault();
|
|
228
|
+
event.stopImmediatePropagation();
|
|
229
|
+
event.stopPropagation();
|
|
230
|
+
return false;
|
|
231
|
+
}
|
|
232
|
+
}
|
|
233
|
+
}
|