@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,17 +0,0 @@
1
- import { runBaseTests } from '../helpers/base';
2
- import BookReader from '../models/BookReader';
3
-
4
- const localURL = 'https://archive.org/details/';
5
- const books = [
6
- 'birdbookillustra00reedrich', // publicDomain
7
- // 'pianoservicingtu00rebl_0', // borrowable,
8
- // 'adventuresoftoms00twaiiala', // has chapter markers
9
- // 'gendaitankashu00meijuoft', // Right to Left book
10
- // 'gov.uspto.patents.application.10074026', // multiple files
11
- ];
12
-
13
- books.forEach(function(page) {
14
- const url = `${localURL}${page}`;
15
- fixture `Archive.org BR Base Tests for: ${page}`.page `${url}`;
16
- runBaseTests(new BookReader());
17
- });
@@ -1,132 +0,0 @@
1
- import {
2
- html,
3
- elementUpdated,
4
- fixtureCleanup,
5
- fixtureSync,
6
- expect,
7
- } from '@open-wc/testing';
8
- import sinon from 'sinon';
9
-
10
- import '../../../src/BookNavigator/BookNavigator.js';
11
- import BRFullscreenMgr from '../../../src/BookNavigator/br-fullscreen-mgr.js';
12
-
13
- const container = () => {
14
- const item = {};
15
- return html`
16
- <book-navigator
17
- .item=${item}
18
- .baseHost
19
- >
20
- <div slot="bookreader">
21
- <p class="visible-in-reader">now showing</p>
22
- <div>
23
- <p class="bunny">foo</p>
24
- </
25
- `;
26
- }
27
-
28
- beforeEach(() => {
29
- const body = document.querySelector('body');
30
- const brHook = document.createElement('div');
31
- brHook.setAttribute('id', 'BookReader');
32
- body.appendChild(brHook);
33
- });
34
-
35
- afterEach(() => {
36
- window.br = null;
37
- fixtureCleanup();
38
- });
39
-
40
-
41
- describe('<book-navigator>', () => {
42
- describe('first update', () => {
43
- it('binds global event listeners', async () => {
44
- const el = fixtureSync(container());
45
- const spy = sinon.spy(el, 'bindEventListeners');
46
- await elementUpdated(el);
47
- expect(spy.callCount).to.equal(1);
48
- });
49
- it('emits a BrBookNav:PostInit event', async () => {
50
- let initEventFired = false;
51
- window.addEventListener('BrBookNav:PostInit', (e) => {
52
- initEventFired = true;
53
- });
54
- const el = fixtureSync(container());
55
- const spy = sinon.spy(el, 'emitPostInit');
56
- await elementUpdated(el);
57
-
58
- expect(initEventFired).to.be.true;
59
- expect(spy.callCount).to.equal(1);
60
- });
61
- });
62
-
63
- it('handles global event: BookReader:PostInit', async () => {
64
- const setTimeoutSpy = sinon.spy(window, 'setTimeout');
65
- const brStub = {
66
- resize: sinon.fake(),
67
- currentIndex: sinon.fake(),
68
- jumpToIndex: sinon.fake(),
69
- el: '#BookReader'
70
- };
71
-
72
- const el = fixtureSync(container());
73
- const initializeBookSubmenus = sinon.spy(el, 'initializeBookSubmenus');
74
-
75
- await elementUpdated(el);
76
- window.dispatchEvent(new CustomEvent('BookReader:PostInit', {
77
- detail: { props: brStub }
78
- }));
79
- await elementUpdated(el);
80
-
81
- expect(initializeBookSubmenus.callCount).to.equal(1);
82
- expect(el.bookreader).to.equal(brStub); // sets bookreader
83
- expect(el.bookReaderLoaded).to.be.true; // notes bookreader is loaded
84
- expect(el.bookReaderCannotLoad).to.be.false;
85
- expect(el.fullscreenMgr).to.an.instanceof(BRFullscreenMgr);
86
- expect(el.brResizeObserver).to.an.instanceof(window.ResizeObserver);
87
- expect(setTimeoutSpy.callCount).to.equal(1); // resizes at end
88
- });
89
-
90
- it('resizes bookreader when side menu toggles', async () => {
91
- const el = fixtureSync(container());
92
- const brStub = {
93
- resize: sinon.fake(),
94
- currentIndex: sinon.fake(),
95
- jumpToIndex: sinon.fake()
96
- }
97
- el.bookreader = brStub;
98
- await elementUpdated(el);
99
-
100
- el.sideMenuOpen = true;
101
- await elementUpdated(el);
102
-
103
- expect(el.bookreader.resize.callCount).to.equal(1);
104
- expect(el.bookreader.currentIndex.callCount).to.equal(1);
105
- expect(el.bookreader.jumpToIndex.callCount).to.equal(1);
106
-
107
- el.sideMenuOpen = false;
108
- await elementUpdated(el);
109
-
110
- expect(el.bookreader.resize.callCount).to.equal(2);
111
- expect(el.bookreader.currentIndex.callCount).to.equal(2);
112
- expect(el.bookreader.jumpToIndex.callCount).to.equal(2);
113
- });
114
- it('does not resize bookreader if animating', async () => {
115
- const el = fixtureSync(container());
116
- const brStub = {
117
- animating: true, // <-- testing for this
118
- resize: sinon.fake(),
119
- currentIndex: sinon.fake(),
120
- jumpToIndex: sinon.fake()
121
- }
122
- el.bookreader = brStub;
123
- await elementUpdated(el);
124
-
125
- el.sideMenuOpen = true;
126
- await elementUpdated(el);
127
-
128
- expect(el.bookreader.resize.callCount).to.equal(0);
129
- expect(el.bookreader.currentIndex.callCount).to.equal(0);
130
- expect(el.bookreader.jumpToIndex.callCount).to.equal(0);
131
- });
132
- });
@@ -1,201 +0,0 @@
1
- import {
2
- html,
3
- fixture,
4
- expect,
5
- oneEvent,
6
- } from '@open-wc/testing';
7
- import sinon from 'sinon';
8
- import { IABookVisualAdjustments } from '../../../src/BookNavigator/visual-adjustments/visual-adjustments.js';
9
-
10
- const options = [{
11
- id: 'contrast',
12
- name: 'Adjust contrast',
13
- active: true,
14
- min: 0,
15
- max: 150,
16
- step: 1,
17
- value: 100,
18
- }, {
19
- id: 'invert',
20
- name: 'Invert colors',
21
- active: false,
22
- }, {
23
- id: 'brightness',
24
- name: 'Adjust brightness',
25
- active: false,
26
- value: 100,
27
- }];
28
-
29
- const container = (renderHeader = false) => (
30
- html`<ia-book-visual-adjustments .options=${options} ?renderHeader=${renderHeader}></ia-book-visual-adjustments>`
31
- );
32
-
33
- describe('<ia-book-visual-adjustments>', () => {
34
- afterEach(() => {
35
- sinon.restore();
36
- });
37
-
38
- it('sets default properties', async () => {
39
- const el = await fixture(container());
40
-
41
- expect(el.options).to.exist;
42
- expect(el.options.length).to.equal(options.length);
43
- expect(el.renderHeader).to.exist;
44
- expect(el.renderHeader).to.be.false;
45
- expect(el.activeCount).to.exist;
46
- expect(el.showZoomControls).to.be.true;
47
- });
48
-
49
- it('renders all properties of a visual adjustment option', async () => {
50
- const el = await fixture(container());
51
-
52
- await el.updateComplete;
53
-
54
- const label = el.shadowRoot.querySelector('label');
55
- const name = label.querySelector('.name');
56
- const checkbox = label.querySelector('input');
57
- expect(name.innerText).to.equal(options[0].name);
58
- expect(checkbox.checked).to.equal(true);
59
- });
60
-
61
- it('can render header with active options count', async () => {
62
- const renderHeader = true;
63
- const el = await fixture(container(renderHeader));
64
- expect(el.shadowRoot.querySelector('header p').innerText).to.include('1');
65
- });
66
-
67
- it('does not render active options count element when none are selected', async () => {
68
- const el = await fixture(container());
69
-
70
- el.options = [options[1]];
71
- await el.updateComplete;
72
-
73
- expect(el.shadowRoot.querySelector('header p')).not.to.exist;
74
- });
75
-
76
- it('changes option\'s active state when input changed', async () => {
77
- const el = await fixture(container());
78
-
79
- el.shadowRoot.querySelector('li input').dispatchEvent(new Event('change'));
80
- await el.updateComplete;
81
-
82
- expect(el.options[0].active).to.equal(false);
83
- });
84
-
85
- it('renders zoom in and out controls when enabled', async () => {
86
- const el = await fixture(container());
87
-
88
- expect(el.shadowRoot.querySelector('.zoom_out')).to.exist;
89
- expect(el.shadowRoot.querySelector('.zoom_in')).to.exist;
90
- });
91
-
92
- it('does not render zoom controls when disabled', async () => {
93
- const el = await fixture(container());
94
-
95
- el.showZoomControls = false;
96
- await el.updateComplete;
97
-
98
- expect(el.shadowRoot.querySelector('.zoom_out')).not.to.exist;
99
- expect(el.shadowRoot.querySelector('.zoom_in')).not.to.exist;
100
- });
101
-
102
- describe('Custom events', () => {
103
- it('prepareEventDetails returns proper params', async () => {
104
- const el = await fixture(container());
105
- await el.updateComplete;
106
- const params = el.prepareEventDetails();
107
-
108
- expect(params.activeCount).to.exist;
109
- expect(typeof (params.activeCount)).to.be.equal('number');
110
- expect(params.changedOptionId).to.exist;
111
- expect(typeof (params.changedOptionId)).to.be.equal('string');
112
- expect(params.options).to.exist;
113
- expect(params.options.length).to.exist;
114
- expect(params.options.length).to.be.greaterThan(0);
115
- });
116
- it('emitOptionChangedEvent calls for the params', async () => {
117
- IABookVisualAdjustments.prototype.prepareEventDetails = sinon.fake();
118
- const el = await fixture(container());
119
- await el.updateComplete;
120
-
121
- expect(el.prepareEventDetails.callCount).to.equal(1);
122
- });
123
- it('triggers an emitOptionChangedEvent event at firstUpdate', async () => {
124
- IABookVisualAdjustments.prototype.emitOptionChangedEvent = sinon.fake();
125
- const el = await fixture(container());
126
-
127
- expect(el.emitOptionChangedEvent.callCount).to.equal(1);
128
- });
129
-
130
- it('triggers an emitOptionChangedEvent event when a checkbox\'s change event fires', async () => {
131
- IABookVisualAdjustments.prototype.emitOptionChangedEvent = sinon.fake();
132
- const el = await fixture(container());
133
-
134
- expect(el.emitOptionChangedEvent.callCount).to.equal(1); // firstUpdate fire
135
-
136
- el.shadowRoot.querySelector('li input').dispatchEvent(new Event('change'));
137
- expect(el.emitOptionChangedEvent.callCount).to.equal(2);
138
- });
139
-
140
- it('triggers an emitOptionChangedEvent event when a range\'s change event fires', async () => {
141
- IABookVisualAdjustments.prototype.emitOptionChangedEvent = sinon.fake();
142
-
143
- const el = await fixture(container());
144
- expect(el.emitOptionChangedEvent.callCount).to.equal(1); // firstUpdate fire
145
-
146
- el.shadowRoot.querySelector('[name="brightness_range"]').dispatchEvent(new Event('change'));
147
- expect(el.emitOptionChangedEvent.callCount).to.equal(2);
148
- });
149
-
150
- it('emits a zoom out event when zoom out button clicked', async () => {
151
- const el = await fixture(container());
152
-
153
- setTimeout(() => (
154
- el.shadowRoot.querySelector('.zoom_out').click()
155
- ));
156
- const response = await oneEvent(el, 'visualAdjustmentZoomOut');
157
-
158
- expect(response).to.exist;
159
- });
160
-
161
- it('emits a zoom in event when zoom in button clicked', async () => {
162
- const el = await fixture(container());
163
-
164
- setTimeout(() => (
165
- el.shadowRoot.querySelector('.zoom_in').click()
166
- ));
167
- const response = await oneEvent(el, 'visualAdjustmentZoomIn');
168
-
169
- expect(response).to.exist;
170
- });
171
- });
172
-
173
- it('sets range defaults when none supplied', async () => {
174
- const el = await fixture(container());
175
- const brightnessRange = el.shadowRoot.querySelector('[name="brightness_range"]');
176
-
177
- expect(brightnessRange.getAttribute('min')).to.equal('0');
178
- expect(brightnessRange.getAttribute('max')).to.equal('100');
179
- expect(brightnessRange.getAttribute('step')).to.equal('1');
180
- });
181
-
182
- it('sets the updated range value on the options prop', async () => {
183
- const el = await fixture(container());
184
- const { id } = options[0];
185
- const newValue = 120;
186
-
187
- el.setRangeValue(id, newValue);
188
- await el.updateComplete;
189
-
190
- expect(el.options[0].value).to.equal(newValue);
191
- });
192
-
193
- it('triggers a setRangeValue event when a range\'s input event fires', async () => {
194
- IABookVisualAdjustments.prototype.setRangeValue = sinon.fake();
195
-
196
- const el = await fixture(container());
197
-
198
- el.shadowRoot.querySelector('[name="brightness_range"]').dispatchEvent(new Event('input'));
199
- expect(el.setRangeValue.callCount).to.equal(1);
200
- });
201
- });
@@ -1,68 +0,0 @@
1
-
2
- import BookReader from '../../../src/BookReader.js';
3
- import '../../../src/plugins/menu_toggle/plugin.menu_toggle.js';
4
-
5
-
6
- let br;
7
- let hideFlag;
8
- beforeAll(() => {
9
- $.fx.off = true;
10
- const OGSpeed = $.speed;
11
- $.speed = function(_speed, easing, callback) {
12
- return OGSpeed(0, easing, callback);
13
- };
14
- document.body.innerHTML = '<div id="BookReader">';
15
- br = new BookReader();
16
- br.init();
17
- });
18
-
19
- afterEach(() => {
20
- $.fx.off = false;
21
- jest.clearAllMocks();
22
- });
23
-
24
- describe('Plugin: Menu Toggle', () => {
25
- test('has option flag', () => {
26
- expect(BookReader.defaultOptions.enableMenuToggle).toEqual(true);
27
- });
28
-
29
- test('core code has animation consts', () => {
30
- expect(BookReader.constNavAnimationDuration).toEqual(300);
31
- expect(BookReader.constResizeAnimationDuration).toEqual(100);
32
- })
33
-
34
- test('core code has registered event: `navToggled`', () => {
35
- expect(BookReader.eventNames.navToggled).toBeTruthy();
36
- })
37
-
38
- test('when bookreader loads, the menu shows', () => {
39
- expect($('.BRfooter').hasClass('js-menu-hide')).toEqual(false);
40
- expect($('.BRtoolbar').hasClass('js-menu-hide')).toEqual(false);
41
- })
42
-
43
- test('clicking on background hides the menu', () => {
44
- expect($('.BRfooter').hasClass('js-menu-hide')).toEqual(false);
45
- expect($('.BRtoolbar').hasClass('js-menu-hide')).toEqual(false);
46
- $('.BRcontainer').click();
47
- expect($('.BRfooter').hasClass('js-menu-hide')).toEqual(true);
48
- expect($('.BRtoolbar').hasClass('js-menu-hide')).toEqual(true);
49
- });
50
-
51
- test('core function `setNavigationView` is called `hideNavigation` is called', () => {
52
- br.setNavigationView = jest.fn((arg) => hideFlag = arg);
53
-
54
- br.hideNavigation();
55
- expect(br.setNavigationView).toHaveBeenCalled();
56
- expect(hideFlag).toEqual(true);
57
- });
58
-
59
- test('core function `setNavigationView` is called `showNavigation` is called', () => {
60
- br.setNavigationView = jest.fn((arg) => hideFlag = arg);
61
- br.navigationIsVisible = jest.fn(() => false);
62
-
63
- br.showNavigation();
64
- expect(br.setNavigationView).toHaveBeenCalled();
65
- expect(br.navigationIsVisible).toHaveBeenCalled();
66
- expect(hideFlag).toEqual(undefined);
67
- });
68
- });
@@ -1,15 +0,0 @@
1
- import * as docCookies from '../../src/util/docCookies.js';
2
-
3
- afterEach(() => {
4
- jest.clearAllMocks();
5
- });
6
-
7
- describe('Helper function: set and get cookie item', () => {
8
- test('set cookie item value', () => {
9
- expect(docCookies.setItem('test-cookie', 'jack-sparow')).toBeTruthy();
10
- });
11
-
12
- test('get cookie item value', () => {
13
- expect(docCookies.getItem('test-cookie')).toEqual('jack-sparow');
14
- });
15
- });