31 lines
1,002 B
TypeScript
31 lines
1,002 B
TypeScript
|
import React from 'react';
|
||
|
|
||
|
import { useSoapboxConfig, useSettings, useSystemTheme } from 'soapbox/hooks';
|
||
|
|
||
|
/** Display the most appropriate site logo based on the theme and configuration. */
|
||
|
const SiteLogo: React.FC<React.ComponentProps<'img'>> = (props) => {
|
||
|
const { logo, logoDarkMode } = useSoapboxConfig();
|
||
|
const settings = useSettings();
|
||
|
|
||
|
const systemTheme = useSystemTheme();
|
||
|
const userTheme = settings.get('themeMode');
|
||
|
const darkMode = userTheme === 'dark' || (userTheme === 'system' && systemTheme === 'dark');
|
||
|
|
||
|
// Use the right logo if provided, then use fallbacks.
|
||
|
const getSrc = () => {
|
||
|
// In demo mode, use the Soapbox logo.
|
||
|
if (settings.get('demo')) return require('images/soapbox-logo.svg');
|
||
|
|
||
|
return (darkMode && logoDarkMode)
|
||
|
? logoDarkMode
|
||
|
: logo || logoDarkMode || require('@tabler/icons/icons/home.svg');
|
||
|
};
|
||
|
|
||
|
return (
|
||
|
// eslint-disable-next-line jsx-a11y/alt-text
|
||
|
<img src={getSrc()} {...props} />
|
||
|
);
|
||
|
};
|
||
|
|
||
|
export default SiteLogo;
|