bootstrap.js 3.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. document.addEventListener("DOMContentLoaded", function () {
  2. handleSubmitButtons();
  3. if (!document.querySelector("body[data-disable-keyboard-shortcuts=true]")) {
  4. let keyboardHandler = new KeyboardHandler();
  5. keyboardHandler.on("g u", () => goToPage("unread"));
  6. keyboardHandler.on("g b", () => goToPage("starred"));
  7. keyboardHandler.on("g h", () => goToPage("history"));
  8. keyboardHandler.on("g f", () => goToFeedOrFeeds());
  9. keyboardHandler.on("g c", () => goToPage("categories"));
  10. keyboardHandler.on("g s", () => goToPage("settings"));
  11. keyboardHandler.on("ArrowLeft", () => goToPrevious());
  12. keyboardHandler.on("ArrowRight", () => goToNext());
  13. keyboardHandler.on("k", () => goToPrevious());
  14. keyboardHandler.on("p", () => goToPrevious());
  15. keyboardHandler.on("j", () => goToNext());
  16. keyboardHandler.on("n", () => goToNext());
  17. keyboardHandler.on("h", () => goToPage("previous"));
  18. keyboardHandler.on("l", () => goToPage("next"));
  19. keyboardHandler.on("o", () => openSelectedItem());
  20. keyboardHandler.on("v", () => openOriginalLink());
  21. keyboardHandler.on("V", () => openOriginalLink(true));
  22. keyboardHandler.on("m", () => handleEntryStatus());
  23. keyboardHandler.on("A", () => markPageAsRead());
  24. keyboardHandler.on("s", () => handleSaveEntry());
  25. keyboardHandler.on("d", () => handleFetchOriginalContent());
  26. keyboardHandler.on("f", () => handleBookmark());
  27. keyboardHandler.on("?", () => showKeyboardShortcuts());
  28. keyboardHandler.on("#", () => unsubscribeFromFeed());
  29. keyboardHandler.on("/", (e) => setFocusToSearchInput(e));
  30. keyboardHandler.on("Escape", () => ModalHandler.close());
  31. keyboardHandler.listen();
  32. }
  33. let touchHandler = new TouchHandler();
  34. touchHandler.listen();
  35. onClick("a[data-save-entry]", (event) => handleSaveEntry(event.target));
  36. onClick("a[data-toggle-bookmark]", (event) => handleBookmark(event.target));
  37. onClick("a[data-fetch-content-entry]", () => handleFetchOriginalContent());
  38. onClick("a[data-action=search]", (event) => setFocusToSearchInput(event));
  39. onClick("a[data-action=markPageAsRead]", () => handleConfirmationMessage(event.target, () => markPageAsRead()));
  40. onClick("a[data-toggle-status]", (event) => handleEntryStatus(event.target));
  41. onClick("a[data-confirm]", (event) => handleConfirmationMessage(event.target, (url, redirectURL) => {
  42. let request = new RequestBuilder(url);
  43. request.withCallback(() => {
  44. if (redirectURL) {
  45. window.location.href = redirectURL;
  46. } else {
  47. window.location.reload();
  48. }
  49. });
  50. request.execute();
  51. }));
  52. if (document.documentElement.clientWidth < 600) {
  53. onClick(".logo", () => toggleMainMenu());
  54. onClick(".header nav li", (event) => onClickMainMenuListItem(event));
  55. }
  56. if ("serviceWorker" in navigator) {
  57. let scriptElement = document.getElementById("service-worker-script");
  58. if (scriptElement) {
  59. navigator.serviceWorker.register(scriptElement.src);
  60. }
  61. }
  62. });