@internetarchive/bookreader 5.0.0-88-alpha.7 → 5.0.0-88-alpha.9

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 (183) hide show
  1. package/babel.config.js +30 -12
  2. package/dist/esm/BookNavigator/assets/bookmark-colors.js +4 -0
  3. package/dist/esm/BookNavigator/assets/button-base.js +4 -0
  4. package/dist/esm/BookNavigator/assets/ia-logo.js +4 -0
  5. package/dist/esm/BookNavigator/assets/icon_checkmark.js +8 -0
  6. package/dist/esm/BookNavigator/assets/icon_close.js +4 -0
  7. package/dist/esm/BookNavigator/book-navigator.js +612 -0
  8. package/dist/esm/BookNavigator/bookmarks/bookmark-button.js +35 -0
  9. package/dist/esm/BookNavigator/bookmarks/bookmark-edit.js +78 -0
  10. package/dist/esm/BookNavigator/bookmarks/bookmarks-list.js +160 -0
  11. package/dist/esm/BookNavigator/bookmarks/bookmarks-loginCTA.js +24 -0
  12. package/dist/esm/BookNavigator/bookmarks/bookmarks-provider.js +55 -0
  13. package/dist/esm/BookNavigator/bookmarks/ia-bookmarks.js +521 -0
  14. package/dist/esm/BookNavigator/delete-modal-actions.js +29 -0
  15. package/dist/esm/BookNavigator/downloads/downloads-provider.js +84 -0
  16. package/dist/esm/BookNavigator/downloads/downloads.js +69 -0
  17. package/dist/esm/BookNavigator/search/search-provider.js +238 -0
  18. package/dist/esm/BookNavigator/search/search-results.js +161 -0
  19. package/dist/esm/BookNavigator/sharing.js +26 -0
  20. package/dist/esm/BookNavigator/viewable-files.js +94 -0
  21. package/dist/esm/BookNavigator/visual-adjustments/visual-adjustments-provider.js +83 -0
  22. package/dist/esm/BookNavigator/visual-adjustments/visual-adjustments.js +131 -0
  23. package/dist/esm/BookReader/BookModel.js +575 -0
  24. package/dist/esm/BookReader/DragScrollable.js +224 -0
  25. package/dist/esm/BookReader/ImageCache.js +122 -0
  26. package/dist/esm/BookReader/Mode1Up.js +114 -0
  27. package/dist/esm/BookReader/Mode1UpLit.js +579 -0
  28. package/dist/esm/BookReader/Mode2Up.js +106 -0
  29. package/dist/esm/BookReader/Mode2UpLit.js +1020 -0
  30. package/dist/esm/BookReader/ModeCoordinateSpace.js +28 -0
  31. package/dist/esm/BookReader/ModeSmoothZoom.js +318 -0
  32. package/dist/esm/BookReader/ModeThumb.js +366 -0
  33. package/dist/esm/BookReader/Navbar/Navbar.js +253 -0
  34. package/dist/esm/BookReader/PageContainer.js +165 -0
  35. package/dist/esm/BookReader/ReduceSet.js +27 -0
  36. package/dist/esm/BookReader/Toolbar/Toolbar.js +242 -0
  37. package/dist/esm/BookReader/events.js +20 -0
  38. package/dist/esm/BookReader/options.js +331 -0
  39. package/dist/esm/BookReader/utils/HTMLDimensionsCacher.js +48 -0
  40. package/dist/esm/BookReader/utils/ScrollClassAdder.js +31 -0
  41. package/dist/esm/BookReader/utils/SelectionObserver.js +42 -0
  42. package/dist/esm/BookReader/utils/classes.js +37 -0
  43. package/dist/esm/BookReader/utils.js +315 -0
  44. package/dist/esm/BookReader.js +1827 -0
  45. package/dist/esm/assets/icons/1up.svg +12 -0
  46. package/dist/esm/assets/icons/2up.svg +15 -0
  47. package/dist/esm/assets/icons/advance.svg +26 -0
  48. package/dist/esm/assets/icons/chevron-right.svg +1 -0
  49. package/dist/esm/assets/icons/close-circle-dark.svg +1 -0
  50. package/dist/esm/assets/icons/close-circle.svg +1 -0
  51. package/dist/esm/assets/icons/fullscreen.svg +17 -0
  52. package/dist/esm/assets/icons/fullscreen_exit.svg +17 -0
  53. package/dist/esm/assets/icons/hamburger.svg +15 -0
  54. package/dist/esm/assets/icons/left-arrow.svg +12 -0
  55. package/dist/esm/assets/icons/magnify-minus.svg +12 -0
  56. package/dist/esm/assets/icons/magnify-plus.svg +13 -0
  57. package/dist/esm/assets/icons/magnify.svg +15 -0
  58. package/dist/esm/assets/icons/pause.svg +23 -0
  59. package/dist/esm/assets/icons/play.svg +22 -0
  60. package/dist/esm/assets/icons/playback-speed.svg +34 -0
  61. package/dist/esm/assets/icons/read-aloud.svg +22 -0
  62. package/dist/esm/assets/icons/review.svg +22 -0
  63. package/dist/esm/assets/icons/thumbnails.svg +17 -0
  64. package/dist/esm/assets/icons/voice.svg +1 -0
  65. package/dist/esm/assets/icons/volume-full.svg +22 -0
  66. package/dist/esm/assets/images/BRicons.png +0 -0
  67. package/dist/esm/assets/images/BRicons.svg +94 -0
  68. package/dist/esm/assets/images/BRicons_ia.png +0 -0
  69. package/dist/esm/assets/images/back_pages.png +0 -0
  70. package/dist/esm/assets/images/book_bottom_icon.png +0 -0
  71. package/dist/esm/assets/images/book_down_icon.png +0 -0
  72. package/dist/esm/assets/images/book_left_icon.png +0 -0
  73. package/dist/esm/assets/images/book_leftmost_icon.png +0 -0
  74. package/dist/esm/assets/images/book_right_icon.png +0 -0
  75. package/dist/esm/assets/images/book_rightmost_icon.png +0 -0
  76. package/dist/esm/assets/images/book_top_icon.png +0 -0
  77. package/dist/esm/assets/images/book_up_icon.png +0 -0
  78. package/dist/esm/assets/images/books_graphic.svg +177 -0
  79. package/dist/esm/assets/images/booksplit.png +0 -0
  80. package/dist/esm/assets/images/control_pause_icon.png +0 -0
  81. package/dist/esm/assets/images/control_play_icon.png +0 -0
  82. package/dist/esm/assets/images/embed_icon.png +0 -0
  83. package/dist/esm/assets/images/icon-home-ia.png +0 -0
  84. package/dist/esm/assets/images/icon_OL-logo-xs.png +0 -0
  85. package/dist/esm/assets/images/icon_alert-xs.png +0 -0
  86. package/dist/esm/assets/images/icon_book.svg +12 -0
  87. package/dist/esm/assets/images/icon_bookmark.svg +12 -0
  88. package/dist/esm/assets/images/icon_close-pop.png +0 -0
  89. package/dist/esm/assets/images/icon_download.png +0 -0
  90. package/dist/esm/assets/images/icon_gear.svg +14 -0
  91. package/dist/esm/assets/images/icon_hamburger.svg +20 -0
  92. package/dist/esm/assets/images/icon_home.png +0 -0
  93. package/dist/esm/assets/images/icon_home.svg +21 -0
  94. package/dist/esm/assets/images/icon_home_ia.png +0 -0
  95. package/dist/esm/assets/images/icon_indicator.png +0 -0
  96. package/dist/esm/assets/images/icon_info.svg +11 -0
  97. package/dist/esm/assets/images/icon_one_page.svg +8 -0
  98. package/dist/esm/assets/images/icon_pause.svg +1 -0
  99. package/dist/esm/assets/images/icon_play.svg +1 -0
  100. package/dist/esm/assets/images/icon_playback-rate.svg +15 -0
  101. package/dist/esm/assets/images/icon_return.png +0 -0
  102. package/dist/esm/assets/images/icon_search_button.svg +8 -0
  103. package/dist/esm/assets/images/icon_share.svg +9 -0
  104. package/dist/esm/assets/images/icon_skip-ahead.svg +6 -0
  105. package/dist/esm/assets/images/icon_skip-back.svg +13 -0
  106. package/dist/esm/assets/images/icon_speaker.svg +18 -0
  107. package/dist/esm/assets/images/icon_speaker_open.svg +10 -0
  108. package/dist/esm/assets/images/icon_thumbnails.svg +12 -0
  109. package/dist/esm/assets/images/icon_toc.svg +5 -0
  110. package/dist/esm/assets/images/icon_two_pages.svg +9 -0
  111. package/dist/esm/assets/images/icon_zoomer.png +0 -0
  112. package/dist/esm/assets/images/loading.gif +0 -0
  113. package/dist/esm/assets/images/logo_icon.png +0 -0
  114. package/dist/esm/assets/images/marker_chap-off.png +0 -0
  115. package/dist/esm/assets/images/marker_chap-off.svg +11 -0
  116. package/dist/esm/assets/images/marker_chap-off_ia.png +0 -0
  117. package/dist/esm/assets/images/marker_chap-on.png +0 -0
  118. package/dist/esm/assets/images/marker_chap-on.svg +11 -0
  119. package/dist/esm/assets/images/marker_srch-on.svg +11 -0
  120. package/dist/esm/assets/images/marker_srchchap-off.png +0 -0
  121. package/dist/esm/assets/images/marker_srchchap-on.png +0 -0
  122. package/dist/esm/assets/images/nav_control-dn.png +0 -0
  123. package/dist/esm/assets/images/nav_control-dn_ia.png +0 -0
  124. package/dist/esm/assets/images/nav_control-up.png +0 -0
  125. package/dist/esm/assets/images/nav_control-up_ia.png +0 -0
  126. package/dist/esm/assets/images/nav_control.png +0 -0
  127. package/dist/esm/assets/images/one_page_mode_icon.png +0 -0
  128. package/dist/esm/assets/images/paper-badge.png +0 -0
  129. package/dist/esm/assets/images/print_icon.png +0 -0
  130. package/dist/esm/assets/images/progressbar.gif +0 -0
  131. package/dist/esm/assets/images/right_edges.png +0 -0
  132. package/dist/esm/assets/images/slider.png +0 -0
  133. package/dist/esm/assets/images/slider_ia.png +0 -0
  134. package/dist/esm/assets/images/thumbnail_mode_icon.png +0 -0
  135. package/dist/esm/assets/images/transparent.png +0 -0
  136. package/dist/esm/assets/images/two_page_mode_icon.png +0 -0
  137. package/dist/esm/assets/images/unviewable_page.png +0 -0
  138. package/dist/esm/assets/images/zoom_in_icon.png +0 -0
  139. package/dist/esm/assets/images/zoom_out_icon.png +0 -0
  140. package/dist/esm/css/BookReader.scss +85 -0
  141. package/dist/esm/css/_BRBookmarks.scss +29 -0
  142. package/dist/esm/css/_BRComponent.scss +13 -0
  143. package/dist/esm/css/_BRfloat.scss +197 -0
  144. package/dist/esm/css/_BRicon.scss +54 -0
  145. package/dist/esm/css/_BRmain.scss +262 -0
  146. package/dist/esm/css/_BRnav.scss +354 -0
  147. package/dist/esm/css/_BRpages.scss +213 -0
  148. package/dist/esm/css/_BRsearch.scss +268 -0
  149. package/dist/esm/css/_BRtoolbar.scss +84 -0
  150. package/dist/esm/css/_BRvendor.scss +5 -0
  151. package/dist/esm/css/_TextSelection.scss +108 -0
  152. package/dist/esm/css/_colorbox.scss +52 -0
  153. package/dist/esm/css/_controls.scss +257 -0
  154. package/dist/esm/css/_icons.scss +121 -0
  155. package/dist/esm/ia-bookreader/ia-bookreader.js +141 -0
  156. package/dist/esm/jquery-wrapper.js +3 -0
  157. package/dist/esm/plugins/plugin.archive_analytics.js +72 -0
  158. package/dist/esm/plugins/plugin.autoplay.js +119 -0
  159. package/dist/esm/plugins/plugin.chapters.js +288 -0
  160. package/dist/esm/plugins/plugin.iframe.js +44 -0
  161. package/dist/esm/plugins/plugin.iiif.js +146 -0
  162. package/dist/esm/plugins/plugin.resume.js +66 -0
  163. package/dist/esm/plugins/plugin.text_selection.js +621 -0
  164. package/dist/esm/plugins/plugin.vendor-fullscreen.js +227 -0
  165. package/dist/esm/plugins/search/plugin.search.js +499 -0
  166. package/dist/esm/plugins/search/utils.js +42 -0
  167. package/dist/esm/plugins/search/view.js +360 -0
  168. package/dist/esm/plugins/tts/AbstractTTSEngine.js +282 -0
  169. package/dist/esm/plugins/tts/FestivalTTSEngine.js +192 -0
  170. package/dist/esm/plugins/tts/PageChunk.js +105 -0
  171. package/dist/esm/plugins/tts/PageChunkIterator.js +155 -0
  172. package/dist/esm/plugins/tts/WebTTSEngine.js +364 -0
  173. package/dist/esm/plugins/tts/plugin.tts.js +315 -0
  174. package/dist/esm/plugins/tts/tooltip_dict.js +14 -0
  175. package/dist/esm/plugins/tts/utils.js +79 -0
  176. package/dist/esm/plugins/url/UrlPlugin.js +197 -0
  177. package/dist/esm/plugins/url/plugin.url.js +212 -0
  178. package/dist/esm/util/browserSniffing.js +56 -0
  179. package/dist/esm/util/debouncer.js +25 -0
  180. package/dist/esm/util/docCookies.js +75 -0
  181. package/dist/esm/util/strings.js +34 -0
  182. package/jsconfig.json +1 -0
  183. package/package.json +13 -6
@@ -0,0 +1,78 @@
1
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5;
2
+ function _taggedTemplateLiteral(e, t) { return t || (t = e.slice(0)), Object.freeze(Object.defineProperties(e, { raw: { value: Object.freeze(t) } })); }
3
+ import { repeat } from 'lit/directives/repeat.js';
4
+ import { css, html, LitElement, nothing } from 'lit';
5
+ import bookmarkColorsCSS from '../assets/bookmark-colors.js';
6
+ import buttonCSS from '../assets/button-base.js';
7
+ export class IABookmarkEdit extends LitElement {
8
+ static get properties() {
9
+ return {
10
+ bookmark: {
11
+ type: Object
12
+ },
13
+ bookmarkColors: {
14
+ type: Array
15
+ },
16
+ renderHeader: {
17
+ type: Boolean
18
+ },
19
+ showBookmark: {
20
+ type: Boolean
21
+ }
22
+ };
23
+ }
24
+ constructor() {
25
+ super();
26
+ this.bookmark = {};
27
+ this.bookmarkColors = [];
28
+ this.renderHeader = false;
29
+ this.showBookmark = true;
30
+ }
31
+ emitSaveEvent(e) {
32
+ e.preventDefault();
33
+ this.dispatchEvent(new CustomEvent('saveBookmark', {
34
+ detail: {
35
+ bookmark: this.bookmark
36
+ }
37
+ }));
38
+ }
39
+ emitDeleteEvent() {
40
+ this.dispatchEvent(new CustomEvent('deleteBookmark', {
41
+ detail: {
42
+ id: this.bookmark.id
43
+ }
44
+ }));
45
+ }
46
+ emitColorChangedEvent(colorId) {
47
+ this.dispatchEvent(new CustomEvent('bookmarkColorChanged', {
48
+ detail: {
49
+ bookmarkId: this.bookmark.id,
50
+ colorId
51
+ }
52
+ }));
53
+ }
54
+ changeColorTo(id) {
55
+ this.bookmark.color = id;
56
+ this.emitColorChangedEvent(id);
57
+ }
58
+ updateNote(e) {
59
+ this.bookmark.note = e.currentTarget.value;
60
+ }
61
+ static get headerSection() {
62
+ return html(_templateObject || (_templateObject = _taggedTemplateLiteral(["<header>\n <h3>Edit Bookmark</h3>\n </header>"])));
63
+ }
64
+ bookmarkColor(color) {
65
+ return html(_templateObject2 || (_templateObject2 = _taggedTemplateLiteral(["\n <li>\n <input type=\"radio\" name=\"color\" id=\"color_", "\" .value=", " @change=", " ?checked=", ">\n <label for=\"color_", "\">\n <icon-bookmark class=", "></icon-bookmark>\n </label>\n </li>\n "])), color.id, color.id, () => this.changeColorTo(color.id), this.bookmark.color === color.id, color.id, color.className);
66
+ }
67
+ get bookmarkTemplate() {
68
+ return html(_templateObject3 || (_templateObject3 = _taggedTemplateLiteral(["\n <div class=\"bookmark\">\n <img src=", " />\n <h4>Page ", "</h4>\n </div>\n "])), this.bookmark.thumbnail, this.bookmark.page);
69
+ }
70
+ render() {
71
+ return html(_templateObject4 || (_templateObject4 = _taggedTemplateLiteral(["\n ", "\n ", "\n <form action=\"\" method=\"put\" @submit=", ">\n <fieldset>\n <label for=\"note\">Note <small>(optional)</small></label>\n <textarea rows=\"4\" cols=\"80\" name=\"note\" id=\"note\" @change=", ">", "</textarea>\n <label for=\"color\">Bookmark color</label>\n <ul>\n ", "\n </ul>\n <div class=\"actions\">\n <button type=\"button\" class=\"ia-button cancel\" @click=", ">Delete</button>\n <input class=\"ia-button\" type=\"submit\" value=\"Save\">\n </div>\n </fieldset>\n </form>\n "])), this.renderHeader ? IABookmarkEdit.headerSection : nothing, this.showBookmark ? this.bookmarkTemplate : nothing, this.emitSaveEvent, this.updateNote, this.bookmark.note, repeat(this.bookmarkColors, color => color.id, this.bookmarkColor.bind(this)), this.emitDeleteEvent);
72
+ }
73
+ static get styles() {
74
+ var bookmarkEditCSS = css(_templateObject5 || (_templateObject5 = _taggedTemplateLiteral(["\n :host {\n display: block;\n padding: 0 1rem 2rem 1rem;\n color: var(--primaryTextColor);\n }\n\n small {\n font-style: italic;\n }\n\n .bookmark {\n display: grid;\n grid-template-columns: 37px 1fr;\n grid-gap: 0 1rem;\n align-items: center;\n }\n\n h4 {\n margin: 0;\n font-size: 1.4rem;\n }\n\n fieldset {\n padding: 2rem 0 0 0;\n border: none;\n }\n\n label {\n display: block;\n font-weight: bold;\n }\n\n p {\n padding: 0;\n margin: .5rem 0;\n font-size: 1.2rem;\n line-height: 120%;\n }\n\n textarea {\n width: 100%;\n margin-bottom: 2rem;\n box-sizing: border-box;\n font: normal 1.4rem \"Helvetica Neue\", Helvetica, Arial, sans-serif;\n resize: vertical;\n }\n\n ul {\n display: grid;\n grid-template-columns: repeat(3, auto);\n grid-gap: 0 2rem;\n justify-content: start;\n padding: 1rem 0 0 0;\n margin: 0 0 2rem 0;\n list-style: none;\n }\n\n li input {\n display: none;\n }\n\n li label {\n display: block;\n min-width: 50px;\n padding-top: .4rem;\n text-align: center;\n border: 1px solid transparent;\n border-radius: 4px;\n cursor: pointer;\n }\n\n li input:checked + label {\n border-color: var(--primaryTextColor);\n }\n\n input[type=\"submit\"] {\n background: var(--primaryCTAFill);\n border-color: var(--primaryCTABorder);\n }\n\n button {\n background: var(--primaryErrorCTAFill);\n border-color: var(--primaryErrorCTABorder);\n }\n\n .button {\n -webkit-appearance: none;\n appearance: none;\n padding: .5rem 1rem;\n box-sizing: border-box;\n color: var(--primaryTextColor);\n border: none;\n border-radius: 4px;\n cursor: pointer;\n }\n\n .actions {\n display: grid;\n grid-template-columns: auto auto;\n grid-gap: 0 1rem;\n justify-items: stretch;\n }\n "])));
75
+ return [buttonCSS, bookmarkColorsCSS, bookmarkEditCSS];
76
+ }
77
+ }
78
+ customElements.define('ia-bookmark-edit', IABookmarkEdit);
@@ -0,0 +1,160 @@
1
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8;
2
+ function _taggedTemplateLiteral(e, t) { return t || (t = e.slice(0)), Object.freeze(Object.defineProperties(e, { raw: { value: Object.freeze(t) } })); }
3
+ import { repeat } from 'lit/directives/repeat.js';
4
+ import { css, html, LitElement, nothing } from 'lit';
5
+ import './bookmark-edit.js';
6
+ import '@internetarchive/icon-edit-pencil/icon-edit-pencil.js';
7
+ import bookmarkColorsCSS from '../assets/bookmark-colors.js';
8
+ export class IABookmarksList extends LitElement {
9
+ static get properties() {
10
+ return {
11
+ activeBookmarkID: {
12
+ type: Number
13
+ },
14
+ bookmarkColors: {
15
+ type: Array
16
+ },
17
+ defaultBookmarkColor: {
18
+ type: Object
19
+ },
20
+ bookmarks: {
21
+ type: Object
22
+ },
23
+ editedBookmark: {
24
+ type: Object
25
+ },
26
+ renderHeader: {
27
+ type: Boolean
28
+ }
29
+ };
30
+ }
31
+ constructor() {
32
+ super();
33
+ this.activeBookmarkID = undefined;
34
+ this.bookmarkColors = [];
35
+ this.defaultBookmarkColor = {};
36
+ this.bookmarks = {};
37
+ this.editedBookmark = {};
38
+ this.renderHeader = false;
39
+ }
40
+ emitEditEvent(e, bookmark) {
41
+ this.dispatchEvent(new CustomEvent('bookmarkEdited', {
42
+ detail: {
43
+ bookmark
44
+ }
45
+ }));
46
+ }
47
+ emitSelectedEvent(bookmark) {
48
+ this.activeBookmarkID = bookmark.id;
49
+ this.dispatchEvent(new CustomEvent('bookmarkSelected', {
50
+ detail: {
51
+ bookmark
52
+ }
53
+ }));
54
+ }
55
+ emitSaveBookmark(bookmark) {
56
+ this.dispatchEvent(new CustomEvent('saveBookmark', {
57
+ detail: {
58
+ bookmark
59
+ }
60
+ }));
61
+ }
62
+ emitDeleteBookmark(id) {
63
+ this.dispatchEvent(new CustomEvent('deleteBookmark', {
64
+ detail: {
65
+ id
66
+ }
67
+ }));
68
+ }
69
+ emitBookmarkColorChanged(_ref) {
70
+ var {
71
+ detail
72
+ } = _ref;
73
+ var {
74
+ bookmarkId,
75
+ colorId
76
+ } = detail;
77
+ this.dispatchEvent(new CustomEvent('bookmarkColorChanged', {
78
+ detail: {
79
+ bookmarkId,
80
+ colorId
81
+ }
82
+ }));
83
+ }
84
+ emitAddBookmark() {
85
+ this.dispatchEvent(new CustomEvent('addBookmark'));
86
+ }
87
+ editBookmark(e, bookmark) {
88
+ this.emitEditEvent(e, bookmark);
89
+ this.editedBookmark = this.editedBookmark === bookmark ? {} : bookmark;
90
+ }
91
+ saveBookmark(_ref2) {
92
+ var {
93
+ detail
94
+ } = _ref2;
95
+ var {
96
+ bookmark
97
+ } = detail;
98
+ this.editedBookmark = {};
99
+ this.emitSaveBookmark(bookmark);
100
+ }
101
+ deleteBookmark(_ref3) {
102
+ var {
103
+ detail
104
+ } = _ref3;
105
+ var {
106
+ id
107
+ } = detail;
108
+ this.editedBookmark = {};
109
+ this.emitDeleteBookmark(id);
110
+ }
111
+ bookmarkColorInfo() {
112
+ var colorVal = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;
113
+ return this.bookmarkColors.find(labelInfo => (labelInfo === null || labelInfo === void 0 ? void 0 : labelInfo.id) === colorVal);
114
+ }
115
+ bookmarkItem(bookmark) {
116
+ var editMode = this.editedBookmark.id === bookmark.id;
117
+ var {
118
+ className
119
+ } = this.bookmarkColorInfo(bookmark.color);
120
+ var activeClass = bookmark.id === this.activeBookmarkID ? 'active' : '';
121
+ return html(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n <li\n @click=", "\n tabindex=\"0\"\n data-pageIndex=", "\n >\n <div class=\"separator\"></div>\n <div class=\"content ", "\">\n <button\n class=\"edit\"\n @click=", "\n title=\"Edit this bookmark\"\n >\n <ia-icon-edit-pencil></ia-icon-edit-pencil>\n </button>\n <h4>\n <icon-bookmark class=", "></icon-bookmark>\n <span> Page ", "</span>\n </h4>\n ", "\n ", "\n </div>\n </li>\n "])), () => this.emitSelectedEvent(bookmark), bookmark.id, activeClass, e => this.editBookmark(e, bookmark), className, bookmark.page, !editMode && bookmark.note ? html(_templateObject2 || (_templateObject2 = _taggedTemplateLiteral(["<p>", "</p>"])), bookmark.note) : nothing, editMode ? this.editBookmarkComponent : nothing);
122
+ }
123
+ get editBookmarkComponent() {
124
+ var showBookmark = false;
125
+ return html(_templateObject3 || (_templateObject3 = _taggedTemplateLiteral(["\n <ia-bookmark-edit\n .bookmark=", "\n .bookmarkColors=", "\n .defaultBookmarkColor=", "\n .showBookmark=", "\n @saveBookmark=", "\n @deleteBookmark=", "\n @bookmarkColorChanged=", "\n ></ia-bookmark-edit>\n "])), this.editedBookmark, this.bookmarkColors, this.defaultBookmarkColor, showBookmark, this.saveBookmark, this.deleteBookmark, this.emitBookmarkColorChanged);
126
+ }
127
+ sortBookmarks() {
128
+ var sortedKeys = Object.keys(this.bookmarks).sort((a, b) => {
129
+ if (+a > +b) {
130
+ return 1;
131
+ }
132
+ if (+a < +b) {
133
+ return -1;
134
+ }
135
+ return 0;
136
+ });
137
+ var sortedBookmarks = sortedKeys.map(key => this.bookmarks[key]);
138
+ return sortedBookmarks;
139
+ }
140
+ get bookmarksCount() {
141
+ var count = this.bookmarks.length;
142
+ return html(_templateObject4 || (_templateObject4 = _taggedTemplateLiteral(["<small>(", ")</small>"])), count);
143
+ }
144
+ get headerSection() {
145
+ return html(_templateObject5 || (_templateObject5 = _taggedTemplateLiteral(["<header>\n <h3>\n Bookmarks\n ", "\n </h3>\n </header>"])), this.bookmarks.length ? this.bookmarksCount : nothing);
146
+ }
147
+ get bookmarkslist() {
148
+ var sortedBookmarks = this.sortBookmarks();
149
+ var bookmarks = repeat(sortedBookmarks, bookmark => bookmark === null || bookmark === void 0 ? void 0 : bookmark.id, this.bookmarkItem.bind(this));
150
+ return html(_templateObject6 || (_templateObject6 = _taggedTemplateLiteral(["\n <ul>\n ", "\n <div class=\"separator\"></div>\n </ul>\n "])), bookmarks);
151
+ }
152
+ render() {
153
+ return html(_templateObject7 || (_templateObject7 = _taggedTemplateLiteral(["\n ", "\n ", "\n "])), this.renderHeader ? this.headerSection : nothing, Object.keys(this.bookmarks).length ? this.bookmarkslist : nothing);
154
+ }
155
+ static get styles() {
156
+ var main = css(_templateObject8 || (_templateObject8 = _taggedTemplateLiteral(["\n :host {\n display: block;\n overflow-y: auto;\n box-sizing: border-box;\n color: var(--primaryTextColor);\n margin-bottom: 2rem;\n --activeBorderWidth: 2px;\n }\n\n icon-bookmark {\n width: 16px;\n height: 24px;\n }\n\n .separator {\n background-color: var(--secondaryBGColor);\n width: 98%;\n margin: 1px auto;\n height: 1px;\n }\n\n small {\n font-style: italic;\n }\n\n h4 {\n margin: 0;\n font-size: 1.4rem;\n }\n h4 * {\n display: inline-block;\n }\n h4 icon-bookmark {\n vertical-align: bottom;\n }\n h4 span {\n vertical-align: top;\n padding-top: 1%;\n }\n\n p {\n padding: 0;\n margin: 5px 0 0 0;\n width: 98%;\n overflow-wrap: break-word;\n }\n\n ia-bookmark-edit {\n margin: 5px 5px 3px 6px;\n }\n\n ul {\n padding: 0;\n list-style: none;\n margin: var(--activeBorderWidth) 0.5rem 1rem 0;\n }\n ul > li:first-child .separator {\n display: none;\n }\n li {\n cursor: pointer;\n outline: none;\n position: relative;\n }\n li .content {\n padding: 2px 0 4px 2px;\n border: var(--activeBorderWidth) solid transparent;\n padding: .2rem 0 .4rem .2rem;\n }\n li .content.active {\n border: var(--activeBorderWidth) solid #538bc5;\n }\n li button.edit {\n padding: 5px 2px 0 0;\n background: transparent;\n cursor: pointer;\n height: 40px;\n width: 40px;\n position: absolute;\n right: 2px;\n top: 2px;\n text-align: right;\n -webkit-appearance: none;\n appearance: none;\n outline: none;\n box-sizing: border-box;\n border: none;\n }\n li button.edit > * {\n display: block;\n height: 100%;\n width: 100%;\n }\n "])));
157
+ return [main, bookmarkColorsCSS];
158
+ }
159
+ }
160
+ customElements.define('ia-bookmarks-list', IABookmarksList);
@@ -0,0 +1,24 @@
1
+ var _templateObject;
2
+ function _taggedTemplateLiteral(e, t) { return t || (t = e.slice(0)), Object.freeze(Object.defineProperties(e, { raw: { value: Object.freeze(t) } })); }
3
+ import { LitElement, html } from 'lit';
4
+ import buttonStyles from '../assets/button-base.js';
5
+ class BookmarksLogin extends LitElement {
6
+ static get properties() {
7
+ return {
8
+ url: {
9
+ type: String
10
+ }
11
+ };
12
+ }
13
+ static get styles() {
14
+ return buttonStyles;
15
+ }
16
+ constructor() {
17
+ super();
18
+ this.url = 'https://archive.org/account/login';
19
+ }
20
+ render() {
21
+ return html(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n <p>A free account is required to save and access bookmarks.</p>\n <a class=\"ia-button link primary\" href=\"", "\">Log in</a>\n "])), this.url);
22
+ }
23
+ }
24
+ customElements.define('bookmarks-login', BookmarksLogin);
@@ -0,0 +1,55 @@
1
+ var _templateObject;
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 '../delete-modal-actions.js';
5
+ import './bookmark-button.js';
6
+ import './ia-bookmarks.js';
7
+ import './bookmark-edit.js';
8
+ import './bookmarks-list.js';
9
+ import '@internetarchive/icon-bookmark';
10
+ export default class BookmarksProvider {
11
+ constructor(options) {
12
+ var {
13
+ baseHost,
14
+ signedIn,
15
+ bookreader,
16
+ modal,
17
+ onProviderChange
18
+ } = options;
19
+ var referrerStr = "referer=".concat(encodeURIComponent(location.href));
20
+ var loginUrl = "https://".concat(baseHost, "/account/login?").concat(referrerStr);
21
+ this.component = document.createElement('ia-bookmarks');
22
+ this.component.bookreader = bookreader;
23
+ this.component.displayMode = signedIn ? 'bookmarks' : 'login';
24
+ this.component.modal = modal;
25
+ this.component.loginOptions = {
26
+ loginClicked: this.bookmarksLoginClicked,
27
+ loginUrl
28
+ };
29
+ this.bindEvents();
30
+ this.icon = html(_templateObject || (_templateObject = _taggedTemplateLiteral(["<icon-bookmark state=\"hollow\" style=\"--iconWidth: 16px; --iconHeight: 24px;\"></icon-bookmark>"])));
31
+ this.label = 'Bookmarks';
32
+ this.id = 'bookmarks';
33
+ this.onProviderChange = onProviderChange;
34
+ this.component.setup();
35
+ this.updateMenu(this.component.bookmarks.length);
36
+ }
37
+ updateMenu(count) {
38
+ this.menuDetails = "(".concat(count, ")");
39
+ }
40
+ bindEvents() {
41
+ this.component.addEventListener('bookmarksChanged', this.bookmarksChanged.bind(this));
42
+ }
43
+ bookmarksChanged(_ref) {
44
+ var {
45
+ detail
46
+ } = _ref;
47
+ var bookmarksLength = Object.keys(detail.bookmarks).length;
48
+ this.updateMenu(bookmarksLength);
49
+ this.onProviderChange(detail.bookmarks, detail.showSidePanel);
50
+ }
51
+ bookmarksLoginClicked() {
52
+ var _window$archive_analy;
53
+ (_window$archive_analy = window.archive_analytics) === null || _window$archive_analy === void 0 || _window$archive_analy.send_event_no_sampling('BookReader', "BookmarksLogin", window.location.path);
54
+ }
55
+ }