aboutsummaryrefslogtreecommitdiff
path: root/extension/src/components/Bookmark.tsx
diff options
context:
space:
mode:
authorsowgro <tpoke.ferrari@gmail.com>2024-11-07 12:40:42 -0500
committersowgro <tpoke.ferrari@gmail.com>2024-11-07 12:40:42 -0500
commit03b7ccaa5c152c8d7ed73374be8ad4d4d034845b (patch)
tree7ce20a5749018fbe82c85ee1bd7c2a5c5083eb4b /extension/src/components/Bookmark.tsx
parent958ab3cd5edad8b48a3fa49e0f151b3285abdbfa (diff)
downloadbookmarks-home-03b7ccaa5c152c8d7ed73374be8ad4d4d034845b.tar.gz
bookmarks-home-03b7ccaa5c152c8d7ed73374be8ad4d4d034845b.tar.bz2
bookmarks-home-03b7ccaa5c152c8d7ed73374be8ad4d4d034845b.zip
Implement sorting and refactor
Diffstat (limited to 'extension/src/components/Bookmark.tsx')
-rw-r--r--extension/src/components/Bookmark.tsx34
1 files changed, 34 insertions, 0 deletions
diff --git a/extension/src/components/Bookmark.tsx b/extension/src/components/Bookmark.tsx
new file mode 100644
index 0000000..75badd7
--- /dev/null
+++ b/extension/src/components/Bookmark.tsx
@@ -0,0 +1,34 @@
+import BookmarkTreeNode = browser.bookmarks.BookmarkTreeNode;
+
+/**
+ * A component for a single bookmark
+ *
+ * @param props.data The BookmarkTreeNode with the data for the bookmark
+ */
+function Bookmark(props: {data: BookmarkTreeNode}) {
+ return(
+ <a className="bookmark draggable" href={props.data.url}>
+ <img alt="Bookmark icon" src={faviconURL(props.data.url)}></img>
+ <span>{props.data.title}</span>
+ </a>
+ );
+}
+
+/**
+ * Gets the icon for a bookmark
+ *
+ * @param u The URL of the link
+ * @return The URL of the icon
+ */
+function faviconURL(u: string | undefined) {
+ if (!u) return "";
+ u = new URL(u).hostname.toString();
+ const url = new URL('https://www.google.com/s2/favicons');
+ url.searchParams.set("sz", "256");
+ // u = u.split(".")[u.split(".").length-2] +"."+ u.split(".")[u.split(".").length-1]
+ url.searchParams.set("domain_url", u);
+ return url.toString();
+
+}
+
+export default Bookmark; \ No newline at end of file