mirror of
https://gitee.com/nocobase/nocobase.git
synced 2025-05-08 15:09:27 +08:00
* fix: add license code * fix: bug * fix: bug * fix: upgrade * fix: improve * chore: add copyright information to the file header * fix: d.ts bug * fix: bug * fix: e2e bug * fix: merge main --------- Co-authored-by: chenos <chenlinxh@gmail.com>
57 lines
1.7 KiB
TypeScript
57 lines
1.7 KiB
TypeScript
/**
|
|
* This file is part of the NocoBase (R) project.
|
|
* Copyright (c) 2020-2024 NocoBase Co., Ltd.
|
|
* Authors: NocoBase Team.
|
|
*
|
|
* This project is dual-licensed under AGPL-3.0 and NocoBase Commercial License.
|
|
* For more information, please refer to: https://www.nocobase.com/agreement.
|
|
*/
|
|
|
|
import { MenuProps } from 'antd';
|
|
import React, { useMemo } from 'react';
|
|
import { useTranslation } from 'react-i18next';
|
|
import { SelectWithTitle, useAPIClient, useSystemSettings } from '..';
|
|
import locale from '../locale';
|
|
|
|
export const useLanguageSettings = () => {
|
|
const { t, i18n } = useTranslation();
|
|
const api = useAPIClient();
|
|
const { data } = useSystemSettings();
|
|
const enabledLanguages: string[] = useMemo(() => data?.data?.enabledLanguages || [], [data?.data?.enabledLanguages]);
|
|
const result = useMemo<MenuProps['items'][0]>(() => {
|
|
return {
|
|
key: 'language',
|
|
eventKey: 'LanguageSettings',
|
|
label: (
|
|
<SelectWithTitle
|
|
title={t('Language')}
|
|
options={Object.keys(locale)
|
|
.filter((lang) => enabledLanguages.includes(lang))
|
|
.map((lang) => {
|
|
return {
|
|
label: locale[lang].label,
|
|
value: lang,
|
|
};
|
|
})}
|
|
defaultValue={i18n.language}
|
|
onChange={async (lang) => {
|
|
await api.resource('users').updateProfile({
|
|
values: {
|
|
appLang: lang,
|
|
},
|
|
});
|
|
api.auth.setLocale(lang);
|
|
window.location.reload();
|
|
}}
|
|
/>
|
|
),
|
|
};
|
|
}, [api, enabledLanguages, i18n, t]);
|
|
|
|
if (enabledLanguages.length < 2) {
|
|
return null;
|
|
}
|
|
|
|
return result;
|
|
};
|