@internetarchive/bookreader 5.0.0-6-14 → 5.0.0-60

Sign up to get free protection for your applications and to get access to all the features.
Files changed (271) hide show
  1. package/.eslintrc.js +17 -15
  2. package/.github/workflows/node.js.yml +72 -10
  3. package/.github/workflows/npm-publish.yml +6 -20
  4. package/.testcaferc.js +10 -0
  5. package/BookReader/BookReader.css +241 -140
  6. package/BookReader/BookReader.js +1 -1
  7. package/BookReader/BookReader.js.LICENSE.txt +24 -20
  8. package/BookReader/BookReader.js.map +1 -1
  9. package/BookReader/ia-bookreader-bundle.js +1519 -0
  10. package/BookReader/ia-bookreader-bundle.js.LICENSE.txt +17 -0
  11. package/BookReader/ia-bookreader-bundle.js.map +1 -0
  12. package/BookReader/icons/close-circle-dark.svg +1 -0
  13. package/BookReader/icons/magnify-minus.svg +1 -1
  14. package/BookReader/icons/magnify-plus.svg +1 -1
  15. package/BookReader/icons/pause.svg +1 -1
  16. package/BookReader/icons/playback-speed.svg +1 -1
  17. package/BookReader/icons/read-aloud.svg +1 -1
  18. package/BookReader/icons/voice.svg +1 -0
  19. package/BookReader/images/BRicons.svg +2 -2
  20. package/BookReader/images/books_graphic.svg +1 -1
  21. package/BookReader/images/icon_book.svg +1 -1
  22. package/BookReader/images/icon_gear.svg +1 -1
  23. package/BookReader/images/icon_info.svg +1 -1
  24. package/BookReader/images/icon_playback-rate.svg +1 -1
  25. package/BookReader/images/icon_search_button.svg +1 -1
  26. package/BookReader/images/icon_share.svg +1 -1
  27. package/BookReader/images/icon_speaker.svg +1 -1
  28. package/BookReader/images/icon_speaker_open.svg +1 -1
  29. package/BookReader/images/marker_chap-off.svg +1 -1
  30. package/BookReader/images/marker_chap-on.svg +1 -1
  31. package/BookReader/images/marker_srch-on.svg +1 -1
  32. package/BookReader/jquery-3.js +2 -0
  33. package/BookReader/jquery-3.js.LICENSE.txt +24 -0
  34. package/BookReader/plugins/plugin.archive_analytics.js +1 -1
  35. package/BookReader/plugins/plugin.archive_analytics.js.map +1 -1
  36. package/BookReader/plugins/plugin.autoplay.js +1 -1
  37. package/BookReader/plugins/plugin.autoplay.js.map +1 -1
  38. package/BookReader/plugins/plugin.chapters.js +1 -1
  39. package/BookReader/plugins/plugin.chapters.js.map +1 -1
  40. package/BookReader/plugins/plugin.iframe.js +1 -1
  41. package/BookReader/plugins/plugin.iframe.js.map +1 -1
  42. package/BookReader/plugins/plugin.mobile_nav.js +1 -1
  43. package/BookReader/plugins/plugin.mobile_nav.js.map +1 -1
  44. package/BookReader/plugins/plugin.resume.js +1 -1
  45. package/BookReader/plugins/plugin.resume.js.map +1 -1
  46. package/BookReader/plugins/plugin.search.js +1 -1
  47. package/BookReader/plugins/plugin.search.js.map +1 -1
  48. package/BookReader/plugins/plugin.text_selection.js +1 -1
  49. package/BookReader/plugins/plugin.text_selection.js.map +1 -1
  50. package/BookReader/plugins/plugin.tts.js +1 -1
  51. package/BookReader/plugins/plugin.tts.js.map +1 -1
  52. package/BookReader/plugins/plugin.url.js +1 -1
  53. package/BookReader/plugins/plugin.url.js.map +1 -1
  54. package/BookReader/plugins/plugin.vendor-fullscreen.js +1 -1
  55. package/BookReader/plugins/plugin.vendor-fullscreen.js.map +1 -1
  56. package/BookReader/webcomponents-bundle.js +3 -0
  57. package/BookReader/webcomponents-bundle.js.LICENSE.txt +9 -0
  58. package/BookReader/webcomponents-bundle.js.map +1 -0
  59. package/BookReaderDemo/BookReaderDemo.css +14 -1
  60. package/BookReaderDemo/BookReaderJSAutoplay.js +4 -1
  61. package/BookReaderDemo/BookReaderJSSimple.js +1 -0
  62. package/BookReaderDemo/IADemoBr.js +147 -0
  63. package/BookReaderDemo/demo-advanced.html +2 -2
  64. package/BookReaderDemo/demo-autoplay.html +2 -1
  65. package/BookReaderDemo/demo-embed-iframe-src.html +2 -1
  66. package/BookReaderDemo/demo-fullscreen-mobile.html +2 -1
  67. package/BookReaderDemo/demo-fullscreen.html +2 -1
  68. package/BookReaderDemo/demo-iiif.html +2 -1
  69. package/BookReaderDemo/demo-internetarchive.html +84 -17
  70. package/BookReaderDemo/demo-multiple.html +2 -1
  71. package/BookReaderDemo/demo-preview-pages.html +2 -1
  72. package/BookReaderDemo/demo-simple.html +2 -1
  73. package/BookReaderDemo/demo-vendor-fullscreen.html +2 -1
  74. package/BookReaderDemo/ia-multiple-volumes-manifest.js +170 -0
  75. package/BookReaderDemo/immersion-1up.html +2 -1
  76. package/BookReaderDemo/immersion-mode.html +2 -1
  77. package/BookReaderDemo/toggle_controls.html +2 -1
  78. package/BookReaderDemo/view_mode.html +2 -1
  79. package/BookReaderDemo/viewmode-cycle.html +2 -3
  80. package/CHANGELOG.md +244 -0
  81. package/README.md +14 -1
  82. package/babel.config.js +19 -0
  83. package/codecov.yml +6 -0
  84. package/index.html +3 -0
  85. package/jsconfig.json +19 -0
  86. package/netlify.toml +5 -0
  87. package/package.json +70 -59
  88. package/renovate.json +52 -0
  89. package/scripts/preversion.js +4 -1
  90. package/src/BookNavigator/assets/bookmark-colors.js +1 -1
  91. package/src/BookNavigator/assets/button-base.js +9 -2
  92. package/src/BookNavigator/assets/ia-logo.js +17 -0
  93. package/src/BookNavigator/assets/icon_checkmark.js +1 -1
  94. package/src/BookNavigator/assets/icon_close.js +1 -1
  95. package/src/BookNavigator/assets/icon_sort_asc.js +5 -0
  96. package/src/BookNavigator/assets/icon_sort_desc.js +5 -0
  97. package/src/BookNavigator/assets/icon_sort_neutral.js +5 -0
  98. package/src/BookNavigator/assets/icon_volumes.js +11 -0
  99. package/src/BookNavigator/book-navigator.js +585 -0
  100. package/src/BookNavigator/bookmarks/bookmark-button.js +3 -2
  101. package/src/BookNavigator/bookmarks/bookmark-edit.js +3 -4
  102. package/src/BookNavigator/bookmarks/bookmarks-list.js +2 -3
  103. package/src/BookNavigator/bookmarks/bookmarks-loginCTA.js +3 -8
  104. package/src/BookNavigator/bookmarks/bookmarks-provider.js +27 -17
  105. package/src/BookNavigator/bookmarks/ia-bookmarks.js +116 -67
  106. package/src/BookNavigator/delete-modal-actions.js +1 -1
  107. package/src/BookNavigator/downloads/downloads-provider.js +36 -21
  108. package/src/BookNavigator/downloads/downloads.js +41 -25
  109. package/src/BookNavigator/search/search-provider.js +80 -28
  110. package/src/BookNavigator/search/search-results.js +34 -25
  111. package/src/BookNavigator/sharing.js +27 -0
  112. package/src/BookNavigator/visual-adjustments/visual-adjustments-provider.js +11 -10
  113. package/src/BookNavigator/visual-adjustments/visual-adjustments.js +3 -3
  114. package/src/BookNavigator/volumes/volumes-provider.js +111 -0
  115. package/src/BookNavigator/volumes/volumes.js +188 -0
  116. package/src/BookReader/BookModel.js +59 -30
  117. package/src/BookReader/DebugConsole.js +3 -3
  118. package/src/BookReader/DragScrollable.js +233 -0
  119. package/src/BookReader/Mode1Up.js +56 -351
  120. package/src/BookReader/Mode1UpLit.js +391 -0
  121. package/src/BookReader/Mode2Up.js +73 -1318
  122. package/src/BookReader/Mode2UpLit.js +781 -0
  123. package/src/BookReader/ModeCoordinateSpace.js +29 -0
  124. package/src/BookReader/ModeSmoothZoom.js +211 -0
  125. package/src/BookReader/ModeThumb.js +17 -11
  126. package/src/BookReader/Navbar/Navbar.js +10 -36
  127. package/src/BookReader/PageContainer.js +69 -6
  128. package/src/BookReader/ReduceSet.js +1 -1
  129. package/src/BookReader/Toolbar/Toolbar.js +10 -37
  130. package/src/BookReader/events.js +2 -0
  131. package/src/BookReader/options.js +24 -2
  132. package/src/BookReader/utils/HTMLDimensionsCacher.js +44 -0
  133. package/src/BookReader/utils/ScrollClassAdder.js +31 -0
  134. package/src/BookReader/utils.js +108 -13
  135. package/src/BookReader.js +481 -828
  136. package/src/assets/icons/close-circle-dark.svg +1 -0
  137. package/src/assets/icons/magnify-minus.svg +3 -7
  138. package/src/assets/icons/magnify-plus.svg +3 -7
  139. package/src/assets/icons/voice.svg +1 -0
  140. package/src/css/_BRBookmarks.scss +1 -1
  141. package/src/css/_BRComponent.scss +1 -1
  142. package/src/css/_BRmain.scss +33 -0
  143. package/src/css/_BRnav.scss +4 -26
  144. package/src/css/_BRpages.scss +147 -40
  145. package/src/css/_BRsearch.scss +25 -11
  146. package/src/css/_TextSelection.scss +16 -17
  147. package/src/css/_colorbox.scss +2 -2
  148. package/src/css/_controls.scss +17 -5
  149. package/src/css/_icons.scss +7 -1
  150. package/src/ia-bookreader/ia-bookreader.js +224 -0
  151. package/src/plugins/plugin.archive_analytics.js +3 -3
  152. package/src/plugins/plugin.autoplay.js +4 -9
  153. package/src/plugins/plugin.chapters.js +28 -35
  154. package/src/plugins/plugin.mobile_nav.js +11 -10
  155. package/src/plugins/plugin.resume.js +3 -3
  156. package/src/plugins/plugin.text_selection.js +32 -41
  157. package/src/plugins/plugin.vendor-fullscreen.js +4 -4
  158. package/src/plugins/search/plugin.search.js +179 -103
  159. package/src/plugins/search/view.js +59 -44
  160. package/src/plugins/tts/AbstractTTSEngine.js +46 -37
  161. package/src/plugins/tts/FestivalTTSEngine.js +13 -14
  162. package/src/plugins/tts/PageChunk.js +15 -21
  163. package/src/plugins/tts/PageChunkIterator.js +8 -12
  164. package/src/plugins/tts/WebTTSEngine.js +87 -71
  165. package/src/plugins/tts/plugin.tts.js +94 -125
  166. package/src/plugins/tts/utils.js +0 -25
  167. package/src/plugins/url/UrlPlugin.js +193 -0
  168. package/src/plugins/{plugin.url.js → url/plugin.url.js} +45 -16
  169. package/src/util/docCookies.js +21 -2
  170. package/tests/e2e/README.md +37 -0
  171. package/tests/e2e/autoplay.test.js +2 -2
  172. package/tests/e2e/base.test.js +7 -7
  173. package/tests/e2e/helpers/base.js +28 -23
  174. package/tests/e2e/helpers/debug.js +1 -1
  175. package/tests/e2e/helpers/desktopSearch.js +14 -13
  176. package/tests/e2e/helpers/mobileSearch.js +3 -3
  177. package/tests/e2e/helpers/params.js +17 -0
  178. package/tests/e2e/helpers/rightToLeft.js +4 -10
  179. package/tests/e2e/models/Navigation.js +13 -4
  180. package/tests/e2e/rightToLeft.test.js +4 -5
  181. package/tests/e2e/viewmode.test.js +40 -33
  182. package/tests/jest/BookNavigator/book-navigator.test.js +658 -0
  183. package/tests/jest/BookNavigator/bookmarks/bookmark-button.test.js +43 -0
  184. package/tests/{karma → jest}/BookNavigator/bookmarks/bookmark-edit.test.js +25 -26
  185. package/tests/{karma → jest}/BookNavigator/bookmarks/bookmarks-list.test.js +41 -42
  186. package/tests/jest/BookNavigator/bookmarks/ia-bookmarks.test.js +45 -0
  187. package/tests/jest/BookNavigator/downloads/downloads-provider.test.js +67 -0
  188. package/tests/jest/BookNavigator/downloads/downloads.test.js +53 -0
  189. package/tests/jest/BookNavigator/search/search-provider.test.js +167 -0
  190. package/tests/{karma/BookNavigator → jest/BookNavigator/search}/search-results.test.js +104 -60
  191. package/tests/jest/BookNavigator/sharing/sharing-provider.test.js +49 -0
  192. package/tests/jest/BookNavigator/visual-adjustments.test.js +200 -0
  193. package/tests/jest/BookNavigator/volumes/volumes-provider.test.js +184 -0
  194. package/tests/jest/BookNavigator/volumes/volumes.test.js +97 -0
  195. package/tests/{BookReader → jest/BookReader}/BookModel.test.js +59 -14
  196. package/tests/jest/BookReader/BookReaderPublicFunctions.test.js +193 -0
  197. package/tests/{BookReader → jest/BookReader}/DebugConsole.test.js +1 -1
  198. package/tests/{BookReader → jest/BookReader}/ImageCache.test.js +4 -4
  199. package/tests/jest/BookReader/Mode1UpLit.test.js +73 -0
  200. package/tests/jest/BookReader/Mode2Up.test.js +98 -0
  201. package/tests/jest/BookReader/Mode2UpLit.test.js +190 -0
  202. package/tests/jest/BookReader/ModeCoordinateSpace.test.js +16 -0
  203. package/tests/jest/BookReader/ModeSmoothZoom.test.js +175 -0
  204. package/tests/jest/BookReader/ModeThumb.test.js +71 -0
  205. package/tests/{BookReader → jest/BookReader}/Navbar/Navbar.test.js +10 -10
  206. package/tests/{BookReader → jest/BookReader}/PageContainer.test.js +88 -6
  207. package/tests/{BookReader → jest/BookReader}/ReduceSet.test.js +1 -1
  208. package/tests/{BookReader → jest/BookReader}/Toolbar/Toolbar.test.js +2 -2
  209. package/tests/jest/BookReader/utils/HTMLDimensionsCacher.test.js +59 -0
  210. package/tests/jest/BookReader/utils/ScrollClassAdder.test.js +49 -0
  211. package/tests/{BookReader → jest/BookReader}/utils/classes.test.js +1 -1
  212. package/tests/jest/BookReader/utils.test.js +217 -0
  213. package/tests/jest/BookReader.keyboard.test.js +190 -0
  214. package/tests/{BookReader.options.test.js → jest/BookReader.options.test.js} +9 -1
  215. package/tests/{BookReader.test.js → jest/BookReader.test.js} +26 -37
  216. package/tests/{plugins → jest/plugins}/plugin.archive_analytics.test.js +2 -2
  217. package/tests/{plugins → jest/plugins}/plugin.autoplay.test.js +4 -4
  218. package/tests/{plugins → jest/plugins}/plugin.chapters.test.js +10 -11
  219. package/tests/{plugins → jest/plugins}/plugin.iframe.test.js +2 -2
  220. package/tests/{plugins → jest/plugins}/plugin.mobile_nav.test.js +5 -5
  221. package/tests/{plugins → jest/plugins}/plugin.resume.test.js +3 -3
  222. package/tests/{plugins → jest/plugins}/plugin.text_selection.test.js +39 -47
  223. package/tests/{plugins → jest/plugins}/plugin.vendor-fullscreen.test.js +2 -2
  224. package/tests/{plugins → jest/plugins}/search/plugin.search.test.js +57 -47
  225. package/tests/{plugins → jest/plugins}/search/plugin.search.view.test.js +35 -6
  226. package/tests/{plugins → jest/plugins}/tts/AbstractTTSEngine.test.js +9 -9
  227. package/tests/{plugins → jest/plugins}/tts/FestivalTTSEngine.test.js +4 -4
  228. package/tests/{plugins → jest/plugins}/tts/PageChunk.test.js +1 -1
  229. package/tests/{plugins → jest/plugins}/tts/PageChunkIterator.test.js +3 -3
  230. package/tests/{plugins → jest/plugins}/tts/WebTTSEngine.test.js +47 -1
  231. package/tests/{plugins → jest/plugins}/tts/utils.test.js +1 -60
  232. package/tests/jest/plugins/url/UrlPlugin.test.js +190 -0
  233. package/tests/{plugins → jest/plugins/url}/plugin.url.test.js +53 -14
  234. package/tests/jest/setup.js +3 -0
  235. package/tests/{util → jest/util}/browserSniffing.test.js +1 -1
  236. package/tests/jest/util/docCookies.test.js +24 -0
  237. package/tests/{util → jest/util}/strings.test.js +1 -1
  238. package/tests/{utils.js → jest/utils.js} +38 -0
  239. package/webpack.config.js +11 -5
  240. package/.babelrc +0 -12
  241. package/.dependabot/config.yml +0 -6
  242. package/.testcaferc.json +0 -5
  243. package/BookReader/bookreader-component-bundle.js +0 -1450
  244. package/BookReader/bookreader-component-bundle.js.LICENSE.txt +0 -38
  245. package/BookReader/bookreader-component-bundle.js.map +0 -1
  246. package/BookReader/jquery-1.10.1.js +0 -2
  247. package/BookReader/jquery-1.10.1.js.LICENSE.txt +0 -24
  248. package/BookReader/plugins/plugin.menu_toggle.js +0 -2
  249. package/BookReader/plugins/plugin.menu_toggle.js.map +0 -1
  250. package/BookReaderDemo/bookreader-template-bundle.js +0 -7178
  251. package/BookReaderDemo/demo-plugin-menu-toggle.html +0 -34
  252. package/karma.conf.js +0 -23
  253. package/src/BookNavigator/BookModel.js +0 -14
  254. package/src/BookNavigator/BookNavigator.js +0 -438
  255. package/src/BookNavigator/assets/book-loader.js +0 -27
  256. package/src/BookNavigator/br-fullscreen-mgr.js +0 -83
  257. package/src/BookNavigator/search/a-search-result.js +0 -55
  258. package/src/BookReaderComponent/BookReaderComponent.js +0 -112
  259. package/src/ItemNavigator/ItemNavigator.js +0 -372
  260. package/src/ItemNavigator/providers/sharing.js +0 -29
  261. package/src/dragscrollable-br.js +0 -261
  262. package/src/plugins/menu_toggle/plugin.menu_toggle.js +0 -324
  263. package/tests/BookReader/BookReaderPublicFunctions.test.js +0 -171
  264. package/tests/BookReader/Mode1Up.test.js +0 -164
  265. package/tests/BookReader/Mode2Up.test.js +0 -247
  266. package/tests/BookReader/utils.test.js +0 -109
  267. package/tests/e2e/ia-production/ia-prod-base.js +0 -17
  268. package/tests/karma/BookNavigator/book-navigator.test.js +0 -132
  269. package/tests/karma/BookNavigator/visual-adjustments.test.js +0 -201
  270. package/tests/plugins/menu_toggle/plugin.menu_toggle.test.js +0 -68
  271. package/tests/util/docCookies.test.js +0 -15
@@ -1,261 +0,0 @@
1
- /*
2
- * jQuery dragscrollable Plugin
3
- * version: 1.0 (25-Jun-2009)
4
- * Copyright (c) 2009 Miquel Herrera
5
- *
6
- * Portions Copyright (c) 2010 Reg Braithwaite
7
- * Copyright (c) 2010 Internet Archive / Michael Ang
8
- * Copyright (c) 2016 Internet Archive / Richard Caceres
9
- *
10
- * Dual licensed under the MIT and GPL licenses:
11
- * http://www.opensource.org/licenses/mit-license.php
12
- * http://www.gnu.org/licenses/gpl.html
13
- *
14
- * Modified by richard@archive.org 2016
15
- * - Added check to disable on touch enabled devices
16
- * - Change dragend handler to bind using event "capturing" instead of "bubbling"
17
- */
18
- (function($) { // secure $ jQuery alias
19
-
20
- /**
21
- * Adds the ability to manage elements scroll by dragging
22
- * one or more of its descendant elements. Options parameter
23
- * allow to specifically select which inner elements will
24
- * respond to the drag events.
25
- *
26
- * options properties:
27
- * ------------------------------------------------------------------------
28
- * dragSelector | jquery selector to apply to each wrapped element
29
- * | to find which will be the dragging elements.
30
- * | Defaults to '>:first' which is the first child of
31
- * | scrollable element
32
- * ------------------------------------------------------------------------
33
- * acceptPropagatedEvent| Will the dragging element accept propagated
34
- * | events? default is yes, a propagated mouse event
35
- * | on a inner element will be accepted and processed.
36
- * | If set to false, only events originated on the
37
- * | draggable elements will be processed.
38
- * ------------------------------------------------------------------------
39
- * preventDefault | Prevents the event to propagate further effectivey
40
- * | disabling other default actions. Defaults to true
41
- * ------------------------------------------------------------------------
42
- * scrollWindow | Scroll the window rather than the element
43
- * | Defaults to false
44
- * ------------------------------------------------------------------------
45
- *
46
- * usage examples:
47
- *
48
- * To add the scroll by drag to the element id=viewport when dragging its
49
- * first child accepting any propagated events
50
- * $('#viewport').dragscrollable();
51
- *
52
- * To add the scroll by drag ability to any element div of class viewport
53
- * when dragging its first descendant of class dragMe responding only to
54
- * evcents originated on the '.dragMe' elements.
55
- * $('div.viewport').dragscrollable({dragSelector:'.dragMe:first',
56
- * acceptPropagatedEvent: false});
57
- *
58
- * Notice that some 'viewports' could be nested within others but events
59
- * would not interfere as acceptPropagatedEvent is set to false.
60
- *
61
- */
62
-
63
- var append_namespace = function (string_of_events, ns) {
64
-
65
- /* IE doesn't have map
66
- return string_of_events
67
- .split(' ')
68
- .map(function (name) { return name + ns; })
69
- .join(' ');
70
- */
71
- var pieces = string_of_events.split(' ');
72
- var ret = new Array();
73
- for (var i = 0; i < pieces.length; i++) {
74
- ret.push(pieces[i] + ns);
75
- }
76
- return ret.join(' ');
77
- };
78
-
79
- var left_top = function(event) {
80
-
81
- var x;
82
- var y;
83
- if (typeof(event.clientX) != 'undefined') {
84
- x = event.clientX;
85
- y = event.clientY;
86
- }
87
- else if (typeof(event.screenX) != 'undefined') {
88
- x = event.screenX;
89
- y = event.screenY;
90
- }
91
- else if (typeof(event.targetTouches) != 'undefined') {
92
- x = event.targetTouches[0].pageX;
93
- y = event.targetTouches[0].pageY;
94
- }
95
- else if (typeof(event.originalEvent) == 'undefined') {
96
- var str = '';
97
- for (const i in event) {
98
- str += ', ' + i + ': ' + event[i];
99
- }
100
- console.error("don't understand x and y for " + event.type + ' event: ' + str);
101
- }
102
- else if (typeof(event.originalEvent.clientX) != 'undefined') {
103
- x = event.originalEvent.clientX;
104
- y = event.originalEvent.clientY;
105
- }
106
- else if (typeof(event.originalEvent.screenX) != 'undefined') {
107
- x = event.originalEvent.screenX;
108
- y = event.originalEvent.screenY;
109
- }
110
- else if (typeof(event.originalEvent.targetTouches) != 'undefined') {
111
- x = event.originalEvent.targetTouches[0].pageX;
112
- y = event.originalEvent.targetTouches[0].pageY;
113
- }
114
-
115
- return {left: x, top:y};
116
- };
117
-
118
- $.fn.dragscrollable = function( options ) {
119
-
120
- var handling_element = $(this);
121
-
122
- var settings = $.extend(
123
- {
124
- dragSelector:'>:first',
125
- acceptPropagatedEvent: true,
126
- preventDefault: true,
127
- dragstart: 'mousedown touchstart',
128
- dragcontinue: 'mousemove touchmove',
129
- dragend: 'mouseup touchend', // mouseleave
130
- dragMinDistance: 5,
131
- namespace: '.ds',
132
- scrollWindow: false,
133
- },options || {});
134
-
135
- settings.dragstart = append_namespace(settings.dragstart, settings.namespace);
136
- settings.dragcontinue = append_namespace(settings.dragcontinue, settings.namespace);
137
- //settings.dragend = append_namespace(settings.dragend, settings.namespace);
138
-
139
- var shouldAbort = function() {
140
- var isTouchDevice = !!('ontouchstart' in window) || !!('msmaxtouchpoints' in window.navigator);
141
- return isTouchDevice;
142
- };
143
-
144
- var dragContinueHandlerProxy;
145
-
146
- var dragscroll = {
147
- dragStartHandler : function(event) {
148
- if (shouldAbort()) { return true; }
149
-
150
- // mousedown, left click, check propagation
151
- if (event.which > 1 ||
152
- (!event.data.acceptPropagatedEvent && event.target != this)) {
153
- return false;
154
- }
155
-
156
- event.data.firstCoord = left_top(event);
157
- // Initial coordinates will be the last when dragging
158
- event.data.lastCoord = event.data.firstCoord;
159
-
160
- handling_element
161
- .bind(settings.dragcontinue, event.data, dragscroll.dragContinueHandler)
162
- //.bind(settings.dragend, event.data, dragscroll.dragEndHandler)
163
- ;
164
-
165
- // Note, we bind using addEventListener so we can use "capture" binding
166
- // instead of "bubble" binding
167
- dragContinueHandlerProxy = function(e) {
168
- e.data = event.data;
169
- dragscroll.dragEndHandler(e);
170
- };
171
- $.each(settings.dragend.split(' '), function(idx, val) {
172
- handling_element.get(0).addEventListener(val, dragContinueHandlerProxy, true);
173
- });
174
-
175
- if (event.data.preventDefault) {
176
- event.preventDefault();
177
- return false;
178
- }
179
- },
180
- dragContinueHandler : function(event) { // User is dragging
181
- // console.log('drag continue');
182
- if (shouldAbort()) { return true; }
183
-
184
- var lt = left_top(event);
185
-
186
- // How much did the mouse move?
187
- var delta = {left: (lt.left - event.data.lastCoord.left),
188
- top: (lt.top - event.data.lastCoord.top)};
189
-
190
- var scrollTarget = event.data.scrollable;
191
- if (event.data.scrollWindow) {
192
- scrollTarget = $(window);
193
- }
194
- // Set the scroll position relative to what ever the scroll is now
195
- scrollTarget.scrollLeft( scrollTarget.scrollLeft() - delta.left );
196
- scrollTarget.scrollTop( scrollTarget.scrollTop() - delta.top );
197
-
198
- // Save where the cursor is
199
- event.data.lastCoord = lt;
200
-
201
- if (event.data.preventDefault) {
202
- event.preventDefault();
203
- return false;
204
- }
205
- },
206
- dragEndHandler : function(event) { // Stop scrolling
207
- //console.log('dragEndHandler');
208
-
209
- if (shouldAbort()) { return true; }
210
-
211
- handling_element
212
- .unbind(settings.dragcontinue)
213
- // Note, for some reason, even though I removeEventListener below,
214
- // this call to unbind is still necessary. I don't know why.
215
- .unbind(settings.dragend)
216
- ;
217
-
218
- // Note, we bind using addEventListener so we can use "capture" binding
219
- // instead of "bubble" binding
220
- $.each(settings.dragend.split(' '), function(idx, val) {
221
- handling_element.get(0).removeEventListener(val, dragContinueHandlerProxy, true);
222
- });
223
-
224
- // How much did the mouse move total?
225
- var delta = {left: Math.abs(event.data.lastCoord.left - event.data.firstCoord.left),
226
- top: Math.abs(event.data.lastCoord.top - event.data.firstCoord.top)};
227
- var distance = Math.max(delta.left, delta.top);
228
-
229
- // Allow event to propagate if min distance was not achieved
230
- if (event.data.preventDefault && distance > settings.dragMinDistance) {
231
- event.preventDefault();
232
- event.stopImmediatePropagation();
233
- event.stopPropagation();
234
- return false;
235
- }
236
- }
237
- };
238
-
239
- // set up the initial events
240
- return this.each(function() {
241
- // closure object data for each scrollable element
242
- var data = {scrollable : $(this),
243
- acceptPropagatedEvent : settings.acceptPropagatedEvent,
244
- preventDefault : settings.preventDefault,
245
- scrollWindow : settings.scrollWindow };
246
- // Set mouse initiating event on the desired descendant
247
- $(this).find(settings.dragSelector).
248
- bind(settings.dragstart, data, dragscroll.dragStartHandler);
249
- });
250
- }; //end plugin dragscrollable
251
-
252
- // Note, this probably doesn't work anymore with our modifications - Nov/8/2016
253
- $.fn.removedragscrollable = function (namespace) {
254
- if (typeof(namespace) == 'undefined')
255
- namespace = '.ds';
256
- return this.each(function() {
257
- $(document).find('*').andSelf().unbind(namespace);
258
- });
259
- };
260
-
261
- })( jQuery ); // confine scope
@@ -1,324 +0,0 @@
1
-
2
- /* global BookReader */
3
- /**
4
- * Plugin for managing menu visibility
5
- * Enabling this plug-in:
6
- * + removes the "menu tab" triangle
7
- * + toggles nav at: book center tap/click
8
- * + toggles nav at: black background tap/click
9
- *
10
- * Handles to events at CAPTURE phase
11
- *
12
- * This uses core BookReader functions and parameters to check its UI state:
13
- * - br.refs = (at best) ui references that are present at any given time
14
- * - br.navigationIsVisible() - checks using refs to confirm the navbar's presence
15
- * - br.showNavigation() & br.hideNavigation()
16
- * - br.constMode1up checks against br.mode;
17
- *
18
- * The list of BookReader custom events this plugin taps into are mainly
19
- * listed in the `.init` function
20
- */
21
-
22
- (function addMenuToggler() {
23
- jQuery.extend(BookReader.defaultOptions, {
24
- enableMenuToggle: true
25
- });
26
-
27
- /**
28
- * `holdOffOnToggle` is used in fn `toggleRouter`
29
- * to determine if menu toggle should happen
30
- * set by `registerDragHandlers`
31
- */
32
- let holdOffOnToggle = false;
33
-
34
- /**
35
- * Hides Nav arrow tab
36
- *
37
- * @param { object } br - BookReader instance
38
- */
39
- function hideArrow(br) {
40
- if (!br.refs || !br.refs.$BRnav) {
41
- return;
42
- }
43
- const $menuTab = br.refs.$BRnav.children('.BRnavCntl');
44
- $menuTab.css('display', 'none');
45
- }
46
-
47
- /**
48
- * Sets up nav - hides arrow tab & adds click events
49
- *
50
- * @param { object } br - BookReader instance
51
- */
52
- function setupNavForToggle(br) {
53
- hideArrow(br);
54
- registerClickHandlers(br);
55
- }
56
-
57
- /**
58
- * Resets nav to always show
59
- * hides arrow tab, removes click events, shows nav chrome
60
- *
61
- * @param { object } br - BookReader instance
62
- */
63
- function alwaysShowNav(br) {
64
- hideArrow(br);
65
- removeClickHandlers(br);
66
- br.showNavigation();
67
- }
68
-
69
- /**
70
- * Removes click handlers on elements that house the book pages
71
- *
72
- * @param { object } br - BookReader instance
73
- */
74
- const removeClickHandlers = function removeClickHandlers(br) {
75
- if (br.refs.$brPageViewEl) {
76
- br.refs.$brPageViewEl[0].removeEventListener('click', onBookClick, true);
77
- }
78
- if (br.refs.$brTwoPageView) {
79
- br.refs.$brTwoPageView[0].removeEventListener('click', onBookClick, true);
80
- }
81
- }
82
-
83
- /**
84
- * Toggle functionality
85
- * Responsible for calling native functions `hideNavigation` & `showNavigation`
86
- * Makes sure only 1 toggle action is taken at a time using `togglingNav` switch.
87
- *
88
- * @params { object } br - bookreader instance
89
- */
90
- let togglingNav = false; /* flag to make sure animations only fire once */
91
- const toggleNav = function toggleNav(br) {
92
- if (togglingNav) {
93
- return;
94
- }
95
-
96
- togglingNav = true;
97
- const navToggled = function navToggled() {
98
- togglingNav = false;
99
- window.removeEventListener('BookReader:navToggled', navToggled);
100
- };
101
- $(document).on('BookReader:navToggled', navToggled);
102
-
103
- const menuIsShowing = br.navigationIsVisible();
104
- if (menuIsShowing) {
105
- br.hideNavigation();
106
- } else {
107
- br.showNavigation();
108
- }
109
- }
110
-
111
- /**
112
- * Check if div `BRcontainer` is scrollable.
113
- * This normally happens when bookreader is zoomed in.
114
- * not using br.refs, because `scrollWidth` & `offsetWidth` is not easily accessible.
115
- */
116
- const isBRcontainerScrollable = function isBRcontainerScrollable() {
117
- const brContainer = document.querySelector('.BRcontainer');
118
- const scrollWidth = brContainer.scrollWidth;
119
- const offsetWidth = brContainer.offsetWidth;
120
-
121
- return scrollWidth > offsetWidth;
122
- }
123
-
124
- /**
125
- * Confirms whether or not the click happened in the nav toggle zone
126
- *
127
- * @param { MouseEvent } event - JS click event object
128
- * @param { DOM } book - DOM element that represents book
129
- */
130
- const isCenterClick = function isCenterClick(event, book) {
131
- const clickPosition = event.clientX;
132
- const bookWidth = book.offsetWidth;
133
- const leftOffset = book.offsetLeft
134
- const bookEndPageFlipArea = Math.round(bookWidth / 3);
135
- const leftThreshold = Math.round(bookEndPageFlipArea + leftOffset); // without it, the click area is small
136
- const rightThreshold = Math.round(bookWidth - bookEndPageFlipArea + leftOffset);
137
- const isOkOnRight = clickPosition > leftThreshold;
138
- const isOkOnLeft = clickPosition < rightThreshold;
139
- const isCenterClick = isOkOnRight && isOkOnLeft;
140
-
141
- return isCenterClick;
142
- }
143
-
144
- /**
145
- * Confirms whether or not the click happened in the background
146
- *
147
- * @param { DOM } element
148
- */
149
- const isBackground = function isBackground(element) {
150
- const isBackgroundClick = $(element).hasClass('BookReader')
151
- || $(element).hasClass('BRcontainer') /* main black theatre */
152
- || $(element).hasClass('BRemptypage') /* empty page placeholder */
153
- || $(element).hasClass('BRpageview') /* empty page placeholder, 1up */
154
- || $(element).hasClass('BRtwopageview'); /* empty page placeholder, 2up */
155
- return isBackgroundClick;
156
- };
157
-
158
- /**
159
- * Main hook into toggle functionality
160
- * This is the only function that should be called by the event handlers
161
- *
162
- * @param { object } br - BookReader instance
163
- * @param { MouseEvent } e - JS event object
164
- * @param { boolean } atBookCenter - optional
165
- */
166
- const toggleRouter = function toggleRouter (br, e, atBookCenter) {
167
- if (holdOffOnToggle) {
168
- return;
169
- }
170
-
171
- const book = isBRcontainerScrollable() ? br.refs.$brContainer[0] : e.currentTarget;
172
- const is1UpMode = br.constMode1up === br.mode;
173
- const validBookClick = is1UpMode || isCenterClick(e, book);
174
- const isValidClickArea = atBookCenter ? validBookClick : isBackground(e.target);
175
- if (isValidClickArea) {
176
- toggleNav(br, atBookCenter);
177
-
178
- if (atBookCenter) {
179
- e.stopPropagation(); // don't turn the page. this takes prescendence
180
- }
181
- }
182
- }
183
-
184
- /**
185
- * background click event handler
186
- * @param { object } br - BookReader instance
187
- * @param { MouseEvent } e - JS event object
188
- */
189
- function onBackgroundClick(br, e) {
190
- toggleRouter(br, e);
191
- }
192
-
193
- /**
194
- * actual book container click event handler
195
- *
196
- * @param { object } br - BookReader instance
197
- * @param { MouseEvent } e - JS event object
198
- */
199
- function onBookClick(br, e) {
200
-
201
- const atBookCenter = true;
202
- toggleRouter(br, e, atBookCenter);
203
- }
204
-
205
- let initialX;
206
- let initialY;
207
- /**
208
- * attaches mouseup & mousedown event handlers to assess if user is dragging
209
- * sets `initialX`, `initialY`, and `holdOffOnToggle`
210
- */
211
- function registerDragHandlers() {
212
- const background = document.querySelector('.BookReader');
213
- if (!background) {
214
- return;
215
- }
216
-
217
- background.addEventListener('mousedown', function (e) {
218
- initialX = e.screenX;
219
- initialY = e.screenY;
220
-
221
- holdOffOnToggle = true;
222
- }, true);
223
- background.addEventListener('mouseup', function (e) {
224
- const isDrag = (Math.abs(initialX - e.screenX) > 5 || Math.abs(initialY - e.screenY) > 5);
225
-
226
- if (!isDrag) {
227
- holdOffOnToggle = false;
228
- initialX = 0;
229
- initialY = 0;
230
- }
231
- }, true);
232
- }
233
-
234
- /**
235
- * attaches click handlers to background & book
236
- * @param { object } br - BookReader instance
237
- */
238
- function registerClickHandlers(br) {
239
- const background = document.querySelector('.BookReader');
240
- if (!background) {
241
- return;
242
- }
243
-
244
- background.addEventListener('click', onBackgroundClick.bind(null, br), { capture: true, passive: true });
245
-
246
- const desk = document.querySelector('.BRcontainer') || {};
247
- const book = desk.firstChild;
248
-
249
- if (book) {
250
- book.addEventListener('click', onBookClick.bind(null, br), true);
251
- registerDragHandlers();
252
- }
253
- }
254
-
255
- /**
256
- * Install menu toggle
257
- * attaches event handlers, sets up DOM on load
258
- */
259
- const installMenuToggle = function installMenuToggle(br) {
260
- let hasNav = false;
261
-
262
- try {
263
- hasNav = br.navigationIsVisible();
264
- } catch (error) {
265
- hasNav = false;
266
- }
267
-
268
- if (!hasNav) {
269
- return;
270
- }
271
-
272
- const menuToggleEventRegister = function menuToggleEventRegister(e) {
273
- registerClickHandlers(br);
274
- };
275
-
276
- const setupDOMandHandlers = function setupDOMandHandlers(e) {
277
- setupNavForToggle(br);
278
- };
279
-
280
- const persistNav = function persistNav(e) {
281
- alwaysShowNav(br);
282
- };
283
-
284
- const whenToToggleNav = [
285
- 'BookReader:1PageViewSelected',
286
- 'BookReader:2PageViewSelected',
287
- 'BookReader:zoomIn',
288
- 'BookReader:zoomOut',
289
- 'BookReader:resize'
290
- ];
291
-
292
- const whenTolwaysShowNavWhen = [
293
- 'BookReader:3PageViewSelected'
294
- ];
295
-
296
- $(document).on(whenTolwaysShowNavWhen.join(' '), persistNav);
297
- $(document).on(whenToToggleNav.join(' '), menuToggleEventRegister);
298
- $(window).on('orientationchange', menuToggleEventRegister);
299
- $(document).on('BookReader:fullscreenToggled', setupDOMandHandlers);
300
- $(window).on('DOMContentLoaded', setupDOMandHandlers);
301
- setupDOMandHandlers();
302
- };
303
-
304
- /**
305
- * Add to BookReader
306
- */
307
- BookReader.prototype.setup = (function(super_) {
308
- return function(options) {
309
- super_.call(this, options);
310
- };
311
- })(BookReader.prototype.setup);
312
-
313
- /**
314
- * Initialize plugin
315
- */
316
- BookReader.prototype.init = (function(super_) {
317
- return function() {
318
- super_.call(this);
319
- if (this.options.enableMenuToggle) {
320
- installMenuToggle(this);
321
- }
322
- };
323
- })(BookReader.prototype.init);
324
- })();