From 22f623c810297467da2d8662c5d4b90ae8e84dae Mon Sep 17 00:00:00 2001 From: Matthias Andreas Benkard Date: Wed, 12 Feb 2020 05:54:53 +0100 Subject: Bookmark submission: Automatically fetch title after URI input. Change-Id: Ieea258e076d1dbaeba2520e583b590822dfdcab8 --- .../META-INF/resources/bookmarks/bookmarkList.js | 27 +++++++++++++++++++++- .../templates/benki/bookmarks/bookmarkList.html | 4 ++++ 2 files changed, 30 insertions(+), 1 deletion(-) (limited to 'src') diff --git a/src/main/resources/META-INF/resources/bookmarks/bookmarkList.js b/src/main/resources/META-INF/resources/bookmarks/bookmarkList.js index eab07f5..11c4b10 100644 --- a/src/main/resources/META-INF/resources/bookmarks/bookmarkList.js +++ b/src/main/resources/META-INF/resources/bookmarks/bookmarkList.js @@ -1,5 +1,30 @@ document.addEventListener('DOMContentLoaded', () => { let bookmarkSubmissionPane = document.getElementById('bookmark-submission-pane'); + let titleInput = document.getElementById('title-input'); let uriInput = document.getElementById('uri-input'); + let uriSpinner = document.getElementById('uri-spinner'); + bookmarkSubmissionPane.addEventListener('opened', () => uriInput.focus()); -}); \ No newline at end of file + + uriInput.addEventListener('blur', async () => { + uriSpinner.hidden = false; + uriSpinner.playing = true; + let r = await fetch(uriInput.value); + uriSpinner.hidden = true; + uriSpinner.playing = false; + + if (!r.ok) { + return; + } + + let html = await r.text(); + let parser = new DOMParser(); + let doc = parser.parseFromString(html, "text/html"); + let titles = doc.getElementsByTagName('title'); + if (titles.length <= 0) { + return; + } + titleInput.value = titles[0].innerText; + }); +}); + diff --git a/src/main/resources/templates/benki/bookmarks/bookmarkList.html b/src/main/resources/templates/benki/bookmarks/bookmarkList.html index 9f7b402..2c35249 100644 --- a/src/main/resources/templates/benki/bookmarks/bookmarkList.html +++ b/src/main/resources/templates/benki/bookmarks/bookmarkList.html @@ -13,7 +13,10 @@ {! #if authenticated !} + + +

@@ -24,6 +27,7 @@
+
-- cgit v1.2.3