@internetarchive/bookreader 5.0.0-88-alpha.11 → 5.0.0-89

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.
Files changed (243) hide show
  1. package/BookReader/BookReader.css +17 -3
  2. package/BookReader/BookReader.js +1 -1
  3. package/BookReader/BookReader.js.map +1 -1
  4. package/BookReader/ia-bookreader-bundle.js +87 -108
  5. package/BookReader/ia-bookreader-bundle.js.map +1 -1
  6. package/BookReader/plugins/plugin.archive_analytics.js +1 -1
  7. package/BookReader/plugins/plugin.archive_analytics.js.map +1 -1
  8. package/BookReader/plugins/plugin.autoplay.js +1 -1
  9. package/BookReader/plugins/plugin.autoplay.js.map +1 -1
  10. package/BookReader/plugins/plugin.iiif.js +1 -1
  11. package/BookReader/plugins/plugin.iiif.js.map +1 -1
  12. package/BookReader/plugins/plugin.resume.js +1 -1
  13. package/BookReader/plugins/plugin.resume.js.map +1 -1
  14. package/BookReader/plugins/plugin.search.js +1 -1
  15. package/BookReader/plugins/plugin.search.js.map +1 -1
  16. package/BookReader/plugins/plugin.text_selection.js +1 -1
  17. package/BookReader/plugins/plugin.text_selection.js.map +1 -1
  18. package/BookReader/plugins/plugin.tts.js +1 -1
  19. package/BookReader/plugins/plugin.tts.js.map +1 -1
  20. package/BookReader/plugins/plugin.url.js +1 -1
  21. package/BookReader/plugins/plugin.url.js.map +1 -1
  22. package/CHANGELOG.md +14 -0
  23. package/babel.config.js +12 -30
  24. package/codecov.yml +1 -1
  25. package/jsconfig.json +1 -3
  26. package/package.json +14 -16
  27. package/src/BookNavigator/search/search-results.js +1 -1
  28. package/src/BookReader/ImageCache.js +48 -15
  29. package/src/BookReader/Mode1UpLit.js +56 -86
  30. package/src/BookReader/Mode2UpLit.js +5 -5
  31. package/src/BookReader/Navbar/Navbar.js +53 -11
  32. package/src/BookReader/PageContainer.js +41 -22
  33. package/src/BookReader/options.js +27 -3
  34. package/src/BookReader/utils.js +10 -0
  35. package/src/BookReader.js +120 -21
  36. package/src/BookReaderPlugin.js +44 -0
  37. package/src/css/_BRnav.scss +0 -3
  38. package/src/css/_BRpages.scss +21 -2
  39. package/src/css/_controls.scss +4 -0
  40. package/src/plugins/plugin.archive_analytics.js +84 -78
  41. package/src/plugins/plugin.autoplay.js +98 -102
  42. package/src/plugins/plugin.chapters.js +17 -22
  43. package/src/plugins/plugin.iiif.js +16 -30
  44. package/src/plugins/plugin.resume.js +54 -51
  45. package/src/plugins/plugin.text_selection.js +68 -76
  46. package/src/plugins/tts/AbstractTTSEngine.js +2 -4
  47. package/src/plugins/tts/PageChunk.js +5 -9
  48. package/src/plugins/tts/PageChunkIterator.js +3 -5
  49. package/src/plugins/tts/plugin.tts.js +309 -329
  50. package/src/plugins/url/plugin.url.js +1 -1
  51. package/src/util/strings.js +1 -0
  52. package/tests/e2e/autoplay.test.js +8 -5
  53. package/tests/e2e/helpers/base.js +2 -2
  54. package/tests/e2e/helpers/mockSearch.js +6 -9
  55. package/tests/jest/BookReader/Navbar/Navbar.test.js +16 -3
  56. package/tests/jest/BookReader/PageContainer.test.js +96 -55
  57. package/tests/jest/BookReader/utils.test.js +21 -0
  58. package/tests/jest/BookReader.test.js +13 -12
  59. package/tests/jest/plugins/plugin.archive_analytics.test.js +8 -11
  60. package/tests/jest/plugins/plugin.autoplay.test.js +9 -22
  61. package/tests/jest/plugins/plugin.resume.test.js +19 -32
  62. package/tests/jest/plugins/plugin.text_selection.test.js +23 -24
  63. package/dist/esm/BookNavigator/assets/bookmark-colors.js +0 -4
  64. package/dist/esm/BookNavigator/assets/button-base.js +0 -4
  65. package/dist/esm/BookNavigator/assets/ia-logo.js +0 -4
  66. package/dist/esm/BookNavigator/assets/icon_checkmark.js +0 -8
  67. package/dist/esm/BookNavigator/assets/icon_close.js +0 -4
  68. package/dist/esm/BookNavigator/book-navigator.js +0 -612
  69. package/dist/esm/BookNavigator/bookmarks/bookmark-button.js +0 -35
  70. package/dist/esm/BookNavigator/bookmarks/bookmark-edit.js +0 -78
  71. package/dist/esm/BookNavigator/bookmarks/bookmarks-list.js +0 -160
  72. package/dist/esm/BookNavigator/bookmarks/bookmarks-loginCTA.js +0 -24
  73. package/dist/esm/BookNavigator/bookmarks/bookmarks-provider.js +0 -55
  74. package/dist/esm/BookNavigator/bookmarks/ia-bookmarks.js +0 -521
  75. package/dist/esm/BookNavigator/delete-modal-actions.js +0 -29
  76. package/dist/esm/BookNavigator/downloads/downloads-provider.js +0 -84
  77. package/dist/esm/BookNavigator/downloads/downloads.js +0 -69
  78. package/dist/esm/BookNavigator/search/search-provider.js +0 -238
  79. package/dist/esm/BookNavigator/search/search-results.js +0 -161
  80. package/dist/esm/BookNavigator/sharing.js +0 -26
  81. package/dist/esm/BookNavigator/viewable-files.js +0 -94
  82. package/dist/esm/BookNavigator/visual-adjustments/visual-adjustments-provider.js +0 -83
  83. package/dist/esm/BookNavigator/visual-adjustments/visual-adjustments.js +0 -131
  84. package/dist/esm/BookReader/BookModel.js +0 -575
  85. package/dist/esm/BookReader/DragScrollable.js +0 -224
  86. package/dist/esm/BookReader/ImageCache.js +0 -122
  87. package/dist/esm/BookReader/Mode1Up.js +0 -114
  88. package/dist/esm/BookReader/Mode1UpLit.js +0 -579
  89. package/dist/esm/BookReader/Mode2Up.js +0 -106
  90. package/dist/esm/BookReader/Mode2UpLit.js +0 -1020
  91. package/dist/esm/BookReader/ModeCoordinateSpace.js +0 -28
  92. package/dist/esm/BookReader/ModeSmoothZoom.js +0 -318
  93. package/dist/esm/BookReader/ModeThumb.js +0 -366
  94. package/dist/esm/BookReader/Navbar/Navbar.js +0 -253
  95. package/dist/esm/BookReader/PageContainer.js +0 -165
  96. package/dist/esm/BookReader/ReduceSet.js +0 -27
  97. package/dist/esm/BookReader/Toolbar/Toolbar.js +0 -242
  98. package/dist/esm/BookReader/events.js +0 -20
  99. package/dist/esm/BookReader/options.js +0 -331
  100. package/dist/esm/BookReader/utils/HTMLDimensionsCacher.js +0 -48
  101. package/dist/esm/BookReader/utils/ScrollClassAdder.js +0 -31
  102. package/dist/esm/BookReader/utils/SelectionObserver.js +0 -42
  103. package/dist/esm/BookReader/utils/classes.js +0 -37
  104. package/dist/esm/BookReader/utils.js +0 -315
  105. package/dist/esm/BookReader.js +0 -1828
  106. package/dist/esm/assets/icons/1up.svg +0 -12
  107. package/dist/esm/assets/icons/2up.svg +0 -15
  108. package/dist/esm/assets/icons/advance.svg +0 -26
  109. package/dist/esm/assets/icons/chevron-right.svg +0 -1
  110. package/dist/esm/assets/icons/close-circle-dark.svg +0 -1
  111. package/dist/esm/assets/icons/close-circle.svg +0 -1
  112. package/dist/esm/assets/icons/fullscreen.svg +0 -17
  113. package/dist/esm/assets/icons/fullscreen_exit.svg +0 -17
  114. package/dist/esm/assets/icons/hamburger.svg +0 -15
  115. package/dist/esm/assets/icons/left-arrow.svg +0 -12
  116. package/dist/esm/assets/icons/magnify-minus.svg +0 -12
  117. package/dist/esm/assets/icons/magnify-plus.svg +0 -13
  118. package/dist/esm/assets/icons/magnify.svg +0 -15
  119. package/dist/esm/assets/icons/pause.svg +0 -23
  120. package/dist/esm/assets/icons/play.svg +0 -22
  121. package/dist/esm/assets/icons/playback-speed.svg +0 -34
  122. package/dist/esm/assets/icons/read-aloud.svg +0 -22
  123. package/dist/esm/assets/icons/review.svg +0 -22
  124. package/dist/esm/assets/icons/thumbnails.svg +0 -17
  125. package/dist/esm/assets/icons/voice.svg +0 -1
  126. package/dist/esm/assets/icons/volume-full.svg +0 -22
  127. package/dist/esm/assets/images/BRicons.png +0 -0
  128. package/dist/esm/assets/images/BRicons.svg +0 -94
  129. package/dist/esm/assets/images/BRicons_ia.png +0 -0
  130. package/dist/esm/assets/images/back_pages.png +0 -0
  131. package/dist/esm/assets/images/book_bottom_icon.png +0 -0
  132. package/dist/esm/assets/images/book_down_icon.png +0 -0
  133. package/dist/esm/assets/images/book_left_icon.png +0 -0
  134. package/dist/esm/assets/images/book_leftmost_icon.png +0 -0
  135. package/dist/esm/assets/images/book_right_icon.png +0 -0
  136. package/dist/esm/assets/images/book_rightmost_icon.png +0 -0
  137. package/dist/esm/assets/images/book_top_icon.png +0 -0
  138. package/dist/esm/assets/images/book_up_icon.png +0 -0
  139. package/dist/esm/assets/images/books_graphic.svg +0 -177
  140. package/dist/esm/assets/images/booksplit.png +0 -0
  141. package/dist/esm/assets/images/control_pause_icon.png +0 -0
  142. package/dist/esm/assets/images/control_play_icon.png +0 -0
  143. package/dist/esm/assets/images/embed_icon.png +0 -0
  144. package/dist/esm/assets/images/icon-home-ia.png +0 -0
  145. package/dist/esm/assets/images/icon_OL-logo-xs.png +0 -0
  146. package/dist/esm/assets/images/icon_alert-xs.png +0 -0
  147. package/dist/esm/assets/images/icon_book.svg +0 -12
  148. package/dist/esm/assets/images/icon_bookmark.svg +0 -12
  149. package/dist/esm/assets/images/icon_close-pop.png +0 -0
  150. package/dist/esm/assets/images/icon_download.png +0 -0
  151. package/dist/esm/assets/images/icon_gear.svg +0 -14
  152. package/dist/esm/assets/images/icon_hamburger.svg +0 -20
  153. package/dist/esm/assets/images/icon_home.png +0 -0
  154. package/dist/esm/assets/images/icon_home.svg +0 -21
  155. package/dist/esm/assets/images/icon_home_ia.png +0 -0
  156. package/dist/esm/assets/images/icon_indicator.png +0 -0
  157. package/dist/esm/assets/images/icon_info.svg +0 -11
  158. package/dist/esm/assets/images/icon_one_page.svg +0 -8
  159. package/dist/esm/assets/images/icon_pause.svg +0 -1
  160. package/dist/esm/assets/images/icon_play.svg +0 -1
  161. package/dist/esm/assets/images/icon_playback-rate.svg +0 -15
  162. package/dist/esm/assets/images/icon_return.png +0 -0
  163. package/dist/esm/assets/images/icon_search_button.svg +0 -8
  164. package/dist/esm/assets/images/icon_share.svg +0 -9
  165. package/dist/esm/assets/images/icon_skip-ahead.svg +0 -6
  166. package/dist/esm/assets/images/icon_skip-back.svg +0 -13
  167. package/dist/esm/assets/images/icon_speaker.svg +0 -18
  168. package/dist/esm/assets/images/icon_speaker_open.svg +0 -10
  169. package/dist/esm/assets/images/icon_thumbnails.svg +0 -12
  170. package/dist/esm/assets/images/icon_toc.svg +0 -5
  171. package/dist/esm/assets/images/icon_two_pages.svg +0 -9
  172. package/dist/esm/assets/images/icon_zoomer.png +0 -0
  173. package/dist/esm/assets/images/loading.gif +0 -0
  174. package/dist/esm/assets/images/logo_icon.png +0 -0
  175. package/dist/esm/assets/images/marker_chap-off.png +0 -0
  176. package/dist/esm/assets/images/marker_chap-off.svg +0 -11
  177. package/dist/esm/assets/images/marker_chap-off_ia.png +0 -0
  178. package/dist/esm/assets/images/marker_chap-on.png +0 -0
  179. package/dist/esm/assets/images/marker_chap-on.svg +0 -11
  180. package/dist/esm/assets/images/marker_srch-on.svg +0 -11
  181. package/dist/esm/assets/images/marker_srchchap-off.png +0 -0
  182. package/dist/esm/assets/images/marker_srchchap-on.png +0 -0
  183. package/dist/esm/assets/images/nav_control-dn.png +0 -0
  184. package/dist/esm/assets/images/nav_control-dn_ia.png +0 -0
  185. package/dist/esm/assets/images/nav_control-up.png +0 -0
  186. package/dist/esm/assets/images/nav_control-up_ia.png +0 -0
  187. package/dist/esm/assets/images/nav_control.png +0 -0
  188. package/dist/esm/assets/images/one_page_mode_icon.png +0 -0
  189. package/dist/esm/assets/images/paper-badge.png +0 -0
  190. package/dist/esm/assets/images/print_icon.png +0 -0
  191. package/dist/esm/assets/images/progressbar.gif +0 -0
  192. package/dist/esm/assets/images/right_edges.png +0 -0
  193. package/dist/esm/assets/images/slider.png +0 -0
  194. package/dist/esm/assets/images/slider_ia.png +0 -0
  195. package/dist/esm/assets/images/thumbnail_mode_icon.png +0 -0
  196. package/dist/esm/assets/images/transparent.png +0 -0
  197. package/dist/esm/assets/images/two_page_mode_icon.png +0 -0
  198. package/dist/esm/assets/images/unviewable_page.png +0 -0
  199. package/dist/esm/assets/images/zoom_in_icon.png +0 -0
  200. package/dist/esm/assets/images/zoom_out_icon.png +0 -0
  201. package/dist/esm/css/BookReader.scss +0 -85
  202. package/dist/esm/css/_BRBookmarks.scss +0 -29
  203. package/dist/esm/css/_BRComponent.scss +0 -13
  204. package/dist/esm/css/_BRfloat.scss +0 -197
  205. package/dist/esm/css/_BRicon.scss +0 -54
  206. package/dist/esm/css/_BRmain.scss +0 -262
  207. package/dist/esm/css/_BRnav.scss +0 -354
  208. package/dist/esm/css/_BRpages.scss +0 -213
  209. package/dist/esm/css/_BRsearch.scss +0 -268
  210. package/dist/esm/css/_BRtoolbar.scss +0 -84
  211. package/dist/esm/css/_BRvendor.scss +0 -5
  212. package/dist/esm/css/_TextSelection.scss +0 -108
  213. package/dist/esm/css/_colorbox.scss +0 -52
  214. package/dist/esm/css/_controls.scss +0 -257
  215. package/dist/esm/css/_icons.scss +0 -121
  216. package/dist/esm/ia-bookreader/ia-bookreader.js +0 -141
  217. package/dist/esm/jquery-wrapper.js +0 -3
  218. package/dist/esm/plugins/plugin.archive_analytics.js +0 -72
  219. package/dist/esm/plugins/plugin.autoplay.js +0 -119
  220. package/dist/esm/plugins/plugin.chapters.js +0 -288
  221. package/dist/esm/plugins/plugin.iframe.js +0 -44
  222. package/dist/esm/plugins/plugin.iiif.js +0 -146
  223. package/dist/esm/plugins/plugin.resume.js +0 -66
  224. package/dist/esm/plugins/plugin.text_selection.js +0 -621
  225. package/dist/esm/plugins/plugin.vendor-fullscreen.js +0 -227
  226. package/dist/esm/plugins/search/plugin.search.js +0 -499
  227. package/dist/esm/plugins/search/utils.js +0 -42
  228. package/dist/esm/plugins/search/view.js +0 -360
  229. package/dist/esm/plugins/tts/AbstractTTSEngine.js +0 -282
  230. package/dist/esm/plugins/tts/FestivalTTSEngine.js +0 -192
  231. package/dist/esm/plugins/tts/PageChunk.js +0 -105
  232. package/dist/esm/plugins/tts/PageChunkIterator.js +0 -155
  233. package/dist/esm/plugins/tts/WebTTSEngine.js +0 -364
  234. package/dist/esm/plugins/tts/plugin.tts.js +0 -315
  235. package/dist/esm/plugins/tts/tooltip_dict.js +0 -14
  236. package/dist/esm/plugins/tts/utils.js +0 -79
  237. package/dist/esm/plugins/url/UrlPlugin.js +0 -197
  238. package/dist/esm/plugins/url/plugin.url.js +0 -212
  239. package/dist/esm/util/browserSniffing.js +0 -56
  240. package/dist/esm/util/debouncer.js +0 -25
  241. package/dist/esm/util/docCookies.js +0 -75
  242. package/dist/esm/util/strings.js +0 -34
  243. package/index.js +0 -2
@@ -1,83 +0,0 @@
1
- var _templateObject, _templateObject2;
2
- function _taggedTemplateLiteral(e, t) { return t || (t = e.slice(0)), Object.freeze(Object.defineProperties(e, { raw: { value: Object.freeze(t) } })); }
3
- import { html } from 'lit';
4
- import '@internetarchive/icon-visual-adjustment/icon-visual-adjustment';
5
- import './visual-adjustments';
6
- var visualAdjustmentOptions = [{
7
- id: 'brightness',
8
- name: 'Adjust brightness',
9
- active: false,
10
- min: 0,
11
- max: 150,
12
- step: 1,
13
- value: 100
14
- }, {
15
- id: 'contrast',
16
- name: 'Adjust contrast',
17
- active: false,
18
- min: 0,
19
- max: 150,
20
- step: 1,
21
- value: 100
22
- }, {
23
- id: 'invert',
24
- name: 'Invert colors (dark mode)',
25
- active: false
26
- }, {
27
- id: 'grayscale',
28
- name: 'Convert to grayscale',
29
- active: false
30
- }];
31
- export default class VisualAdjustmentsProvider {
32
- constructor(options) {
33
- var {
34
- onProviderChange,
35
- bookreader
36
- } = options;
37
- this.onProviderChange = onProviderChange;
38
- this.bookContainer = bookreader.refs.$brContainer;
39
- this.bookreader = bookreader;
40
- this.onAdjustmentChange = this.onAdjustmentChange.bind(this);
41
- this.optionUpdateComplete = this.optionUpdateComplete.bind(this);
42
- this.updateOptionsCount = this.updateOptionsCount.bind(this);
43
- this.onZoomIn = this.onZoomIn.bind(this);
44
- this.onZoomOut = this.onZoomOut.bind(this);
45
- this.activeCount = 0;
46
- this.icon = html(_templateObject || (_templateObject = _taggedTemplateLiteral(["<ia-icon-visual-adjustment style=\"width: var(--iconWidth); height: var(--iconHeight);\"></ia-icon-visual-adjustment>"])));
47
- this.label = 'Visual Adjustments';
48
- this.menuDetails = this.updateOptionsCount();
49
- this.id = 'adjustment';
50
- this.component = html(_templateObject2 || (_templateObject2 = _taggedTemplateLiteral(["\n <ia-book-visual-adjustments\n .options=", "\n @visualAdjustmentOptionChanged=", "\n @visualAdjustmentZoomIn=", "\n @visualAdjustmentZoomOut=", "\n ></ia-book-visual-adjustments>\n "])), visualAdjustmentOptions, this.onAdjustmentChange, this.onZoomIn, this.onZoomOut);
51
- }
52
- onZoomIn() {
53
- this.bookreader.zoom(1);
54
- }
55
- onZoomOut() {
56
- this.bookreader.zoom(-1);
57
- }
58
- onAdjustmentChange(event) {
59
- var {
60
- detail
61
- } = event;
62
- var adjustments = {
63
- brightness: value => "brightness(".concat(value, "%)"),
64
- contrast: value => "contrast(".concat(value, "%)"),
65
- grayscale: () => 'grayscale(100%)',
66
- invert: () => 'invert(100%)'
67
- };
68
- var filters = detail.options.reduce((values, option) => {
69
- var newValue = "".concat(option.active ? adjustments[option.id](option.value) : '');
70
- return newValue ? [...values, newValue] : values;
71
- }, []).join(' ');
72
- this.bookContainer.css('filter', filters);
73
- this.optionUpdateComplete(event);
74
- }
75
- optionUpdateComplete(event) {
76
- this.activeCount = event.detail.activeCount;
77
- this.updateOptionsCount(event);
78
- this.onProviderChange();
79
- }
80
- updateOptionsCount() {
81
- this.menuDetails = "(".concat(this.activeCount, " active)");
82
- }
83
- }
@@ -1,131 +0,0 @@
1
- var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7;
2
- function _taggedTemplateLiteral(e, t) { return t || (t = e.slice(0)), Object.freeze(Object.defineProperties(e, { raw: { value: Object.freeze(t) } })); }
3
- import { css, html, LitElement } from "lit";
4
- import { repeat } from "lit/directives/repeat.js";
5
- import { nothing } from "lit";
6
- import checkmarkIcon from '../assets/icon_checkmark.js';
7
- import "@internetarchive/icon-magnify-minus/icon-magnify-minus";
8
- import "@internetarchive/icon-magnify-plus/icon-magnify-plus";
9
- var namespacedEvent = eventName => "visualAdjustment".concat(eventName);
10
- var events = {
11
- optionChange: namespacedEvent("OptionChanged"),
12
- zoomIn: namespacedEvent("ZoomIn"),
13
- zoomOut: namespacedEvent("ZoomOut")
14
- };
15
- export class IABookVisualAdjustments extends LitElement {
16
- static get properties() {
17
- return {
18
- activeCount: {
19
- type: Number
20
- },
21
- options: {
22
- type: Array
23
- },
24
- renderHeader: {
25
- type: Boolean
26
- },
27
- showZoomControls: {
28
- type: Boolean
29
- }
30
- };
31
- }
32
- constructor() {
33
- super();
34
- this.activeCount = 0;
35
- this.options = [];
36
- this.renderHeader = false;
37
- this.showZoomControls = true;
38
- }
39
- firstUpdated() {
40
- this.activeCount = this.activeOptions.length;
41
- this.emitOptionChangedEvent();
42
- }
43
-
44
- /** Gets list of active options
45
- * @return array
46
- */
47
- get activeOptions() {
48
- return this.options.reduce((results, option) => option.active ? [...results, option.id] : results, []);
49
- }
50
-
51
- /**
52
- * Returns blob that will be emitted by event
53
- */
54
- prepareEventDetails() {
55
- var changedOptionId = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : "";
56
- return {
57
- options: this.options,
58
- activeCount: this.activeCount,
59
- changedOptionId
60
- };
61
- }
62
-
63
- /**
64
- * Fires custom event when options change
65
- * Provides state details: { options, activeCount, changedOptionId }
66
- *
67
- * @param { string } changedOptionId
68
- */
69
- emitOptionChangedEvent() {
70
- var changedOptionId = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : "";
71
- var detail = this.prepareEventDetails(changedOptionId);
72
- this.dispatchEvent(new CustomEvent(events.optionChange, {
73
- bubbles: true,
74
- composed: true,
75
- detail
76
- }));
77
- }
78
- emitZoomIn() {
79
- this.dispatchEvent(new CustomEvent(events.zoomIn));
80
- }
81
- emitZoomOut() {
82
- this.dispatchEvent(new CustomEvent(events.zoomOut));
83
- }
84
-
85
- /**
86
- * Updates adjustment & component state
87
- * updates params of available ajdustment options list
88
- * updates active adjustment count
89
- * triggers custom event
90
- * @param { string } optionName
91
- */
92
- changeActiveStateFor(optionName) {
93
- var updatedOptions = [...this.options];
94
- var checkedOption = updatedOptions.find(option => option.id === optionName);
95
- checkedOption.active = !checkedOption.active;
96
- this.options = updatedOptions;
97
- this.activeCount = this.activeOptions.length;
98
- this.emitOptionChangedEvent(checkedOption.id);
99
- }
100
- setRangeValue(id, value) {
101
- var updatedOptions = [...this.options];
102
- updatedOptions.find(o => o.id === id).value = value;
103
- this.options = [...updatedOptions];
104
- }
105
-
106
- /* render */
107
- rangeSlider(option) {
108
- return html(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n <div class=", ">\n <input\n type=\"range\"\n name=\"", "_range\"\n min=", "\n max=", "\n step=", "\n .value=", "\n @input=", "\n @change=", "\n />\n <p>", "%</p>\n </div>\n "])), "range".concat(option.active ? " visible" : ""), option.id, option.min || 0, option.max || 100, option.step || 1, option.value, e => this.setRangeValue(option.id, e.target.value), () => this.emitOptionChangedEvent(), option.value);
109
- }
110
- adjustmentCheckbox(option) {
111
- var formID = "adjustment_".concat(option.id);
112
- return html(_templateObject2 || (_templateObject2 = _taggedTemplateLiteral(["<li>\n <label for=\"", "\">\n <span class=\"name\">", "</span>\n <input\n type=\"checkbox\"\n name=\"", "\"\n id=\"", "\"\n @change=", "\n ?checked=", "\n />\n <span class=\"icon\"></span>\n </label>\n ", "\n </li>"])), formID, option.name, formID, formID, () => this.changeActiveStateFor(option.id), option.active, option.value !== undefined ? this.rangeSlider(option) : nothing);
113
- }
114
- get headerSection() {
115
- var activeAdjustments = this.activeCount ? html(_templateObject3 || (_templateObject3 = _taggedTemplateLiteral(["<p>(", " active)</p>"])), this.activeCount) : nothing;
116
- var header = html(_templateObject4 || (_templateObject4 = _taggedTemplateLiteral(["<header>\n <h3>Visual adjustments</h3>\n ", "\n </header>"])), activeAdjustments);
117
- return this.renderHeader ? header : nothing;
118
- }
119
- get zoomControls() {
120
- return html(_templateObject5 || (_templateObject5 = _taggedTemplateLiteral(["\n <h4>Adjust zoom</h4>\n <button class=\"zoom_out\" @click=", " title=\"zoom out\">\n <ia-icon-magnify-minus></ia-icon-magnify-minus>\n </button>\n <button class=\"zoom_in\" @click=", " title=\"zoom in\">\n <ia-icon-magnify-plus></ia-icon-magnify-plus>\n </button>\n "])), this.emitZoomOut, this.emitZoomIn);
121
- }
122
-
123
- /** @inheritdoc */
124
- render() {
125
- return html(_templateObject6 || (_templateObject6 = _taggedTemplateLiteral(["\n ", "\n <ul>\n ", "\n </ul>\n ", "\n "])), this.headerSection, repeat(this.options, option => option.id, this.adjustmentCheckbox.bind(this)), this.showZoomControls ? this.zoomControls : nothing);
126
- }
127
- static get styles() {
128
- return css(_templateObject7 || (_templateObject7 = _taggedTemplateLiteral(["\n :host {\n display: block;\n height: 100%;\n overflow-y: auto;\n font-size: 1.4rem;\n box-sizing: border-box;\n }\n\n header {\n display: flex;\n align-items: baseline;\n }\n\n h3 {\n padding: 0;\n margin: 0 1rem 0 0;\n font-size: 1.6rem;\n }\n\n header p {\n padding: 0;\n margin: 0;\n font-size: 1.2rem;\n font-weight: bold;\n font-style: italic;\n }\n\n ul {\n padding: 1rem 2rem 0 0;\n list-style: none;\n margin-top: 0;\n }\n\n [type=\"checkbox\"] {\n display: none;\n }\n\n label {\n display: flex;\n justify-content: space-between;\n align-items: baseline;\n font-size: 1.4rem;\n font-weight: bold;\n line-height: 150%;\n vertical-align: middle;\n }\n\n .icon {\n display: inline-block;\n width: 14px;\n height: 14px;\n margin-left: .7rem;\n border: 1px solid var(--primaryTextColor);\n border-radius: 2px;\n background: var(--activeButtonBg) 50% 50% no-repeat;\n }\n :checked + .icon {\n background-image: url('", "');\n }\n\n .range {\n display: none;\n padding-top: .5rem;\n }\n .range.visible {\n display: flex;\n }\n\n .range p {\n margin-left: 1rem;\n }\n\n h4 {\n padding: 1rem 0;\n margin: 0;\n font-size: 1.4rem;\n }\n\n button {\n -webkit-appearance: none;\n appearance: none;\n border: none;\n border-radius: 0;\n background: transparent;\n outline: none;\n cursor: pointer;\n --iconFillColor: var(--primaryTextColor);\n --iconStrokeColor: var(--primaryTextColor);\n height: 4rem;\n width: 4rem;\n }\n\n button * {\n display: inline-block;\n }"])), checkmarkIcon);
129
- }
130
- }
131
- customElements.define('ia-book-visual-adjustments', IABookVisualAdjustments);