@liberfi.io/i18n 0.1.13 → 0.1.15

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/types.ts","../src/constant.ts","../src/locale/module/channels.ts","../src/locale/module/common.ts","../src/locale/module/mediaTrack.ts","../src/locale/module/scaffold.ts","../src/locale/module/tokens.ts","../src/locale/en.ts","../src/i18n.ts","../src/backend.ts","../src/context.ts","../src/utils/getLocalePathFromPathname.ts","../src/utils/parseI18nLang.ts","../src/utils/generatePath.ts","../src/utils/removeLangPrefix.ts","../src/provider.tsx","../src/useTranslation.ts","../src/useLocale.ts","../src/useChangeLocale.ts"],"names":["LocaleEnum","defaultLanguages","defaultLng","defaultNS","i18nLocalStorageKey","i18nCookieKey","channels","common","mediaTrack","scaffold","tokens","en","i18n","createInstance","LanguageDetector","initReactI18next","i18n_default","Backend","options","url","error","lang","ns","paths","promises","path","data","LocaleContext","createContext","useLocaleContext","context","useContext","getLocalePathFromPathname","pathname","localeCodes","locale","parseI18nLang","defaultLang","regex","match","matchLang","generatePath","params","search","searchUrl","localePath","removeLangPrefix","LocaleProvider","children","resource","resources","backend","supportedLanguages","convertDetectedLanguage","languagesProp","beforeLanguageChange","afterLanguageChange","languages","setLanguages","useState","backendRef","useRef","useEffect","messages","localCode","l","item","beforeLanguageChangeHandler","useCallback","afterLanguageChangeHandler","contextValue","useMemo","jsx","I18nextProvider","useTranslation","I18nContext","_useTranslation","useLocale","localeCode","setLocaleCode","useChangeLocale"],"mappings":"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","file":"index.mjs","sourcesContent":["// import the original type declarations\nimport \"i18next\";\n// import all namespaces (for the default language, only)\nimport { en } from \"./locale/en\";\n\nexport enum LocaleEnum {\n /** English */\n en = \"en\",\n /** Chinese */\n zh = \"zh\",\n /** Japanese */\n ja = \"ja\",\n /** Spanish */\n es = \"es\",\n /** Korean */\n ko = \"ko\",\n /** Vietnamese */\n vi = \"vi\",\n /** German */\n de = \"de\",\n /** French */\n fr = \"fr\",\n /** Russian */\n ru = \"ru\",\n /** Indonesian */\n id = \"id\",\n /** Turkish */\n tr = \"tr\",\n /** Italian */\n it = \"it\",\n /** Portuguese */\n pt = \"pt\",\n /** Ukrainian */\n uk = \"uk\",\n /** Polish */\n pl = \"pl\",\n /** Dutch */\n nl = \"nl\",\n}\n\nexport type LocaleCode = keyof typeof LocaleEnum | (string & {});\n\nexport type Language = {\n localCode: LocaleCode;\n displayName: string;\n};\n\nexport type ExtendLocaleMessages = Record<`extend.${string}`, string>;\n\nexport type LocaleMessages = typeof en & ExtendLocaleMessages;\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nexport type Resources<T extends {} = {}> = {\n [key in LocaleCode]?: Partial<LocaleMessages & T>;\n};\n\n// https://www.i18next.com/overview/typescript#create-a-declaration-file\n// Enhance the input parameter intelliSense for the t function.\ndeclare module \"i18next\" {\n // Extend CustomTypeOptions\n interface CustomTypeOptions {\n // custom namespace type, if you changed it\n defaultNS: \"translation\";\n // custom resources type\n resources: {\n translation: LocaleMessages;\n };\n }\n}\n","import { Language, LocaleEnum } from \"./types\";\n\nexport const defaultLanguages: Language[] = [\n { localCode: LocaleEnum.en, displayName: \"English\" }, // English\n { localCode: LocaleEnum.zh, displayName: \"中文\" }, // Chinese\n { localCode: LocaleEnum.ja, displayName: \"日本語\" }, // Japanese\n { localCode: LocaleEnum.es, displayName: \"Español\" }, // Spanish\n { localCode: LocaleEnum.ko, displayName: \"한국어\" }, // Korean\n { localCode: LocaleEnum.vi, displayName: \"Tiếng Việt\" }, // Vietnamese\n { localCode: LocaleEnum.de, displayName: \"Deutsch\" }, // German\n { localCode: LocaleEnum.fr, displayName: \"Français\" }, // French\n { localCode: LocaleEnum.ru, displayName: \"Русский\" }, // Russian\n { localCode: LocaleEnum.id, displayName: \"Bahasa Indonesia\" }, // Indonesian\n { localCode: LocaleEnum.tr, displayName: \"Türkçe\" }, // Turkish\n { localCode: LocaleEnum.it, displayName: \"Italiano\" }, // Italian\n { localCode: LocaleEnum.pt, displayName: \"Português\" }, // Portuguese\n { localCode: LocaleEnum.uk, displayName: \"Українська\" }, // Ukrainian\n { localCode: LocaleEnum.pl, displayName: \"Polski\" }, // Polish\n { localCode: LocaleEnum.nl, displayName: \"Nederlands\" }, // Dutch\n];\n\nexport const defaultLng = LocaleEnum.en;\n\nexport const defaultNS = \"translation\";\n\nexport const i18nLocalStorageKey = \"liberfi_i18nLng\";\n\nexport const i18nCookieKey = \"liberfi_i18nLng\";\n","export const channels = {\n \"channels.forms.base.title\": \"Base Info\",\n \"channels.forms.base.name.label\": \"Name\",\n \"channels.forms.base.name.placeholder\": \"Please enter the channel name\",\n \"channels.forms.base.name.required\": \"Name is required\",\n \"channels.forms.base.name.min\": \"Name must be at least 1 character\",\n \"channels.forms.base.name.max\": \"Name must be less than 24 characters\",\n \"channels.forms.base.description.label\": \"Description\",\n \"channels.forms.base.description.placeholder\":\n \"Please enter the channel description\",\n \"channels.forms.base.icon.label\": \"Icon\",\n \"channels.forms.base.icon.placeholder\": \"Please upload the channel icon\",\n \"channels.forms.base.icon.hint\":\n \"A square image of at least 128x128 is suggested. File size cannot exceed 10mb.\",\n \"channels.forms.base.icon.required\": \"Icon is required\",\n \"channels.forms.base.icon.maxSize\": \"Icon size cannot exceed 10MB\",\n \"channels.forms.base.submit\": \"Create Channel\",\n \"channels.forms.base.update.submit\": \"Update Channel\",\n \"channels.forms.wallets.title\": \"Wallet Management\",\n \"channels.forms.wallets.label\": \"Add Wallets\",\n \"channels.forms.wallets.placeholder\":\n \"Text Format:\\n8zFZHuSRuDpuAR7J6FzwyF3vKNx4CVW3DFHJerQhc7Zd,pow\\n0x4DB5a66E937A9F4473fA95b1cAF1d1E1D62E29EA,Smart Money\",\n \"channels.forms.wallets.required\": \"Wallets are required\",\n \"channels.forms.wallets.invalid\": \"Invalid wallets format\",\n \"channels.forms.wallets.chain.required\": \"Chain is required\",\n \"channels.forms.wallets.address.required\": \"Wallet address is required\",\n \"channels.forms.wallets.address.duplicated\":\n \"There are {{count}} duplicated wallet addresses in the input\",\n \"channels.forms.wallets.address.invalid\":\n \"There are {{count}} invalid wallet addresses\",\n \"channels.forms.wallets.address.alreadyAdded\":\n \"There are {{count}} wallet addresses already added\",\n \"channels.forms.wallets.maxCount\": \"Wallet count cannot exceed 500\",\n \"channels.forms.wallets.submit\": \"Add Wallets\",\n \"channels.forms.wallets.supportedFormats\": \"Supported Formats\",\n \"channels.forms.wallets.supportedFormats.text\": \"Text\",\n \"channels.forms.wallets.supportedFormats.text.hint\":\n \"Text Format:\\n\\n8zFZHuSRuDpuAR7J6FzwyF3vKNx4CVW3DFHJerQhc7Zd,pow\\n0x4DB5a66E937A9F4473fA95b1cAF1d1E1D62E29EA,Smart Money\",\n \"channels.forms.wallets.addedCount\": \"added wallets\",\n \"channels.forms.wallets.list.title\": \"Added Wallets\",\n \"channels.forms.wallets.list.header.address\": \"Alias/Address\",\n \"channels.forms.wallets.list.header.balance\": \"Balance\",\n \"channels.forms.wallets.list.header.importedAt\": \"Imported At\",\n \"channels.forms.wallets.list.header.lastActiveAt\": \"Last Active At\",\n \"channels.forms.wallets.list.header.7dBuys\": \"7 Days Buys\",\n \"channels.forms.wallets.list.header.7dSells\": \"7 Days Sells\",\n \"channels.forms.wallets.list.header.actions\": \"Actions\",\n \"channels.forms.wallets.list.empty\": \"No wallets added yet\",\n \"channels.forms.wallets.list.search.placeholder\":\n \"Search by address or alias\",\n \"channels.forms.wallets.update.success\": \"Update wallets successfully\",\n \"channels.forms.wallets.update.error\": \"Update wallets error\",\n \"channels.forms.socials.title\": \"Social Medias\",\n \"channels.forms.socials.telegram.guide\":\n \"⚡️ Quick Start\\n1. Search for @BotFather on Telegram\\n2. Send /newbot to create a bot and get Token\\n3. Enter the Bot Token here and save\\n4. Add the bot to your group/channel\",\n \"channels.forms.socials.telegram.placeholder\":\n \"Enter your Telegram Bot Token\",\n \"channels.list.title\": \"Channel List\",\n \"channels.trending.title\": \"Trending Channels\",\n \"channels.my.title\": \"My Channels\",\n \"channels.subscribe.submit\": \"Subscribe\",\n \"channels.subscribe.error\": \"Subscribe channel error\",\n \"channels.subscribe.success\": \"Subscribe channel successfully\",\n \"channels.unsubscribe.submit\": \"Subscribed\",\n \"channels.unsubscribe.error\": \"Unsubscribe channel error\",\n \"channels.unsubscribe.success\": \"Unsubscribe channel successfully\",\n \"channels.subscribed.title\": \"Subscribed Channels\",\n \"channels.create.title\": \"Create Channel\",\n \"channels.create.success\": \"Channel created successfully\",\n \"channels.create.error\": \"Create channel error\",\n \"channels.update.title\": \"Update Channel\",\n \"channels.update.success\": \"Channel updated successfully\",\n \"channels.update.error\": \"Update channel error\",\n \"channels.info.walletCount\": \"Wallet Count\",\n \"channels.info.subscribeCount\": \"Subscribe Count\",\n \"channels.info.createdAt\": \"created at\",\n \"channels.info.updatedAt\": \"last updated at\",\n \"channels.stats.7dTxs.title\": \"7D TXs\",\n \"channels.stats.7dTxs.hint\": \"7 Days Transactions\",\n \"channels.stats.7dPnl.title\": \"7D PnL\",\n \"channels.stats.7dPnl.hint\": \"7 Days Profit and Loss\",\n \"channels.stats.7dWr.title\": \"7D WR\",\n \"channels.stats.7dWr.hint\": \"7 Days Winning Rate\",\n \"channels.detail.title\": \"Channel Detail\",\n \"channels.detail.notfound\": \"Channel not found\",\n \"channels.events.title\": \"Channel Events\",\n \"channels.events.empty\": \"No events yet\",\n \"channels.events.walletTrade.buy\": \"bought\",\n \"channels.events.walletTrade.sell\": \"sold\",\n \"channels.events.walletTrade.got\": \"got\",\n \"channels.events.walletTrade.cost\": \"cost\",\n \"channels.events.walletTrade.price\": \"price\",\n};\n","export const common = {\n \"common.cancel\": \"Cancel\",\n \"common.confirm\": \"Confirm\",\n \"common.reset\": \"Reset\",\n \"common.apply\": \"Apply\",\n \"common.ok\": \"OK\",\n \"common.yes\": \"Yes\",\n \"common.no\": \"No\",\n \"common.all\": \"All\",\n \"common.buy\": \"Buy\",\n \"common.sell\": \"Sell\",\n \"common.long\": \"Long\",\n \"common.short\": \"Short\",\n \"common.edit\": \"Edit\",\n \"common.save\": \"Save\",\n \"common.add\": \"Add\",\n \"common.delete\": \"Delete\",\n \"common.tips\": \"Tips\",\n \"common.max\": \"Max\",\n \"common.download\": \"Download\",\n \"common.copy\": \"Copy\",\n \"common.copy.failed\": \"Copy failed\",\n \"common.copy.copied\": \"Copied to clipboard\",\n \"common.share\": \"Share\",\n \"common.export\": \"Export\",\n \"common.empty\": \"No data\",\n \"common.unauthenticated\": \"Please sign in to continue\",\n \"common.signIn\": \"Sign In\",\n \"common.signOut\": \"Sign Out\",\n \"common.resolution.1s\": \"1s\",\n \"common.resolution.15s\": \"15s\",\n \"common.resolution.30s\": \"30s\",\n \"common.resolution.1m\": \"1m\",\n \"common.resolution.5m\": \"5m\",\n \"common.resolution.15m\": \"15m\",\n \"common.resolution.30m\": \"30m\",\n \"common.resolution.1h\": \"1h\",\n \"common.resolution.4h\": \"4h\",\n \"common.resolution.12h\": \"12h\",\n \"common.resolution.24h\": \"24h\",\n \"common.upload.submit\": \"Upload\",\n \"common.upload.resubmit\": \"Reupload\",\n \"common.upload.error\": \"Upload error\",\n \"common.loadingMore\": \"Loading more...\",\n};\n","export const mediaTrack = {\n \"mediaTrack.tweets.translate.show\": \"Show Translation\",\n \"mediaTrack.tweets.translate.hide\": \"Hide Translation\",\n \"mediaTrack.tweets.expand\": \"Expand\",\n \"mediaTrack.tweets.collapse\": \"Collapse\",\n};\n","export const scaffold = {\n \"scaffold.draggableModal.snapToEdge\": \"Drag to edge to show side panel\",\n \"scaffold.draggablePanel.snapToModal\": \"Drag away to show floating modal\",\n \"scaffold.home\": \"Home\",\n};\n","export const tokens = {\n \"tokens.search.placeholder\": \"Search by token or CA...\",\n \"tokens.copied.address\": \"Token address copied to clipboard\",\n \"tokens.listHeader.token\": \"Token\",\n \"tokens.listHeader.priceHistories\": \"Price Histories\",\n \"tokens.listHeader.price\": \"Price\",\n \"tokens.listHeader.priceChange\": \"{{resolution}}%\",\n \"tokens.listHeader.marketCap\": \"Market Cap\",\n \"tokens.listHeader.liquidity\": \"Liquidity\",\n \"tokens.listHeader.volumes\": \"{{resolution}} Volumes\",\n \"tokens.listHeader.txs\": \"{{resolution}} TXNS\",\n \"tokens.listHeader.traders\": \"{{resolution}} Traders\",\n \"tokens.listHeader.bluechip\": \"BlueChip\",\n \"tokens.listHeader.tokenInfo\": \"Token Info\",\n \"tokens.listHeader.actions\": \"Actions\",\n \"tokens.listHeader.filter\": \"Filter\",\n \"tokens.listType.trending\": \"Trending\",\n \"tokens.listType.new\": \"New\",\n \"tokens.listType.stocks\": \"Stocks\",\n \"tokens.filters.protocols.title\": \"Protocols\",\n \"tokens.filters.protocols.selectAll\": \"Select All\",\n \"tokens.filters.protocols.unselectAll\": \"Unselect All\",\n \"tokens.filters.keywords.title\": \"Search Keywords\",\n \"tokens.filters.keywords.exclude.title\": \"Exclude Keywords\",\n \"tokens.filters.keywords.placeholder\": \"keyword1, keyword2...\",\n \"tokens.filters.stats.min\": \"Min\",\n \"tokens.filters.stats.max\": \"Max\",\n \"tokens.filters.stats.audits\": \"Audits\",\n \"tokens.filters.stats.audits.holders\": \"Holders Count\",\n \"tokens.filters.stats.audits.top10HoldingsRatio\": \"Top 10 Holders %\",\n \"tokens.filters.stats.audits.top100HoldingsRatio\": \"Top 100 Holders %\",\n \"tokens.filters.stats.audits.devHoldingsRatio\": \"Dev Holdings %\",\n \"tokens.filters.stats.metrics\": \"Metrics\",\n \"tokens.filters.stats.metrics.volumes\": \"{{resolution}} Volumes ($)\",\n \"tokens.filters.stats.metrics.txns\": \"{{resolution}} Transactions\",\n \"tokens.filters.stats.metrics.liquidity\": \"Liquidity ($)\",\n \"tokens.filters.stats.metrics.marketCap\": \"Market Cap ($)\",\n \"tokens.filters.modal.title\": \"Filters\",\n \"tokens.tokenInfo.holders\": \"Holders\",\n \"tokens.tokenInfo.proHolders\": \"Pro Holders\",\n \"tokens.tokenInfo.kolHolders\": \"KOL Holders\",\n \"tokens.tokenInfo.top10HoldingsRatio\": \"Top 10 Holders\",\n \"tokens.tokenInfo.top100HoldingsRatio\": \"Top 100 Holders\",\n \"tokens.tokenInfo.devHoldingsRatio\": \"Dev Holders\",\n \"tokens.tokenInfo.sniperHoldingsRatio\": \"Snipers\",\n \"tokens.tokenInfo.insiderHoldingsRatio\": \"Insiders\",\n \"tokens.tokenInfo.bundleHoldingsRatio\": \"Bundlers\",\n \"tokens.bluechip.explained\":\n \"BlueChip index is the ratio of holders who also own BlueChip tokens\",\n};\n","import { channels } from \"./module/channels\";\nimport { common } from \"./module/common\";\nimport { mediaTrack } from \"./module/mediaTrack\";\nimport { scaffold } from \"./module/scaffold\";\nimport { tokens } from \"./module/tokens\";\n\nexport const en = {\n ...common,\n ...mediaTrack,\n ...scaffold,\n ...tokens,\n ...channels,\n};\n","import { initReactI18next } from \"react-i18next\";\nimport { i18n as I18nInstance, createInstance } from \"i18next\";\nimport LanguageDetector from \"i18next-browser-languagedetector\";\nimport {\n defaultLng,\n defaultNS,\n i18nCookieKey,\n i18nLocalStorageKey,\n} from \"./constant\";\nimport { en } from \"./locale/en\";\n\nconst i18n: I18nInstance = createInstance();\n\ni18n\n .use(LanguageDetector)\n .use(initReactI18next) // bind react-i18next to the instance\n .init({\n fallbackLng: defaultLng,\n ns: [defaultNS],\n defaultNS,\n interpolation: {\n escapeValue: false, // not needed for react!!\n },\n detection: {\n lookupLocalStorage: i18nLocalStorageKey,\n lookupCookie: i18nCookieKey,\n caches: [\"cookie\", \"localStorage\"],\n order: [\"cookie\", \"localStorage\", \"htmlTag\", \"navigator\"],\n },\n resources: {\n [defaultLng]: { [defaultNS]: en },\n },\n });\n\nexport default i18n;\n","import i18n from \"./i18n\";\nimport { LocaleCode } from \"./types\";\n\nexport type BackendOptions = {\n /**\n * Load url for a given language and namespace\n * @param lang language code\n * @param ns namespace\n * @returns url or urls\n */\n loadPath: (lang: LocaleCode, ns: string) => string | string[];\n};\n\n/**\n * Async resources loading through HTTP, resources must be placed in the site's public directory\n */\nexport class Backend {\n private readonly cache: Set<string>;\n\n constructor(private readonly options?: BackendOptions) {\n this.cache = new Set();\n }\n\n async fetchData(url: string): Promise<Record<string, string>> {\n try {\n const res = await fetch(url);\n return await res.json();\n } catch (error) {\n console.warn(\n `Failed to fetch locale resource bundle from ${url}:`,\n error,\n );\n return {};\n }\n }\n\n async loadLanguage(lang: LocaleCode, ns: string) {\n if (typeof this.options?.loadPath !== \"function\") return;\n\n // get load url paths\n let paths = this.options.loadPath(lang, ns);\n if (typeof paths === \"string\") paths = [paths];\n if (!paths.length) return;\n\n // filter out the paths that have already been loaded\n const urls = paths.filter((path) => {\n const loaded = i18n.hasResourceBundle(lang, ns);\n return !loaded || !this.cache.has(path);\n });\n\n const promises = urls.map(async (url) => {\n const data = await this.fetchData(url);\n i18n.addResourceBundle(lang, ns, data, true, true);\n this.cache.add(url);\n });\n await Promise.all(promises);\n }\n}\n","import { createContext, useContext } from \"react\";\nimport { Language, LocaleCode } from \"./types\";\n\nexport type LocaleContextState = {\n /**\n * Supported languages\n */\n languages: Language[];\n\n /**\n * Called before language change\n * @param lang - new language code\n * @returns\n */\n beforeLanguageChange: (lang: LocaleCode) => Promise<void>;\n /**\n * Called after language changed\n * @param lang - new language code\n * @returns\n */\n afterLanguageChange: (lang: LocaleCode) => Promise<void>;\n};\n\nexport const LocaleContext = createContext<LocaleContextState>({\n languages: [],\n beforeLanguageChange: () => Promise.resolve(),\n afterLanguageChange: () => Promise.resolve(),\n});\n\nexport const useLocaleContext = () => {\n const context = useContext(LocaleContext);\n if (!context) {\n throw new Error(\"useLocaleContext must be used within a LocaleProvider\");\n }\n return context;\n};\n","import { LocaleEnum } from \"../types\";\n\n/**\n * get locale path from pathname\n * @param pathname - pathname to get locale path\n * @param localeCodes - locale codes to check\n * @example\n * getLocalePathFromPathname('/en/perp/PERP_ETH_USDC') => 'en'\n * getLocalePathFromPathname('/perp/PERP_ETH_USDC') => null\n * getLocalePathFromPathname('/en/markets') => 'en'\n * getLocalePathFromPathname('/markets') => null\n */\nexport function getLocalePathFromPathname(\n pathname: string,\n localeCodes?: string[],\n) {\n const locale = pathname.split(\"/\")[1];\n localeCodes = localeCodes || Object.values(LocaleEnum);\n return localeCodes.includes(locale as LocaleEnum) ? locale : null;\n}\n","import { type LocaleCode, LocaleEnum } from \"../types\";\n\n/**\n * transform browser language to i18n locale codes\n * @param lang - browser language\n * @param localeCodes - locale codes to check\n * @param defaultLang - default locale code\n * @example\n * parseI18nLang('en-US') => 'en'\n * parseI18nLang('zh-CN') => 'zh'\n * parseI18nLang('zh-TW') => 'zh'\n * parseI18nLang('ja') => 'ja'\n * */\nexport function parseI18nLang(\n lang: string,\n localeCodes?: LocaleCode[],\n defaultLang?: LocaleCode,\n) {\n localeCodes = localeCodes || Object.values(LocaleEnum);\n defaultLang = defaultLang || LocaleEnum.en;\n\n const regex = /^([a-z]{2})/i;\n const match = lang?.match(regex);\n\n if (!match) {\n return defaultLang;\n }\n\n const matchLang = match[1];\n\n if (localeCodes.includes(lang)) {\n return lang;\n }\n\n if (localeCodes.includes(matchLang)) {\n return matchLang;\n }\n\n return defaultLang;\n}\n","import i18n from \"../i18n\";\nimport { getLocalePathFromPathname } from \"./getLocalePathFromPathname\";\nimport { parseI18nLang } from \"./parseI18nLang\";\n\n/**\n * Generate a localized path with proper locale prefix and search parameters\n *\n * This function ensures that the returned path includes the appropriate locale prefix.\n * If the path already contains a valid locale prefix, it returns the path as-is.\n * Otherwise, it prepends the specified locale or falls back to the current i18n language.\n *\n * @param params - Configuration object for path generation\n * @param params.path - The base pathname (e.g., '/markets', '/perp/PERP_ETH_USDC')\n * @param params.locale - Optional locale code to use as prefix. If not provided, uses i18n.language\n * @param params.search - Optional search query string. If not provided, uses window.location.search\n *\n * @returns A complete URL path with locale prefix and search parameters\n *\n * @example\n * generatePath({ path: '/markets' }) => '/en/markets?tab=spot'\n * generatePath({ path: '/en/markets', search: '?tab=futures' }) => '/en/markets?tab=futures'\n * generatePath({ path: '/perp/PERP_ETH_USDC', locale: 'zh' }) => '/zh/perp/PERP_ETH_USDC'\n * generatePath({ path: '/en/perp/PERP_ETH_USDC' }) => '/en/perp/PERP_ETH_USDC'\n */\nexport function generatePath(params: {\n path: string;\n locale?: string;\n search?: string;\n}) {\n const { path, locale, search } = params;\n const searchUrl =\n search || (typeof window !== \"undefined\" ? window.location.search : \"\");\n\n let localePath = getLocalePathFromPathname(path);\n\n // If path already contains a valid locale prefix, return it unchanged\n if (localePath) {\n return `${path}${searchUrl}`;\n }\n\n // Use provided locale or fall back to current i18n language\n localePath = locale || parseI18nLang(i18n.language);\n\n // Prepend locale prefix to path\n return `/${localePath}${path}${searchUrl}`;\n}\n","import { getLocalePathFromPathname } from \"./getLocalePathFromPathname\";\n\n/**\n * remove lang prefix from pathname\n * @param pathname - pathname to remove lang prefix\n * @param localeCodes - locale codes to check\n * @example\n * removeLangPrefix('/en/perp/PERP_ETH_USDC') => '/perp/PERP_ETH_USDC'\n * removeLangPrefix('/en/markets') => '/markets'\n * removeLangPrefix('/perp/PERP_ETH_USDC') => '/perp/PERP_ETH_USDC'\n * removeLangPrefix('/markets') => '/markets'\n */\nexport function removeLangPrefix(pathname: string, localeCodes?: string[]) {\n const localePath = getLocalePathFromPathname(pathname, localeCodes);\n\n return localePath\n ? pathname.replace(new RegExp(`^/${localePath}(?=/)`), \"\")\n : pathname;\n}\n","import {\n PropsWithChildren,\n useCallback,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from \"react\";\nimport { I18nextProvider } from \"react-i18next\";\nimport { Backend, BackendOptions } from \"./backend\";\nimport { defaultLanguages, defaultNS } from \"./constant\";\nimport { LocaleContext, LocaleContextState } from \"./context\";\nimport i18n from \"./i18n\";\nimport { LocaleCode, Resources, Language } from \"./types\";\nimport { parseI18nLang } from \"./utils\";\n\nexport type LocaleProviderProps = PropsWithChildren<\n {\n /** current locale */\n locale?: LocaleCode;\n /** current locale's resource */\n resource?: Record<string, string>;\n /** all synchronously loaded resources */\n resources?: Resources;\n /** supported languages, must be a subset of {@link defaultLanguages}, used when {@link languages} is not provided */\n supportedLanguages?: LocaleCode[];\n /** optional conversion function to modify the detected language code */\n convertDetectedLanguage?: (lang: string) => LocaleCode;\n /** options to load resources asynchronously */\n backend?: BackendOptions;\n } & Partial<LocaleContextState>\n>;\n\nexport function LocaleProvider({\n children,\n locale,\n resource,\n resources,\n backend,\n supportedLanguages,\n convertDetectedLanguage,\n languages: languagesProp,\n beforeLanguageChange,\n afterLanguageChange,\n}: LocaleProviderProps) {\n // calculated supported languages\n const [languages, setLanguages] = useState<Language[]>(defaultLanguages);\n\n // backend instance to load resources asynchronously\n const backendRef = useRef(new Backend(backend!));\n\n // load resources synchronously\n useEffect(() => {\n if (resources) {\n Object.entries(resources).forEach(([locale, messages]) => {\n i18n.addResourceBundle(locale, defaultNS, messages, true, true);\n });\n return;\n }\n if (resource && locale) {\n i18n.addResourceBundle(locale, defaultNS, resource, true, true);\n }\n }, [locale, resource, resources]);\n\n // change language when locale changed\n useEffect(() => {\n if (locale && locale !== i18n.language) {\n i18n.changeLanguage(locale);\n }\n }, [locale]);\n\n // calculate supported languages\n useEffect(() => {\n if (Array.isArray(languagesProp)) {\n setLanguages(languagesProp);\n } else if (Array.isArray(supportedLanguages)) {\n setLanguages(\n supportedLanguages\n .map((localCode) =>\n defaultLanguages.find((l) => l.localCode === localCode),\n )\n .filter((item) => !!item),\n );\n }\n }, [supportedLanguages, languagesProp]);\n\n // if browser language is not a valid language, change language\n useEffect(() => {\n const fixLanguage = async () => {\n const lang =\n typeof convertDetectedLanguage === \"function\"\n ? convertDetectedLanguage(i18n.language)\n : parseI18nLang(i18n.language);\n await backendRef.current.loadLanguage(lang, defaultNS);\n if (lang !== i18n.language) {\n await i18n.changeLanguage(lang);\n }\n };\n fixLanguage();\n }, [i18n.language]);\n\n const beforeLanguageChangeHandler = useCallback(\n async (lang: LocaleCode) => {\n await beforeLanguageChange?.(lang);\n // load language before language changed\n await backendRef.current.loadLanguage(lang, defaultNS);\n },\n [beforeLanguageChange],\n );\n\n const afterLanguageChangeHandler = useCallback(\n async (lang: LocaleCode) => {\n afterLanguageChange?.(lang);\n },\n [afterLanguageChange],\n );\n\n const contextValue = useMemo<LocaleContextState>(() => {\n return {\n languages,\n beforeLanguageChange: beforeLanguageChangeHandler,\n afterLanguageChange: afterLanguageChangeHandler,\n };\n }, [languages, beforeLanguageChangeHandler, afterLanguageChangeHandler]);\n\n return (\n <LocaleContext.Provider value={contextValue}>\n <I18nextProvider i18n={i18n} defaultNS={defaultNS}>\n {children}\n </I18nextProvider>\n </LocaleContext.Provider>\n );\n}\n","import { useContext } from \"react\";\nimport {\n FallbackNs,\n useTranslation as _useTranslation,\n UseTranslationOptions,\n I18nContext,\n} from \"react-i18next\";\nimport { FlatNamespace, KeyPrefix } from \"i18next\";\nimport i18n from \"./i18n\";\n\ntype $Tuple<T> = readonly [T?, ...T[]];\n\n/**\n * Hook to get translation function\n * @param ns\n * @param options\n * @returns\n */\nexport function useTranslation<\n Ns extends FlatNamespace | $Tuple<FlatNamespace> | undefined = undefined,\n KPrefix extends KeyPrefix<FallbackNs<Ns>> = undefined,\n>(ns?: Ns, options?: UseTranslationOptions<KPrefix>) {\n const context = useContext(I18nContext);\n return _useTranslation(ns, { i18n: context?.i18n || i18n, ...options });\n}\n","import { useEffect, useState } from \"react\";\nimport i18n from \"./i18n\";\nimport { LocaleCode } from \"./types\";\n\n/**\n * Hooks to get current locale code\n * @returns current locale code\n */\nexport function useLocale() {\n const [localeCode, setLocaleCode] = useState<LocaleCode>(i18n.language);\n\n useEffect(() => {\n i18n.on(\"languageChanged\", setLocaleCode);\n return () => {\n i18n.off(\"languageChanged\", setLocaleCode);\n };\n }, [i18n]);\n\n return localeCode;\n}\n","import { useCallback } from \"react\";\nimport { useLocaleContext } from \"./context\";\nimport i18n from \"./i18n\";\nimport { LocaleCode } from \"./types\";\n\nexport function useChangeLocale() {\n const { beforeLanguageChange, afterLanguageChange } = useLocaleContext();\n\n const changeLocale = useCallback(\n async (locale: LocaleCode) => {\n await beforeLanguageChange(locale);\n await i18n.changeLanguage(locale);\n await afterLanguageChange(locale);\n },\n [beforeLanguageChange, afterLanguageChange, i18n],\n );\n\n return changeLocale;\n}\n"]}
1
+ {"version":3,"sources":["../src/types.ts","../src/constant.ts","../src/locale/module/channels.ts","../src/locale/module/common.ts","../src/locale/module/mediaTrack.ts","../src/locale/module/predict.ts","../src/locale/module/scaffold.ts","../src/locale/module/tokens.ts","../src/locale/en.ts","../src/i18n.ts","../src/backend.ts","../src/context.ts","../src/utils/getLocalePathFromPathname.ts","../src/utils/parseI18nLang.ts","../src/utils/generatePath.ts","../src/utils/removeLangPrefix.ts","../src/provider.tsx","../src/useTranslation.ts","../src/useLocale.ts","../src/useChangeLocale.ts"],"names":["LocaleEnum","defaultLanguages","defaultLng","defaultNS","i18nLocalStorageKey","i18nCookieKey","channels","common","mediaTrack","predict","scaffold","tokens","en","i18n","createInstance","LanguageDetector","initReactI18next","i18n_default","Backend","options","url","error","lang","ns","paths","promises","path","data","LocaleContext","createContext","useLocaleContext","context","useContext","getLocalePathFromPathname","pathname","localeCodes","locale","parseI18nLang","defaultLang","regex","match","matchLang","generatePath","params","search","searchUrl","localePath","removeLangPrefix","LocaleProvider","children","resource","resources","backend","supportedLanguages","convertDetectedLanguage","languagesProp","beforeLanguageChange","afterLanguageChange","languages","setLanguages","useState","backendRef","useRef","useEffect","messages","localCode","l","item","beforeLanguageChangeHandler","useCallback","afterLanguageChangeHandler","contextValue","useMemo","jsx","I18nextProvider","useTranslation","I18nContext","_useTranslation","useLocale","localeCode","setLocaleCode","useChangeLocale"],"mappings":"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","file":"index.mjs","sourcesContent":["// import the original type declarations\nimport \"i18next\";\n// import all namespaces (for the default language, only)\nimport { en } from \"./locale/en\";\n\nexport enum LocaleEnum {\n /** English */\n en = \"en\",\n /** Chinese */\n zh = \"zh\",\n /** Japanese */\n ja = \"ja\",\n /** Spanish */\n es = \"es\",\n /** Korean */\n ko = \"ko\",\n /** Vietnamese */\n vi = \"vi\",\n /** German */\n de = \"de\",\n /** French */\n fr = \"fr\",\n /** Russian */\n ru = \"ru\",\n /** Indonesian */\n id = \"id\",\n /** Turkish */\n tr = \"tr\",\n /** Italian */\n it = \"it\",\n /** Portuguese */\n pt = \"pt\",\n /** Ukrainian */\n uk = \"uk\",\n /** Polish */\n pl = \"pl\",\n /** Dutch */\n nl = \"nl\",\n}\n\nexport type LocaleCode = keyof typeof LocaleEnum | (string & {});\n\nexport type Language = {\n localCode: LocaleCode;\n displayName: string;\n};\n\nexport type ExtendLocaleMessages = Record<`extend.${string}`, string>;\n\nexport type LocaleMessages = typeof en & ExtendLocaleMessages;\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nexport type Resources<T extends {} = {}> = {\n [key in LocaleCode]?: Partial<LocaleMessages & T>;\n};\n\n// https://www.i18next.com/overview/typescript#create-a-declaration-file\n// Enhance the input parameter intelliSense for the t function.\ndeclare module \"i18next\" {\n // Extend CustomTypeOptions\n interface CustomTypeOptions {\n // custom namespace type, if you changed it\n defaultNS: \"translation\";\n // custom resources type\n resources: {\n translation: LocaleMessages;\n };\n }\n}\n","import { Language, LocaleEnum } from \"./types\";\n\nexport const defaultLanguages: Language[] = [\n { localCode: LocaleEnum.en, displayName: \"English\" }, // English\n { localCode: LocaleEnum.zh, displayName: \"中文\" }, // Chinese\n { localCode: LocaleEnum.ja, displayName: \"日本語\" }, // Japanese\n { localCode: LocaleEnum.es, displayName: \"Español\" }, // Spanish\n { localCode: LocaleEnum.ko, displayName: \"한국어\" }, // Korean\n { localCode: LocaleEnum.vi, displayName: \"Tiếng Việt\" }, // Vietnamese\n { localCode: LocaleEnum.de, displayName: \"Deutsch\" }, // German\n { localCode: LocaleEnum.fr, displayName: \"Français\" }, // French\n { localCode: LocaleEnum.ru, displayName: \"Русский\" }, // Russian\n { localCode: LocaleEnum.id, displayName: \"Bahasa Indonesia\" }, // Indonesian\n { localCode: LocaleEnum.tr, displayName: \"Türkçe\" }, // Turkish\n { localCode: LocaleEnum.it, displayName: \"Italiano\" }, // Italian\n { localCode: LocaleEnum.pt, displayName: \"Português\" }, // Portuguese\n { localCode: LocaleEnum.uk, displayName: \"Українська\" }, // Ukrainian\n { localCode: LocaleEnum.pl, displayName: \"Polski\" }, // Polish\n { localCode: LocaleEnum.nl, displayName: \"Nederlands\" }, // Dutch\n];\n\nexport const defaultLng = LocaleEnum.en;\n\nexport const defaultNS = \"translation\";\n\nexport const i18nLocalStorageKey = \"liberfi_i18nLng\";\n\nexport const i18nCookieKey = \"liberfi_i18nLng\";\n","export const channels = {\n \"channels.forms.base.title\": \"Base Info\",\n \"channels.forms.base.name.label\": \"Name\",\n \"channels.forms.base.name.placeholder\": \"Please enter the channel name\",\n \"channels.forms.base.name.required\": \"Name is required\",\n \"channels.forms.base.name.min\": \"Name must be at least 1 character\",\n \"channels.forms.base.name.max\": \"Name must be less than 24 characters\",\n \"channels.forms.base.description.label\": \"Description\",\n \"channels.forms.base.description.placeholder\":\n \"Please enter the channel description\",\n \"channels.forms.base.icon.label\": \"Icon\",\n \"channels.forms.base.icon.placeholder\": \"Please upload the channel icon\",\n \"channels.forms.base.icon.hint\":\n \"A square image of at least 128x128 is suggested. File size cannot exceed 10mb.\",\n \"channels.forms.base.icon.required\": \"Icon is required\",\n \"channels.forms.base.icon.maxSize\": \"Icon size cannot exceed 10MB\",\n \"channels.forms.base.submit\": \"Create Channel\",\n \"channels.forms.base.update.submit\": \"Update Channel\",\n \"channels.forms.wallets.title\": \"Wallet Management\",\n \"channels.forms.wallets.label\": \"Add Wallets\",\n \"channels.forms.wallets.placeholder\":\n \"Text Format:\\n8zFZHuSRuDpuAR7J6FzwyF3vKNx4CVW3DFHJerQhc7Zd,pow\\n0x4DB5a66E937A9F4473fA95b1cAF1d1E1D62E29EA,Smart Money\",\n \"channels.forms.wallets.required\": \"Wallets are required\",\n \"channels.forms.wallets.invalid\": \"Invalid wallets format\",\n \"channels.forms.wallets.chain.required\": \"Chain is required\",\n \"channels.forms.wallets.address.required\": \"Wallet address is required\",\n \"channels.forms.wallets.address.duplicated\":\n \"There are {{count}} duplicated wallet addresses in the input\",\n \"channels.forms.wallets.address.invalid\":\n \"There are {{count}} invalid wallet addresses\",\n \"channels.forms.wallets.address.alreadyAdded\":\n \"There are {{count}} wallet addresses already added\",\n \"channels.forms.wallets.maxCount\": \"Wallet count cannot exceed 500\",\n \"channels.forms.wallets.submit\": \"Add Wallets\",\n \"channels.forms.wallets.supportedFormats\": \"Supported Formats\",\n \"channels.forms.wallets.supportedFormats.text\": \"Text\",\n \"channels.forms.wallets.supportedFormats.text.hint\":\n \"Text Format:\\n\\n8zFZHuSRuDpuAR7J6FzwyF3vKNx4CVW3DFHJerQhc7Zd,pow\\n0x4DB5a66E937A9F4473fA95b1cAF1d1E1D62E29EA,Smart Money\",\n \"channels.forms.wallets.addedCount\": \"added wallets\",\n \"channels.forms.wallets.list.title\": \"Added Wallets\",\n \"channels.forms.wallets.list.header.address\": \"Alias/Address\",\n \"channels.forms.wallets.list.header.balance\": \"Balance\",\n \"channels.forms.wallets.list.header.importedAt\": \"Imported At\",\n \"channels.forms.wallets.list.header.lastActiveAt\": \"Last Active At\",\n \"channels.forms.wallets.list.header.7dBuys\": \"7 Days Buys\",\n \"channels.forms.wallets.list.header.7dSells\": \"7 Days Sells\",\n \"channels.forms.wallets.list.header.actions\": \"Actions\",\n \"channels.forms.wallets.list.empty\": \"No wallets added yet\",\n \"channels.forms.wallets.list.search.placeholder\":\n \"Search by address or alias\",\n \"channels.forms.wallets.update.success\": \"Update wallets successfully\",\n \"channels.forms.wallets.update.error\": \"Update wallets error\",\n \"channels.forms.socials.title\": \"Social Medias\",\n \"channels.forms.socials.telegram.guide\":\n \"⚡️ Quick Start\\n1. Search for @BotFather on Telegram\\n2. Send /newbot to create a bot and get Token\\n3. Enter the Bot Token here and save\\n4. Add the bot to your group/channel\",\n \"channels.forms.socials.telegram.placeholder\":\n \"Enter your Telegram Bot Token\",\n \"channels.list.title\": \"Channel List\",\n \"channels.trending.title\": \"Trending Channels\",\n \"channels.my.title\": \"My Channels\",\n \"channels.subscribe.submit\": \"Subscribe\",\n \"channels.subscribe.error\": \"Subscribe channel error\",\n \"channels.subscribe.success\": \"Subscribe channel successfully\",\n \"channels.unsubscribe.submit\": \"Subscribed\",\n \"channels.unsubscribe.error\": \"Unsubscribe channel error\",\n \"channels.unsubscribe.success\": \"Unsubscribe channel successfully\",\n \"channels.subscribed.title\": \"Subscribed Channels\",\n \"channels.create.title\": \"Create Channel\",\n \"channels.create.success\": \"Channel created successfully\",\n \"channels.create.error\": \"Create channel error\",\n \"channels.create.eligibility.title\": \"Check Eligibility\",\n \"channels.create.eligibility.description\":\n \"Verify your X (Twitter) account to ensure it meets the requirements for creating a channel.\",\n \"channels.create.eligibility.xConnection\": \"X Account Connection\",\n \"channels.create.eligibility.connected\": \"Connected as\",\n \"channels.create.eligibility.notConnected\": \"No X account connected\",\n \"channels.create.eligibility.connect\": \"Connect X Account\",\n \"channels.create.eligibility.disconnect\": \"Disconnect\",\n \"channels.create.eligibility.verifying\": \"Verifying eligibility...\",\n \"channels.create.eligibility.requirementsTitle\": \"Eligibility Requirements\",\n \"channels.create.eligibility.followersCount\": \"Followers Count\",\n \"channels.create.eligibility.accountAge\": \"Account Age\",\n \"channels.create.eligibility.behaviorScore\": \"Behavior Score\",\n \"channels.create.eligibility.clean\": \"Clean\",\n \"channels.create.eligibility.allPassed\":\n \"All eligibility checks passed! You can now create a channel.\",\n \"channels.create.eligibility.failed\":\n \"Some requirements are not met. Please check your account.\",\n \"channels.update.title\": \"Update Channel\",\n \"channels.update.success\": \"Channel updated successfully\",\n \"channels.update.error\": \"Update channel error\",\n \"channels.info.walletCount\": \"Wallet Count\",\n \"channels.info.subscribeCount\": \"Subscribe Count\",\n \"channels.info.createdAt\": \"created at\",\n \"channels.info.updatedAt\": \"last updated at\",\n \"channels.stats.7dTxs.title\": \"7D TXs\",\n \"channels.stats.7dTxs.hint\": \"7 Days Transactions\",\n \"channels.stats.7dPnl.title\": \"7D PnL\",\n \"channels.stats.7dPnl.hint\": \"7 Days Profit and Loss\",\n \"channels.stats.7dWr.title\": \"7D WR\",\n \"channels.stats.7dWr.hint\": \"7 Days Winning Rate\",\n \"channels.detail.title\": \"Channel Detail\",\n \"channels.detail.notfound\": \"Channel not found\",\n \"channels.events.title\": \"Channel Events\",\n \"channels.events.empty\": \"No events yet\",\n \"channels.events.walletTrade.buy\": \"bought\",\n \"channels.events.walletTrade.sell\": \"sold\",\n \"channels.events.walletTrade.got\": \"got\",\n \"channels.events.walletTrade.cost\": \"cost\",\n \"channels.events.walletTrade.price\": \"price\",\n};\n","export const common = {\n \"common.cancel\": \"Cancel\",\n \"common.confirm\": \"Confirm\",\n \"common.reset\": \"Reset\",\n \"common.apply\": \"Apply\",\n \"common.ok\": \"OK\",\n \"common.yes\": \"Yes\",\n \"common.no\": \"No\",\n \"common.all\": \"All\",\n \"common.buy\": \"Buy\",\n \"common.sell\": \"Sell\",\n \"common.long\": \"Long\",\n \"common.short\": \"Short\",\n \"common.edit\": \"Edit\",\n \"common.save\": \"Save\",\n \"common.add\": \"Add\",\n \"common.delete\": \"Delete\",\n \"common.tips\": \"Tips\",\n \"common.max\": \"Max\",\n \"common.download\": \"Download\",\n \"common.copy\": \"Copy\",\n \"common.copy.failed\": \"Copy failed\",\n \"common.copy.copied\": \"Copied to clipboard\",\n \"common.share\": \"Share\",\n \"common.export\": \"Export\",\n \"common.empty\": \"No data\",\n \"common.unauthenticated\": \"Please sign in to continue\",\n \"common.signIn\": \"Sign In\",\n \"common.signOut\": \"Sign Out\",\n \"common.resolution.1s\": \"1s\",\n \"common.resolution.15s\": \"15s\",\n \"common.resolution.30s\": \"30s\",\n \"common.resolution.1m\": \"1m\",\n \"common.resolution.5m\": \"5m\",\n \"common.resolution.15m\": \"15m\",\n \"common.resolution.30m\": \"30m\",\n \"common.resolution.1h\": \"1h\",\n \"common.resolution.4h\": \"4h\",\n \"common.resolution.12h\": \"12h\",\n \"common.resolution.24h\": \"24h\",\n \"common.upload.submit\": \"Upload\",\n \"common.upload.resubmit\": \"Reupload\",\n \"common.upload.error\": \"Upload error\",\n \"common.loadingMore\": \"Loading more...\",\n \"common.continue\": \"Continue\",\n \"common.months\": \"months\",\n \"common.days\": \"days\",\n};\n","export const mediaTrack = {\n \"mediaTrack.tweets.translate.show\": \"Show Translation\",\n \"mediaTrack.tweets.translate.hide\": \"Hide Translation\",\n \"mediaTrack.tweets.expand\": \"Expand\",\n \"mediaTrack.tweets.collapse\": \"Collapse\",\n};\n","export const predict = {\n // Event status\n \"predict.event.status.closed\": \"Closed\",\n \"predict.event.status.live\": \"Live\",\n \"predict.event.status.pending\": \"Pending\",\n\n // Event detail\n \"predict.event.volume\": \"vol\",\n \"predict.event.endDate\": \"Ends {{date}}\",\n \"predict.event.rules\": \"Rules\",\n \"predict.event.rules.collapse\": \"Collapse\",\n \"predict.event.rules.expand\": \"Expand all\",\n \"predict.event.showMore\": \"Show More\",\n \"predict.event.back\": \"Back\",\n \"predict.event.moreMarkets\": \"+{{count}} more\",\n\n // Markets table\n \"predict.market.table.outcome\": \"Outcome\",\n \"predict.market.table.chance\": \"Chance\",\n \"predict.market.table.actions\": \"Actions\",\n \"predict.market.action.yes\": \"Yes {{price}}¢\",\n \"predict.market.action.no\": \"No {{price}}¢\",\n\n // Market options\n \"predict.market.yes\": \"Yes\",\n \"predict.market.no\": \"No\",\n \"predict.market.sharesYes\": \"{{shares}} Yes\",\n \"predict.market.sharesNo\": \"{{shares}} No\",\n \"predict.market.tradeYes\": \"Trade Yes\",\n \"predict.market.tradeNo\": \"Trade No\",\n \"predict.market.graph\": \"Graph\",\n\n // Trade form\n \"predict.trade.action\": \"Trade\",\n \"predict.trade.buy\": \"Buy\",\n \"predict.trade.sell\": \"Sell\",\n \"predict.trade.yes\": \"Yes\",\n \"predict.trade.no\": \"No\",\n \"predict.trade.limit\": \"Limit\",\n \"predict.trade.market\": \"Market\",\n \"predict.trade.price\": \"Price\",\n \"predict.trade.amount\": \"Amount\",\n \"predict.trade.contracts\": \"Contracts\",\n \"predict.trade.estimatedCost\": \"Est. Cost\",\n \"predict.trade.potentialPayout\": \"Potential Payout\",\n \"predict.trade.potentialProfit\": \"Potential Profit\",\n \"predict.trade.potentialWin\": \"Potential Win\",\n \"predict.trade.estimatedReceive\": \"Est. Receive\",\n \"predict.trade.balance\": \"Available Balance\",\n \"predict.trade.bestBid\": \"Bid\",\n \"predict.trade.bestAsk\": \"Ask\",\n \"predict.trade.priceImpact\": \"Price Impact\",\n \"predict.trade.quoteError\": \"Unable to get quote. Please try again.\",\n \"predict.trade.connectWallet\": \"Connect Wallet\",\n \"predict.trade.submitting\": \"Submitting…\",\n \"predict.trade.submitSuccess\": \"Transaction submitted successfully!\",\n \"predict.trade.submitError\": \"Transaction failed. Please try again.\",\n\n // Order book\n \"predict.orderBook.title\": \"Order Book\",\n \"predict.orderBook.empty\": \"No orders yet\",\n \"predict.orderBook.type\": \"Type\",\n \"predict.orderBook.price\": \"Price\",\n \"predict.orderBook.contracts\": \"Contracts\",\n \"predict.orderBook.qty\": \"Qty\",\n \"predict.orderBook.total\": \"Total\",\n \"predict.orderBook.spread\": \"Spread\",\n\n // Open orders\n \"predict.openOrders.title\": \"Open Orders\",\n \"predict.openOrders.empty\": \"No open orders\",\n \"predict.openOrders.side\": \"Side\",\n \"predict.openOrders.outcome\": \"Outcome\",\n \"predict.openOrders.type\": \"Type\",\n \"predict.openOrders.price\": \"Price\",\n \"predict.openOrders.filled\": \"Filled\",\n \"predict.openOrders.status\": \"Status\",\n \"predict.openOrders.time\": \"Time\",\n \"predict.openOrders.cancel\": \"Cancel\",\n\n // Trade history\n \"predict.tradeHistory.title\": \"Trade History\",\n \"predict.tradeHistory.empty\": \"No trades yet\",\n \"predict.tradeHistory.side\": \"Side\",\n \"predict.tradeHistory.outcome\": \"Outcome\",\n \"predict.tradeHistory.price\": \"Price\",\n \"predict.tradeHistory.qty\": \"Qty\",\n \"predict.tradeHistory.total\": \"Total\",\n \"predict.tradeHistory.fee\": \"Fee\",\n \"predict.tradeHistory.time\": \"Time\",\n\n // Positions\n \"predict.positions.title\": \"Positions\",\n \"predict.positions.empty\": \"No positions\",\n \"predict.positions.market\": \"Market\",\n \"predict.positions.outcome\": \"Outcome\",\n \"predict.positions.qty\": \"Qty\",\n \"predict.positions.avgCost\": \"Avg Cost\",\n \"predict.positions.currentPrice\": \"Price\",\n \"predict.positions.value\": \"Value\",\n \"predict.positions.pnl\": \"P&L\",\n \"predict.positions.totalValue\": \"Total Value\",\n \"predict.positions.unrealizedPnl\": \"Unrealized P&L\",\n \"predict.positions.realizedPnl\": \"Realized P&L\",\n\n // Pagination\n \"predict.pagination.prev\": \"Prev\",\n \"predict.pagination.next\": \"Next\",\n \"predict.pagination.page\": \"Page {{page}}\",\n};\n","export const scaffold = {\n \"scaffold.draggableModal.snapToEdge\": \"Drag to edge to show side panel\",\n \"scaffold.draggablePanel.snapToModal\": \"Drag away to show floating modal\",\n \"scaffold.home\": \"Home\",\n};\n","export const tokens = {\n \"tokens.search.placeholder\": \"Search by token or CA...\",\n \"tokens.copied.address\": \"Token address copied to clipboard\",\n \"tokens.listHeader.token\": \"Token\",\n \"tokens.listHeader.priceHistories\": \"Price Histories\",\n \"tokens.listHeader.price\": \"Price\",\n \"tokens.listHeader.priceChange\": \"{{resolution}}%\",\n \"tokens.listHeader.marketCap\": \"Market Cap\",\n \"tokens.listHeader.liquidity\": \"Liquidity\",\n \"tokens.listHeader.volumes\": \"{{resolution}} Volumes\",\n \"tokens.listHeader.txs\": \"{{resolution}} TXNS\",\n \"tokens.listHeader.traders\": \"{{resolution}} Traders\",\n \"tokens.listHeader.bluechip\": \"BlueChip\",\n \"tokens.listHeader.tokenInfo\": \"Token Info\",\n \"tokens.listHeader.actions\": \"Actions\",\n \"tokens.listHeader.filter\": \"Filter\",\n \"tokens.listType.trending\": \"Trending\",\n \"tokens.listType.new\": \"New\",\n \"tokens.listType.stocks\": \"Stocks\",\n \"tokens.filters.protocols.title\": \"Protocols\",\n \"tokens.filters.protocols.selectAll\": \"Select All\",\n \"tokens.filters.protocols.unselectAll\": \"Unselect All\",\n \"tokens.filters.keywords.title\": \"Search Keywords\",\n \"tokens.filters.keywords.exclude.title\": \"Exclude Keywords\",\n \"tokens.filters.keywords.placeholder\": \"keyword1, keyword2...\",\n \"tokens.filters.stats.min\": \"Min\",\n \"tokens.filters.stats.max\": \"Max\",\n \"tokens.filters.stats.audits\": \"Audits\",\n \"tokens.filters.stats.audits.holders\": \"Holders Count\",\n \"tokens.filters.stats.audits.top10HoldingsRatio\": \"Top 10 Holders %\",\n \"tokens.filters.stats.audits.top100HoldingsRatio\": \"Top 100 Holders %\",\n \"tokens.filters.stats.audits.devHoldingsRatio\": \"Dev Holdings %\",\n \"tokens.filters.stats.metrics\": \"Metrics\",\n \"tokens.filters.stats.metrics.volumes\": \"{{resolution}} Volumes ($)\",\n \"tokens.filters.stats.metrics.txns\": \"{{resolution}} Transactions\",\n \"tokens.filters.stats.metrics.liquidity\": \"Liquidity ($)\",\n \"tokens.filters.stats.metrics.marketCap\": \"Market Cap ($)\",\n \"tokens.filters.modal.title\": \"Filters\",\n \"tokens.tokenInfo.holders\": \"Holders\",\n \"tokens.tokenInfo.proHolders\": \"Pro Holders\",\n \"tokens.tokenInfo.kolHolders\": \"KOL Holders\",\n \"tokens.tokenInfo.top10HoldingsRatio\": \"Top 10 Holders\",\n \"tokens.tokenInfo.top100HoldingsRatio\": \"Top 100 Holders\",\n \"tokens.tokenInfo.devHoldingsRatio\": \"Dev Holders\",\n \"tokens.tokenInfo.sniperHoldingsRatio\": \"Snipers\",\n \"tokens.tokenInfo.insiderHoldingsRatio\": \"Insiders\",\n \"tokens.tokenInfo.bundleHoldingsRatio\": \"Bundlers\",\n \"tokens.bluechip.explained\":\n \"BlueChip index is the ratio of holders who also own BlueChip tokens\",\n};\n","import { channels } from \"./module/channels\";\nimport { common } from \"./module/common\";\nimport { mediaTrack } from \"./module/mediaTrack\";\nimport { predict } from \"./module/predict\";\nimport { scaffold } from \"./module/scaffold\";\nimport { tokens } from \"./module/tokens\";\n\nexport const en = {\n ...common,\n ...mediaTrack,\n ...predict,\n ...scaffold,\n ...tokens,\n ...channels,\n};\n","import { initReactI18next } from \"react-i18next\";\nimport { i18n as I18nInstance, createInstance } from \"i18next\";\nimport LanguageDetector from \"i18next-browser-languagedetector\";\nimport {\n defaultLng,\n defaultNS,\n i18nCookieKey,\n i18nLocalStorageKey,\n} from \"./constant\";\nimport { en } from \"./locale/en\";\n\nconst i18n: I18nInstance = createInstance();\n\ni18n\n .use(LanguageDetector)\n .use(initReactI18next) // bind react-i18next to the instance\n .init({\n fallbackLng: defaultLng,\n ns: [defaultNS],\n defaultNS,\n interpolation: {\n escapeValue: false, // not needed for react!!\n },\n detection: {\n lookupLocalStorage: i18nLocalStorageKey,\n lookupCookie: i18nCookieKey,\n caches: [\"cookie\", \"localStorage\"],\n order: [\"cookie\", \"localStorage\", \"htmlTag\", \"navigator\"],\n },\n resources: {\n [defaultLng]: { [defaultNS]: en },\n },\n });\n\nexport default i18n;\n","import i18n from \"./i18n\";\nimport { LocaleCode } from \"./types\";\n\nexport type BackendOptions = {\n /**\n * Load url for a given language and namespace\n * @param lang language code\n * @param ns namespace\n * @returns url or urls\n */\n loadPath: (lang: LocaleCode, ns: string) => string | string[];\n};\n\n/**\n * Async resources loading through HTTP, resources must be placed in the site's public directory\n */\nexport class Backend {\n private readonly cache: Set<string>;\n\n constructor(private readonly options?: BackendOptions) {\n this.cache = new Set();\n }\n\n async fetchData(url: string): Promise<Record<string, string>> {\n try {\n const res = await fetch(url);\n return await res.json();\n } catch (error) {\n console.warn(\n `Failed to fetch locale resource bundle from ${url}:`,\n error,\n );\n return {};\n }\n }\n\n async loadLanguage(lang: LocaleCode, ns: string) {\n if (typeof this.options?.loadPath !== \"function\") return;\n\n // get load url paths\n let paths = this.options.loadPath(lang, ns);\n if (typeof paths === \"string\") paths = [paths];\n if (!paths.length) return;\n\n // filter out the paths that have already been loaded\n const urls = paths.filter((path) => {\n const loaded = i18n.hasResourceBundle(lang, ns);\n return !loaded || !this.cache.has(path);\n });\n\n const promises = urls.map(async (url) => {\n const data = await this.fetchData(url);\n i18n.addResourceBundle(lang, ns, data, true, true);\n this.cache.add(url);\n });\n await Promise.all(promises);\n }\n}\n","import { createContext, useContext } from \"react\";\nimport { Language, LocaleCode } from \"./types\";\n\nexport type LocaleContextState = {\n /**\n * Supported languages\n */\n languages: Language[];\n\n /**\n * Called before language change\n * @param lang - new language code\n * @returns\n */\n beforeLanguageChange: (lang: LocaleCode) => Promise<void>;\n /**\n * Called after language changed\n * @param lang - new language code\n * @returns\n */\n afterLanguageChange: (lang: LocaleCode) => Promise<void>;\n};\n\nexport const LocaleContext = createContext<LocaleContextState>({\n languages: [],\n beforeLanguageChange: () => Promise.resolve(),\n afterLanguageChange: () => Promise.resolve(),\n});\n\nexport const useLocaleContext = () => {\n const context = useContext(LocaleContext);\n if (!context) {\n throw new Error(\"useLocaleContext must be used within a LocaleProvider\");\n }\n return context;\n};\n","import { LocaleEnum } from \"../types\";\n\n/**\n * get locale path from pathname\n * @param pathname - pathname to get locale path\n * @param localeCodes - locale codes to check\n * @example\n * getLocalePathFromPathname('/en/perp/PERP_ETH_USDC') => 'en'\n * getLocalePathFromPathname('/perp/PERP_ETH_USDC') => null\n * getLocalePathFromPathname('/en/markets') => 'en'\n * getLocalePathFromPathname('/markets') => null\n */\nexport function getLocalePathFromPathname(\n pathname: string,\n localeCodes?: string[],\n) {\n const locale = pathname.split(\"/\")[1];\n localeCodes = localeCodes || Object.values(LocaleEnum);\n return localeCodes.includes(locale as LocaleEnum) ? locale : null;\n}\n","import { type LocaleCode, LocaleEnum } from \"../types\";\n\n/**\n * transform browser language to i18n locale codes\n * @param lang - browser language\n * @param localeCodes - locale codes to check\n * @param defaultLang - default locale code\n * @example\n * parseI18nLang('en-US') => 'en'\n * parseI18nLang('zh-CN') => 'zh'\n * parseI18nLang('zh-TW') => 'zh'\n * parseI18nLang('ja') => 'ja'\n * */\nexport function parseI18nLang(\n lang: string,\n localeCodes?: LocaleCode[],\n defaultLang?: LocaleCode,\n) {\n localeCodes = localeCodes || Object.values(LocaleEnum);\n defaultLang = defaultLang || LocaleEnum.en;\n\n const regex = /^([a-z]{2})/i;\n const match = lang?.match(regex);\n\n if (!match) {\n return defaultLang;\n }\n\n const matchLang = match[1];\n\n if (localeCodes.includes(lang)) {\n return lang;\n }\n\n if (localeCodes.includes(matchLang)) {\n return matchLang;\n }\n\n return defaultLang;\n}\n","import i18n from \"../i18n\";\nimport { getLocalePathFromPathname } from \"./getLocalePathFromPathname\";\nimport { parseI18nLang } from \"./parseI18nLang\";\n\n/**\n * Generate a localized path with proper locale prefix and search parameters\n *\n * This function ensures that the returned path includes the appropriate locale prefix.\n * If the path already contains a valid locale prefix, it returns the path as-is.\n * Otherwise, it prepends the specified locale or falls back to the current i18n language.\n *\n * @param params - Configuration object for path generation\n * @param params.path - The base pathname (e.g., '/markets', '/perp/PERP_ETH_USDC')\n * @param params.locale - Optional locale code to use as prefix. If not provided, uses i18n.language\n * @param params.search - Optional search query string. If not provided, uses window.location.search\n *\n * @returns A complete URL path with locale prefix and search parameters\n *\n * @example\n * generatePath({ path: '/markets' }) => '/en/markets?tab=spot'\n * generatePath({ path: '/en/markets', search: '?tab=futures' }) => '/en/markets?tab=futures'\n * generatePath({ path: '/perp/PERP_ETH_USDC', locale: 'zh' }) => '/zh/perp/PERP_ETH_USDC'\n * generatePath({ path: '/en/perp/PERP_ETH_USDC' }) => '/en/perp/PERP_ETH_USDC'\n */\nexport function generatePath(params: {\n path: string;\n locale?: string;\n search?: string;\n}) {\n const { path, locale, search } = params;\n const searchUrl =\n search || (typeof window !== \"undefined\" ? window.location.search : \"\");\n\n let localePath = getLocalePathFromPathname(path);\n\n // If path already contains a valid locale prefix, return it unchanged\n if (localePath) {\n return `${path}${searchUrl}`;\n }\n\n // Use provided locale or fall back to current i18n language\n localePath = locale || parseI18nLang(i18n.language);\n\n // Prepend locale prefix to path\n return `/${localePath}${path}${searchUrl}`;\n}\n","import { getLocalePathFromPathname } from \"./getLocalePathFromPathname\";\n\n/**\n * remove lang prefix from pathname\n * @param pathname - pathname to remove lang prefix\n * @param localeCodes - locale codes to check\n * @example\n * removeLangPrefix('/en/perp/PERP_ETH_USDC') => '/perp/PERP_ETH_USDC'\n * removeLangPrefix('/en/markets') => '/markets'\n * removeLangPrefix('/perp/PERP_ETH_USDC') => '/perp/PERP_ETH_USDC'\n * removeLangPrefix('/markets') => '/markets'\n */\nexport function removeLangPrefix(pathname: string, localeCodes?: string[]) {\n const localePath = getLocalePathFromPathname(pathname, localeCodes);\n\n return localePath\n ? pathname.replace(new RegExp(`^/${localePath}(?=/)`), \"\")\n : pathname;\n}\n","import {\n PropsWithChildren,\n useCallback,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from \"react\";\nimport { I18nextProvider } from \"react-i18next\";\nimport { Backend, BackendOptions } from \"./backend\";\nimport { defaultLanguages, defaultNS } from \"./constant\";\nimport { LocaleContext, LocaleContextState } from \"./context\";\nimport i18n from \"./i18n\";\nimport { LocaleCode, Resources, Language } from \"./types\";\nimport { parseI18nLang } from \"./utils\";\n\nexport type LocaleProviderProps = PropsWithChildren<\n {\n /** current locale */\n locale?: LocaleCode;\n /** current locale's resource */\n resource?: Record<string, string>;\n /** all synchronously loaded resources */\n resources?: Resources;\n /** supported languages, must be a subset of {@link defaultLanguages}, used when {@link languages} is not provided */\n supportedLanguages?: LocaleCode[];\n /** optional conversion function to modify the detected language code */\n convertDetectedLanguage?: (lang: string) => LocaleCode;\n /** options to load resources asynchronously */\n backend?: BackendOptions;\n } & Partial<LocaleContextState>\n>;\n\nexport function LocaleProvider({\n children,\n locale,\n resource,\n resources,\n backend,\n supportedLanguages,\n convertDetectedLanguage,\n languages: languagesProp,\n beforeLanguageChange,\n afterLanguageChange,\n}: LocaleProviderProps) {\n // calculated supported languages\n const [languages, setLanguages] = useState<Language[]>(defaultLanguages);\n\n // backend instance to load resources asynchronously\n const backendRef = useRef(new Backend(backend!));\n\n // load resources synchronously\n useEffect(() => {\n if (resources) {\n Object.entries(resources).forEach(([locale, messages]) => {\n i18n.addResourceBundle(locale, defaultNS, messages, true, true);\n });\n return;\n }\n if (resource && locale) {\n i18n.addResourceBundle(locale, defaultNS, resource, true, true);\n }\n }, [locale, resource, resources]);\n\n // change language when locale changed\n useEffect(() => {\n if (locale && locale !== i18n.language) {\n i18n.changeLanguage(locale);\n }\n }, [locale]);\n\n // calculate supported languages\n useEffect(() => {\n if (Array.isArray(languagesProp)) {\n setLanguages(languagesProp);\n } else if (Array.isArray(supportedLanguages)) {\n setLanguages(\n supportedLanguages\n .map((localCode) =>\n defaultLanguages.find((l) => l.localCode === localCode),\n )\n .filter((item) => !!item),\n );\n }\n }, [supportedLanguages, languagesProp]);\n\n // if browser language is not a valid language, change language\n useEffect(() => {\n const fixLanguage = async () => {\n const lang =\n typeof convertDetectedLanguage === \"function\"\n ? convertDetectedLanguage(i18n.language)\n : parseI18nLang(i18n.language);\n await backendRef.current.loadLanguage(lang, defaultNS);\n if (lang !== i18n.language) {\n await i18n.changeLanguage(lang);\n }\n };\n fixLanguage();\n }, [i18n.language]);\n\n const beforeLanguageChangeHandler = useCallback(\n async (lang: LocaleCode) => {\n await beforeLanguageChange?.(lang);\n // load language before language changed\n await backendRef.current.loadLanguage(lang, defaultNS);\n },\n [beforeLanguageChange],\n );\n\n const afterLanguageChangeHandler = useCallback(\n async (lang: LocaleCode) => {\n afterLanguageChange?.(lang);\n },\n [afterLanguageChange],\n );\n\n const contextValue = useMemo<LocaleContextState>(() => {\n return {\n languages,\n beforeLanguageChange: beforeLanguageChangeHandler,\n afterLanguageChange: afterLanguageChangeHandler,\n };\n }, [languages, beforeLanguageChangeHandler, afterLanguageChangeHandler]);\n\n return (\n <LocaleContext.Provider value={contextValue}>\n <I18nextProvider i18n={i18n} defaultNS={defaultNS}>\n {children}\n </I18nextProvider>\n </LocaleContext.Provider>\n );\n}\n","import { useContext } from \"react\";\nimport {\n FallbackNs,\n useTranslation as _useTranslation,\n UseTranslationOptions,\n I18nContext,\n} from \"react-i18next\";\nimport { FlatNamespace, KeyPrefix } from \"i18next\";\nimport i18n from \"./i18n\";\n\ntype $Tuple<T> = readonly [T?, ...T[]];\n\n/**\n * Hook to get translation function\n * @param ns\n * @param options\n * @returns\n */\nexport function useTranslation<\n Ns extends FlatNamespace | $Tuple<FlatNamespace> | undefined = undefined,\n KPrefix extends KeyPrefix<FallbackNs<Ns>> = undefined,\n>(ns?: Ns, options?: UseTranslationOptions<KPrefix>) {\n const context = useContext(I18nContext);\n return _useTranslation(ns, { i18n: context?.i18n || i18n, ...options });\n}\n","import { useEffect, useState } from \"react\";\nimport i18n from \"./i18n\";\nimport { LocaleCode } from \"./types\";\n\n/**\n * Hooks to get current locale code\n * @returns current locale code\n */\nexport function useLocale() {\n const [localeCode, setLocaleCode] = useState<LocaleCode>(i18n.language);\n\n useEffect(() => {\n i18n.on(\"languageChanged\", setLocaleCode);\n return () => {\n i18n.off(\"languageChanged\", setLocaleCode);\n };\n }, [i18n]);\n\n return localeCode;\n}\n","import { useCallback } from \"react\";\nimport { useLocaleContext } from \"./context\";\nimport i18n from \"./i18n\";\nimport { LocaleCode } from \"./types\";\n\nexport function useChangeLocale() {\n const { beforeLanguageChange, afterLanguageChange } = useLocaleContext();\n\n const changeLocale = useCallback(\n async (locale: LocaleCode) => {\n await beforeLanguageChange(locale);\n await i18n.changeLanguage(locale);\n await afterLanguageChange(locale);\n },\n [beforeLanguageChange, afterLanguageChange, i18n],\n );\n\n return changeLocale;\n}\n"]}
package/dist/locale.csv CHANGED
@@ -42,10 +42,102 @@
42
42
  "common.upload.resubmit","Reupload","重新上傳"
43
43
  "common.upload.error","Upload error","上傳失敗"
44
44
  "common.loadingMore","Loading more...","載入更多中……"
45
+ "common.continue","Continue","繼續"
46
+ "common.months","months","月"
47
+ "common.days","days","天"
45
48
  "mediaTrack.tweets.translate.show","Show Translation","顯示翻譯"
46
49
  "mediaTrack.tweets.translate.hide","Hide Translation","隱藏翻譯"
47
50
  "mediaTrack.tweets.expand","Expand","展開"
48
51
  "mediaTrack.tweets.collapse","Collapse","折疊"
52
+ "predict.event.status.closed","Closed","已結束"
53
+ "predict.event.status.live","Live","進行中"
54
+ "predict.event.status.pending","Pending","待開始"
55
+ "predict.event.volume","vol","交易量"
56
+ "predict.event.endDate","Ends {{date}}","結束於 {{date}}"
57
+ "predict.event.rules","Rules","規則"
58
+ "predict.event.rules.collapse","Collapse","收起"
59
+ "predict.event.rules.expand","Expand all","展開全部"
60
+ "predict.event.showMore","Show More","顯示更多"
61
+ "predict.event.back","Back","返回"
62
+ "predict.event.moreMarkets","+{{count}} more","還有 {{count}} 個"
63
+ "predict.market.table.outcome","Outcome","結果"
64
+ "predict.market.table.chance","Chance","機率"
65
+ "predict.market.table.actions","Actions","操作"
66
+ "predict.market.action.yes","Yes {{price}}¢","是 {{price}}¢"
67
+ "predict.market.action.no","No {{price}}¢","否 {{price}}¢"
68
+ "predict.market.yes","Yes","是"
69
+ "predict.market.no","No","否"
70
+ "predict.market.sharesYes","{{shares}} Yes","{{shares}} Yes"
71
+ "predict.market.sharesNo","{{shares}} No","{{shares}} No"
72
+ "predict.market.tradeYes","Trade Yes","買入 Yes"
73
+ "predict.market.tradeNo","Trade No","買入 No"
74
+ "predict.market.graph","Graph","圖表"
75
+ "predict.trade.action","Trade","交易"
76
+ "predict.trade.buy","Buy","買入"
77
+ "predict.trade.sell","Sell","賣出"
78
+ "predict.trade.yes","Yes","是"
79
+ "predict.trade.no","No","否"
80
+ "predict.trade.limit","Limit","限價"
81
+ "predict.trade.market","Market","市價"
82
+ "predict.trade.price","Price","價格"
83
+ "predict.trade.amount","Amount","金額"
84
+ "predict.trade.contracts","Contracts","份额"
85
+ "predict.trade.estimatedCost","Est. Cost","預估成本"
86
+ "predict.trade.potentialPayout","Potential Payout","預估收益"
87
+ "predict.trade.potentialProfit","Potential Profit","預估利潤"
88
+ "predict.trade.potentialWin","Potential Win","赢取金额"
89
+ "predict.trade.estimatedReceive","Est. Receive","预计收到"
90
+ "predict.trade.balance","Available Balance","可用餘額"
91
+ "predict.trade.bestBid","Bid","買一"
92
+ "predict.trade.bestAsk","Ask","賣一"
93
+ "predict.trade.priceImpact","Price Impact","價格影響"
94
+ "predict.trade.quoteError","Unable to get quote. Please try again.","無法獲取報價,請重試。"
95
+ "predict.trade.connectWallet","Connect Wallet","連接錢包"
96
+ "predict.trade.submitting","Submitting…","提交中…"
97
+ "predict.trade.submitSuccess","Transaction submitted successfully!","交易提交成功!🎉"
98
+ "predict.trade.submitError","Transaction failed. Please try again.","交易失败,请重试。"
99
+ "predict.orderBook.title","Order Book","訂單簿"
100
+ "predict.orderBook.empty","No orders yet","暫無訂單"
101
+ "predict.orderBook.type","Type","類型"
102
+ "predict.orderBook.price","Price","價格"
103
+ "predict.orderBook.contracts","Contracts","合約"
104
+ "predict.orderBook.qty","Qty","數量"
105
+ "predict.orderBook.total","Total","交易量"
106
+ "predict.orderBook.spread","Spread","價差"
107
+ "predict.openOrders.title","Open Orders","未成交訂單"
108
+ "predict.openOrders.empty","No open orders","暫無未成交訂單"
109
+ "predict.openOrders.side","Side","方向"
110
+ "predict.openOrders.outcome","Outcome","結果"
111
+ "predict.openOrders.type","Type","類型"
112
+ "predict.openOrders.price","Price","價格"
113
+ "predict.openOrders.filled","Filled","成交"
114
+ "predict.openOrders.status","Status","狀態"
115
+ "predict.openOrders.time","Time","時間"
116
+ "predict.openOrders.cancel","Cancel","取消"
117
+ "predict.tradeHistory.title","Trade History","成交歷史"
118
+ "predict.tradeHistory.empty","No trades yet","暫無成交記錄"
119
+ "predict.tradeHistory.side","Side","方向"
120
+ "predict.tradeHistory.outcome","Outcome","結果"
121
+ "predict.tradeHistory.price","Price","價格"
122
+ "predict.tradeHistory.qty","Qty","數量"
123
+ "predict.tradeHistory.total","Total","總計"
124
+ "predict.tradeHistory.fee","Fee","手續費"
125
+ "predict.tradeHistory.time","Time","時間"
126
+ "predict.positions.title","Positions","持倉"
127
+ "predict.positions.empty","No positions","暫無持倉"
128
+ "predict.positions.market","Market","市場"
129
+ "predict.positions.outcome","Outcome","結果"
130
+ "predict.positions.qty","Qty","數量"
131
+ "predict.positions.avgCost","Avg Cost","均價"
132
+ "predict.positions.currentPrice","Price","現價"
133
+ "predict.positions.value","Value","市值"
134
+ "predict.positions.pnl","P&L","盈虧"
135
+ "predict.positions.totalValue","Total Value","總市值"
136
+ "predict.positions.unrealizedPnl","Unrealized P&L","未實現盈虧"
137
+ "predict.positions.realizedPnl","Realized P&L","已實現盈虧"
138
+ "predict.pagination.prev","Prev","上一頁"
139
+ "predict.pagination.next","Next","下一頁"
140
+ "predict.pagination.page","Page {{page}}","第 {{page}} 頁"
49
141
  "scaffold.draggableModal.snapToEdge","Drag to edge to show side panel","拖曳到邊緣以顯示側邊面板"
50
142
  "scaffold.draggablePanel.snapToModal","Drag away to show floating modal","拖曳離開以顯示浮動面板"
51
143
  "scaffold.home","Home","主頁"
@@ -173,6 +265,21 @@
173
265
  "channels.create.title","Create Channel","創建頻道"
174
266
  "channels.create.success","Channel created successfully","頻道創建成功"
175
267
  "channels.create.error","Create channel error","頻道創建失敗"
268
+ "channels.create.eligibility.title","Check Eligibility","資格檢測"
269
+ "channels.create.eligibility.description","Verify your X (Twitter) account to ensure it meets the requirements for creating a channel.","驗證您的帳號是否符合創建交易頻道的要求。"
270
+ "channels.create.eligibility.xConnection","X Account Connection","X (Twitter) 連接"
271
+ "channels.create.eligibility.connected","Connected as","已連接"
272
+ "channels.create.eligibility.notConnected","No X account connected","未連接"
273
+ "channels.create.eligibility.connect","Connect X Account","連接"
274
+ "channels.create.eligibility.disconnect","Disconnect","斷開連接"
275
+ "channels.create.eligibility.verifying","Verifying eligibility...","正在驗證資格..."
276
+ "channels.create.eligibility.requirementsTitle","Eligibility Requirements","資格要求"
277
+ "channels.create.eligibility.followersCount","Followers Count","粉絲數"
278
+ "channels.create.eligibility.accountAge","Account Age","帳號年齡"
279
+ "channels.create.eligibility.behaviorScore","Behavior Score","行為評分"
280
+ "channels.create.eligibility.clean","Clean","良好"
281
+ "channels.create.eligibility.allPassed","All eligibility checks passed! You can now create a channel.","所有資格檢查已通過!您現在可以創建頻道了。"
282
+ "channels.create.eligibility.failed","Some requirements are not met. Please check your account.","部分要求未滿足。請檢查您的帳號。"
176
283
  "channels.update.title","Update Channel","更新頻道"
177
284
  "channels.update.success","Channel updated successfully","頻道更新成功"
178
285
  "channels.update.error","Update channel error","頻道更新失敗"
@@ -42,10 +42,102 @@
42
42
  "common.upload.resubmit": "Reupload",
43
43
  "common.upload.error": "Upload error",
44
44
  "common.loadingMore": "Loading more...",
45
+ "common.continue": "Continue",
46
+ "common.months": "months",
47
+ "common.days": "days",
45
48
  "mediaTrack.tweets.translate.show": "Show Translation",
46
49
  "mediaTrack.tweets.translate.hide": "Hide Translation",
47
50
  "mediaTrack.tweets.expand": "Expand",
48
51
  "mediaTrack.tweets.collapse": "Collapse",
52
+ "predict.event.status.closed": "Closed",
53
+ "predict.event.status.live": "Live",
54
+ "predict.event.status.pending": "Pending",
55
+ "predict.event.volume": "vol",
56
+ "predict.event.endDate": "Ends {{date}}",
57
+ "predict.event.rules": "Rules",
58
+ "predict.event.rules.collapse": "Collapse",
59
+ "predict.event.rules.expand": "Expand all",
60
+ "predict.event.showMore": "Show More",
61
+ "predict.event.back": "Back",
62
+ "predict.event.moreMarkets": "+{{count}} more",
63
+ "predict.market.table.outcome": "Outcome",
64
+ "predict.market.table.chance": "Chance",
65
+ "predict.market.table.actions": "Actions",
66
+ "predict.market.action.yes": "Yes {{price}}¢",
67
+ "predict.market.action.no": "No {{price}}¢",
68
+ "predict.market.yes": "Yes",
69
+ "predict.market.no": "No",
70
+ "predict.market.sharesYes": "{{shares}} Yes",
71
+ "predict.market.sharesNo": "{{shares}} No",
72
+ "predict.market.tradeYes": "Trade Yes",
73
+ "predict.market.tradeNo": "Trade No",
74
+ "predict.market.graph": "Graph",
75
+ "predict.trade.action": "Trade",
76
+ "predict.trade.buy": "Buy",
77
+ "predict.trade.sell": "Sell",
78
+ "predict.trade.yes": "Yes",
79
+ "predict.trade.no": "No",
80
+ "predict.trade.limit": "Limit",
81
+ "predict.trade.market": "Market",
82
+ "predict.trade.price": "Price",
83
+ "predict.trade.amount": "Amount",
84
+ "predict.trade.contracts": "Contracts",
85
+ "predict.trade.estimatedCost": "Est. Cost",
86
+ "predict.trade.potentialPayout": "Potential Payout",
87
+ "predict.trade.potentialProfit": "Potential Profit",
88
+ "predict.trade.potentialWin": "Potential Win",
89
+ "predict.trade.estimatedReceive": "Est. Receive",
90
+ "predict.trade.balance": "Available Balance",
91
+ "predict.trade.bestBid": "Bid",
92
+ "predict.trade.bestAsk": "Ask",
93
+ "predict.trade.priceImpact": "Price Impact",
94
+ "predict.trade.quoteError": "Unable to get quote. Please try again.",
95
+ "predict.trade.connectWallet": "Connect Wallet",
96
+ "predict.trade.submitting": "Submitting…",
97
+ "predict.trade.submitSuccess": "Transaction submitted successfully!",
98
+ "predict.trade.submitError": "Transaction failed. Please try again.",
99
+ "predict.orderBook.title": "Order Book",
100
+ "predict.orderBook.empty": "No orders yet",
101
+ "predict.orderBook.type": "Type",
102
+ "predict.orderBook.price": "Price",
103
+ "predict.orderBook.contracts": "Contracts",
104
+ "predict.orderBook.qty": "Qty",
105
+ "predict.orderBook.total": "Total",
106
+ "predict.orderBook.spread": "Spread",
107
+ "predict.openOrders.title": "Open Orders",
108
+ "predict.openOrders.empty": "No open orders",
109
+ "predict.openOrders.side": "Side",
110
+ "predict.openOrders.outcome": "Outcome",
111
+ "predict.openOrders.type": "Type",
112
+ "predict.openOrders.price": "Price",
113
+ "predict.openOrders.filled": "Filled",
114
+ "predict.openOrders.status": "Status",
115
+ "predict.openOrders.time": "Time",
116
+ "predict.openOrders.cancel": "Cancel",
117
+ "predict.tradeHistory.title": "Trade History",
118
+ "predict.tradeHistory.empty": "No trades yet",
119
+ "predict.tradeHistory.side": "Side",
120
+ "predict.tradeHistory.outcome": "Outcome",
121
+ "predict.tradeHistory.price": "Price",
122
+ "predict.tradeHistory.qty": "Qty",
123
+ "predict.tradeHistory.total": "Total",
124
+ "predict.tradeHistory.fee": "Fee",
125
+ "predict.tradeHistory.time": "Time",
126
+ "predict.positions.title": "Positions",
127
+ "predict.positions.empty": "No positions",
128
+ "predict.positions.market": "Market",
129
+ "predict.positions.outcome": "Outcome",
130
+ "predict.positions.qty": "Qty",
131
+ "predict.positions.avgCost": "Avg Cost",
132
+ "predict.positions.currentPrice": "Price",
133
+ "predict.positions.value": "Value",
134
+ "predict.positions.pnl": "P&L",
135
+ "predict.positions.totalValue": "Total Value",
136
+ "predict.positions.unrealizedPnl": "Unrealized P&L",
137
+ "predict.positions.realizedPnl": "Realized P&L",
138
+ "predict.pagination.prev": "Prev",
139
+ "predict.pagination.next": "Next",
140
+ "predict.pagination.page": "Page {{page}}",
49
141
  "scaffold.draggableModal.snapToEdge": "Drag to edge to show side panel",
50
142
  "scaffold.draggablePanel.snapToModal": "Drag away to show floating modal",
51
143
  "scaffold.home": "Home",
@@ -155,6 +247,21 @@
155
247
  "channels.create.title": "Create Channel",
156
248
  "channels.create.success": "Channel created successfully",
157
249
  "channels.create.error": "Create channel error",
250
+ "channels.create.eligibility.title": "Check Eligibility",
251
+ "channels.create.eligibility.description": "Verify your X (Twitter) account to ensure it meets the requirements for creating a channel.",
252
+ "channels.create.eligibility.xConnection": "X Account Connection",
253
+ "channels.create.eligibility.connected": "Connected as",
254
+ "channels.create.eligibility.notConnected": "No X account connected",
255
+ "channels.create.eligibility.connect": "Connect X Account",
256
+ "channels.create.eligibility.disconnect": "Disconnect",
257
+ "channels.create.eligibility.verifying": "Verifying eligibility...",
258
+ "channels.create.eligibility.requirementsTitle": "Eligibility Requirements",
259
+ "channels.create.eligibility.followersCount": "Followers Count",
260
+ "channels.create.eligibility.accountAge": "Account Age",
261
+ "channels.create.eligibility.behaviorScore": "Behavior Score",
262
+ "channels.create.eligibility.clean": "Clean",
263
+ "channels.create.eligibility.allPassed": "All eligibility checks passed! You can now create a channel.",
264
+ "channels.create.eligibility.failed": "Some requirements are not met. Please check your account.",
158
265
  "channels.update.title": "Update Channel",
159
266
  "channels.update.success": "Channel updated successfully",
160
267
  "channels.update.error": "Update channel error",