document.addEventListener("DOMContentLoaded", function () { handleSubmitButtons(); if (!document.querySelector("body[data-disable-keyboard-shortcuts=true]")) { let keyboardHandler = new KeyboardHandler(); keyboardHandler.on("g u", () => goToPage("unread")); keyboardHandler.on("g b", () => goToPage("starred")); keyboardHandler.on("g h", () => goToPage("history")); keyboardHandler.on("g f", () => goToFeedOrFeeds()); keyboardHandler.on("g c", () => goToPage("categories")); keyboardHandler.on("g s", () => goToPage("settings")); keyboardHandler.on("ArrowLeft", () => goToPrevious()); keyboardHandler.on("ArrowRight", () => goToNext()); keyboardHandler.on("k", () => goToPrevious()); keyboardHandler.on("p", () => goToPrevious()); keyboardHandler.on("j", () => goToNext()); keyboardHandler.on("n", () => goToNext()); keyboardHandler.on("h", () => goToPage("previous")); keyboardHandler.on("l", () => goToPage("next")); keyboardHandler.on("o", () => openSelectedItem()); keyboardHandler.on("v", () => openOriginalLink()); keyboardHandler.on("m", () => handleEntryStatus()); keyboardHandler.on("A", () => markPageAsRead()); keyboardHandler.on("s", () => handleSaveEntry()); keyboardHandler.on("d", () => handleFetchOriginalContent()); keyboardHandler.on("f", () => handleBookmark()); keyboardHandler.on("?", () => showKeyboardShortcuts()); keyboardHandler.on("#", () => unsubscribeFromFeed()); keyboardHandler.on("/", (e) => setFocusToSearchInput(e)); keyboardHandler.on("Escape", () => ModalHandler.close()); keyboardHandler.listen(); } let touchHandler = new TouchHandler(); touchHandler.listen(); onClick("a[data-save-entry]", () => handleSaveEntry()); onClick("a[data-toggle-bookmark]", () => handleBookmark()); onClick("a[data-fetch-content-entry]", () => handleFetchOriginalContent()); onClick("a[data-action=search]", (event) => setFocusToSearchInput(event)); onClick("a[data-on-click=markPageAsRead]", () => markPageAsRead()); onClick("a[data-toggle-status]", (event) => { let currentItem = DomHelper.findParent(event.target, "entry"); if (!currentItem) { currentItem = DomHelper.findParent(event.target, "item"); } if (currentItem) { toggleEntryStatus(currentItem); } }); onClick("a[data-confirm]", (event) => { (new ConfirmHandler()).handle(event); }); onClick("a[data-link-state=flip]", (event) => { flipElementState(event.target); }, true); if (document.documentElement.clientWidth < 600) { onClick(".logo", () => toggleMainMenu()); onClick(".header nav li", (event) => onClickMainMenuListItem(event)); } if ("serviceWorker" in navigator) { let scriptElement = document.getElementById("service-worker-script"); if (scriptElement) { navigator.serviceWorker.register(scriptElement.src); } } });