@liberfi.io/i18n 0.1.0 → 0.1.1

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.
@@ -0,0 +1,126 @@
1
+ export { createInstance, default as i18next } from 'i18next';
2
+
3
+ declare const en: {
4
+ "mediaTrack.title": string;
5
+ "mediaTrack.description": string;
6
+ "common.cancel": string;
7
+ "common.confirm": string;
8
+ "common.ok": string;
9
+ "common.yes": string;
10
+ "common.no": string;
11
+ "common.all": string;
12
+ "common.buy": string;
13
+ "common.sell": string;
14
+ "common.long": string;
15
+ "common.short": string;
16
+ "common.edit": string;
17
+ "common.save": string;
18
+ "common.add": string;
19
+ "common.delete": string;
20
+ "common.tips": string;
21
+ "common.max": string;
22
+ "common.download": string;
23
+ "common.copy": string;
24
+ "common.copy.failed": string;
25
+ "common.copy.copied": string;
26
+ "common.share": string;
27
+ "common.export": string;
28
+ };
29
+
30
+ declare enum LocaleEnum {
31
+ /** English */
32
+ en = "en",
33
+ /** Chinese */
34
+ zh = "zh",
35
+ /** Japanese */
36
+ ja = "ja",
37
+ /** Spanish */
38
+ es = "es",
39
+ /** Korean */
40
+ ko = "ko",
41
+ /** Vietnamese */
42
+ vi = "vi",
43
+ /** German */
44
+ de = "de",
45
+ /** French */
46
+ fr = "fr",
47
+ /** Russian */
48
+ ru = "ru",
49
+ /** Indonesian */
50
+ id = "id",
51
+ /** Turkish */
52
+ tr = "tr",
53
+ /** Italian */
54
+ it = "it",
55
+ /** Portuguese */
56
+ pt = "pt",
57
+ /** Ukrainian */
58
+ uk = "uk",
59
+ /** Polish */
60
+ pl = "pl",
61
+ /** Dutch */
62
+ nl = "nl"
63
+ }
64
+ type LocaleCode = keyof typeof LocaleEnum | (string & {});
65
+ type Language = {
66
+ localCode: LocaleCode;
67
+ displayName: string;
68
+ };
69
+ type ExtendLocaleMessages = Record<`extend.${string}`, string>;
70
+ type LocaleMessages = typeof en & ExtendLocaleMessages;
71
+ type Resources<T extends {} = {}> = {
72
+ [key in LocaleCode]?: Partial<LocaleMessages & T>;
73
+ };
74
+ declare module "i18next" {
75
+ interface CustomTypeOptions {
76
+ defaultNS: "translation";
77
+ resources: {
78
+ translation: LocaleMessages;
79
+ };
80
+ }
81
+ }
82
+
83
+ declare const defaultLanguages: Language[];
84
+ declare const defaultLng = LocaleEnum.en;
85
+ declare const defaultNS = "translation";
86
+ declare const i18nLocalStorageKey = "liberfi_i18nLng";
87
+ declare const i18nCookieKey = "liberfi_i18nLng";
88
+
89
+ /**
90
+ * get locale path from pathname
91
+ * @param pathname - pathname to get locale path
92
+ * @param localeCodes - locale codes to check
93
+ * @example
94
+ * getLocalePathFromPathname('/en/perp/PERP_ETH_USDC') => 'en'
95
+ * getLocalePathFromPathname('/perp/PERP_ETH_USDC') => null
96
+ * getLocalePathFromPathname('/en/markets') => 'en'
97
+ * getLocalePathFromPathname('/markets') => null
98
+ */
99
+ declare function getLocalePathFromPathname(pathname: string, localeCodes?: string[]): string | null;
100
+
101
+ /**
102
+ * transform browser language to i18n locale codes
103
+ * @param lang - browser language
104
+ * @param localeCodes - locale codes to check
105
+ * @param defaultLang - default locale code
106
+ * @example
107
+ * parseI18nLang('en-US') => 'en'
108
+ * parseI18nLang('zh-CN') => 'zh'
109
+ * parseI18nLang('zh-TW') => 'zh'
110
+ * parseI18nLang('ja') => 'ja'
111
+ * */
112
+ declare function parseI18nLang(lang: string, localeCodes?: LocaleCode[], defaultLang?: LocaleCode): string;
113
+
114
+ /**
115
+ * remove lang prefix from pathname
116
+ * @param pathname - pathname to remove lang prefix
117
+ * @param localeCodes - locale codes to check
118
+ * @example
119
+ * removeLangPrefix('/en/perp/PERP_ETH_USDC') => '/perp/PERP_ETH_USDC'
120
+ * removeLangPrefix('/en/markets') => '/markets'
121
+ * removeLangPrefix('/perp/PERP_ETH_USDC') => '/perp/PERP_ETH_USDC'
122
+ * removeLangPrefix('/markets') => '/markets'
123
+ */
124
+ declare function removeLangPrefix(pathname: string, localeCodes?: string[]): string;
125
+
126
+ export { type ExtendLocaleMessages, type Language, type LocaleCode, LocaleEnum, type LocaleMessages, type Resources, defaultLanguages, defaultLng, defaultNS, en, getLocalePathFromPathname, i18nCookieKey, i18nLocalStorageKey, parseI18nLang, removeLangPrefix };
package/dist/server.js ADDED
@@ -0,0 +1,2 @@
1
+ 'use strict';var i18next=require('i18next');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var i18next__default=/*#__PURE__*/_interopDefault(i18next);var r=(o=>(o.en="en",o.zh="zh",o.ja="ja",o.es="es",o.ko="ko",o.vi="vi",o.de="de",o.fr="fr",o.ru="ru",o.id="id",o.tr="tr",o.it="it",o.pt="pt",o.uk="uk",o.pl="pl",o.nl="nl",o))(r||{});var f=[{localCode:"en",displayName:"English"},{localCode:"zh",displayName:"\u4E2D\u6587"},{localCode:"ja",displayName:"\u65E5\u672C\u8A9E"},{localCode:"es",displayName:"Espa\xF1ol"},{localCode:"ko",displayName:"\uD55C\uAD6D\uC5B4"},{localCode:"vi",displayName:"Ti\u1EBFng Vi\u1EC7t"},{localCode:"de",displayName:"Deutsch"},{localCode:"fr",displayName:"Fran\xE7ais"},{localCode:"ru",displayName:"\u0420\u0443\u0441\u0441\u043A\u0438\u0439"},{localCode:"id",displayName:"Bahasa Indonesia"},{localCode:"tr",displayName:"T\xFCrk\xE7e"},{localCode:"it",displayName:"Italiano"},{localCode:"pt",displayName:"Portugu\xEAs"},{localCode:"uk",displayName:"\u0423\u043A\u0440\u0430\u0457\u043D\u0441\u044C\u043A\u0430"},{localCode:"pl",displayName:"Polski"},{localCode:"nl",displayName:"Nederlands"}],g="en",u="translation",C="liberfi_i18nLng",N="liberfi_i18nLng";var l={"common.cancel":"Cancel","common.confirm":"Confirm","common.ok":"OK","common.yes":"Yes","common.no":"No","common.all":"All","common.buy":"Buy","common.sell":"Sell","common.long":"Long","common.short":"Short","common.edit":"Edit","common.save":"Save","common.add":"Add","common.delete":"Delete","common.tips":"Tips","common.max":"Max","common.download":"Download","common.copy":"Copy","common.copy.failed":"Copy failed","common.copy.copied":"Copied","common.share":"Share","common.export":"Export"};var m={"mediaTrack.title":"Media Track","mediaTrack.description":"Media Track"};var v={...l,...m};function s(t,e){let a=t.split("/")[1];return e=e||Object.values(r),e.includes(a)?a:null}function z(t,e,a){e=e||Object.values(r),a=a||"en";let c=/^([a-z]{2})/i,n=t?.match(c);if(!n)return a;let i=n[1];return e.includes(t)?t:e.includes(i)?i:a}function w(t,e){let a=s(t,e);return a?t.replace(new RegExp(`^/${a}(?=/)`),""):t}Object.defineProperty(exports,"createInstance",{enumerable:true,get:function(){return i18next.createInstance}});Object.defineProperty(exports,"i18next",{enumerable:true,get:function(){return i18next__default.default}});exports.LocaleEnum=r;exports.defaultLanguages=f;exports.defaultLng=g;exports.defaultNS=u;exports.en=v;exports.getLocalePathFromPathname=s;exports.i18nCookieKey=N;exports.i18nLocalStorageKey=C;exports.parseI18nLang=z;exports.removeLangPrefix=w;//# sourceMappingURL=server.js.map
2
+ //# sourceMappingURL=server.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/types.ts","../src/constant.ts","../src/locale/module/common.ts","../src/locale/module/mediaTrack.ts","../src/locale/en.ts","../src/utils/getLocalePathFromPathname.ts","../src/utils/parseI18nLang.ts","../src/utils/removeLangPrefix.ts"],"names":["LocaleEnum","defaultLanguages","defaultLng","defaultNS","i18nLocalStorageKey","i18nCookieKey","common","mediaTrack","en","getLocalePathFromPathname","pathname","localeCodes","locale","parseI18nLang","lang","defaultLang","regex","match","matchLang","removeLangPrefix","localePath"],"mappings":"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","file":"server.js","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 common = {\n \"common.cancel\": \"Cancel\",\n \"common.confirm\": \"Confirm\",\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\",\n \"common.share\": \"Share\",\n \"common.export\": \"Export\",\n};\n","export const mediaTrack = {\n \"mediaTrack.title\": \"Media Track\",\n \"mediaTrack.description\": \"Media Track\",\n};\n","import { common } from \"./module/common\";\nimport { mediaTrack } from \"./module/mediaTrack\";\n\nexport const en = {\n ...common,\n ...mediaTrack,\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 { 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"]}
@@ -0,0 +1,2 @@
1
+ export{createInstance,default as i18next}from'i18next';var r=(o=>(o.en="en",o.zh="zh",o.ja="ja",o.es="es",o.ko="ko",o.vi="vi",o.de="de",o.fr="fr",o.ru="ru",o.id="id",o.tr="tr",o.it="it",o.pt="pt",o.uk="uk",o.pl="pl",o.nl="nl",o))(r||{});var f=[{localCode:"en",displayName:"English"},{localCode:"zh",displayName:"\u4E2D\u6587"},{localCode:"ja",displayName:"\u65E5\u672C\u8A9E"},{localCode:"es",displayName:"Espa\xF1ol"},{localCode:"ko",displayName:"\uD55C\uAD6D\uC5B4"},{localCode:"vi",displayName:"Ti\u1EBFng Vi\u1EC7t"},{localCode:"de",displayName:"Deutsch"},{localCode:"fr",displayName:"Fran\xE7ais"},{localCode:"ru",displayName:"\u0420\u0443\u0441\u0441\u043A\u0438\u0439"},{localCode:"id",displayName:"Bahasa Indonesia"},{localCode:"tr",displayName:"T\xFCrk\xE7e"},{localCode:"it",displayName:"Italiano"},{localCode:"pt",displayName:"Portugu\xEAs"},{localCode:"uk",displayName:"\u0423\u043A\u0440\u0430\u0457\u043D\u0441\u044C\u043A\u0430"},{localCode:"pl",displayName:"Polski"},{localCode:"nl",displayName:"Nederlands"}],g="en",u="translation",C="liberfi_i18nLng",N="liberfi_i18nLng";var l={"common.cancel":"Cancel","common.confirm":"Confirm","common.ok":"OK","common.yes":"Yes","common.no":"No","common.all":"All","common.buy":"Buy","common.sell":"Sell","common.long":"Long","common.short":"Short","common.edit":"Edit","common.save":"Save","common.add":"Add","common.delete":"Delete","common.tips":"Tips","common.max":"Max","common.download":"Download","common.copy":"Copy","common.copy.failed":"Copy failed","common.copy.copied":"Copied","common.share":"Share","common.export":"Export"};var m={"mediaTrack.title":"Media Track","mediaTrack.description":"Media Track"};var v={...l,...m};function s(t,e){let a=t.split("/")[1];return e=e||Object.values(r),e.includes(a)?a:null}function z(t,e,a){e=e||Object.values(r),a=a||"en";let c=/^([a-z]{2})/i,n=t?.match(c);if(!n)return a;let i=n[1];return e.includes(t)?t:e.includes(i)?i:a}function w(t,e){let a=s(t,e);return a?t.replace(new RegExp(`^/${a}(?=/)`),""):t}export{r as LocaleEnum,f as defaultLanguages,g as defaultLng,u as defaultNS,v as en,s as getLocalePathFromPathname,N as i18nCookieKey,C as i18nLocalStorageKey,z as parseI18nLang,w as removeLangPrefix};//# sourceMappingURL=server.mjs.map
2
+ //# sourceMappingURL=server.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/types.ts","../src/constant.ts","../src/locale/module/common.ts","../src/locale/module/mediaTrack.ts","../src/locale/en.ts","../src/utils/getLocalePathFromPathname.ts","../src/utils/parseI18nLang.ts","../src/utils/removeLangPrefix.ts"],"names":["LocaleEnum","defaultLanguages","defaultLng","defaultNS","i18nLocalStorageKey","i18nCookieKey","common","mediaTrack","en","getLocalePathFromPathname","pathname","localeCodes","locale","parseI18nLang","lang","defaultLang","regex","match","matchLang","removeLangPrefix","localePath"],"mappings":"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","file":"server.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 common = {\n \"common.cancel\": \"Cancel\",\n \"common.confirm\": \"Confirm\",\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\",\n \"common.share\": \"Share\",\n \"common.export\": \"Export\",\n};\n","export const mediaTrack = {\n \"mediaTrack.title\": \"Media Track\",\n \"mediaTrack.description\": \"Media Track\",\n};\n","import { common } from \"./module/common\";\nimport { mediaTrack } from \"./module/mediaTrack\";\n\nexport const en = {\n ...common,\n ...mediaTrack,\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 { 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"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@liberfi.io/i18n",
3
- "version": "0.1.0",
3
+ "version": "0.1.1",
4
4
  "description": "Internationalization for Liberfi React SDK",
5
5
  "main": "dist/index.js",
6
6
  "module": "dist/index.mjs",
@@ -11,17 +11,12 @@
11
11
  "require": "./dist/index.js",
12
12
  "import": "./dist/index.mjs"
13
13
  },
14
- "./locales/*": "./dist/locales/*",
15
- "./constant": {
16
- "types": "./dist/constant.d.ts",
17
- "require": "./dist/constant.js",
18
- "import": "./dist/constant.mjs"
14
+ "./server": {
15
+ "types": "./dist/server.d.ts",
16
+ "require": "./dist/server.js",
17
+ "import": "./dist/server.mjs"
19
18
  },
20
- "./utils": {
21
- "types": "./dist/utils.d.ts",
22
- "require": "./dist/utils.js",
23
- "import": "./dist/utils.mjs"
24
- }
19
+ "./locales/*": "./dist/locales/*"
25
20
  },
26
21
  "bin": {
27
22
  "i18n": "bin/cli.js"
@@ -1,9 +0,0 @@
1
- import { a as Language } from './types-DY-Gbo__.mjs';
2
-
3
- declare const defaultLanguages: Language[];
4
- declare const defaultLng = LocaleEnum.en;
5
- declare const defaultNS = "translation";
6
- declare const i18nLocalStorageKey = "liberfi_i18nLng";
7
- declare const i18nCookieKey = "liberfi_i18nLng";
8
-
9
- export { defaultLanguages, defaultLng, defaultNS, i18nCookieKey, i18nLocalStorageKey };
@@ -1,9 +0,0 @@
1
- import { a as Language } from './types-DY-Gbo__.js';
2
-
3
- declare const defaultLanguages: Language[];
4
- declare const defaultLng = LocaleEnum.en;
5
- declare const defaultNS = "translation";
6
- declare const i18nLocalStorageKey = "liberfi_i18nLng";
7
- declare const i18nCookieKey = "liberfi_i18nLng";
8
-
9
- export { defaultLanguages, defaultLng, defaultNS, i18nCookieKey, i18nLocalStorageKey };
package/dist/constant.js DELETED
@@ -1,2 +0,0 @@
1
- 'use strict';require('i18next');var t=[{localCode:"en",displayName:"English"},{localCode:"zh",displayName:"\u4E2D\u6587"},{localCode:"ja",displayName:"\u65E5\u672C\u8A9E"},{localCode:"es",displayName:"Espa\xF1ol"},{localCode:"ko",displayName:"\uD55C\uAD6D\uC5B4"},{localCode:"vi",displayName:"Ti\u1EBFng Vi\u1EC7t"},{localCode:"de",displayName:"Deutsch"},{localCode:"fr",displayName:"Fran\xE7ais"},{localCode:"ru",displayName:"\u0420\u0443\u0441\u0441\u043A\u0438\u0439"},{localCode:"id",displayName:"Bahasa Indonesia"},{localCode:"tr",displayName:"T\xFCrk\xE7e"},{localCode:"it",displayName:"Italiano"},{localCode:"pt",displayName:"Portugu\xEAs"},{localCode:"uk",displayName:"\u0423\u043A\u0440\u0430\u0457\u043D\u0441\u044C\u043A\u0430"},{localCode:"pl",displayName:"Polski"},{localCode:"nl",displayName:"Nederlands"}],d="en",i="translation",p="liberfi_i18nLng",r="liberfi_i18nLng";exports.defaultLanguages=t;exports.defaultLng=d;exports.defaultNS=i;exports.i18nCookieKey=r;exports.i18nLocalStorageKey=p;//# sourceMappingURL=constant.js.map
2
- //# sourceMappingURL=constant.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/constant.ts"],"names":["defaultLanguages","defaultLng","defaultNS","i18nLocalStorageKey","i18nCookieKey"],"mappings":"gCAEO,IAAMA,CAAAA,CAA+B,CAC1C,CAAE,SAAA,CAAA,IAAA,CAA0B,YAAa,SAAU,CAAA,CACnD,CAAE,SAAA,CAAA,IAAA,CAA0B,WAAA,CAAa,cAAK,CAAA,CAC9C,CAAE,eAA0B,WAAA,CAAa,oBAAM,EAC/C,CAAE,SAAA,CAAA,IAAA,CAA0B,YAAa,YAAU,CAAA,CACnD,CAAE,SAAA,CAAA,IAAA,CAA0B,WAAA,CAAa,oBAAM,CAAA,CAC/C,CAAE,eAA0B,WAAA,CAAa,sBAAa,EACtD,CAAE,SAAA,CAAA,IAAA,CAA0B,YAAa,SAAU,CAAA,CACnD,CAAE,SAAA,CAAA,IAAA,CAA0B,WAAA,CAAa,aAAW,CAAA,CACpD,CAAE,SAAA,CAAA,IAAA,CAA0B,WAAA,CAAa,4CAAU,CAAA,CACnD,CAAE,eAA0B,WAAA,CAAa,kBAAmB,EAC5D,CAAE,SAAA,CAAA,IAAA,CAA0B,YAAa,cAAS,CAAA,CAClD,CAAE,SAAA,CAAA,IAAA,CAA0B,WAAA,CAAa,UAAW,CAAA,CACpD,CAAE,eAA0B,WAAA,CAAa,cAAY,EACrD,CAAE,SAAA,CAAA,IAAA,CAA0B,YAAa,8DAAa,CAAA,CACtD,CAAE,SAAA,CAAA,IAAA,CAA0B,WAAA,CAAa,QAAS,CAAA,CAClD,CAAE,eAA0B,WAAA,CAAa,YAAa,CACxD,CAAA,CAEaC,CAAAA,CAAAA,IAAAA,CAEAC,EAAY,aAAA,CAEZC,CAAAA,CAAsB,kBAEtBC,CAAAA,CAAgB","file":"constant.js","sourcesContent":["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"]}
package/dist/constant.mjs DELETED
@@ -1,2 +0,0 @@
1
- import'i18next';var t=[{localCode:"en",displayName:"English"},{localCode:"zh",displayName:"\u4E2D\u6587"},{localCode:"ja",displayName:"\u65E5\u672C\u8A9E"},{localCode:"es",displayName:"Espa\xF1ol"},{localCode:"ko",displayName:"\uD55C\uAD6D\uC5B4"},{localCode:"vi",displayName:"Ti\u1EBFng Vi\u1EC7t"},{localCode:"de",displayName:"Deutsch"},{localCode:"fr",displayName:"Fran\xE7ais"},{localCode:"ru",displayName:"\u0420\u0443\u0441\u0441\u043A\u0438\u0439"},{localCode:"id",displayName:"Bahasa Indonesia"},{localCode:"tr",displayName:"T\xFCrk\xE7e"},{localCode:"it",displayName:"Italiano"},{localCode:"pt",displayName:"Portugu\xEAs"},{localCode:"uk",displayName:"\u0423\u043A\u0440\u0430\u0457\u043D\u0441\u044C\u043A\u0430"},{localCode:"pl",displayName:"Polski"},{localCode:"nl",displayName:"Nederlands"}],d="en",i="translation",p="liberfi_i18nLng",r="liberfi_i18nLng";export{t as defaultLanguages,d as defaultLng,i as defaultNS,r as i18nCookieKey,p as i18nLocalStorageKey};//# sourceMappingURL=constant.mjs.map
2
- //# sourceMappingURL=constant.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/constant.ts"],"names":["defaultLanguages","defaultLng","defaultNS","i18nLocalStorageKey","i18nCookieKey"],"mappings":"gBAEO,IAAMA,CAAAA,CAA+B,CAC1C,CAAE,SAAA,CAAA,IAAA,CAA0B,YAAa,SAAU,CAAA,CACnD,CAAE,SAAA,CAAA,IAAA,CAA0B,WAAA,CAAa,cAAK,CAAA,CAC9C,CAAE,eAA0B,WAAA,CAAa,oBAAM,EAC/C,CAAE,SAAA,CAAA,IAAA,CAA0B,YAAa,YAAU,CAAA,CACnD,CAAE,SAAA,CAAA,IAAA,CAA0B,WAAA,CAAa,oBAAM,CAAA,CAC/C,CAAE,eAA0B,WAAA,CAAa,sBAAa,EACtD,CAAE,SAAA,CAAA,IAAA,CAA0B,YAAa,SAAU,CAAA,CACnD,CAAE,SAAA,CAAA,IAAA,CAA0B,WAAA,CAAa,aAAW,CAAA,CACpD,CAAE,SAAA,CAAA,IAAA,CAA0B,WAAA,CAAa,4CAAU,CAAA,CACnD,CAAE,eAA0B,WAAA,CAAa,kBAAmB,EAC5D,CAAE,SAAA,CAAA,IAAA,CAA0B,YAAa,cAAS,CAAA,CAClD,CAAE,SAAA,CAAA,IAAA,CAA0B,WAAA,CAAa,UAAW,CAAA,CACpD,CAAE,eAA0B,WAAA,CAAa,cAAY,EACrD,CAAE,SAAA,CAAA,IAAA,CAA0B,YAAa,8DAAa,CAAA,CACtD,CAAE,SAAA,CAAA,IAAA,CAA0B,WAAA,CAAa,QAAS,CAAA,CAClD,CAAE,eAA0B,WAAA,CAAa,YAAa,CACxD,CAAA,CAEaC,CAAAA,CAAAA,IAAAA,CAEAC,EAAY,aAAA,CAEZC,CAAAA,CAAsB,kBAEtBC,CAAAA,CAAgB","file":"constant.mjs","sourcesContent":["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"]}
@@ -1,81 +0,0 @@
1
- declare const en: {
2
- "mediaTrack.title": string;
3
- "mediaTrack.description": string;
4
- "common.cancel": string;
5
- "common.confirm": string;
6
- "common.ok": string;
7
- "common.yes": string;
8
- "common.no": string;
9
- "common.all": string;
10
- "common.buy": string;
11
- "common.sell": string;
12
- "common.long": string;
13
- "common.short": string;
14
- "common.edit": string;
15
- "common.save": string;
16
- "common.add": string;
17
- "common.delete": string;
18
- "common.tips": string;
19
- "common.max": string;
20
- "common.download": string;
21
- "common.copy": string;
22
- "common.copy.failed": string;
23
- "common.copy.copied": string;
24
- "common.share": string;
25
- "common.export": string;
26
- };
27
-
28
- declare enum LocaleEnum {
29
- /** English */
30
- en = "en",
31
- /** Chinese */
32
- zh = "zh",
33
- /** Japanese */
34
- ja = "ja",
35
- /** Spanish */
36
- es = "es",
37
- /** Korean */
38
- ko = "ko",
39
- /** Vietnamese */
40
- vi = "vi",
41
- /** German */
42
- de = "de",
43
- /** French */
44
- fr = "fr",
45
- /** Russian */
46
- ru = "ru",
47
- /** Indonesian */
48
- id = "id",
49
- /** Turkish */
50
- tr = "tr",
51
- /** Italian */
52
- it = "it",
53
- /** Portuguese */
54
- pt = "pt",
55
- /** Ukrainian */
56
- uk = "uk",
57
- /** Polish */
58
- pl = "pl",
59
- /** Dutch */
60
- nl = "nl"
61
- }
62
- type LocaleCode = keyof typeof LocaleEnum | (string & {});
63
- type Language = {
64
- localCode: LocaleCode;
65
- displayName: string;
66
- };
67
- type ExtendLocaleMessages = Record<`extend.${string}`, string>;
68
- type LocaleMessages = typeof en & ExtendLocaleMessages;
69
- type Resources<T extends {} = {}> = {
70
- [key in LocaleCode]?: Partial<LocaleMessages & T>;
71
- };
72
- declare module "i18next" {
73
- interface CustomTypeOptions {
74
- defaultNS: "translation";
75
- resources: {
76
- translation: LocaleMessages;
77
- };
78
- }
79
- }
80
-
81
- export { type ExtendLocaleMessages as E, type LocaleCode as L, type Resources as R, type Language as a, LocaleEnum as b, type LocaleMessages as c, en as e };
@@ -1,81 +0,0 @@
1
- declare const en: {
2
- "mediaTrack.title": string;
3
- "mediaTrack.description": string;
4
- "common.cancel": string;
5
- "common.confirm": string;
6
- "common.ok": string;
7
- "common.yes": string;
8
- "common.no": string;
9
- "common.all": string;
10
- "common.buy": string;
11
- "common.sell": string;
12
- "common.long": string;
13
- "common.short": string;
14
- "common.edit": string;
15
- "common.save": string;
16
- "common.add": string;
17
- "common.delete": string;
18
- "common.tips": string;
19
- "common.max": string;
20
- "common.download": string;
21
- "common.copy": string;
22
- "common.copy.failed": string;
23
- "common.copy.copied": string;
24
- "common.share": string;
25
- "common.export": string;
26
- };
27
-
28
- declare enum LocaleEnum {
29
- /** English */
30
- en = "en",
31
- /** Chinese */
32
- zh = "zh",
33
- /** Japanese */
34
- ja = "ja",
35
- /** Spanish */
36
- es = "es",
37
- /** Korean */
38
- ko = "ko",
39
- /** Vietnamese */
40
- vi = "vi",
41
- /** German */
42
- de = "de",
43
- /** French */
44
- fr = "fr",
45
- /** Russian */
46
- ru = "ru",
47
- /** Indonesian */
48
- id = "id",
49
- /** Turkish */
50
- tr = "tr",
51
- /** Italian */
52
- it = "it",
53
- /** Portuguese */
54
- pt = "pt",
55
- /** Ukrainian */
56
- uk = "uk",
57
- /** Polish */
58
- pl = "pl",
59
- /** Dutch */
60
- nl = "nl"
61
- }
62
- type LocaleCode = keyof typeof LocaleEnum | (string & {});
63
- type Language = {
64
- localCode: LocaleCode;
65
- displayName: string;
66
- };
67
- type ExtendLocaleMessages = Record<`extend.${string}`, string>;
68
- type LocaleMessages = typeof en & ExtendLocaleMessages;
69
- type Resources<T extends {} = {}> = {
70
- [key in LocaleCode]?: Partial<LocaleMessages & T>;
71
- };
72
- declare module "i18next" {
73
- interface CustomTypeOptions {
74
- defaultNS: "translation";
75
- resources: {
76
- translation: LocaleMessages;
77
- };
78
- }
79
- }
80
-
81
- export { type ExtendLocaleMessages as E, type LocaleCode as L, type Resources as R, type Language as a, LocaleEnum as b, type LocaleMessages as c, en as e };
package/dist/utils.d.mts DELETED
@@ -1,63 +0,0 @@
1
- import { L as LocaleCode } from './types-DY-Gbo__.mjs';
2
-
3
- /**
4
- * transform browser language to i18n locale codes
5
- * @param lang - browser language
6
- * @param localeCodes - locale codes to check
7
- * @param defaultLang - default locale code
8
- * @example
9
- * parseI18nLang('en-US') => 'en'
10
- * parseI18nLang('zh-CN') => 'zh'
11
- * parseI18nLang('zh-TW') => 'zh'
12
- * parseI18nLang('ja') => 'ja'
13
- * */
14
- declare function parseI18nLang(lang: string, localeCodes?: LocaleCode[], defaultLang?: LocaleCode): string;
15
- /**
16
- * remove lang prefix from pathname
17
- * @param pathname - pathname to remove lang prefix
18
- * @param localeCodes - locale codes to check
19
- * @example
20
- * removeLangPrefix('/en/perp/PERP_ETH_USDC') => '/perp/PERP_ETH_USDC'
21
- * removeLangPrefix('/en/markets') => '/markets'
22
- * removeLangPrefix('/perp/PERP_ETH_USDC') => '/perp/PERP_ETH_USDC'
23
- * removeLangPrefix('/markets') => '/markets'
24
- */
25
- declare function removeLangPrefix(pathname: string, localeCodes?: string[]): string;
26
- /**
27
- * get locale path from pathname
28
- * @param pathname - pathname to get locale path
29
- * @param localeCodes - locale codes to check
30
- * @example
31
- * getLocalePathFromPathname('/en/perp/PERP_ETH_USDC') => 'en'
32
- * getLocalePathFromPathname('/perp/PERP_ETH_USDC') => null
33
- * getLocalePathFromPathname('/en/markets') => 'en'
34
- * getLocalePathFromPathname('/markets') => null
35
- */
36
- declare function getLocalePathFromPathname(pathname: string, localeCodes?: string[]): string | null;
37
- /**
38
- * Generate a localized path with proper locale prefix and search parameters
39
- *
40
- * This function ensures that the returned path includes the appropriate locale prefix.
41
- * If the path already contains a valid locale prefix, it returns the path as-is.
42
- * Otherwise, it prepends the specified locale or falls back to the current i18n language.
43
- *
44
- * @param params - Configuration object for path generation
45
- * @param params.path - The base pathname (e.g., '/markets', '/perp/PERP_ETH_USDC')
46
- * @param params.locale - Optional locale code to use as prefix. If not provided, uses i18n.language
47
- * @param params.search - Optional search query string. If not provided, uses window.location.search
48
- *
49
- * @returns A complete URL path with locale prefix and search parameters
50
- *
51
- * @example
52
- * generatePath({ path: '/markets' }) => '/en/markets?tab=spot'
53
- * generatePath({ path: '/en/markets', search: '?tab=futures' }) => '/en/markets?tab=futures'
54
- * generatePath({ path: '/perp/PERP_ETH_USDC', locale: 'zh' }) => '/zh/perp/PERP_ETH_USDC'
55
- * generatePath({ path: '/en/perp/PERP_ETH_USDC' }) => '/en/perp/PERP_ETH_USDC'
56
- */
57
- declare function generatePath(params: {
58
- path: string;
59
- locale?: string;
60
- search?: string;
61
- }): string;
62
-
63
- export { generatePath, getLocalePathFromPathname, parseI18nLang, removeLangPrefix };
package/dist/utils.d.ts DELETED
@@ -1,63 +0,0 @@
1
- import { L as LocaleCode } from './types-DY-Gbo__.js';
2
-
3
- /**
4
- * transform browser language to i18n locale codes
5
- * @param lang - browser language
6
- * @param localeCodes - locale codes to check
7
- * @param defaultLang - default locale code
8
- * @example
9
- * parseI18nLang('en-US') => 'en'
10
- * parseI18nLang('zh-CN') => 'zh'
11
- * parseI18nLang('zh-TW') => 'zh'
12
- * parseI18nLang('ja') => 'ja'
13
- * */
14
- declare function parseI18nLang(lang: string, localeCodes?: LocaleCode[], defaultLang?: LocaleCode): string;
15
- /**
16
- * remove lang prefix from pathname
17
- * @param pathname - pathname to remove lang prefix
18
- * @param localeCodes - locale codes to check
19
- * @example
20
- * removeLangPrefix('/en/perp/PERP_ETH_USDC') => '/perp/PERP_ETH_USDC'
21
- * removeLangPrefix('/en/markets') => '/markets'
22
- * removeLangPrefix('/perp/PERP_ETH_USDC') => '/perp/PERP_ETH_USDC'
23
- * removeLangPrefix('/markets') => '/markets'
24
- */
25
- declare function removeLangPrefix(pathname: string, localeCodes?: string[]): string;
26
- /**
27
- * get locale path from pathname
28
- * @param pathname - pathname to get locale path
29
- * @param localeCodes - locale codes to check
30
- * @example
31
- * getLocalePathFromPathname('/en/perp/PERP_ETH_USDC') => 'en'
32
- * getLocalePathFromPathname('/perp/PERP_ETH_USDC') => null
33
- * getLocalePathFromPathname('/en/markets') => 'en'
34
- * getLocalePathFromPathname('/markets') => null
35
- */
36
- declare function getLocalePathFromPathname(pathname: string, localeCodes?: string[]): string | null;
37
- /**
38
- * Generate a localized path with proper locale prefix and search parameters
39
- *
40
- * This function ensures that the returned path includes the appropriate locale prefix.
41
- * If the path already contains a valid locale prefix, it returns the path as-is.
42
- * Otherwise, it prepends the specified locale or falls back to the current i18n language.
43
- *
44
- * @param params - Configuration object for path generation
45
- * @param params.path - The base pathname (e.g., '/markets', '/perp/PERP_ETH_USDC')
46
- * @param params.locale - Optional locale code to use as prefix. If not provided, uses i18n.language
47
- * @param params.search - Optional search query string. If not provided, uses window.location.search
48
- *
49
- * @returns A complete URL path with locale prefix and search parameters
50
- *
51
- * @example
52
- * generatePath({ path: '/markets' }) => '/en/markets?tab=spot'
53
- * generatePath({ path: '/en/markets', search: '?tab=futures' }) => '/en/markets?tab=futures'
54
- * generatePath({ path: '/perp/PERP_ETH_USDC', locale: 'zh' }) => '/zh/perp/PERP_ETH_USDC'
55
- * generatePath({ path: '/en/perp/PERP_ETH_USDC' }) => '/en/perp/PERP_ETH_USDC'
56
- */
57
- declare function generatePath(params: {
58
- path: string;
59
- locale?: string;
60
- search?: string;
61
- }): string;
62
-
63
- export { generatePath, getLocalePathFromPathname, parseI18nLang, removeLangPrefix };
package/dist/utils.js DELETED
@@ -1,2 +0,0 @@
1
- 'use strict';var reactI18next=require('react-i18next'),i18next=require('i18next'),h=require('i18next-browser-languagedetector');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var h__default=/*#__PURE__*/_interopDefault(h);var i=(e=>(e.en="en",e.zh="zh",e.ja="ja",e.es="es",e.ko="ko",e.vi="vi",e.de="de",e.fr="fr",e.ru="ru",e.id="id",e.tr="tr",e.it="it",e.pt="pt",e.uk="uk",e.pl="pl",e.nl="nl",e))(i||{});var s="en",l="translation",m="liberfi_i18nLng",p="liberfi_i18nLng";var d={"common.cancel":"Cancel","common.confirm":"Confirm","common.ok":"OK","common.yes":"Yes","common.no":"No","common.all":"All","common.buy":"Buy","common.sell":"Sell","common.long":"Long","common.short":"Short","common.edit":"Edit","common.save":"Save","common.add":"Add","common.delete":"Delete","common.tips":"Tips","common.max":"Max","common.download":"Download","common.copy":"Copy","common.copy.failed":"Copy failed","common.copy.copied":"Copied","common.share":"Share","common.export":"Export"};var g={"mediaTrack.title":"Media Track","mediaTrack.description":"Media Track"};var f={...d,...g};var y=i18next.createInstance();y.use(h__default.default).use(reactI18next.initReactI18next).init({fallbackLng:s,ns:[l],defaultNS:l,interpolation:{escapeValue:false},detection:{lookupLocalStorage:m,lookupCookie:p,caches:["cookie","localStorage"],order:["cookie","localStorage","htmlTag","navigator"]},resources:{[s]:{[l]:f}}});var u=y;function N(t,o,a){o=o||Object.values(i),a=a||"en";let c=/^([a-z]{2})/i,r=t?.match(c);if(!r)return a;let n=r[1];return o.includes(t)?t:o.includes(n)?n:a}function _(t,o){let a=x(t,o);return a?t.replace(new RegExp(`^/${a}(?=/)`),""):t}function x(t,o){let a=t.split("/")[1];return o=o||Object.values(i),o.includes(a)?a:null}function U(t){let{path:o,locale:a,search:c}=t,r=c||(typeof window<"u"?window.location.search:""),n=x(o);return n?`${o}${r}`:(n=a||N(u.language),`/${n}${o}${r}`)}exports.generatePath=U;exports.getLocalePathFromPathname=x;exports.parseI18nLang=N;exports.removeLangPrefix=_;//# sourceMappingURL=utils.js.map
2
- //# sourceMappingURL=utils.js.map
package/dist/utils.js.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/types.ts","../src/constant.ts","../src/locale/module/common.ts","../src/locale/module/mediaTrack.ts","../src/locale/en.ts","../src/i18n.ts","../src/utils.ts"],"names":["LocaleEnum","defaultLng","defaultNS","i18nLocalStorageKey","i18nCookieKey","common","mediaTrack","en","i18n","createInstance","LanguageDetector","initReactI18next","i18n_default","parseI18nLang","lang","localeCodes","defaultLang","regex","match","matchLang","removeLangPrefix","pathname","localePath","getLocalePathFromPathname","locale","generatePath","params","path","search","searchUrl"],"mappings":"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","file":"utils.js","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 common = {\n \"common.cancel\": \"Cancel\",\n \"common.confirm\": \"Confirm\",\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\",\n \"common.share\": \"Share\",\n \"common.export\": \"Export\",\n};\n","export const mediaTrack = {\n \"mediaTrack.title\": \"Media Track\",\n \"mediaTrack.description\": \"Media Track\",\n};\n","import { common } from \"./module/common\";\nimport { mediaTrack } from \"./module/mediaTrack\";\n\nexport const en = {\n ...common,\n ...mediaTrack,\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 { 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\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\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\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"]}
package/dist/utils.mjs DELETED
@@ -1,2 +0,0 @@
1
- import {initReactI18next}from'react-i18next';import {createInstance}from'i18next';import h from'i18next-browser-languagedetector';var i=(e=>(e.en="en",e.zh="zh",e.ja="ja",e.es="es",e.ko="ko",e.vi="vi",e.de="de",e.fr="fr",e.ru="ru",e.id="id",e.tr="tr",e.it="it",e.pt="pt",e.uk="uk",e.pl="pl",e.nl="nl",e))(i||{});var s="en",l="translation",m="liberfi_i18nLng",p="liberfi_i18nLng";var d={"common.cancel":"Cancel","common.confirm":"Confirm","common.ok":"OK","common.yes":"Yes","common.no":"No","common.all":"All","common.buy":"Buy","common.sell":"Sell","common.long":"Long","common.short":"Short","common.edit":"Edit","common.save":"Save","common.add":"Add","common.delete":"Delete","common.tips":"Tips","common.max":"Max","common.download":"Download","common.copy":"Copy","common.copy.failed":"Copy failed","common.copy.copied":"Copied","common.share":"Share","common.export":"Export"};var g={"mediaTrack.title":"Media Track","mediaTrack.description":"Media Track"};var f={...d,...g};var y=createInstance();y.use(h).use(initReactI18next).init({fallbackLng:s,ns:[l],defaultNS:l,interpolation:{escapeValue:false},detection:{lookupLocalStorage:m,lookupCookie:p,caches:["cookie","localStorage"],order:["cookie","localStorage","htmlTag","navigator"]},resources:{[s]:{[l]:f}}});var u=y;function N(t,o,a){o=o||Object.values(i),a=a||"en";let c=/^([a-z]{2})/i,r=t?.match(c);if(!r)return a;let n=r[1];return o.includes(t)?t:o.includes(n)?n:a}function _(t,o){let a=x(t,o);return a?t.replace(new RegExp(`^/${a}(?=/)`),""):t}function x(t,o){let a=t.split("/")[1];return o=o||Object.values(i),o.includes(a)?a:null}function U(t){let{path:o,locale:a,search:c}=t,r=c||(typeof window<"u"?window.location.search:""),n=x(o);return n?`${o}${r}`:(n=a||N(u.language),`/${n}${o}${r}`)}export{U as generatePath,x as getLocalePathFromPathname,N as parseI18nLang,_ as removeLangPrefix};//# sourceMappingURL=utils.mjs.map
2
- //# sourceMappingURL=utils.mjs.map