You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
tailchat/client/web/src/components/modals/SettingsView/System.tsx

55 lines
1.7 KiB
TypeScript

import { FullModalField } from '@/components/FullModal/Field';
import { LanguageSelect } from '@/components/LanguageSelect';
import { pluginColorScheme } from '@/plugin/common';
import { Select, Switch } from 'antd';
import React from 'react';
import { t, useColorScheme, useSingleUserSetting } from 'tailchat-shared';
export const SettingsSystem: React.FC = React.memo(() => {
const { colorScheme, setColorScheme } = useColorScheme();
const {
value: messageListVirtualization,
setValue: setMessageListVirtualization,
loading,
} = useSingleUserSetting('messageListVirtualization', false);
return (
<div>
<FullModalField title={t('系统语言')} content={<LanguageSelect />} />
<FullModalField
title={t('配色方案')}
content={
<Select
style={{ width: 280 }}
size="large"
value={colorScheme}
onChange={setColorScheme}
>
<Select.Option value="dark">{t('暗黑模式')}</Select.Option>
<Select.Option value="light">{t('亮色模式')}</Select.Option>
<Select.Option value="auto">{t('自动')}</Select.Option>
{pluginColorScheme.map((pcs, i) => (
<Select.Option key={pcs.name + i} value={pcs.name}>
{pcs.label}
</Select.Option>
))}
</Select>
}
/>
<FullModalField
title={t('聊天列表虚拟化') + ' (Beta)'}
content={
<Switch
disabled={loading}
checked={messageListVirtualization}
onChange={(checked) => setMessageListVirtualization(checked)}
/>
}
/>
</div>
);
});
SettingsSystem.displayName = 'SettingsSystem';