aboutsummaryrefslogtreecommitdiff
path: root/src/components/common/Favicon.tsx
diff options
context:
space:
mode:
Diffstat (limited to 'src/components/common/Favicon.tsx')
-rw-r--r--src/components/common/Favicon.tsx22
1 files changed, 22 insertions, 0 deletions
diff --git a/src/components/common/Favicon.tsx b/src/components/common/Favicon.tsx
new file mode 100644
index 0000000..a6b5e52
--- /dev/null
+++ b/src/components/common/Favicon.tsx
@@ -0,0 +1,22 @@
+import { useConfig } from '@/components/hooks';
+import { FAVICON_URL, GROUPED_DOMAINS } from '@/lib/constants';
+
+function getHostName(url: string) {
+ const match = url.match(/^(?:https?:\/\/)?(?:[^@\n]+@)?([^:/\n?=]+)/im);
+ return match && match.length > 1 ? match[1] : null;
+}
+
+export function Favicon({ domain, ...props }) {
+ const config = useConfig();
+
+ if (config?.privateMode) {
+ return null;
+ }
+
+ const url = config?.faviconUrl || FAVICON_URL;
+ const hostName = domain ? getHostName(domain) : null;
+ const domainName = GROUPED_DOMAINS[hostName]?.domain || hostName;
+ const src = hostName ? url.replace(/\{\{\s*domain\s*}}/, domainName) : null;
+
+ return hostName ? <img src={src} width={16} height={16} alt="" {...props} /> : null;
+}