@liberfi.io/i18n 0.1.5 → 0.1.7

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.
package/dist/index.js CHANGED
@@ -1,2 +1,11 @@
1
- 'use strict';var reactI18next=require('react-i18next'),i18next=require('i18next'),V=require('i18next-browser-languagedetector'),react=require('react'),jsxRuntime=require('react/jsx-runtime');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var i18next__default=/*#__PURE__*/_interopDefault(i18next);var V__default=/*#__PURE__*/_interopDefault(V);var p=(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))(p||{});var x=[{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"}],h="en",i="translation",H="liberfi_i18nLng",S="liberfi_i18nLng";var b={"common.cancel":"Cancel","common.confirm":"Confirm","common.reset":"Reset","common.apply":"Apply","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 to clipboard","common.share":"Share","common.export":"Export","common.empty":"No data","common.resolution.1s":"1s","common.resolution.15s":"15s","common.resolution.30s":"30s","common.resolution.1m":"1m","common.resolution.5m":"5m","common.resolution.15m":"15m","common.resolution.30m":"30m","common.resolution.1h":"1h","common.resolution.4h":"4h","common.resolution.12h":"12h","common.resolution.24h":"24h"};var I={"mediaTrack.tweets.translate.show":"Show Translation","mediaTrack.tweets.translate.hide":"Hide Translation","mediaTrack.tweets.expand":"Expand","mediaTrack.tweets.collapse":"Collapse"};var R={"scaffold.draggableModal.snapToEdge":"Drag to edge to show side panel","scaffold.draggablePanel.snapToModal":"Drag away to show floating modal"};var M={"tokens.copied.address":"Token address copied to clipboard","tokens.listHeader.token":"Token","tokens.listHeader.priceHistories":"Price Histories","tokens.listHeader.price":"Price","tokens.listHeader.priceChange":"{{resolution}}%","tokens.listHeader.marketCap":"Market Cap","tokens.listHeader.liquidity":"Liquidity","tokens.listHeader.volumes":"{{resolution}} Volumes","tokens.listHeader.txs":"{{resolution}} TXNS","tokens.listHeader.traders":"{{resolution}} Traders","tokens.listHeader.tokenInfo":"Token Info","tokens.listHeader.actions":"Actions","tokens.listHeader.filter":"Filter","tokens.listType.trending":"Trending","tokens.listType.new":"New","tokens.listType.stocks":"Stocks","tokens.filters.protocols.title":"Protocols","tokens.filters.protocols.selectAll":"Select All","tokens.filters.protocols.unselectAll":"Unselect All","tokens.filters.keywords.title":"Search Keywords","tokens.filters.keywords.exclude.title":"Exclude Keywords","tokens.filters.keywords.placeholder":"keyword1, keyword2...","tokens.filters.stats.min":"Min","tokens.filters.stats.max":"Max","tokens.filters.stats.audits":"Audits","tokens.filters.stats.audits.holders":"Holders Count","tokens.filters.stats.audits.top10HoldingsRatio":"Top 10 Holders %","tokens.filters.stats.audits.top100HoldingsRatio":"Top 100 Holders %","tokens.filters.stats.audits.devHoldingsRatio":"Dev Holdings %","tokens.filters.stats.metrics":"Metrics","tokens.filters.stats.metrics.volumes":"{{resolution}} Volumes ($)","tokens.filters.stats.metrics.txns":"{{resolution}} Transactions","tokens.filters.stats.metrics.liquidity":"Liquidity ($)","tokens.filters.stats.metrics.marketCap":"Market Cap ($)","tokens.filters.modal.title":"Filters","tokens.tokenInfo.holders":"Holders","tokens.tokenInfo.top10HoldingsRatio":"Top 10 Holders","tokens.tokenInfo.top100HoldingsRatio":"Top 100 Holders","tokens.tokenInfo.devHoldingsRatio":"Dev Holders"};var A={...b,...I,...R,...M};var $=i18next.createInstance();$.use(V__default.default).use(reactI18next.initReactI18next).init({fallbackLng:h,ns:[i],defaultNS:i,interpolation:{escapeValue:false},detection:{lookupLocalStorage:H,lookupCookie:S,caches:["cookie","localStorage"],order:["cookie","localStorage","htmlTag","navigator"]},resources:{[h]:{[i]:A}}});var t=$;var f=class{constructor(e){this.options=e;this.cache=new Set;}cache;async fetchData(e){try{return await(await fetch(e)).json()}catch{return {}}}async loadLanguage(e,a){if(typeof this.options?.loadPath!="function")return;let n=this.options.loadPath(e,a);if(typeof n=="string"&&(n=[n]),!n.length)return;let s=n.filter(c=>!t.hasResourceBundle(e,a)||!this.cache.has(c)).map(async c=>{let m=await this.fetchData(c);t.addResourceBundle(e,a,m,true,true),this.cache.add(c);});await Promise.all(s);}};var y=react.createContext({languages:[],beforeLanguageChange:()=>Promise.resolve(),afterLanguageChange:()=>Promise.resolve()}),F=()=>{let r=react.useContext(y);if(!r)throw new Error("useLocaleContext must be used within a LocaleProvider");return r};function u(r,e){let a=r.split("/")[1];return e=e||Object.values(p),e.includes(a)?a:null}function g(r,e,a){e=e||Object.values(p),a=a||"en";let n=/^([a-z]{2})/i,l=r?.match(n);if(!l)return a;let s=l[1];return e.includes(r)?r:e.includes(s)?s:a}function Ke(r){let{path:e,locale:a,search:n}=r,l=n||(typeof window<"u"?window.location.search:""),s=u(e);return s?`${e}${l}`:(s=a||g(t.language),`/${s}${e}${l}`)}function De(r,e){let a=u(r,e);return a?r.replace(new RegExp(`^/${a}(?=/)`),""):r}function X({children:r,locale:e,resource:a,resources:n,backend:l,supportedLanguages:s,convertDetectedLanguage:c,languages:m,beforeLanguageChange:C,afterLanguageChange:L}){let[P,w]=react.useState(x),T=react.useRef(new f(l));react.useEffect(()=>{if(n){Object.entries(n).forEach(([o,d])=>{t.addResourceBundle(o,i,d,true,true);});return}a&&e&&t.addResourceBundle(e,i,a,true,true);},[e,a,n]),react.useEffect(()=>{e&&e!==t.language&&t.changeLanguage(e);},[e]),react.useEffect(()=>{Array.isArray(m)?w(m):Array.isArray(s)&&w(s.map(o=>x.find(d=>d.localCode===o)).filter(o=>!!o));},[s,m]),react.useEffect(()=>{(async()=>{let d=typeof c=="function"?c(t.language):g(t.language);await T.current.loadLanguage(d,i),d!==t.language&&await t.changeLanguage(d);})();},[t.language]);let N=react.useCallback(async o=>{await C?.(o),await T.current.loadLanguage(o,i);},[C]),v=react.useCallback(async o=>{L?.(o);},[L]),B=react.useMemo(()=>({languages:P,beforeLanguageChange:N,afterLanguageChange:v}),[P,N,v]);return jsxRuntime.jsx(y.Provider,{value:B,children:jsxRuntime.jsx(reactI18next.I18nextProvider,{i18n:t,defaultNS:i,children:r})})}function Q(r,e){let a=react.useContext(reactI18next.I18nContext);return reactI18next.useTranslation(r,{i18n:a?.i18n||t,...e})}function oe(){let[r,e]=react.useState(t.language);return react.useEffect(()=>(t.on("languageChanged",e),()=>{t.off("languageChanged",e);}),[t]),r}function ae(){let{beforeLanguageChange:r,afterLanguageChange:e}=F();return react.useCallback(async n=>{await r(n),await t.changeLanguage(n),await e(n);},[r,e,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.LocaleContext=y;exports.LocaleEnum=p;exports.LocaleProvider=X;exports.defaultLanguages=x;exports.defaultLng=h;exports.defaultNS=i;exports.en=A;exports.generatePath=Ke;exports.getLocalePathFromPathname=u;exports.i18n=t;exports.i18nCookieKey=S;exports.i18nLocalStorageKey=H;exports.parseI18nLang=g;exports.removeLangPrefix=De;exports.useChangeLocale=ae;exports.useLocale=oe;exports.useLocaleContext=F;exports.useTranslation=Q;Object.keys(reactI18next).forEach(function(k){if(k!=='default'&&!Object.prototype.hasOwnProperty.call(exports,k))Object.defineProperty(exports,k,{enumerable:true,get:function(){return reactI18next[k]}})});//# sourceMappingURL=index.js.map
1
+ 'use strict';var reactI18next=require('react-i18next'),i18next=require('i18next'),U=require('i18next-browser-languagedetector'),react=require('react'),jsxRuntime=require('react/jsx-runtime');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var i18next__default=/*#__PURE__*/_interopDefault(i18next);var U__default=/*#__PURE__*/_interopDefault(U);var u=(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))(u||{});var x=[{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"}],y="en",l="translation",v="liberfi_i18nLng",N="liberfi_i18nLng";var A={"channels.forms.base.title":"Base Info","channels.forms.base.name.label":"Name","channels.forms.base.name.placeholder":"Please enter the channel name","channels.forms.base.name.required":"Name is required","channels.forms.base.name.min":"Name must be at least 1 character","channels.forms.base.name.max":"Name must be less than 24 characters","channels.forms.base.description.label":"Description","channels.forms.base.description.placeholder":"Please enter the channel description","channels.forms.base.icon.label":"Icon","channels.forms.base.icon.placeholder":"Please upload the channel icon","channels.forms.base.icon.hint":"A square image of at least 128x128 is suggested. File size cannot exceed 10mb.","channels.forms.base.icon.required":"Icon is required","channels.forms.base.icon.maxSize":"Icon size cannot exceed 10MB","channels.forms.base.submit":"Create Channel","channels.forms.base.update.submit":"Update Channel","channels.forms.wallets.title":"Wallet Management","channels.forms.wallets.label":"Add Wallets","channels.forms.wallets.placeholder":`Text Format:
2
+ 8zFZHuSRuDpuAR7J6FzwyF3vKNx4CVW3DFHJerQhc7Zd,pow
3
+ 0x4DB5a66E937A9F4473fA95b1cAF1d1E1D62E29EA,Smart Money`,"channels.forms.wallets.required":"Wallets are required","channels.forms.wallets.invalid":"Invalid wallets format","channels.forms.wallets.chain.required":"Chain is required","channels.forms.wallets.address.required":"Wallet address is required","channels.forms.wallets.address.duplicated":"There are {{count}} duplicated wallet addresses in the input","channels.forms.wallets.address.invalid":"There are {{count}} invalid wallet addresses","channels.forms.wallets.address.alreadyAdded":"There are {{count}} wallet addresses already added","channels.forms.wallets.maxCount":"Wallet count cannot exceed 500","channels.forms.wallets.submit":"Add Wallets","channels.forms.wallets.supportedFormats":"Supported Formats","channels.forms.wallets.supportedFormats.text":"Text","channels.forms.wallets.supportedFormats.text.hint":`Text Format:
4
+
5
+ 8zFZHuSRuDpuAR7J6FzwyF3vKNx4CVW3DFHJerQhc7Zd,pow
6
+ 0x4DB5a66E937A9F4473fA95b1cAF1d1E1D62E29EA,Smart Money`,"channels.forms.wallets.addedCount":"added wallets","channels.forms.wallets.list.title":"Added Wallets","channels.forms.wallets.list.header.address":"Alias/Address","channels.forms.wallets.list.header.balance":"Balance","channels.forms.wallets.list.header.importedAt":"Imported At","channels.forms.wallets.list.header.lastActiveAt":"Last Active At","channels.forms.wallets.list.header.7dBuys":"7 Days Buys","channels.forms.wallets.list.header.7dSells":"7 Days Sells","channels.forms.wallets.list.header.actions":"Actions","channels.forms.wallets.list.empty":"No wallets added yet","channels.forms.wallets.list.search.placeholder":"Search by address or alias","channels.forms.wallets.update.success":"Update wallets successfully","channels.forms.wallets.update.error":"Update wallets error","channels.forms.socials.title":"Social Medias","channels.forms.socials.telegram.guide":`\u26A1\uFE0F Quick Start
7
+ 1. Search for @BotFather on Telegram
8
+ 2. Send /newbot to create a bot and get Token
9
+ 3. Enter the Bot Token here and save
10
+ 4. Add the bot to your group/channel`,"channels.forms.socials.telegram.placeholder":"Enter your Telegram Bot Token","channels.list.title":"Channel List","channels.trending.title":"Trending Channels","channels.my.title":"My Channels","channels.subscribe.submit":"Subscribe","channels.subscribe.error":"Subscribe channel error","channels.subscribe.success":"Subscribe channel successfully","channels.unsubscribe.submit":"Subscribed","channels.unsubscribe.error":"Unsubscribe channel error","channels.unsubscribe.success":"Unsubscribe channel successfully","channels.subscribed.title":"Subscribed Channels","channels.create.title":"Create Channel","channels.create.success":"Channel created successfully","channels.create.error":"Create channel error","channels.update.title":"Update Channel","channels.update.success":"Channel updated successfully","channels.update.error":"Update channel error","channels.info.walletCount":"Wallet Count","channels.info.subscribeCount":"Subscribe Count","channels.info.createdAt":"created at","channels.info.updatedAt":"last updated at","channels.stats.7dTxs.title":"7D TXs","channels.stats.7dTxs.hint":"7 Days Transactions","channels.stats.7dPnl.title":"7D PnL","channels.stats.7dPnl.hint":"7 Days Profit and Loss","channels.stats.7dWr.title":"7D WR","channels.stats.7dWr.hint":"7 Days Winning Rate","channels.detail.title":"Channel Detail","channels.detail.events.title":"Channel Events","channels.detail.notfound":"Channel not found"};var H={"common.cancel":"Cancel","common.confirm":"Confirm","common.reset":"Reset","common.apply":"Apply","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 to clipboard","common.share":"Share","common.export":"Export","common.empty":"No data","common.unauthenticated":"Please sign in to continue","common.signIn":"Sign In","common.signOut":"Sign Out","common.resolution.1s":"1s","common.resolution.15s":"15s","common.resolution.30s":"30s","common.resolution.1m":"1m","common.resolution.5m":"5m","common.resolution.15m":"15m","common.resolution.30m":"30m","common.resolution.1h":"1h","common.resolution.4h":"4h","common.resolution.12h":"12h","common.resolution.24h":"24h","common.upload.submit":"Upload","common.upload.resubmit":"Reupload","common.upload.error":"Upload error"};var F={"mediaTrack.tweets.translate.show":"Show Translation","mediaTrack.tweets.translate.hide":"Hide Translation","mediaTrack.tweets.expand":"Expand","mediaTrack.tweets.collapse":"Collapse"};var I={"scaffold.draggableModal.snapToEdge":"Drag to edge to show side panel","scaffold.draggablePanel.snapToModal":"Drag away to show floating modal","scaffold.home":"Home"};var D={"tokens.search.placeholder":"Search by token or CA...","tokens.copied.address":"Token address copied to clipboard","tokens.listHeader.token":"Token","tokens.listHeader.priceHistories":"Price Histories","tokens.listHeader.price":"Price","tokens.listHeader.priceChange":"{{resolution}}%","tokens.listHeader.marketCap":"Market Cap","tokens.listHeader.liquidity":"Liquidity","tokens.listHeader.volumes":"{{resolution}} Volumes","tokens.listHeader.txs":"{{resolution}} TXNS","tokens.listHeader.traders":"{{resolution}} Traders","tokens.listHeader.tokenInfo":"Token Info","tokens.listHeader.actions":"Actions","tokens.listHeader.filter":"Filter","tokens.listType.trending":"Trending","tokens.listType.new":"New","tokens.listType.stocks":"Stocks","tokens.filters.protocols.title":"Protocols","tokens.filters.protocols.selectAll":"Select All","tokens.filters.protocols.unselectAll":"Unselect All","tokens.filters.keywords.title":"Search Keywords","tokens.filters.keywords.exclude.title":"Exclude Keywords","tokens.filters.keywords.placeholder":"keyword1, keyword2...","tokens.filters.stats.min":"Min","tokens.filters.stats.max":"Max","tokens.filters.stats.audits":"Audits","tokens.filters.stats.audits.holders":"Holders Count","tokens.filters.stats.audits.top10HoldingsRatio":"Top 10 Holders %","tokens.filters.stats.audits.top100HoldingsRatio":"Top 100 Holders %","tokens.filters.stats.audits.devHoldingsRatio":"Dev Holdings %","tokens.filters.stats.metrics":"Metrics","tokens.filters.stats.metrics.volumes":"{{resolution}} Volumes ($)","tokens.filters.stats.metrics.txns":"{{resolution}} Transactions","tokens.filters.stats.metrics.liquidity":"Liquidity ($)","tokens.filters.stats.metrics.marketCap":"Market Cap ($)","tokens.filters.modal.title":"Filters","tokens.tokenInfo.holders":"Holders","tokens.tokenInfo.top10HoldingsRatio":"Top 10 Holders","tokens.tokenInfo.top100HoldingsRatio":"Top 100 Holders","tokens.tokenInfo.devHoldingsRatio":"Dev Holders"};var R={...H,...F,...I,...D,...A};var B=i18next.createInstance();B.use(U__default.default).use(reactI18next.initReactI18next).init({fallbackLng:y,ns:[l],defaultNS:l,interpolation:{escapeValue:false},detection:{lookupLocalStorage:v,lookupCookie:N,caches:["cookie","localStorage"],order:["cookie","localStorage","htmlTag","navigator"]},resources:{[y]:{[l]:R}}});var t=B;var p=class{constructor(e){this.options=e;this.cache=new Set;}cache;async fetchData(e){try{return await(await fetch(e)).json()}catch{return {}}}async loadLanguage(e,a){if(typeof this.options?.loadPath!="function")return;let n=this.options.loadPath(e,a);if(typeof n=="string"&&(n=[n]),!n.length)return;let r=n.filter(c=>!t.hasResourceBundle(e,a)||!this.cache.has(c)).map(async c=>{let m=await this.fetchData(c);t.addResourceBundle(e,a,m,true,true),this.cache.add(c);});await Promise.all(r);}};var C=react.createContext({languages:[],beforeLanguageChange:()=>Promise.resolve(),afterLanguageChange:()=>Promise.resolve()}),M=()=>{let s=react.useContext(C);if(!s)throw new Error("useLocaleContext must be used within a LocaleProvider");return s};function f(s,e){let a=s.split("/")[1];return e=e||Object.values(u),e.includes(a)?a:null}function h(s,e,a){e=e||Object.values(u),a=a||"en";let n=/^([a-z]{2})/i,i=s?.match(n);if(!i)return a;let r=i[1];return e.includes(s)?s:e.includes(r)?r:a}function Ee(s){let{path:e,locale:a,search:n}=s,i=n||(typeof window<"u"?window.location.search:""),r=f(e);return r?`${e}${i}`:(r=a||h(t.language),`/${r}${e}${i}`)}function Ue(s,e){let a=f(s,e);return a?s.replace(new RegExp(`^/${a}(?=/)`),""):s}function Q({children:s,locale:e,resource:a,resources:n,backend:i,supportedLanguages:r,convertDetectedLanguage:c,languages:m,beforeLanguageChange:k,afterLanguageChange:b}){let[L,w]=react.useState(x),T=react.useRef(new p(i));react.useEffect(()=>{if(n){Object.entries(n).forEach(([o,d])=>{t.addResourceBundle(o,l,d,true,true);});return}a&&e&&t.addResourceBundle(e,l,a,true,true);},[e,a,n]),react.useEffect(()=>{e&&e!==t.language&&t.changeLanguage(e);},[e]),react.useEffect(()=>{Array.isArray(m)?w(m):Array.isArray(r)&&w(r.map(o=>x.find(d=>d.localCode===o)).filter(o=>!!o));},[r,m]),react.useEffect(()=>{(async()=>{let d=typeof c=="function"?c(t.language):h(t.language);await T.current.loadLanguage(d,l),d!==t.language&&await t.changeLanguage(d);})();},[t.language]);let P=react.useCallback(async o=>{await k?.(o),await T.current.loadLanguage(o,l);},[k]),S=react.useCallback(async o=>{b?.(o);},[b]),E=react.useMemo(()=>({languages:L,beforeLanguageChange:P,afterLanguageChange:S}),[L,P,S]);return jsxRuntime.jsx(C.Provider,{value:E,children:jsxRuntime.jsx(reactI18next.I18nextProvider,{i18n:t,defaultNS:l,children:s})})}function G(s,e){let a=react.useContext(reactI18next.I18nContext);return reactI18next.useTranslation(s,{i18n:a?.i18n||t,...e})}function te(){let[s,e]=react.useState(t.language);return react.useEffect(()=>(t.on("languageChanged",e),()=>{t.off("languageChanged",e);}),[t]),s}function se(){let{beforeLanguageChange:s,afterLanguageChange:e}=M();return react.useCallback(async n=>{await s(n),await t.changeLanguage(n),await e(n);},[s,e,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.LocaleContext=C;exports.LocaleEnum=u;exports.LocaleProvider=Q;exports.defaultLanguages=x;exports.defaultLng=y;exports.defaultNS=l;exports.en=R;exports.generatePath=Ee;exports.getLocalePathFromPathname=f;exports.i18n=t;exports.i18nCookieKey=N;exports.i18nLocalStorageKey=v;exports.parseI18nLang=h;exports.removeLangPrefix=Ue;exports.useChangeLocale=se;exports.useLocale=te;exports.useLocaleContext=M;exports.useTranslation=G;Object.keys(reactI18next).forEach(function(k){if(k!=='default'&&!Object.prototype.hasOwnProperty.call(exports,k))Object.defineProperty(exports,k,{enumerable:true,get:function(){return reactI18next[k]}})});//# sourceMappingURL=index.js.map
2
11
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/types.ts","../src/constant.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","common","mediaTrack","scaffold","tokens","en","i18n","createInstance","LanguageDetector","initReactI18next","i18n_default","Backend","options","url","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.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.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.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};\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};\n","export const tokens = {\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.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.top10HoldingsRatio\": \"Top 10 Holders\",\n \"tokens.tokenInfo.top100HoldingsRatio\": \"Top 100 Holders\",\n \"tokens.tokenInfo.devHoldingsRatio\": \"Dev Holders\",\n};\n","import { 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};\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/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","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.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 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.events.title\": \"Channel Events\",\n \"channels.detail.notfound\": \"Channel not found\",\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};\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.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.top10HoldingsRatio\": \"Top 10 Holders\",\n \"tokens.tokenInfo.top100HoldingsRatio\": \"Top 100 Holders\",\n \"tokens.tokenInfo.devHoldingsRatio\": \"Dev Holders\",\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"]}
package/dist/index.mjs CHANGED
@@ -1,2 +1,11 @@
1
- import {initReactI18next,I18nextProvider,I18nContext,useTranslation}from'react-i18next';export*from'react-i18next';import {createInstance}from'i18next';export{createInstance,default as i18next}from'i18next';import V from'i18next-browser-languagedetector';import {createContext,useContext,useState,useRef,useEffect,useCallback,useMemo}from'react';import {jsx}from'react/jsx-runtime';var p=(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))(p||{});var x=[{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"}],h="en",i="translation",H="liberfi_i18nLng",S="liberfi_i18nLng";var b={"common.cancel":"Cancel","common.confirm":"Confirm","common.reset":"Reset","common.apply":"Apply","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 to clipboard","common.share":"Share","common.export":"Export","common.empty":"No data","common.resolution.1s":"1s","common.resolution.15s":"15s","common.resolution.30s":"30s","common.resolution.1m":"1m","common.resolution.5m":"5m","common.resolution.15m":"15m","common.resolution.30m":"30m","common.resolution.1h":"1h","common.resolution.4h":"4h","common.resolution.12h":"12h","common.resolution.24h":"24h"};var I={"mediaTrack.tweets.translate.show":"Show Translation","mediaTrack.tweets.translate.hide":"Hide Translation","mediaTrack.tweets.expand":"Expand","mediaTrack.tweets.collapse":"Collapse"};var R={"scaffold.draggableModal.snapToEdge":"Drag to edge to show side panel","scaffold.draggablePanel.snapToModal":"Drag away to show floating modal"};var M={"tokens.copied.address":"Token address copied to clipboard","tokens.listHeader.token":"Token","tokens.listHeader.priceHistories":"Price Histories","tokens.listHeader.price":"Price","tokens.listHeader.priceChange":"{{resolution}}%","tokens.listHeader.marketCap":"Market Cap","tokens.listHeader.liquidity":"Liquidity","tokens.listHeader.volumes":"{{resolution}} Volumes","tokens.listHeader.txs":"{{resolution}} TXNS","tokens.listHeader.traders":"{{resolution}} Traders","tokens.listHeader.tokenInfo":"Token Info","tokens.listHeader.actions":"Actions","tokens.listHeader.filter":"Filter","tokens.listType.trending":"Trending","tokens.listType.new":"New","tokens.listType.stocks":"Stocks","tokens.filters.protocols.title":"Protocols","tokens.filters.protocols.selectAll":"Select All","tokens.filters.protocols.unselectAll":"Unselect All","tokens.filters.keywords.title":"Search Keywords","tokens.filters.keywords.exclude.title":"Exclude Keywords","tokens.filters.keywords.placeholder":"keyword1, keyword2...","tokens.filters.stats.min":"Min","tokens.filters.stats.max":"Max","tokens.filters.stats.audits":"Audits","tokens.filters.stats.audits.holders":"Holders Count","tokens.filters.stats.audits.top10HoldingsRatio":"Top 10 Holders %","tokens.filters.stats.audits.top100HoldingsRatio":"Top 100 Holders %","tokens.filters.stats.audits.devHoldingsRatio":"Dev Holdings %","tokens.filters.stats.metrics":"Metrics","tokens.filters.stats.metrics.volumes":"{{resolution}} Volumes ($)","tokens.filters.stats.metrics.txns":"{{resolution}} Transactions","tokens.filters.stats.metrics.liquidity":"Liquidity ($)","tokens.filters.stats.metrics.marketCap":"Market Cap ($)","tokens.filters.modal.title":"Filters","tokens.tokenInfo.holders":"Holders","tokens.tokenInfo.top10HoldingsRatio":"Top 10 Holders","tokens.tokenInfo.top100HoldingsRatio":"Top 100 Holders","tokens.tokenInfo.devHoldingsRatio":"Dev Holders"};var A={...b,...I,...R,...M};var $=createInstance();$.use(V).use(initReactI18next).init({fallbackLng:h,ns:[i],defaultNS:i,interpolation:{escapeValue:false},detection:{lookupLocalStorage:H,lookupCookie:S,caches:["cookie","localStorage"],order:["cookie","localStorage","htmlTag","navigator"]},resources:{[h]:{[i]:A}}});var t=$;var f=class{constructor(e){this.options=e;this.cache=new Set;}cache;async fetchData(e){try{return await(await fetch(e)).json()}catch{return {}}}async loadLanguage(e,a){if(typeof this.options?.loadPath!="function")return;let n=this.options.loadPath(e,a);if(typeof n=="string"&&(n=[n]),!n.length)return;let s=n.filter(c=>!t.hasResourceBundle(e,a)||!this.cache.has(c)).map(async c=>{let m=await this.fetchData(c);t.addResourceBundle(e,a,m,true,true),this.cache.add(c);});await Promise.all(s);}};var y=createContext({languages:[],beforeLanguageChange:()=>Promise.resolve(),afterLanguageChange:()=>Promise.resolve()}),F=()=>{let r=useContext(y);if(!r)throw new Error("useLocaleContext must be used within a LocaleProvider");return r};function u(r,e){let a=r.split("/")[1];return e=e||Object.values(p),e.includes(a)?a:null}function g(r,e,a){e=e||Object.values(p),a=a||"en";let n=/^([a-z]{2})/i,l=r?.match(n);if(!l)return a;let s=l[1];return e.includes(r)?r:e.includes(s)?s:a}function Ke(r){let{path:e,locale:a,search:n}=r,l=n||(typeof window<"u"?window.location.search:""),s=u(e);return s?`${e}${l}`:(s=a||g(t.language),`/${s}${e}${l}`)}function De(r,e){let a=u(r,e);return a?r.replace(new RegExp(`^/${a}(?=/)`),""):r}function X({children:r,locale:e,resource:a,resources:n,backend:l,supportedLanguages:s,convertDetectedLanguage:c,languages:m,beforeLanguageChange:C,afterLanguageChange:L}){let[P,w]=useState(x),T=useRef(new f(l));useEffect(()=>{if(n){Object.entries(n).forEach(([o,d])=>{t.addResourceBundle(o,i,d,true,true);});return}a&&e&&t.addResourceBundle(e,i,a,true,true);},[e,a,n]),useEffect(()=>{e&&e!==t.language&&t.changeLanguage(e);},[e]),useEffect(()=>{Array.isArray(m)?w(m):Array.isArray(s)&&w(s.map(o=>x.find(d=>d.localCode===o)).filter(o=>!!o));},[s,m]),useEffect(()=>{(async()=>{let d=typeof c=="function"?c(t.language):g(t.language);await T.current.loadLanguage(d,i),d!==t.language&&await t.changeLanguage(d);})();},[t.language]);let N=useCallback(async o=>{await C?.(o),await T.current.loadLanguage(o,i);},[C]),v=useCallback(async o=>{L?.(o);},[L]),B=useMemo(()=>({languages:P,beforeLanguageChange:N,afterLanguageChange:v}),[P,N,v]);return jsx(y.Provider,{value:B,children:jsx(I18nextProvider,{i18n:t,defaultNS:i,children:r})})}function Q(r,e){let a=useContext(I18nContext);return useTranslation(r,{i18n:a?.i18n||t,...e})}function oe(){let[r,e]=useState(t.language);return useEffect(()=>(t.on("languageChanged",e),()=>{t.off("languageChanged",e);}),[t]),r}function ae(){let{beforeLanguageChange:r,afterLanguageChange:e}=F();return useCallback(async n=>{await r(n),await t.changeLanguage(n),await e(n);},[r,e,t])}export{y as LocaleContext,p as LocaleEnum,X as LocaleProvider,x as defaultLanguages,h as defaultLng,i as defaultNS,A as en,Ke as generatePath,u as getLocalePathFromPathname,t as i18n,S as i18nCookieKey,H as i18nLocalStorageKey,g as parseI18nLang,De as removeLangPrefix,ae as useChangeLocale,oe as useLocale,F as useLocaleContext,Q as useTranslation};//# sourceMappingURL=index.mjs.map
1
+ import {initReactI18next,I18nextProvider,I18nContext,useTranslation}from'react-i18next';export*from'react-i18next';import {createInstance}from'i18next';export{createInstance,default as i18next}from'i18next';import U from'i18next-browser-languagedetector';import {createContext,useContext,useState,useRef,useEffect,useCallback,useMemo}from'react';import {jsx}from'react/jsx-runtime';var u=(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))(u||{});var x=[{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"}],y="en",l="translation",v="liberfi_i18nLng",N="liberfi_i18nLng";var A={"channels.forms.base.title":"Base Info","channels.forms.base.name.label":"Name","channels.forms.base.name.placeholder":"Please enter the channel name","channels.forms.base.name.required":"Name is required","channels.forms.base.name.min":"Name must be at least 1 character","channels.forms.base.name.max":"Name must be less than 24 characters","channels.forms.base.description.label":"Description","channels.forms.base.description.placeholder":"Please enter the channel description","channels.forms.base.icon.label":"Icon","channels.forms.base.icon.placeholder":"Please upload the channel icon","channels.forms.base.icon.hint":"A square image of at least 128x128 is suggested. File size cannot exceed 10mb.","channels.forms.base.icon.required":"Icon is required","channels.forms.base.icon.maxSize":"Icon size cannot exceed 10MB","channels.forms.base.submit":"Create Channel","channels.forms.base.update.submit":"Update Channel","channels.forms.wallets.title":"Wallet Management","channels.forms.wallets.label":"Add Wallets","channels.forms.wallets.placeholder":`Text Format:
2
+ 8zFZHuSRuDpuAR7J6FzwyF3vKNx4CVW3DFHJerQhc7Zd,pow
3
+ 0x4DB5a66E937A9F4473fA95b1cAF1d1E1D62E29EA,Smart Money`,"channels.forms.wallets.required":"Wallets are required","channels.forms.wallets.invalid":"Invalid wallets format","channels.forms.wallets.chain.required":"Chain is required","channels.forms.wallets.address.required":"Wallet address is required","channels.forms.wallets.address.duplicated":"There are {{count}} duplicated wallet addresses in the input","channels.forms.wallets.address.invalid":"There are {{count}} invalid wallet addresses","channels.forms.wallets.address.alreadyAdded":"There are {{count}} wallet addresses already added","channels.forms.wallets.maxCount":"Wallet count cannot exceed 500","channels.forms.wallets.submit":"Add Wallets","channels.forms.wallets.supportedFormats":"Supported Formats","channels.forms.wallets.supportedFormats.text":"Text","channels.forms.wallets.supportedFormats.text.hint":`Text Format:
4
+
5
+ 8zFZHuSRuDpuAR7J6FzwyF3vKNx4CVW3DFHJerQhc7Zd,pow
6
+ 0x4DB5a66E937A9F4473fA95b1cAF1d1E1D62E29EA,Smart Money`,"channels.forms.wallets.addedCount":"added wallets","channels.forms.wallets.list.title":"Added Wallets","channels.forms.wallets.list.header.address":"Alias/Address","channels.forms.wallets.list.header.balance":"Balance","channels.forms.wallets.list.header.importedAt":"Imported At","channels.forms.wallets.list.header.lastActiveAt":"Last Active At","channels.forms.wallets.list.header.7dBuys":"7 Days Buys","channels.forms.wallets.list.header.7dSells":"7 Days Sells","channels.forms.wallets.list.header.actions":"Actions","channels.forms.wallets.list.empty":"No wallets added yet","channels.forms.wallets.list.search.placeholder":"Search by address or alias","channels.forms.wallets.update.success":"Update wallets successfully","channels.forms.wallets.update.error":"Update wallets error","channels.forms.socials.title":"Social Medias","channels.forms.socials.telegram.guide":`\u26A1\uFE0F Quick Start
7
+ 1. Search for @BotFather on Telegram
8
+ 2. Send /newbot to create a bot and get Token
9
+ 3. Enter the Bot Token here and save
10
+ 4. Add the bot to your group/channel`,"channels.forms.socials.telegram.placeholder":"Enter your Telegram Bot Token","channels.list.title":"Channel List","channels.trending.title":"Trending Channels","channels.my.title":"My Channels","channels.subscribe.submit":"Subscribe","channels.subscribe.error":"Subscribe channel error","channels.subscribe.success":"Subscribe channel successfully","channels.unsubscribe.submit":"Subscribed","channels.unsubscribe.error":"Unsubscribe channel error","channels.unsubscribe.success":"Unsubscribe channel successfully","channels.subscribed.title":"Subscribed Channels","channels.create.title":"Create Channel","channels.create.success":"Channel created successfully","channels.create.error":"Create channel error","channels.update.title":"Update Channel","channels.update.success":"Channel updated successfully","channels.update.error":"Update channel error","channels.info.walletCount":"Wallet Count","channels.info.subscribeCount":"Subscribe Count","channels.info.createdAt":"created at","channels.info.updatedAt":"last updated at","channels.stats.7dTxs.title":"7D TXs","channels.stats.7dTxs.hint":"7 Days Transactions","channels.stats.7dPnl.title":"7D PnL","channels.stats.7dPnl.hint":"7 Days Profit and Loss","channels.stats.7dWr.title":"7D WR","channels.stats.7dWr.hint":"7 Days Winning Rate","channels.detail.title":"Channel Detail","channels.detail.events.title":"Channel Events","channels.detail.notfound":"Channel not found"};var H={"common.cancel":"Cancel","common.confirm":"Confirm","common.reset":"Reset","common.apply":"Apply","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 to clipboard","common.share":"Share","common.export":"Export","common.empty":"No data","common.unauthenticated":"Please sign in to continue","common.signIn":"Sign In","common.signOut":"Sign Out","common.resolution.1s":"1s","common.resolution.15s":"15s","common.resolution.30s":"30s","common.resolution.1m":"1m","common.resolution.5m":"5m","common.resolution.15m":"15m","common.resolution.30m":"30m","common.resolution.1h":"1h","common.resolution.4h":"4h","common.resolution.12h":"12h","common.resolution.24h":"24h","common.upload.submit":"Upload","common.upload.resubmit":"Reupload","common.upload.error":"Upload error"};var F={"mediaTrack.tweets.translate.show":"Show Translation","mediaTrack.tweets.translate.hide":"Hide Translation","mediaTrack.tweets.expand":"Expand","mediaTrack.tweets.collapse":"Collapse"};var I={"scaffold.draggableModal.snapToEdge":"Drag to edge to show side panel","scaffold.draggablePanel.snapToModal":"Drag away to show floating modal","scaffold.home":"Home"};var D={"tokens.search.placeholder":"Search by token or CA...","tokens.copied.address":"Token address copied to clipboard","tokens.listHeader.token":"Token","tokens.listHeader.priceHistories":"Price Histories","tokens.listHeader.price":"Price","tokens.listHeader.priceChange":"{{resolution}}%","tokens.listHeader.marketCap":"Market Cap","tokens.listHeader.liquidity":"Liquidity","tokens.listHeader.volumes":"{{resolution}} Volumes","tokens.listHeader.txs":"{{resolution}} TXNS","tokens.listHeader.traders":"{{resolution}} Traders","tokens.listHeader.tokenInfo":"Token Info","tokens.listHeader.actions":"Actions","tokens.listHeader.filter":"Filter","tokens.listType.trending":"Trending","tokens.listType.new":"New","tokens.listType.stocks":"Stocks","tokens.filters.protocols.title":"Protocols","tokens.filters.protocols.selectAll":"Select All","tokens.filters.protocols.unselectAll":"Unselect All","tokens.filters.keywords.title":"Search Keywords","tokens.filters.keywords.exclude.title":"Exclude Keywords","tokens.filters.keywords.placeholder":"keyword1, keyword2...","tokens.filters.stats.min":"Min","tokens.filters.stats.max":"Max","tokens.filters.stats.audits":"Audits","tokens.filters.stats.audits.holders":"Holders Count","tokens.filters.stats.audits.top10HoldingsRatio":"Top 10 Holders %","tokens.filters.stats.audits.top100HoldingsRatio":"Top 100 Holders %","tokens.filters.stats.audits.devHoldingsRatio":"Dev Holdings %","tokens.filters.stats.metrics":"Metrics","tokens.filters.stats.metrics.volumes":"{{resolution}} Volumes ($)","tokens.filters.stats.metrics.txns":"{{resolution}} Transactions","tokens.filters.stats.metrics.liquidity":"Liquidity ($)","tokens.filters.stats.metrics.marketCap":"Market Cap ($)","tokens.filters.modal.title":"Filters","tokens.tokenInfo.holders":"Holders","tokens.tokenInfo.top10HoldingsRatio":"Top 10 Holders","tokens.tokenInfo.top100HoldingsRatio":"Top 100 Holders","tokens.tokenInfo.devHoldingsRatio":"Dev Holders"};var R={...H,...F,...I,...D,...A};var B=createInstance();B.use(U).use(initReactI18next).init({fallbackLng:y,ns:[l],defaultNS:l,interpolation:{escapeValue:false},detection:{lookupLocalStorage:v,lookupCookie:N,caches:["cookie","localStorage"],order:["cookie","localStorage","htmlTag","navigator"]},resources:{[y]:{[l]:R}}});var t=B;var p=class{constructor(e){this.options=e;this.cache=new Set;}cache;async fetchData(e){try{return await(await fetch(e)).json()}catch{return {}}}async loadLanguage(e,a){if(typeof this.options?.loadPath!="function")return;let n=this.options.loadPath(e,a);if(typeof n=="string"&&(n=[n]),!n.length)return;let r=n.filter(c=>!t.hasResourceBundle(e,a)||!this.cache.has(c)).map(async c=>{let m=await this.fetchData(c);t.addResourceBundle(e,a,m,true,true),this.cache.add(c);});await Promise.all(r);}};var C=createContext({languages:[],beforeLanguageChange:()=>Promise.resolve(),afterLanguageChange:()=>Promise.resolve()}),M=()=>{let s=useContext(C);if(!s)throw new Error("useLocaleContext must be used within a LocaleProvider");return s};function f(s,e){let a=s.split("/")[1];return e=e||Object.values(u),e.includes(a)?a:null}function h(s,e,a){e=e||Object.values(u),a=a||"en";let n=/^([a-z]{2})/i,i=s?.match(n);if(!i)return a;let r=i[1];return e.includes(s)?s:e.includes(r)?r:a}function Ee(s){let{path:e,locale:a,search:n}=s,i=n||(typeof window<"u"?window.location.search:""),r=f(e);return r?`${e}${i}`:(r=a||h(t.language),`/${r}${e}${i}`)}function Ue(s,e){let a=f(s,e);return a?s.replace(new RegExp(`^/${a}(?=/)`),""):s}function Q({children:s,locale:e,resource:a,resources:n,backend:i,supportedLanguages:r,convertDetectedLanguage:c,languages:m,beforeLanguageChange:k,afterLanguageChange:b}){let[L,w]=useState(x),T=useRef(new p(i));useEffect(()=>{if(n){Object.entries(n).forEach(([o,d])=>{t.addResourceBundle(o,l,d,true,true);});return}a&&e&&t.addResourceBundle(e,l,a,true,true);},[e,a,n]),useEffect(()=>{e&&e!==t.language&&t.changeLanguage(e);},[e]),useEffect(()=>{Array.isArray(m)?w(m):Array.isArray(r)&&w(r.map(o=>x.find(d=>d.localCode===o)).filter(o=>!!o));},[r,m]),useEffect(()=>{(async()=>{let d=typeof c=="function"?c(t.language):h(t.language);await T.current.loadLanguage(d,l),d!==t.language&&await t.changeLanguage(d);})();},[t.language]);let P=useCallback(async o=>{await k?.(o),await T.current.loadLanguage(o,l);},[k]),S=useCallback(async o=>{b?.(o);},[b]),E=useMemo(()=>({languages:L,beforeLanguageChange:P,afterLanguageChange:S}),[L,P,S]);return jsx(C.Provider,{value:E,children:jsx(I18nextProvider,{i18n:t,defaultNS:l,children:s})})}function G(s,e){let a=useContext(I18nContext);return useTranslation(s,{i18n:a?.i18n||t,...e})}function te(){let[s,e]=useState(t.language);return useEffect(()=>(t.on("languageChanged",e),()=>{t.off("languageChanged",e);}),[t]),s}function se(){let{beforeLanguageChange:s,afterLanguageChange:e}=M();return useCallback(async n=>{await s(n),await t.changeLanguage(n),await e(n);},[s,e,t])}export{C as LocaleContext,u as LocaleEnum,Q as LocaleProvider,x as defaultLanguages,y as defaultLng,l as defaultNS,R as en,Ee as generatePath,f as getLocalePathFromPathname,t as i18n,N as i18nCookieKey,v as i18nLocalStorageKey,h as parseI18nLang,Ue as removeLangPrefix,se as useChangeLocale,te as useLocale,M as useLocaleContext,G as useTranslation};//# sourceMappingURL=index.mjs.map
2
11
  //# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/types.ts","../src/constant.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","common","mediaTrack","scaffold","tokens","en","i18n","createInstance","LanguageDetector","initReactI18next","i18n_default","Backend","options","url","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 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.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};\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};\n","export const tokens = {\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.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.top10HoldingsRatio\": \"Top 10 Holders\",\n \"tokens.tokenInfo.top100HoldingsRatio\": \"Top 100 Holders\",\n \"tokens.tokenInfo.devHoldingsRatio\": \"Dev Holders\",\n};\n","import { 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};\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/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","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.events.title\": \"Channel Events\",\n \"channels.detail.notfound\": \"Channel not found\",\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};\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.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.top10HoldingsRatio\": \"Top 10 Holders\",\n \"tokens.tokenInfo.top100HoldingsRatio\": \"Top 100 Holders\",\n \"tokens.tokenInfo.devHoldingsRatio\": \"Dev Holders\",\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"]}