@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.
- package/BookReader/BookReader.css +17 -3
- package/BookReader/BookReader.js +1 -1
- package/BookReader/BookReader.js.map +1 -1
- package/BookReader/ia-bookreader-bundle.js +87 -108
- package/BookReader/ia-bookreader-bundle.js.map +1 -1
- package/BookReader/plugins/plugin.archive_analytics.js +1 -1
- package/BookReader/plugins/plugin.archive_analytics.js.map +1 -1
- package/BookReader/plugins/plugin.autoplay.js +1 -1
- package/BookReader/plugins/plugin.autoplay.js.map +1 -1
- package/BookReader/plugins/plugin.iiif.js +1 -1
- package/BookReader/plugins/plugin.iiif.js.map +1 -1
- package/BookReader/plugins/plugin.resume.js +1 -1
- package/BookReader/plugins/plugin.resume.js.map +1 -1
- package/BookReader/plugins/plugin.search.js +1 -1
- package/BookReader/plugins/plugin.search.js.map +1 -1
- package/BookReader/plugins/plugin.text_selection.js +1 -1
- package/BookReader/plugins/plugin.text_selection.js.map +1 -1
- package/BookReader/plugins/plugin.tts.js +1 -1
- package/BookReader/plugins/plugin.tts.js.map +1 -1
- package/BookReader/plugins/plugin.url.js +1 -1
- package/BookReader/plugins/plugin.url.js.map +1 -1
- package/CHANGELOG.md +14 -0
- package/babel.config.js +12 -30
- package/codecov.yml +1 -1
- package/jsconfig.json +1 -3
- package/package.json +14 -16
- package/src/BookNavigator/search/search-results.js +1 -1
- package/src/BookReader/ImageCache.js +48 -15
- package/src/BookReader/Mode1UpLit.js +56 -86
- package/src/BookReader/Mode2UpLit.js +5 -5
- package/src/BookReader/Navbar/Navbar.js +53 -11
- package/src/BookReader/PageContainer.js +41 -22
- package/src/BookReader/options.js +27 -3
- package/src/BookReader/utils.js +10 -0
- package/src/BookReader.js +120 -21
- package/src/BookReaderPlugin.js +44 -0
- package/src/css/_BRnav.scss +0 -3
- package/src/css/_BRpages.scss +21 -2
- package/src/css/_controls.scss +4 -0
- package/src/plugins/plugin.archive_analytics.js +84 -78
- package/src/plugins/plugin.autoplay.js +98 -102
- package/src/plugins/plugin.chapters.js +17 -22
- package/src/plugins/plugin.iiif.js +16 -30
- package/src/plugins/plugin.resume.js +54 -51
- package/src/plugins/plugin.text_selection.js +68 -76
- package/src/plugins/tts/AbstractTTSEngine.js +2 -4
- package/src/plugins/tts/PageChunk.js +5 -9
- package/src/plugins/tts/PageChunkIterator.js +3 -5
- package/src/plugins/tts/plugin.tts.js +309 -329
- package/src/plugins/url/plugin.url.js +1 -1
- package/src/util/strings.js +1 -0
- package/tests/e2e/autoplay.test.js +8 -5
- package/tests/e2e/helpers/base.js +2 -2
- package/tests/e2e/helpers/mockSearch.js +6 -9
- package/tests/jest/BookReader/Navbar/Navbar.test.js +16 -3
- package/tests/jest/BookReader/PageContainer.test.js +96 -55
- package/tests/jest/BookReader/utils.test.js +21 -0
- package/tests/jest/BookReader.test.js +13 -12
- package/tests/jest/plugins/plugin.archive_analytics.test.js +8 -11
- package/tests/jest/plugins/plugin.autoplay.test.js +9 -22
- package/tests/jest/plugins/plugin.resume.test.js +19 -32
- package/tests/jest/plugins/plugin.text_selection.test.js +23 -24
- package/dist/esm/BookNavigator/assets/bookmark-colors.js +0 -4
- package/dist/esm/BookNavigator/assets/button-base.js +0 -4
- package/dist/esm/BookNavigator/assets/ia-logo.js +0 -4
- package/dist/esm/BookNavigator/assets/icon_checkmark.js +0 -8
- package/dist/esm/BookNavigator/assets/icon_close.js +0 -4
- package/dist/esm/BookNavigator/book-navigator.js +0 -612
- package/dist/esm/BookNavigator/bookmarks/bookmark-button.js +0 -35
- package/dist/esm/BookNavigator/bookmarks/bookmark-edit.js +0 -78
- package/dist/esm/BookNavigator/bookmarks/bookmarks-list.js +0 -160
- package/dist/esm/BookNavigator/bookmarks/bookmarks-loginCTA.js +0 -24
- package/dist/esm/BookNavigator/bookmarks/bookmarks-provider.js +0 -55
- package/dist/esm/BookNavigator/bookmarks/ia-bookmarks.js +0 -521
- package/dist/esm/BookNavigator/delete-modal-actions.js +0 -29
- package/dist/esm/BookNavigator/downloads/downloads-provider.js +0 -84
- package/dist/esm/BookNavigator/downloads/downloads.js +0 -69
- package/dist/esm/BookNavigator/search/search-provider.js +0 -238
- package/dist/esm/BookNavigator/search/search-results.js +0 -161
- package/dist/esm/BookNavigator/sharing.js +0 -26
- package/dist/esm/BookNavigator/viewable-files.js +0 -94
- package/dist/esm/BookNavigator/visual-adjustments/visual-adjustments-provider.js +0 -83
- package/dist/esm/BookNavigator/visual-adjustments/visual-adjustments.js +0 -131
- package/dist/esm/BookReader/BookModel.js +0 -575
- package/dist/esm/BookReader/DragScrollable.js +0 -224
- package/dist/esm/BookReader/ImageCache.js +0 -122
- package/dist/esm/BookReader/Mode1Up.js +0 -114
- package/dist/esm/BookReader/Mode1UpLit.js +0 -579
- package/dist/esm/BookReader/Mode2Up.js +0 -106
- package/dist/esm/BookReader/Mode2UpLit.js +0 -1020
- package/dist/esm/BookReader/ModeCoordinateSpace.js +0 -28
- package/dist/esm/BookReader/ModeSmoothZoom.js +0 -318
- package/dist/esm/BookReader/ModeThumb.js +0 -366
- package/dist/esm/BookReader/Navbar/Navbar.js +0 -253
- package/dist/esm/BookReader/PageContainer.js +0 -165
- package/dist/esm/BookReader/ReduceSet.js +0 -27
- package/dist/esm/BookReader/Toolbar/Toolbar.js +0 -242
- package/dist/esm/BookReader/events.js +0 -20
- package/dist/esm/BookReader/options.js +0 -331
- package/dist/esm/BookReader/utils/HTMLDimensionsCacher.js +0 -48
- package/dist/esm/BookReader/utils/ScrollClassAdder.js +0 -31
- package/dist/esm/BookReader/utils/SelectionObserver.js +0 -42
- package/dist/esm/BookReader/utils/classes.js +0 -37
- package/dist/esm/BookReader/utils.js +0 -315
- package/dist/esm/BookReader.js +0 -1828
- package/dist/esm/assets/icons/1up.svg +0 -12
- package/dist/esm/assets/icons/2up.svg +0 -15
- package/dist/esm/assets/icons/advance.svg +0 -26
- package/dist/esm/assets/icons/chevron-right.svg +0 -1
- package/dist/esm/assets/icons/close-circle-dark.svg +0 -1
- package/dist/esm/assets/icons/close-circle.svg +0 -1
- package/dist/esm/assets/icons/fullscreen.svg +0 -17
- package/dist/esm/assets/icons/fullscreen_exit.svg +0 -17
- package/dist/esm/assets/icons/hamburger.svg +0 -15
- package/dist/esm/assets/icons/left-arrow.svg +0 -12
- package/dist/esm/assets/icons/magnify-minus.svg +0 -12
- package/dist/esm/assets/icons/magnify-plus.svg +0 -13
- package/dist/esm/assets/icons/magnify.svg +0 -15
- package/dist/esm/assets/icons/pause.svg +0 -23
- package/dist/esm/assets/icons/play.svg +0 -22
- package/dist/esm/assets/icons/playback-speed.svg +0 -34
- package/dist/esm/assets/icons/read-aloud.svg +0 -22
- package/dist/esm/assets/icons/review.svg +0 -22
- package/dist/esm/assets/icons/thumbnails.svg +0 -17
- package/dist/esm/assets/icons/voice.svg +0 -1
- package/dist/esm/assets/icons/volume-full.svg +0 -22
- package/dist/esm/assets/images/BRicons.png +0 -0
- package/dist/esm/assets/images/BRicons.svg +0 -94
- package/dist/esm/assets/images/BRicons_ia.png +0 -0
- package/dist/esm/assets/images/back_pages.png +0 -0
- package/dist/esm/assets/images/book_bottom_icon.png +0 -0
- package/dist/esm/assets/images/book_down_icon.png +0 -0
- package/dist/esm/assets/images/book_left_icon.png +0 -0
- package/dist/esm/assets/images/book_leftmost_icon.png +0 -0
- package/dist/esm/assets/images/book_right_icon.png +0 -0
- package/dist/esm/assets/images/book_rightmost_icon.png +0 -0
- package/dist/esm/assets/images/book_top_icon.png +0 -0
- package/dist/esm/assets/images/book_up_icon.png +0 -0
- package/dist/esm/assets/images/books_graphic.svg +0 -177
- package/dist/esm/assets/images/booksplit.png +0 -0
- package/dist/esm/assets/images/control_pause_icon.png +0 -0
- package/dist/esm/assets/images/control_play_icon.png +0 -0
- package/dist/esm/assets/images/embed_icon.png +0 -0
- package/dist/esm/assets/images/icon-home-ia.png +0 -0
- package/dist/esm/assets/images/icon_OL-logo-xs.png +0 -0
- package/dist/esm/assets/images/icon_alert-xs.png +0 -0
- package/dist/esm/assets/images/icon_book.svg +0 -12
- package/dist/esm/assets/images/icon_bookmark.svg +0 -12
- package/dist/esm/assets/images/icon_close-pop.png +0 -0
- package/dist/esm/assets/images/icon_download.png +0 -0
- package/dist/esm/assets/images/icon_gear.svg +0 -14
- package/dist/esm/assets/images/icon_hamburger.svg +0 -20
- package/dist/esm/assets/images/icon_home.png +0 -0
- package/dist/esm/assets/images/icon_home.svg +0 -21
- package/dist/esm/assets/images/icon_home_ia.png +0 -0
- package/dist/esm/assets/images/icon_indicator.png +0 -0
- package/dist/esm/assets/images/icon_info.svg +0 -11
- package/dist/esm/assets/images/icon_one_page.svg +0 -8
- package/dist/esm/assets/images/icon_pause.svg +0 -1
- package/dist/esm/assets/images/icon_play.svg +0 -1
- package/dist/esm/assets/images/icon_playback-rate.svg +0 -15
- package/dist/esm/assets/images/icon_return.png +0 -0
- package/dist/esm/assets/images/icon_search_button.svg +0 -8
- package/dist/esm/assets/images/icon_share.svg +0 -9
- package/dist/esm/assets/images/icon_skip-ahead.svg +0 -6
- package/dist/esm/assets/images/icon_skip-back.svg +0 -13
- package/dist/esm/assets/images/icon_speaker.svg +0 -18
- package/dist/esm/assets/images/icon_speaker_open.svg +0 -10
- package/dist/esm/assets/images/icon_thumbnails.svg +0 -12
- package/dist/esm/assets/images/icon_toc.svg +0 -5
- package/dist/esm/assets/images/icon_two_pages.svg +0 -9
- package/dist/esm/assets/images/icon_zoomer.png +0 -0
- package/dist/esm/assets/images/loading.gif +0 -0
- package/dist/esm/assets/images/logo_icon.png +0 -0
- package/dist/esm/assets/images/marker_chap-off.png +0 -0
- package/dist/esm/assets/images/marker_chap-off.svg +0 -11
- package/dist/esm/assets/images/marker_chap-off_ia.png +0 -0
- package/dist/esm/assets/images/marker_chap-on.png +0 -0
- package/dist/esm/assets/images/marker_chap-on.svg +0 -11
- package/dist/esm/assets/images/marker_srch-on.svg +0 -11
- package/dist/esm/assets/images/marker_srchchap-off.png +0 -0
- package/dist/esm/assets/images/marker_srchchap-on.png +0 -0
- package/dist/esm/assets/images/nav_control-dn.png +0 -0
- package/dist/esm/assets/images/nav_control-dn_ia.png +0 -0
- package/dist/esm/assets/images/nav_control-up.png +0 -0
- package/dist/esm/assets/images/nav_control-up_ia.png +0 -0
- package/dist/esm/assets/images/nav_control.png +0 -0
- package/dist/esm/assets/images/one_page_mode_icon.png +0 -0
- package/dist/esm/assets/images/paper-badge.png +0 -0
- package/dist/esm/assets/images/print_icon.png +0 -0
- package/dist/esm/assets/images/progressbar.gif +0 -0
- package/dist/esm/assets/images/right_edges.png +0 -0
- package/dist/esm/assets/images/slider.png +0 -0
- package/dist/esm/assets/images/slider_ia.png +0 -0
- package/dist/esm/assets/images/thumbnail_mode_icon.png +0 -0
- package/dist/esm/assets/images/transparent.png +0 -0
- package/dist/esm/assets/images/two_page_mode_icon.png +0 -0
- package/dist/esm/assets/images/unviewable_page.png +0 -0
- package/dist/esm/assets/images/zoom_in_icon.png +0 -0
- package/dist/esm/assets/images/zoom_out_icon.png +0 -0
- package/dist/esm/css/BookReader.scss +0 -85
- package/dist/esm/css/_BRBookmarks.scss +0 -29
- package/dist/esm/css/_BRComponent.scss +0 -13
- package/dist/esm/css/_BRfloat.scss +0 -197
- package/dist/esm/css/_BRicon.scss +0 -54
- package/dist/esm/css/_BRmain.scss +0 -262
- package/dist/esm/css/_BRnav.scss +0 -354
- package/dist/esm/css/_BRpages.scss +0 -213
- package/dist/esm/css/_BRsearch.scss +0 -268
- package/dist/esm/css/_BRtoolbar.scss +0 -84
- package/dist/esm/css/_BRvendor.scss +0 -5
- package/dist/esm/css/_TextSelection.scss +0 -108
- package/dist/esm/css/_colorbox.scss +0 -52
- package/dist/esm/css/_controls.scss +0 -257
- package/dist/esm/css/_icons.scss +0 -121
- package/dist/esm/ia-bookreader/ia-bookreader.js +0 -141
- package/dist/esm/jquery-wrapper.js +0 -3
- package/dist/esm/plugins/plugin.archive_analytics.js +0 -72
- package/dist/esm/plugins/plugin.autoplay.js +0 -119
- package/dist/esm/plugins/plugin.chapters.js +0 -288
- package/dist/esm/plugins/plugin.iframe.js +0 -44
- package/dist/esm/plugins/plugin.iiif.js +0 -146
- package/dist/esm/plugins/plugin.resume.js +0 -66
- package/dist/esm/plugins/plugin.text_selection.js +0 -621
- package/dist/esm/plugins/plugin.vendor-fullscreen.js +0 -227
- package/dist/esm/plugins/search/plugin.search.js +0 -499
- package/dist/esm/plugins/search/utils.js +0 -42
- package/dist/esm/plugins/search/view.js +0 -360
- package/dist/esm/plugins/tts/AbstractTTSEngine.js +0 -282
- package/dist/esm/plugins/tts/FestivalTTSEngine.js +0 -192
- package/dist/esm/plugins/tts/PageChunk.js +0 -105
- package/dist/esm/plugins/tts/PageChunkIterator.js +0 -155
- package/dist/esm/plugins/tts/WebTTSEngine.js +0 -364
- package/dist/esm/plugins/tts/plugin.tts.js +0 -315
- package/dist/esm/plugins/tts/tooltip_dict.js +0 -14
- package/dist/esm/plugins/tts/utils.js +0 -79
- package/dist/esm/plugins/url/UrlPlugin.js +0 -197
- package/dist/esm/plugins/url/plugin.url.js +0 -212
- package/dist/esm/util/browserSniffing.js +0 -56
- package/dist/esm/util/debouncer.js +0 -25
- package/dist/esm/util/docCookies.js +0 -75
- package/dist/esm/util/strings.js +0 -34
- package/index.js +0 -2
@@ -1,78 +0,0 @@
|
|
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);
|
@@ -1,160 +0,0 @@
|
|
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);
|
@@ -1,24 +0,0 @@
|
|
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);
|
@@ -1,55 +0,0 @@
|
|
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
|
-
}
|