1
0
mirror of https://github.com/h3poteto/whalebird-desktop synced 2025-01-28 16:20:21 +01:00

148 lines
3.5 KiB
TypeScript
Raw Normal View History

import { localeType } from '@/provider/i18n'
import { Dialog, DialogBody, DialogHeader, Input, Option, Select, Typography } from '@material-tailwind/react'
2023-12-05 01:17:52 +09:00
import { ChangeEvent, useEffect, useState } from 'react'
2023-12-05 01:08:12 +09:00
import { FormattedMessage } from 'react-intl'
type Props = {
opened: boolean
close: () => void
2023-12-05 01:17:52 +09:00
reloadSettings: () => void
2023-12-05 01:08:12 +09:00
}
const languages = [
{
label: 'English',
value: 'en'
},
{
label: '日本語',
value: 'ja'
2024-02-05 21:52:13 +09:00
},
{
label: 'Português',
value: 'pt-PT'
2023-12-05 01:08:12 +09:00
}
]
2024-03-09 19:09:36 +09:00
const themes = [
{
label: 'Blue',
value: 'theme-blue'
},
{
label: 'Orange',
value: 'theme-orange'
2024-03-09 22:13:44 +09:00
},
{
label: 'Purple',
value: 'theme-purple'
},
{
label: 'Green',
value: 'theme-green'
},
{
label: 'Brown',
value: 'theme-brown'
},
{
label: 'Gray',
value: 'theme-gray'
2024-03-09 19:09:36 +09:00
}
]
2023-12-05 01:08:12 +09:00
export default function Settings(props: Props) {
const [language, setLanguage] = useState<localeType>('en')
2023-12-07 00:10:16 +09:00
const [fontSize, setFontSize] = useState<number>(16)
2024-03-09 19:09:36 +09:00
const [theme, setTheme] = useState<string>('theme-blue')
2023-12-05 01:08:12 +09:00
useEffect(() => {
if (typeof localStorage !== 'undefined') {
const lang = localStorage.getItem('language')
2024-02-05 21:52:13 +09:00
if (lang) {
setLanguage(lang as localeType)
} else {
setLanguage('en')
}
2023-12-05 01:08:12 +09:00
}
}, [])
const languageChanged = (e: string) => {
2024-02-05 21:52:13 +09:00
setLanguage(e as localeType)
2023-12-05 01:08:12 +09:00
if (typeof localStorage !== 'undefined') {
localStorage.setItem('language', e)
2023-12-05 01:08:12 +09:00
}
2023-12-05 01:17:52 +09:00
props.reloadSettings()
2023-12-05 01:08:12 +09:00
}
2023-12-07 00:10:16 +09:00
const fontSizeChanged = (e: ChangeEvent<HTMLInputElement>) => {
setFontSize(parseInt(e.target.value))
if (typeof localStorage !== 'undefined') {
localStorage.setItem('fontSize', e.target.value)
}
props.reloadSettings()
}
2024-03-09 19:09:36 +09:00
const themeChanged = (e: string) => {
setTheme(e)
if (typeof localStorage !== 'undefined') {
localStorage.setItem('theme', e)
}
props.reloadSettings()
}
2023-12-05 01:08:12 +09:00
return (
<Dialog open={props.opened} handler={props.close} size="sm">
<DialogHeader>
2023-12-05 01:08:12 +09:00
<FormattedMessage id="settings.title" />
</DialogHeader>
<DialogBody>
2023-12-07 00:10:16 +09:00
<div className="flex flex-col gap-4">
<div>
<div className="mb-2">
<Typography>
2023-12-07 00:10:16 +09:00
<FormattedMessage id="settings.font_size" />
</Typography>
2023-12-07 00:10:16 +09:00
</div>
<div>
<Input type="number" value={fontSize} onChange={fontSizeChanged} />
2023-12-07 00:10:16 +09:00
</div>
</div>
<div>
<div className="mb-2">
<Typography>
2023-12-07 00:10:16 +09:00
<FormattedMessage id="settings.language" />
</Typography>
2023-12-07 00:10:16 +09:00
</div>
<div>
<Select id="language" onChange={languageChanged} value={language}>
2023-12-07 00:10:16 +09:00
{languages.map(lang => (
<Option key={lang.value} value={lang.value}>
2023-12-07 00:10:16 +09:00
{lang.label}
</Option>
2023-12-07 00:10:16 +09:00
))}
</Select>
</div>
</div>
2024-03-09 19:09:36 +09:00
<div>
<div className="mb-2">
<Typography>
<FormattedMessage id="settings.theme" />
</Typography>
</div>
<div>
<Select id="theme" onChange={themeChanged} value={theme}>
{themes.map(t => (
<Option key={t.value} value={t.value}>
{t.label}
</Option>
))}
</Select>
</div>
</div>
2023-12-05 01:08:12 +09:00
</div>
</DialogBody>
</Dialog>
2023-12-05 01:08:12 +09:00
)
}