Files
seedit/src/components/header/header.tsx
2023-10-28 21:23:59 +02:00

85 lines
2.7 KiB
TypeScript

import { FC } from 'react';
import { Link, useLocation, useParams } from 'react-router-dom';
import { useTranslation } from 'react-i18next';
import styles from './header.module.css';
import useTheme from '../../hooks/use-theme';
import AccountBar from './account-bar';
import CommentsButtons from '../header/comments-buttons';
import SortButtons from '../header/sort-buttons';
// prettier-ignore
const availableLanguages = ['ar', 'bn', 'cs', 'da', 'de', 'el', 'en', 'es', 'fa', 'fi', 'fil', 'fr', 'he', 'hi', 'hu', 'id', 'it', 'ja', 'ko', 'mr', 'nl', 'no', 'pl', 'pt', 'ro', 'ru', 'sq', 'sv', 'te', 'th', 'tr', 'uk', 'ur', 'vi', 'zh'];
// TODO: move to settings page
const Theme: FC = () => {
const [theme, setTheme] = useTheme();
const { t } = useTranslation();
return (
<div style={{ padding: '5px' }}>
<select value={theme} onChange={(e) => setTheme(e.target.value)}>
<option value='light'>{t('light')}</option>
<option value='dark'>{t('dark')}</option>
</select>
</div>
);
};
// TODO: move to settings page
const Language: FC = () => {
const { i18n } = useTranslation();
const { changeLanguage, language } = i18n;
const onSelectLanguage = (e: React.ChangeEvent<HTMLSelectElement>) => {
changeLanguage(e.target.value);
};
return (
<div style={{ padding: '5px' }}>
<select value={language} onChange={onSelectLanguage}>
{availableLanguages.map((lang) => (
<option key={lang} value={lang}>
{lang}
</option>
))}
</select>
</div>
);
};
const Header: FC = () => {
const [theme] = useTheme();
const { sortType, subplebbitAddress, commentCid } = useParams();
const location = useLocation();
let buttons = null;
if (location.pathname === `/p/${subplebbitAddress}/c/${commentCid}`) {
buttons = <CommentsButtons />;
} else if (location.pathname === `/` || (sortType && ['hot', 'new', 'active', 'controversialAll', 'topAll'].includes(sortType))) {
buttons = <SortButtons />;
}
return (
<div className={styles.header}>
<div className={styles.headerBottomLeft}>
<span className={styles.container}>
<Link to='/' style={{ all: 'unset', cursor: 'pointer' }}>
<img className={styles.logo} src='/assets/logo/seedit.png' alt='logo' />
<img src={`${process.env.PUBLIC_URL}/assets/logo/seedit-text-${theme === 'dark' ? 'dark' : 'light'}.svg`} className={styles.logoText} alt='logo' />
</Link>
{buttons}
</span>
&nbsp;
</div>
<AccountBar />
<div className={styles.temporary}>
<Language />
<Theme />
</div>
</div>
);
};
export default Header;