* Refactor translation imports and update text for localization across settings and system monitor routes - Changed translation import from 'react-i18next' to '@/i18n/react-i18next-compat' in multiple files. - Updated various text strings to use translation keys for better localization support in: - Local API Server settings - MCP Servers settings - Privacy settings - Provider settings - Shortcuts settings - System Monitor - Thread details - Ensured consistent use of translation keys for all user-facing text. Update web-app/src/routes/settings/appearance.tsx Co-authored-by: ellipsis-dev[bot] <65095814+ellipsis-dev[bot]@users.noreply.github.com> Update web-app/src/routes/settings/appearance.tsx Co-authored-by: ellipsis-dev[bot] <65095814+ellipsis-dev[bot]@users.noreply.github.com> Update web-app/src/locales/vn/settings.json Co-authored-by: ellipsis-dev[bot] <65095814+ellipsis-dev[bot]@users.noreply.github.com> Update web-app/src/containers/dialogs/DeleteMCPServerConfirm.tsx Co-authored-by: ellipsis-dev[bot] <65095814+ellipsis-dev[bot]@users.noreply.github.com> Update web-app/src/locales/id/common.json Co-authored-by: ellipsis-dev[bot] <65095814+ellipsis-dev[bot]@users.noreply.github.com> * Add Chinese (Simplified and Traditional) localization files for various components - Created `tools.json`, `updater.json`, `assistants.json`, `chat.json`, `common.json`, `hub.json`, `logs.json`, `mcp-servers.json`, `provider.json`, `providers.json`, `settings.json`, `setup.json`, `system-monitor.json`, `tool-approval.json` in both `zh-CN` and `zh-TW` locales. - Added translations for tool approval, updater notifications, assistant management, chat interface, common UI elements, hub interactions, logging messages, MCP server configurations, provider management, settings options, setup instructions, and system monitoring. * Refactor localization strings for improved clarity and consistency in English, Indonesian, and Vietnamese settings files * Fix missing key and reword * fix pr comment --------- Co-authored-by: ellipsis-dev[bot] <65095814+ellipsis-dev[bot]@users.noreply.github.com>
34 lines
1.1 KiB
TypeScript
34 lines
1.1 KiB
TypeScript
import { useAppTranslation } from './hooks'
|
|
|
|
// Compatibility layer for react-i18next
|
|
// This allows existing code to work without changes
|
|
|
|
/**
|
|
* Hook that mimics react-i18next's useTranslation hook
|
|
* @param namespace - Optional namespace (not used in our implementation as we handle it in the key)
|
|
* @returns Object with t function and i18n instance
|
|
*/
|
|
export const useTranslation = (namespace?: string) => {
|
|
const { t, i18n: i18nInstance } = useAppTranslation()
|
|
|
|
// If namespace is provided, we can prefix keys with it
|
|
const namespacedT = namespace
|
|
? (key: string, options?: Record<string, unknown>) => {
|
|
// If key already has namespace, use as-is, otherwise prefix with namespace
|
|
const finalKey = key.includes(':') ? key : `${namespace}:${key}`
|
|
return t(finalKey, options)
|
|
}
|
|
: t
|
|
|
|
return {
|
|
t: namespacedT,
|
|
i18n: i18nInstance,
|
|
}
|
|
}
|
|
|
|
// Export the i18n instance for direct usage
|
|
export { default as i18n } from './setup'
|
|
|
|
// Re-export other utilities
|
|
export { TranslationProvider } from './TranslationContext'
|
|
export { useAppTranslation } from './hooks' |