|  | 2 年 前 | |
|---|---|---|
| .. | ||
| lang | 2 年 前 | |
| README_CN.md | 2 年 前 | |
| README_EN.md | 2 年 前 | |
| client.ts | 2 年 前 | |
| i18next-config.ts | 2 年 前 | |
| i18next-serverside-config.ts | 2 年 前 | |
| index.ts | 2 年 前 | |
| server.ts | 2 年 前 | |
api/libs/helper.py:117 中添加对应的语言支持。如:
def supported_language(lang):
    if lang in ['en-US', 'zh-Hans', 'de', 'de-AT']:
        return lang
在 web/i18n/lang 下添加不同模块的多语言文件。文件命令为 模块名.{LANG}.ts。详细参考LANG
在 web/i18n/i18next-config.ts 中 resources 对象中中引入新添加的多语言文件。如:
const resources = {
    'en': {...},
    'zh-Hans': {...},
    // 引入新添加的语言
    'new LANG': {
      translation: {
        common: commonNewLan,
        layout: layoutNewLan,
        ...
      }
    }
}
目前日期做多语言格式化的文件涉及到如下 2 个:
1. web/app/components/header/account-setting/members-page/index.tsx
// Line: 78 
{dayjs(Number((account.last_login_at || account.created_at)) * 1000).locale(locale === 'zh-Hans' ? 'zh-cn' : 'en').fromNow()}
2. web/app/components/develop/secret-key/secret-key-modal.tsx
// Line:82
const formatDate = (timestamp: any) => {
    if (locale === 'en') {
      return new Intl.DateTimeFormat('en-US', { year: 'numeric', month: 'long', day: 'numeric' }).format((+timestamp) * 1000)
    } else {
      return new Intl.DateTimeFormat('fr-CA', { year: 'numeric', month: '2-digit', day: '2-digit' }).format((+timestamp) * 1000)
    }
  }
看需求做对应的改动。
翻译中会存在带变量的情况,变量的值会在运行时被替换。翻译中的变量会用{{ 和 }} 包裹。 翻译带变量的内容时:
查找所有翻译中带变量的方式:在 ./web/i18n/lang 下搜索:{{。
如果某个翻译的内容比其他语言的长很多,检查下是否会破坏 UI。
目前的帮助文档的调整逻辑是:中文跳转中文,其他语言跳英文。如果帮助文档也做了多语言。需要做这块的改动。
新增语言包建议通过本地部署最新代码来验证,可参考:https://docs.dify.ai/getting-started/install-self-hosted/local-source-code 验证点: