@liberfi.io/i18n 0.1.49 → 0.1.51

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
@@ -7,5 +7,5 @@
7
7
  1. Search for @BotFather on Telegram
8
8
  2. Send /newbot to create a bot and get Token
9
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.create.eligibility.title":"Check Eligibility","channels.create.eligibility.description":"Verify your X (Twitter) account to ensure it meets the requirements for creating a channel.","channels.create.eligibility.xConnection":"X Account Connection","channels.create.eligibility.connected":"Connected as","channels.create.eligibility.notConnected":"No X account connected","channels.create.eligibility.connect":"Connect X Account","channels.create.eligibility.disconnect":"Disconnect","channels.create.eligibility.verifying":"Verifying eligibility...","channels.create.eligibility.requirementsTitle":"Eligibility Requirements","channels.create.eligibility.followersCount":"Followers Count","channels.create.eligibility.accountAge":"Account Age","channels.create.eligibility.behaviorScore":"Behavior Score","channels.create.eligibility.clean":"Clean","channels.create.eligibility.allPassed":"All eligibility checks passed! You can now create a channel.","channels.create.eligibility.failed":"Some requirements are not met. Please check your account.","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.notfound":"Channel not found","channels.events.title":"Channel Events","channels.events.empty":"No events yet","channels.events.walletTrade.buy":"bought","channels.events.walletTrade.sell":"sold","channels.events.walletTrade.got":"got","channels.events.walletTrade.cost":"cost","channels.events.walletTrade.price":"price"};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","common.loadingMore":"Loading more...","common.continue":"Continue","common.months":"months","common.days":"days"};var F={"mediaTrack.tweets.translate.show":"Show Translation","mediaTrack.tweets.translate.hide":"Hide Translation","mediaTrack.tweets.expand":"Expand","mediaTrack.tweets.collapse":"Collapse"};var B={"portfolio.tabs.spot":"Spot","portfolio.tabs.perps":"Perps","portfolio.tabs.prediction":"Prediction","portfolio.address.allWallets":"All Wallets","portfolio.address.aggregated":"Aggregated","portfolio.address.copy":"Copy Address","portfolio.address.copied":"Address copied","portfolio.address.owner":"Owner","portfolio.address.viewing":"Viewing","portfolio.address.search.placeholder":"Search wallet address\u2026","portfolio.address.search.view":"View","portfolio.address.search.invalid":"Enter a valid address","portfolio.balance.uPnl":"uPNL","portfolio.balance.realized":"Realized","portfolio.balance.gas":"Gas","portfolio.curve.netWorth":"Net Worth","portfolio.curve.pnl":"PNL","portfolio.curve.noData":"Not enough data","portfolio.distribution.title":"Distribution","portfolio.distribution.other":"Other","portfolio.viewing.banner":"Viewing external portfolio","portfolio.viewing.back":"Back to My Portfolio","portfolio.spot.holdings":"Holdings","portfolio.spot.history":"History","portfolio.spot.search.placeholder":"Search token\u2026","portfolio.spot.hideSmall":"Hide small","portfolio.spot.group.tokens":"Tokens","portfolio.spot.header.asset":"Asset","portfolio.spot.header.balance":"Balance","portfolio.spot.header.price":"Price","portfolio.spot.header.value":"Value","portfolio.spot.header.24h":"24h","portfolio.spot.empty":"No tokens found","portfolio.spot.empty.hint":"Your spot tokens will appear here","portfolio.spot.history.header.type":"Type","portfolio.spot.history.header.detail":"Detail","portfolio.spot.history.header.amount":"Amount","portfolio.spot.history.header.value":"Value","portfolio.spot.history.header.time":"Time","portfolio.spot.history.header.txHash":"TxHash","portfolio.spot.history.type.swap":"Swap","portfolio.spot.history.type.send":"Send","portfolio.spot.history.type.receive":"Receive","portfolio.perps.openPositions":"Open Positions","portfolio.perps.tradeHistory":"Trade History","portfolio.perps.closeAll":"Close All","portfolio.perps.close":"Close","portfolio.perps.closeAll.confirm":"Close all positions? This will route to each protocol to execute.","portfolio.perps.closeAll.confirmBtn":"Confirm Close All","portfolio.perps.closeAll.cancel":"Cancel","portfolio.perps.header.pair":"Pair / Side","portfolio.perps.header.size":"Size","portfolio.perps.header.entry":"Entry","portfolio.perps.header.mark":"Mark","portfolio.perps.header.uPnl":"uPNL","portfolio.perps.search.placeholder":"Search pair\u2026","portfolio.perps.empty":"No open positions","portfolio.perps.empty.hint":"Start trading \u2192","portfolio.perps.history.header.pair":"Pair","portfolio.perps.history.header.side":"Side","portfolio.perps.history.header.size":"Size","portfolio.perps.history.header.pnl":"PNL","portfolio.perps.history.header.closePrice":"Close Price","portfolio.perps.history.header.time":"Time","portfolio.prediction.activeBets":"Active Bets","portfolio.prediction.settled":"Settled","portfolio.prediction.sellAll":"Sell All","portfolio.prediction.sell":"Sell","portfolio.prediction.sellAll.confirm":"Sell all positions? This will route to each platform to execute.","portfolio.prediction.sellAll.confirmBtn":"Confirm Sell All","portfolio.prediction.sellAll.cancel":"Cancel","portfolio.prediction.header.market":"Market / Source","portfolio.prediction.header.position":"Position","portfolio.prediction.header.stake":"Stake","portfolio.prediction.header.potential":"Potential","portfolio.prediction.header.status":"Status","portfolio.prediction.search.placeholder":"Search market\u2026","portfolio.prediction.empty":"No active bets","portfolio.prediction.empty.hint":"Explore prediction markets \u2192","portfolio.prediction.settled.header.market":"Market","portfolio.prediction.settled.header.source":"Source","portfolio.prediction.settled.header.position":"Position","portfolio.prediction.settled.header.stake":"Stake","portfolio.prediction.settled.header.result":"Result","portfolio.prediction.settled.header.payout":"Payout","portfolio.connectWallet":"Connect Wallet","portfolio.connectWallet.hint":"Connect your wallet to view your portfolio","portfolio.error.load":"Failed to load portfolio data","portfolio.error.retry":"Retry"};var M={"predict.categories.trending":"Trending","predict.categories.allMarkets":"All Markets","predict.event.status.closed":"Closed","predict.event.status.live":"Live","predict.event.status.pending":"Pending","predict.event.volume":"vol","predict.event.endDate":"Ends {{date}}","predict.event.rules":"Rules","predict.event.rules.collapse":"Collapse","predict.event.rules.expand":"Expand all","predict.event.showMore":"Show More","predict.event.back":"Back","predict.event.moreMarkets":"+{{count}} more","predict.market.table.outcome":"Outcome","predict.market.table.chance":"Chance","predict.market.table.actions":"Actions","predict.market.action.yes":"Yes {{price}}\xA2","predict.market.action.no":"No {{price}}\xA2","predict.market.yes":"Yes","predict.market.no":"No","predict.market.sharesYes":"{{shares}} Yes","predict.market.sharesNo":"{{shares}} No","predict.market.tradeYes":"Trade Yes","predict.market.tradeNo":"Trade No","predict.market.graph":"Graph","predict.trade.action":"Trade","predict.trade.buy":"Buy","predict.trade.sell":"Sell","predict.trade.yes":"Yes","predict.trade.no":"No","predict.trade.limit":"Limit","predict.trade.market":"Market","predict.trade.price":"Price","predict.trade.amount":"Amount","predict.trade.contracts":"Contracts","predict.trade.estimatedCost":"Est. Cost","predict.trade.potentialPayout":"Potential Payout","predict.trade.potentialProfit":"Potential Profit","predict.trade.potentialWin":"Potential Win","predict.trade.estimatedReceive":"Est. Receive","predict.trade.balance":"Available Balance","predict.trade.bestBid":"Bid","predict.trade.bestAsk":"Ask","predict.trade.priceImpact":"Price Impact","predict.trade.quoteError":"Unable to get quote. Please try again.","predict.trade.connectWallet":"Connect Wallet","predict.trade.submitting":"Submitting\u2026","predict.trade.submitSuccess":"Transaction submitted successfully!","predict.trade.submitError":"Transaction failed. Please try again.","predict.orderBook.title":"Order Book","predict.orderBook.empty":"No orders yet","predict.orderBook.type":"Type","predict.orderBook.price":"Price","predict.orderBook.contracts":"Contracts","predict.orderBook.qty":"Qty","predict.orderBook.total":"Total","predict.orderBook.spread":"Spread","predict.openOrders.title":"Open Orders","predict.openOrders.empty":"No open orders","predict.openOrders.side":"Side","predict.openOrders.outcome":"Outcome","predict.openOrders.type":"Type","predict.openOrders.price":"Price","predict.openOrders.filled":"Filled","predict.openOrders.status":"Status","predict.openOrders.time":"Time","predict.openOrders.cancel":"Cancel","predict.tradeHistory.title":"Trade History","predict.tradeHistory.empty":"No trades yet","predict.tradeHistory.side":"Side","predict.tradeHistory.outcome":"Outcome","predict.tradeHistory.price":"Price","predict.tradeHistory.qty":"Qty","predict.tradeHistory.total":"Total","predict.tradeHistory.fee":"Fee","predict.tradeHistory.time":"Time","predict.positions.title":"Positions","predict.positions.empty":"No positions","predict.positions.market":"Market","predict.positions.outcome":"Outcome","predict.positions.qty":"Qty","predict.positions.avgCost":"Avg Cost","predict.positions.currentPrice":"Price","predict.positions.value":"Value","predict.positions.pnl":"P&L","predict.positions.totalValue":"Total Value","predict.positions.unrealizedPnl":"Unrealized P&L","predict.positions.realizedPnl":"Realized P&L","predict.pagination.prev":"Prev","predict.pagination.next":"Next","predict.pagination.page":"Page {{page}}"};var R={"scaffold.draggableModal.snapToEdge":"Drag to edge to show side panel","scaffold.draggablePanel.snapToModal":"Drag away to show floating modal","scaffold.home":"Home"};var I={"tokens.search.title":"Search","tokens.search.placeholder":"Search by token or CA...","tokens.search.history":"Search History","tokens.search.noResults":"No results found","tokens.search.hint":"Enter token name or contract address to search","tokens.copied.address":"Token address copied to clipboard","tokens.listHeader.token":"Token","tokens.listHeader.age":"Age","tokens.listHeader.24hChange":"24h%","tokens.listHeader.priceHistories":"Price Histories","tokens.listHeader.price":"Price","tokens.listHeader.priceChange":"{{resolution}}%","tokens.listHeader.marketCap":"Market Cap","tokens.listHeader.liquidity":"Liquidity","tokens.listHeader.mcShort":"MC","tokens.listHeader.liqShort":"Liq","tokens.listHeader.volumes":"{{resolution}} Volumes","tokens.listHeader.txs":"{{resolution}} TXNS","tokens.listHeader.traders":"{{resolution}} Traders","tokens.listHeader.bluechip":"BlueChip","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.proHolders":"Pro Holders","tokens.tokenInfo.kolHolders":"KOL Holders","tokens.tokenInfo.top10HoldingsRatio":"Top 10 Holders","tokens.tokenInfo.top100HoldingsRatio":"Top 100 Holders","tokens.tokenInfo.devHoldingsRatio":"Dev Holders","tokens.tokenInfo.sniperHoldingsRatio":"Snipers","tokens.tokenInfo.insiderHoldingsRatio":"Insiders","tokens.tokenInfo.bundleHoldingsRatio":"Bundlers","tokens.bluechip.explained":"BlueChip index is the ratio of holders who also own BlueChip tokens","tokens.pulse.new":"New","tokens.pulse.migrated":"Migrated","tokens.pulse.finalStretch":"Final Stretch","tokens.pulse.paused":"Paused","tokens.pulse.vol":"Vol","tokens.pulse.txs":"Txs"};var D={"trade.market":"Market","trade.balance":"Balance:","trade.amount":"Amount","trade.insufficientBalance":"Insufficient balance","trade.submitBuyAmount":"Buy {{amount}} {{symbol}} ({{usd}})","trade.submitSellAmount":"Sell {{amount}} {{symbol}} ({{usd}})","trade.submitBuyAmountNoUsd":"Buy {{amount}} {{symbol}}","trade.submitSellAmountNoUsd":"Sell {{amount}} {{symbol}}","trade.preset.label":"Preset {{n}}","trade.preset.short":"P{{n}}","trade.instantTradeAmount":"Instant trade amount","trade.preset.slippage":"Slippage","trade.preset.priorityFee":"Priority Fee","trade.preset.priorityFee.tooltip":"Extra fee paid to validators to prioritize your transaction.","trade.preset.gasFee":"Gas Fee","trade.preset.gasFee.tooltip":"Extra fee paid to validators to prioritize your transaction.","trade.preset.tipFee":"Tip Fee","trade.preset.tipFee.tooltip":"Additional tip sent alongside the transaction (e.g. Jito tip).","trade.preset.autoFee":"Auto Fee","trade.preset.autoFee.tooltip":"Automatically estimate optimal fee based on network conditions.","trade.preset.maxAutoFee":"Max Auto Fee","trade.preset.antiMev":"Anti-MEV","trade.preset.antiMev.tooltip":"MEV protection shields your transaction from sandwich attacks.","trade.preset.antiMev.off":"Off","trade.preset.antiMev.off.desc":"No MEV protection. Fastest execution.","trade.preset.antiMev.reduced":"Reduced","trade.preset.antiMev.reduced.desc":"Basic MEV protection with minimal impact on execution speed.","trade.preset.antiMev.secure":"Secure","trade.preset.antiMev.secure.desc":"Full MEV protection. May slightly increase execution time.","trade.preset.customRpc":"Custom RPC","trade.preset.presets":"Presets","trade.preset.instantTradeSettings":"Instant Trade Settings","trade.swap.from":"From","trade.swap.to":"To","trade.swap.selectToken":"Select token","trade.swap.half":"Half","trade.swap.swap":"Swap","trade.swap.swapping":"Swapping...","trade.swap.findingRoute":"Finding route...","trade.swap.preview":"Preview","trade.swap.estimatedReceive":"Estimated Receive","trade.swap.routeDetails":"Route Details","trade.swap.dex":"DEX","trade.swap.fee":"Fee","trade.swap.showMore":"Show More","trade.swap.showLess":"Show Less"};var E={...H,...F,...M,...R,...I,...N,...B,...D};var O=i18next.createInstance();O.use($__default.default).use(reactI18next.initReactI18next).init({fallbackLng:k,ns:[i],defaultNS:i,interpolation:{escapeValue:false},detection:{lookupLocalStorage:T,lookupCookie:A,caches:["cookie","localStorage"],order:["cookie","localStorage","htmlTag","navigator"]},resources:{[k]:{[i]:E}}});var a=O;var u=class{constructor(e,o){this.i18n=e;this.options=o;this.cache=new Set;}cache;async fetchData(e){try{return await(await fetch(e)).json()}catch(o){return console.warn(`Failed to fetch locale resource bundle from ${e}:`,o),{}}}async loadLanguage(e,o){if(typeof this.options?.loadPath!="function")return;let s=this.options.loadPath(e,o);if(typeof s=="string"&&(s=[s]),!s.length)return;let n=s.filter(c=>!this.i18n.hasResourceBundle(e,o)||!this.cache.has(c)).map(async c=>{let p=await this.fetchData(c);this.i18n.addResourceBundle(e,o,p,true,true),this.cache.add(c);});await Promise.all(n);}};var b=react.createContext(null),W=()=>{let r=react.useContext(b);if(!r)throw new Error("useLocaleContext must be used within a LocaleProvider");return r};function h(r,e){let o=r.split("/")[1];return e=e||Object.values(m),e.includes(o)?o:null}function f(r,e,o){e=e||Object.values(m),o=o||"en";let s=/^([a-z]{2})/i,l=r?.match(s);if(!l)return o;let n=l[1];return e.includes(r)?r:e.includes(n)?n:o}function Xe(r){let{path:e,locale:o,search:s}=r,l=s||(typeof window<"u"?window.location.search:""),n=h(e);return n?`${e}${l}`:(n=o||f(a.language),`/${n}${e}${l}`)}function Je(r,e){let o=h(r,e);return o?r.replace(new RegExp(`^/${o}(?=/)`),""):r}function G({children:r,locale:e,resource:o,resources:s,backend:l,supportedLanguages:n,convertDetectedLanguage:c,languages:p,beforeLanguageChange:C,afterLanguageChange:w}){let[x,v]=react.useState(y),P=react.useRef(new u(a,l));react.useEffect(()=>{if(s){Object.entries(s).forEach(([t,d])=>{a.addResourceBundle(t,i,d,true,true);});return}o&&e&&a.addResourceBundle(e,i,o,true,true);},[e,o,s]),react.useEffect(()=>{e&&e!==a.language&&a.changeLanguage(e);},[e]),react.useEffect(()=>{Array.isArray(p)?v(p):Array.isArray(n)&&v(n.map(t=>y.find(d=>d.localCode===t)).filter(t=>!!t));},[n,p]),react.useEffect(()=>{(async()=>{let d=typeof c=="function"?c(a.language):f(a.language);await P.current.loadLanguage(d,i),d!==a.language&&await a.changeLanguage(d);})();},[]);let S=react.useCallback(async t=>{await C?.(t),await P.current.loadLanguage(t,i);},[C]),L=react.useCallback(async t=>{w?.(t);},[w]),V=react.useMemo(()=>({languages:x,beforeLanguageChange:S,afterLanguageChange:L}),[x,S,L]);return jsxRuntime.jsx(b.Provider,{value:V,children:jsxRuntime.jsx(reactI18next.I18nextProvider,{i18n:a,defaultNS:i,children:r})})}function oe(r,e){let o=react.useContext(reactI18next.I18nContext);return reactI18next.useTranslation(r,{i18n:o?.i18n||a,...e})}function se(){let[r,e]=react.useState(a.language);return react.useEffect(()=>(a.on("languageChanged",e),()=>{a.off("languageChanged",e);}),[a]),r}function ie(){let{beforeLanguageChange:r,afterLanguageChange:e}=W();return react.useCallback(async s=>{await r(s),await a.changeLanguage(s),await e(s);},[r,e,a])}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=b;exports.LocaleEnum=m;exports.LocaleProvider=G;exports.defaultLanguages=y;exports.defaultLng=k;exports.defaultNS=i;exports.en=E;exports.generatePath=Xe;exports.getLocalePathFromPathname=h;exports.i18n=a;exports.i18nCookieKey=A;exports.i18nLocalStorageKey=T;exports.parseI18nLang=f;exports.removeLangPrefix=Je;exports.useChangeLocale=ie;exports.useLocale=se;exports.useLocaleContext=W;exports.useTranslation=oe;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
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.create.eligibility.title":"Check Eligibility","channels.create.eligibility.description":"Verify your X (Twitter) account to ensure it meets the requirements for creating a channel.","channels.create.eligibility.xConnection":"X Account Connection","channels.create.eligibility.connected":"Connected as","channels.create.eligibility.notConnected":"No X account connected","channels.create.eligibility.connect":"Connect X Account","channels.create.eligibility.disconnect":"Disconnect","channels.create.eligibility.verifying":"Verifying eligibility...","channels.create.eligibility.requirementsTitle":"Eligibility Requirements","channels.create.eligibility.followersCount":"Followers Count","channels.create.eligibility.accountAge":"Account Age","channels.create.eligibility.behaviorScore":"Behavior Score","channels.create.eligibility.clean":"Clean","channels.create.eligibility.allPassed":"All eligibility checks passed! You can now create a channel.","channels.create.eligibility.failed":"Some requirements are not met. Please check your account.","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.notfound":"Channel not found","channels.events.title":"Channel Events","channels.events.empty":"No events yet","channels.events.walletTrade.buy":"bought","channels.events.walletTrade.sell":"sold","channels.events.walletTrade.got":"got","channels.events.walletTrade.cost":"cost","channels.events.walletTrade.price":"price"};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","common.loadingMore":"Loading more...","common.continue":"Continue","common.months":"months","common.days":"days"};var F={"mediaTrack.tweets.translate.show":"Show Translation","mediaTrack.tweets.translate.hide":"Hide Translation","mediaTrack.tweets.expand":"Expand","mediaTrack.tweets.collapse":"Collapse"};var B={"portfolio.tabs.spot":"Spot","portfolio.tabs.perps":"Perps","portfolio.tabs.prediction":"Prediction","portfolio.address.allWallets":"All Wallets","portfolio.address.aggregated":"Aggregated","portfolio.address.copy":"Copy Address","portfolio.address.copied":"Address copied","portfolio.address.owner":"Owner","portfolio.address.viewing":"Viewing","portfolio.address.search.placeholder":"Search wallet address\u2026","portfolio.address.search.view":"View","portfolio.address.search.invalid":"Enter a valid address","portfolio.balance.uPnl":"uPNL","portfolio.balance.realized":"Realized","portfolio.balance.gas":"Gas","portfolio.curve.netWorth":"Net Worth","portfolio.curve.pnl":"PNL","portfolio.curve.noData":"Not enough data","portfolio.distribution.title":"Distribution","portfolio.distribution.other":"Other","portfolio.viewing.banner":"Viewing external portfolio","portfolio.viewing.back":"Back to My Portfolio","portfolio.spot.holdings":"Holdings","portfolio.spot.history":"History","portfolio.spot.search.placeholder":"Search token\u2026","portfolio.spot.hideSmall":"Hide small","portfolio.spot.group.tokens":"Tokens","portfolio.spot.header.asset":"Asset","portfolio.spot.header.balance":"Balance","portfolio.spot.header.price":"Price","portfolio.spot.header.value":"Value","portfolio.spot.header.24h":"24h","portfolio.spot.empty":"No tokens found","portfolio.spot.empty.hint":"Your spot tokens will appear here","portfolio.spot.history.header.type":"Type","portfolio.spot.history.header.detail":"Detail","portfolio.spot.history.header.amount":"Amount","portfolio.spot.history.header.value":"Value","portfolio.spot.history.header.time":"Time","portfolio.spot.history.header.txHash":"TxHash","portfolio.spot.history.type.swap":"Swap","portfolio.spot.history.type.send":"Send","portfolio.spot.history.type.receive":"Receive","portfolio.perps.openPositions":"Open Positions","portfolio.perps.tradeHistory":"Trade History","portfolio.perps.closeAll":"Close All","portfolio.perps.close":"Close","portfolio.perps.closeAll.confirm":"Close all positions? This will route to each protocol to execute.","portfolio.perps.closeAll.confirmBtn":"Confirm Close All","portfolio.perps.closeAll.cancel":"Cancel","portfolio.perps.header.pair":"Pair / Side","portfolio.perps.header.size":"Size","portfolio.perps.header.entry":"Entry","portfolio.perps.header.mark":"Mark","portfolio.perps.header.uPnl":"uPNL","portfolio.perps.search.placeholder":"Search pair\u2026","portfolio.perps.empty":"No open positions","portfolio.perps.empty.hint":"Start trading \u2192","portfolio.perps.history.header.pair":"Pair","portfolio.perps.history.header.side":"Side","portfolio.perps.history.header.size":"Size","portfolio.perps.history.header.pnl":"PNL","portfolio.perps.history.header.closePrice":"Close Price","portfolio.perps.history.header.time":"Time","portfolio.prediction.activeBets":"Active Bets","portfolio.prediction.settled":"Settled","portfolio.prediction.sellAll":"Sell All","portfolio.prediction.sell":"Sell","portfolio.prediction.sellAll.confirm":"Sell all positions? This will route to each platform to execute.","portfolio.prediction.sellAll.confirmBtn":"Confirm Sell All","portfolio.prediction.sellAll.cancel":"Cancel","portfolio.prediction.header.market":"Market / Source","portfolio.prediction.header.position":"Position","portfolio.prediction.header.stake":"Stake","portfolio.prediction.header.potential":"Potential","portfolio.prediction.header.status":"Status","portfolio.prediction.search.placeholder":"Search market\u2026","portfolio.prediction.empty":"No active bets","portfolio.prediction.empty.hint":"Explore prediction markets \u2192","portfolio.prediction.settled.header.market":"Market","portfolio.prediction.settled.header.source":"Source","portfolio.prediction.settled.header.position":"Position","portfolio.prediction.settled.header.stake":"Stake","portfolio.prediction.settled.header.result":"Result","portfolio.prediction.settled.header.payout":"Payout","portfolio.connectWallet":"Connect Wallet","portfolio.connectWallet.hint":"Connect your wallet to view your portfolio","portfolio.error.load":"Failed to load portfolio data","portfolio.error.retry":"Retry"};var M={"predict.categories.trending":"Trending","predict.categories.allMarkets":"All Markets","predict.event.status.closed":"Closed","predict.event.status.live":"Live","predict.event.status.pending":"Pending","predict.event.volume":"vol","predict.event.endDate":"Ends {{date}}","predict.event.rules":"Rules","predict.event.rules.collapse":"Collapse","predict.event.rules.expand":"Expand all","predict.event.showMore":"Show More","predict.event.back":"Back","predict.event.moreMarkets":"+{{count}} more","predict.market.table.outcome":"Outcome","predict.market.table.chance":"Chance","predict.market.table.actions":"Actions","predict.market.action.yes":"Yes {{price}}\xA2","predict.market.action.no":"No {{price}}\xA2","predict.market.yes":"Yes","predict.market.no":"No","predict.market.sharesYes":"{{shares}} Yes","predict.market.sharesNo":"{{shares}} No","predict.market.tradeYes":"Trade Yes","predict.market.tradeNo":"Trade No","predict.market.graph":"Graph","predict.trade.action":"Trade","predict.trade.buy":"Buy","predict.trade.sell":"Sell","predict.trade.yes":"Yes","predict.trade.no":"No","predict.trade.limit":"Limit","predict.trade.market":"Market","predict.trade.price":"Price","predict.trade.amount":"Amount","predict.trade.contracts":"Contracts","predict.trade.estimatedCost":"Est. Cost","predict.trade.potentialPayout":"Potential Payout","predict.trade.potentialProfit":"Potential Profit","predict.trade.potentialWin":"Potential Win","predict.trade.estimatedReceive":"Est. Receive","predict.trade.balance":"Available Balance","predict.trade.bestBid":"Bid","predict.trade.bestAsk":"Ask","predict.trade.priceImpact":"Price Impact","predict.trade.quoteError":"Unable to get quote. Please try again.","predict.trade.connectWallet":"Connect Wallet","predict.trade.submitting":"Submitting\u2026","predict.trade.submitSuccess":"Transaction submitted successfully!","predict.trade.submitError":"Transaction failed. Please try again.","predict.orderBook.title":"Order Book","predict.orderBook.empty":"No orders yet","predict.orderBook.type":"Type","predict.orderBook.price":"Price","predict.orderBook.contracts":"Contracts","predict.orderBook.qty":"Qty","predict.orderBook.total":"Total","predict.orderBook.spread":"Spread","predict.openOrders.title":"Open Orders","predict.openOrders.empty":"No open orders","predict.openOrders.side":"Side","predict.openOrders.outcome":"Outcome","predict.openOrders.type":"Type","predict.openOrders.price":"Price","predict.openOrders.filled":"Filled","predict.openOrders.status":"Status","predict.openOrders.time":"Time","predict.openOrders.cancel":"Cancel","predict.tradeHistory.title":"Trade History","predict.tradeHistory.empty":"No trades yet","predict.tradeHistory.side":"Side","predict.tradeHistory.outcome":"Outcome","predict.tradeHistory.price":"Price","predict.tradeHistory.qty":"Qty","predict.tradeHistory.total":"Total","predict.tradeHistory.fee":"Fee","predict.tradeHistory.time":"Time","predict.positions.title":"Positions","predict.positions.empty":"No positions","predict.positions.market":"Market","predict.positions.outcome":"Outcome","predict.positions.qty":"Qty","predict.positions.avgCost":"Avg Cost","predict.positions.currentPrice":"Price","predict.positions.value":"Value","predict.positions.pnl":"P&L","predict.positions.totalValue":"Total Value","predict.positions.unrealizedPnl":"Unrealized P&L","predict.positions.realizedPnl":"Realized P&L","predict.pagination.prev":"Prev","predict.pagination.next":"Next","predict.pagination.page":"Page {{page}}"};var R={"scaffold.draggableModal.snapToEdge":"Drag to edge to show side panel","scaffold.draggablePanel.snapToModal":"Drag away to show floating modal","scaffold.home":"Home"};var I={"tokens.search.title":"Search","tokens.search.placeholder":"Search by token or CA...","tokens.search.history":"Search History","tokens.search.noResults":"No results found","tokens.search.hint":"Enter token name or contract address to search","tokens.copied.address":"Token address copied to clipboard","tokens.listHeader.token":"Token","tokens.listHeader.age":"Age","tokens.listHeader.24hChange":"24h%","tokens.listHeader.priceHistories":"Price Histories","tokens.listHeader.price":"Price","tokens.listHeader.priceChange":"{{resolution}}%","tokens.listHeader.marketCap":"Market Cap","tokens.listHeader.liquidity":"Liquidity","tokens.listHeader.mcShort":"MC","tokens.listHeader.liqShort":"Liq","tokens.listHeader.volumes":"{{resolution}} Volumes","tokens.listHeader.txs":"{{resolution}} TXNS","tokens.listHeader.traders":"{{resolution}} Traders","tokens.listHeader.bluechip":"BlueChip","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.resolutionSelector.title":"Resolution","tokens.tokenInfo.holders":"Holders","tokens.tokenInfo.proHolders":"Pro Holders","tokens.tokenInfo.kolHolders":"KOL Holders","tokens.tokenInfo.top10HoldingsRatio":"Top 10 Holders","tokens.tokenInfo.top100HoldingsRatio":"Top 100 Holders","tokens.tokenInfo.devHoldingsRatio":"Dev Holders","tokens.tokenInfo.sniperHoldingsRatio":"Snipers","tokens.tokenInfo.insiderHoldingsRatio":"Insiders","tokens.tokenInfo.bundleHoldingsRatio":"Bundlers","tokens.bluechip.explained":"BlueChip index is the ratio of holders who also own BlueChip tokens","tokens.pulse.new":"New","tokens.pulse.migrated":"Migrated","tokens.pulse.finalStretch":"Final Stretch","tokens.pulse.paused":"Paused","tokens.pulse.vol":"Vol","tokens.pulse.txs":"Txs"};var D={"trade.market":"Market","trade.balance":"Balance:","trade.amount":"Amount","trade.insufficientBalance":"Insufficient balance","trade.submitBuyAmount":"Buy {{amount}} {{symbol}} ({{usd}})","trade.submitSellAmount":"Sell {{amount}} {{symbol}} ({{usd}})","trade.submitBuyAmountNoUsd":"Buy {{amount}} {{symbol}}","trade.submitSellAmountNoUsd":"Sell {{amount}} {{symbol}}","trade.preset.label":"Preset {{n}}","trade.preset.short":"P{{n}}","trade.instantTradeAmount":"Instant trade amount","trade.preset.slippage":"Slippage","trade.preset.priorityFee":"Priority Fee","trade.preset.priorityFee.tooltip":"Extra fee paid to validators to prioritize your transaction.","trade.preset.gasFee":"Gas Fee","trade.preset.gasFee.tooltip":"Extra fee paid to validators to prioritize your transaction.","trade.preset.tipFee":"Tip Fee","trade.preset.tipFee.tooltip":"Additional tip sent alongside the transaction (e.g. Jito tip).","trade.preset.autoFee":"Auto Fee","trade.preset.autoFee.tooltip":"Automatically estimate optimal fee based on network conditions.","trade.preset.maxAutoFee":"Max Auto Fee","trade.preset.antiMev":"Anti-MEV","trade.preset.antiMev.tooltip":"MEV protection shields your transaction from sandwich attacks.","trade.preset.antiMev.off":"Off","trade.preset.antiMev.off.desc":"No MEV protection. Fastest execution.","trade.preset.antiMev.reduced":"Reduced","trade.preset.antiMev.reduced.desc":"Basic MEV protection with minimal impact on execution speed.","trade.preset.antiMev.secure":"Secure","trade.preset.antiMev.secure.desc":"Full MEV protection. May slightly increase execution time.","trade.preset.customRpc":"Custom RPC","trade.preset.presets":"Presets","trade.preset.instantTradeSettings":"Instant Trade Settings","trade.swap.from":"From","trade.swap.to":"To","trade.swap.selectToken":"Select token","trade.swap.half":"Half","trade.swap.swap":"Swap","trade.swap.swapping":"Swapping...","trade.swap.findingRoute":"Finding route...","trade.swap.preview":"Preview","trade.swap.estimatedReceive":"Estimated Receive","trade.swap.routeDetails":"Route Details","trade.swap.dex":"DEX","trade.swap.fee":"Fee","trade.swap.showMore":"Show More","trade.swap.showLess":"Show Less"};var E={...H,...F,...M,...R,...I,...N,...B,...D};var O=i18next.createInstance();O.use($__default.default).use(reactI18next.initReactI18next).init({fallbackLng:k,ns:[i],defaultNS:i,interpolation:{escapeValue:false},detection:{lookupLocalStorage:T,lookupCookie:A,caches:["cookie","localStorage"],order:["cookie","localStorage","htmlTag","navigator"]},resources:{[k]:{[i]:E}}});var a=O;var u=class{constructor(e,o){this.i18n=e;this.options=o;this.cache=new Set;}cache;async fetchData(e){try{return await(await fetch(e)).json()}catch(o){return console.warn(`Failed to fetch locale resource bundle from ${e}:`,o),{}}}async loadLanguage(e,o){if(typeof this.options?.loadPath!="function")return;let s=this.options.loadPath(e,o);if(typeof s=="string"&&(s=[s]),!s.length)return;let n=s.filter(c=>!this.i18n.hasResourceBundle(e,o)||!this.cache.has(c)).map(async c=>{let p=await this.fetchData(c);this.i18n.addResourceBundle(e,o,p,true,true),this.cache.add(c);});await Promise.all(n);}};var b=react.createContext(null),W=()=>{let r=react.useContext(b);if(!r)throw new Error("useLocaleContext must be used within a LocaleProvider");return r};function h(r,e){let o=r.split("/")[1];return e=e||Object.values(m),e.includes(o)?o:null}function f(r,e,o){e=e||Object.values(m),o=o||"en";let s=/^([a-z]{2})/i,l=r?.match(s);if(!l)return o;let n=l[1];return e.includes(r)?r:e.includes(n)?n:o}function Xe(r){let{path:e,locale:o,search:s}=r,l=s||(typeof window<"u"?window.location.search:""),n=h(e);return n?`${e}${l}`:(n=o||f(a.language),`/${n}${e}${l}`)}function Je(r,e){let o=h(r,e);return o?r.replace(new RegExp(`^/${o}(?=/)`),""):r}function G({children:r,locale:e,resource:o,resources:s,backend:l,supportedLanguages:n,convertDetectedLanguage:c,languages:p,beforeLanguageChange:C,afterLanguageChange:w}){let[x,v]=react.useState(y),P=react.useRef(new u(a,l));react.useEffect(()=>{if(s){Object.entries(s).forEach(([t,d])=>{a.addResourceBundle(t,i,d,true,true);});return}o&&e&&a.addResourceBundle(e,i,o,true,true);},[e,o,s]),react.useEffect(()=>{e&&e!==a.language&&a.changeLanguage(e);},[e]),react.useEffect(()=>{Array.isArray(p)?v(p):Array.isArray(n)&&v(n.map(t=>y.find(d=>d.localCode===t)).filter(t=>!!t));},[n,p]),react.useEffect(()=>{(async()=>{let d=typeof c=="function"?c(a.language):f(a.language);await P.current.loadLanguage(d,i),d!==a.language&&await a.changeLanguage(d);})();},[]);let S=react.useCallback(async t=>{await C?.(t),await P.current.loadLanguage(t,i);},[C]),L=react.useCallback(async t=>{w?.(t);},[w]),V=react.useMemo(()=>({languages:x,beforeLanguageChange:S,afterLanguageChange:L}),[x,S,L]);return jsxRuntime.jsx(b.Provider,{value:V,children:jsxRuntime.jsx(reactI18next.I18nextProvider,{i18n:a,defaultNS:i,children:r})})}function oe(r,e){let o=react.useContext(reactI18next.I18nContext);return reactI18next.useTranslation(r,{i18n:o?.i18n||a,...e})}function se(){let[r,e]=react.useState(a.language);return react.useEffect(()=>(a.on("languageChanged",e),()=>{a.off("languageChanged",e);}),[a]),r}function ie(){let{beforeLanguageChange:r,afterLanguageChange:e}=W();return react.useCallback(async s=>{await r(s),await a.changeLanguage(s),await e(s);},[r,e,a])}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=b;exports.LocaleEnum=m;exports.LocaleProvider=G;exports.defaultLanguages=y;exports.defaultLng=k;exports.defaultNS=i;exports.en=E;exports.generatePath=Xe;exports.getLocalePathFromPathname=h;exports.i18n=a;exports.i18nCookieKey=A;exports.i18nLocalStorageKey=T;exports.parseI18nLang=f;exports.removeLangPrefix=Je;exports.useChangeLocale=ie;exports.useLocale=se;exports.useLocaleContext=W;exports.useTranslation=oe;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
11
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/channels.ts","../src/locale/module/common.ts","../src/locale/module/mediaTrack.ts","../src/locale/module/portfolio.ts","../src/locale/module/predict.ts","../src/locale/module/scaffold.ts","../src/locale/module/tokens.ts","../src/locale/module/trade.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","portfolio","predict","scaffold","tokens","trade","en","i18n","createInstance","LanguageDetector","initReactI18next","i18n_default","Backend","options","url","error","lang","ns","paths","promises","path","data","LocaleContext","createContext","useLocaleContext","context","useContext","getLocalePathFromPathname","pathname","localeCodes","locale","parseI18nLang","defaultLang","regex","match","matchLang","generatePath","params","search","searchUrl","localePath","removeLangPrefix","LocaleProvider","children","resource","resources","backend","supportedLanguages","convertDetectedLanguage","languagesProp","beforeLanguageChange","afterLanguageChange","languages","setLanguages","useState","backendRef","useRef","useEffect","messages","localCode","l","item","beforeLanguageChangeHandler","useCallback","afterLanguageChangeHandler","contextValue","useMemo","jsx","I18nextProvider","useTranslation","I18nContext","_useTranslation","useLocale","localeCode","setLocaleCode","useChangeLocale"],"mappings":"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","file":"index.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.create.eligibility.title\": \"Check Eligibility\",\n \"channels.create.eligibility.description\":\n \"Verify your X (Twitter) account to ensure it meets the requirements for creating a channel.\",\n \"channels.create.eligibility.xConnection\": \"X Account Connection\",\n \"channels.create.eligibility.connected\": \"Connected as\",\n \"channels.create.eligibility.notConnected\": \"No X account connected\",\n \"channels.create.eligibility.connect\": \"Connect X Account\",\n \"channels.create.eligibility.disconnect\": \"Disconnect\",\n \"channels.create.eligibility.verifying\": \"Verifying eligibility...\",\n \"channels.create.eligibility.requirementsTitle\": \"Eligibility Requirements\",\n \"channels.create.eligibility.followersCount\": \"Followers Count\",\n \"channels.create.eligibility.accountAge\": \"Account Age\",\n \"channels.create.eligibility.behaviorScore\": \"Behavior Score\",\n \"channels.create.eligibility.clean\": \"Clean\",\n \"channels.create.eligibility.allPassed\":\n \"All eligibility checks passed! You can now create a channel.\",\n \"channels.create.eligibility.failed\":\n \"Some requirements are not met. Please check your account.\",\n \"channels.update.title\": \"Update Channel\",\n \"channels.update.success\": \"Channel updated successfully\",\n \"channels.update.error\": \"Update channel error\",\n \"channels.info.walletCount\": \"Wallet Count\",\n \"channels.info.subscribeCount\": \"Subscribe Count\",\n \"channels.info.createdAt\": \"created at\",\n \"channels.info.updatedAt\": \"last updated at\",\n \"channels.stats.7dTxs.title\": \"7D TXs\",\n \"channels.stats.7dTxs.hint\": \"7 Days Transactions\",\n \"channels.stats.7dPnl.title\": \"7D PnL\",\n \"channels.stats.7dPnl.hint\": \"7 Days Profit and Loss\",\n \"channels.stats.7dWr.title\": \"7D WR\",\n \"channels.stats.7dWr.hint\": \"7 Days Winning Rate\",\n \"channels.detail.title\": \"Channel Detail\",\n \"channels.detail.notfound\": \"Channel not found\",\n \"channels.events.title\": \"Channel Events\",\n \"channels.events.empty\": \"No events yet\",\n \"channels.events.walletTrade.buy\": \"bought\",\n \"channels.events.walletTrade.sell\": \"sold\",\n \"channels.events.walletTrade.got\": \"got\",\n \"channels.events.walletTrade.cost\": \"cost\",\n \"channels.events.walletTrade.price\": \"price\",\n};\n","export const common = {\n \"common.cancel\": \"Cancel\",\n \"common.confirm\": \"Confirm\",\n \"common.reset\": \"Reset\",\n \"common.apply\": \"Apply\",\n \"common.ok\": \"OK\",\n \"common.yes\": \"Yes\",\n \"common.no\": \"No\",\n \"common.all\": \"All\",\n \"common.buy\": \"Buy\",\n \"common.sell\": \"Sell\",\n \"common.long\": \"Long\",\n \"common.short\": \"Short\",\n \"common.edit\": \"Edit\",\n \"common.save\": \"Save\",\n \"common.add\": \"Add\",\n \"common.delete\": \"Delete\",\n \"common.tips\": \"Tips\",\n \"common.max\": \"Max\",\n \"common.download\": \"Download\",\n \"common.copy\": \"Copy\",\n \"common.copy.failed\": \"Copy failed\",\n \"common.copy.copied\": \"Copied to clipboard\",\n \"common.share\": \"Share\",\n \"common.export\": \"Export\",\n \"common.empty\": \"No data\",\n \"common.unauthenticated\": \"Please sign in to continue\",\n \"common.signIn\": \"Sign In\",\n \"common.signOut\": \"Sign Out\",\n \"common.resolution.1s\": \"1s\",\n \"common.resolution.15s\": \"15s\",\n \"common.resolution.30s\": \"30s\",\n \"common.resolution.1m\": \"1m\",\n \"common.resolution.5m\": \"5m\",\n \"common.resolution.15m\": \"15m\",\n \"common.resolution.30m\": \"30m\",\n \"common.resolution.1h\": \"1h\",\n \"common.resolution.4h\": \"4h\",\n \"common.resolution.12h\": \"12h\",\n \"common.resolution.24h\": \"24h\",\n \"common.upload.submit\": \"Upload\",\n \"common.upload.resubmit\": \"Reupload\",\n \"common.upload.error\": \"Upload error\",\n \"common.loadingMore\": \"Loading more...\",\n \"common.continue\": \"Continue\",\n \"common.months\": \"months\",\n \"common.days\": \"days\",\n};\n","export const mediaTrack = {\n \"mediaTrack.tweets.translate.show\": \"Show Translation\",\n \"mediaTrack.tweets.translate.hide\": \"Hide Translation\",\n \"mediaTrack.tweets.expand\": \"Expand\",\n \"mediaTrack.tweets.collapse\": \"Collapse\",\n};\n","export const portfolio = {\n // Asset Tabs\n \"portfolio.tabs.spot\": \"Spot\",\n \"portfolio.tabs.perps\": \"Perps\",\n \"portfolio.tabs.prediction\": \"Prediction\",\n\n // Address Row\n \"portfolio.address.allWallets\": \"All Wallets\",\n \"portfolio.address.aggregated\": \"Aggregated\",\n \"portfolio.address.copy\": \"Copy Address\",\n \"portfolio.address.copied\": \"Address copied\",\n \"portfolio.address.owner\": \"Owner\",\n \"portfolio.address.viewing\": \"Viewing\",\n \"portfolio.address.search.placeholder\": \"Search wallet address…\",\n \"portfolio.address.search.view\": \"View\",\n \"portfolio.address.search.invalid\": \"Enter a valid address\",\n\n // Balance Row\n \"portfolio.balance.uPnl\": \"uPNL\",\n \"portfolio.balance.realized\": \"Realized\",\n \"portfolio.balance.gas\": \"Gas\",\n\n // Curve Card\n \"portfolio.curve.netWorth\": \"Net Worth\",\n \"portfolio.curve.pnl\": \"PNL\",\n \"portfolio.curve.noData\": \"Not enough data\",\n\n // Distribution Card\n \"portfolio.distribution.title\": \"Distribution\",\n \"portfolio.distribution.other\": \"Other\",\n\n // Viewing Mode\n \"portfolio.viewing.banner\": \"Viewing external portfolio\",\n \"portfolio.viewing.back\": \"Back to My Portfolio\",\n\n // Spot Holdings\n \"portfolio.spot.holdings\": \"Holdings\",\n \"portfolio.spot.history\": \"History\",\n \"portfolio.spot.search.placeholder\": \"Search token…\",\n \"portfolio.spot.hideSmall\": \"Hide small\",\n \"portfolio.spot.group.tokens\": \"Tokens\",\n \"portfolio.spot.header.asset\": \"Asset\",\n \"portfolio.spot.header.balance\": \"Balance\",\n \"portfolio.spot.header.price\": \"Price\",\n \"portfolio.spot.header.value\": \"Value\",\n \"portfolio.spot.header.24h\": \"24h\",\n \"portfolio.spot.empty\": \"No tokens found\",\n \"portfolio.spot.empty.hint\": \"Your spot tokens will appear here\",\n\n // Spot History\n \"portfolio.spot.history.header.type\": \"Type\",\n \"portfolio.spot.history.header.detail\": \"Detail\",\n \"portfolio.spot.history.header.amount\": \"Amount\",\n \"portfolio.spot.history.header.value\": \"Value\",\n \"portfolio.spot.history.header.time\": \"Time\",\n \"portfolio.spot.history.header.txHash\": \"TxHash\",\n \"portfolio.spot.history.type.swap\": \"Swap\",\n \"portfolio.spot.history.type.send\": \"Send\",\n \"portfolio.spot.history.type.receive\": \"Receive\",\n\n // Perps\n \"portfolio.perps.openPositions\": \"Open Positions\",\n \"portfolio.perps.tradeHistory\": \"Trade History\",\n \"portfolio.perps.closeAll\": \"Close All\",\n \"portfolio.perps.close\": \"Close\",\n \"portfolio.perps.closeAll.confirm\":\n \"Close all positions? This will route to each protocol to execute.\",\n \"portfolio.perps.closeAll.confirmBtn\": \"Confirm Close All\",\n \"portfolio.perps.closeAll.cancel\": \"Cancel\",\n \"portfolio.perps.header.pair\": \"Pair / Side\",\n \"portfolio.perps.header.size\": \"Size\",\n \"portfolio.perps.header.entry\": \"Entry\",\n \"portfolio.perps.header.mark\": \"Mark\",\n \"portfolio.perps.header.uPnl\": \"uPNL\",\n \"portfolio.perps.search.placeholder\": \"Search pair…\",\n \"portfolio.perps.empty\": \"No open positions\",\n \"portfolio.perps.empty.hint\": \"Start trading →\",\n \"portfolio.perps.history.header.pair\": \"Pair\",\n \"portfolio.perps.history.header.side\": \"Side\",\n \"portfolio.perps.history.header.size\": \"Size\",\n \"portfolio.perps.history.header.pnl\": \"PNL\",\n \"portfolio.perps.history.header.closePrice\": \"Close Price\",\n \"portfolio.perps.history.header.time\": \"Time\",\n\n // Prediction\n \"portfolio.prediction.activeBets\": \"Active Bets\",\n \"portfolio.prediction.settled\": \"Settled\",\n \"portfolio.prediction.sellAll\": \"Sell All\",\n \"portfolio.prediction.sell\": \"Sell\",\n \"portfolio.prediction.sellAll.confirm\":\n \"Sell all positions? This will route to each platform to execute.\",\n \"portfolio.prediction.sellAll.confirmBtn\": \"Confirm Sell All\",\n \"portfolio.prediction.sellAll.cancel\": \"Cancel\",\n \"portfolio.prediction.header.market\": \"Market / Source\",\n \"portfolio.prediction.header.position\": \"Position\",\n \"portfolio.prediction.header.stake\": \"Stake\",\n \"portfolio.prediction.header.potential\": \"Potential\",\n \"portfolio.prediction.header.status\": \"Status\",\n \"portfolio.prediction.search.placeholder\": \"Search market…\",\n \"portfolio.prediction.empty\": \"No active bets\",\n \"portfolio.prediction.empty.hint\": \"Explore prediction markets →\",\n \"portfolio.prediction.settled.header.market\": \"Market\",\n \"portfolio.prediction.settled.header.source\": \"Source\",\n \"portfolio.prediction.settled.header.position\": \"Position\",\n \"portfolio.prediction.settled.header.stake\": \"Stake\",\n \"portfolio.prediction.settled.header.result\": \"Result\",\n \"portfolio.prediction.settled.header.payout\": \"Payout\",\n\n // Empty / Error states\n \"portfolio.connectWallet\": \"Connect Wallet\",\n \"portfolio.connectWallet.hint\": \"Connect your wallet to view your portfolio\",\n \"portfolio.error.load\": \"Failed to load portfolio data\",\n \"portfolio.error.retry\": \"Retry\",\n};\n","export const predict = {\n // Categories\n \"predict.categories.trending\": \"Trending\",\n \"predict.categories.allMarkets\": \"All Markets\",\n\n // Event status\n \"predict.event.status.closed\": \"Closed\",\n \"predict.event.status.live\": \"Live\",\n \"predict.event.status.pending\": \"Pending\",\n\n // Event detail\n \"predict.event.volume\": \"vol\",\n \"predict.event.endDate\": \"Ends {{date}}\",\n \"predict.event.rules\": \"Rules\",\n \"predict.event.rules.collapse\": \"Collapse\",\n \"predict.event.rules.expand\": \"Expand all\",\n \"predict.event.showMore\": \"Show More\",\n \"predict.event.back\": \"Back\",\n \"predict.event.moreMarkets\": \"+{{count}} more\",\n\n // Markets table\n \"predict.market.table.outcome\": \"Outcome\",\n \"predict.market.table.chance\": \"Chance\",\n \"predict.market.table.actions\": \"Actions\",\n \"predict.market.action.yes\": \"Yes {{price}}¢\",\n \"predict.market.action.no\": \"No {{price}}¢\",\n\n // Market options\n \"predict.market.yes\": \"Yes\",\n \"predict.market.no\": \"No\",\n \"predict.market.sharesYes\": \"{{shares}} Yes\",\n \"predict.market.sharesNo\": \"{{shares}} No\",\n \"predict.market.tradeYes\": \"Trade Yes\",\n \"predict.market.tradeNo\": \"Trade No\",\n \"predict.market.graph\": \"Graph\",\n\n // Trade form\n \"predict.trade.action\": \"Trade\",\n \"predict.trade.buy\": \"Buy\",\n \"predict.trade.sell\": \"Sell\",\n \"predict.trade.yes\": \"Yes\",\n \"predict.trade.no\": \"No\",\n \"predict.trade.limit\": \"Limit\",\n \"predict.trade.market\": \"Market\",\n \"predict.trade.price\": \"Price\",\n \"predict.trade.amount\": \"Amount\",\n \"predict.trade.contracts\": \"Contracts\",\n \"predict.trade.estimatedCost\": \"Est. Cost\",\n \"predict.trade.potentialPayout\": \"Potential Payout\",\n \"predict.trade.potentialProfit\": \"Potential Profit\",\n \"predict.trade.potentialWin\": \"Potential Win\",\n \"predict.trade.estimatedReceive\": \"Est. Receive\",\n \"predict.trade.balance\": \"Available Balance\",\n \"predict.trade.bestBid\": \"Bid\",\n \"predict.trade.bestAsk\": \"Ask\",\n \"predict.trade.priceImpact\": \"Price Impact\",\n \"predict.trade.quoteError\": \"Unable to get quote. Please try again.\",\n \"predict.trade.connectWallet\": \"Connect Wallet\",\n \"predict.trade.submitting\": \"Submitting…\",\n \"predict.trade.submitSuccess\": \"Transaction submitted successfully!\",\n \"predict.trade.submitError\": \"Transaction failed. Please try again.\",\n\n // Order book\n \"predict.orderBook.title\": \"Order Book\",\n \"predict.orderBook.empty\": \"No orders yet\",\n \"predict.orderBook.type\": \"Type\",\n \"predict.orderBook.price\": \"Price\",\n \"predict.orderBook.contracts\": \"Contracts\",\n \"predict.orderBook.qty\": \"Qty\",\n \"predict.orderBook.total\": \"Total\",\n \"predict.orderBook.spread\": \"Spread\",\n\n // Open orders\n \"predict.openOrders.title\": \"Open Orders\",\n \"predict.openOrders.empty\": \"No open orders\",\n \"predict.openOrders.side\": \"Side\",\n \"predict.openOrders.outcome\": \"Outcome\",\n \"predict.openOrders.type\": \"Type\",\n \"predict.openOrders.price\": \"Price\",\n \"predict.openOrders.filled\": \"Filled\",\n \"predict.openOrders.status\": \"Status\",\n \"predict.openOrders.time\": \"Time\",\n \"predict.openOrders.cancel\": \"Cancel\",\n\n // Trade history\n \"predict.tradeHistory.title\": \"Trade History\",\n \"predict.tradeHistory.empty\": \"No trades yet\",\n \"predict.tradeHistory.side\": \"Side\",\n \"predict.tradeHistory.outcome\": \"Outcome\",\n \"predict.tradeHistory.price\": \"Price\",\n \"predict.tradeHistory.qty\": \"Qty\",\n \"predict.tradeHistory.total\": \"Total\",\n \"predict.tradeHistory.fee\": \"Fee\",\n \"predict.tradeHistory.time\": \"Time\",\n\n // Positions\n \"predict.positions.title\": \"Positions\",\n \"predict.positions.empty\": \"No positions\",\n \"predict.positions.market\": \"Market\",\n \"predict.positions.outcome\": \"Outcome\",\n \"predict.positions.qty\": \"Qty\",\n \"predict.positions.avgCost\": \"Avg Cost\",\n \"predict.positions.currentPrice\": \"Price\",\n \"predict.positions.value\": \"Value\",\n \"predict.positions.pnl\": \"P&L\",\n \"predict.positions.totalValue\": \"Total Value\",\n \"predict.positions.unrealizedPnl\": \"Unrealized P&L\",\n \"predict.positions.realizedPnl\": \"Realized P&L\",\n\n // Pagination\n \"predict.pagination.prev\": \"Prev\",\n \"predict.pagination.next\": \"Next\",\n \"predict.pagination.page\": \"Page {{page}}\",\n};\n","export const scaffold = {\n \"scaffold.draggableModal.snapToEdge\": \"Drag to edge to show side panel\",\n \"scaffold.draggablePanel.snapToModal\": \"Drag away to show floating modal\",\n \"scaffold.home\": \"Home\",\n};\n","export const tokens = {\n \"tokens.search.title\": \"Search\",\n \"tokens.search.placeholder\": \"Search by token or CA...\",\n \"tokens.search.history\": \"Search History\",\n \"tokens.search.noResults\": \"No results found\",\n \"tokens.search.hint\": \"Enter token name or contract address to search\",\n \"tokens.copied.address\": \"Token address copied to clipboard\",\n \"tokens.listHeader.token\": \"Token\",\n \"tokens.listHeader.age\": \"Age\",\n \"tokens.listHeader.24hChange\": \"24h%\",\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.mcShort\": \"MC\",\n \"tokens.listHeader.liqShort\": \"Liq\",\n \"tokens.listHeader.volumes\": \"{{resolution}} Volumes\",\n \"tokens.listHeader.txs\": \"{{resolution}} TXNS\",\n \"tokens.listHeader.traders\": \"{{resolution}} Traders\",\n \"tokens.listHeader.bluechip\": \"BlueChip\",\n \"tokens.listHeader.tokenInfo\": \"Token Info\",\n \"tokens.listHeader.actions\": \"Actions\",\n \"tokens.listHeader.filter\": \"Filter\",\n \"tokens.listType.trending\": \"Trending\",\n \"tokens.listType.new\": \"New\",\n \"tokens.listType.stocks\": \"Stocks\",\n \"tokens.filters.protocols.title\": \"Protocols\",\n \"tokens.filters.protocols.selectAll\": \"Select All\",\n \"tokens.filters.protocols.unselectAll\": \"Unselect All\",\n \"tokens.filters.keywords.title\": \"Search Keywords\",\n \"tokens.filters.keywords.exclude.title\": \"Exclude Keywords\",\n \"tokens.filters.keywords.placeholder\": \"keyword1, keyword2...\",\n \"tokens.filters.stats.min\": \"Min\",\n \"tokens.filters.stats.max\": \"Max\",\n \"tokens.filters.stats.audits\": \"Audits\",\n \"tokens.filters.stats.audits.holders\": \"Holders Count\",\n \"tokens.filters.stats.audits.top10HoldingsRatio\": \"Top 10 Holders %\",\n \"tokens.filters.stats.audits.top100HoldingsRatio\": \"Top 100 Holders %\",\n \"tokens.filters.stats.audits.devHoldingsRatio\": \"Dev Holdings %\",\n \"tokens.filters.stats.metrics\": \"Metrics\",\n \"tokens.filters.stats.metrics.volumes\": \"{{resolution}} Volumes ($)\",\n \"tokens.filters.stats.metrics.txns\": \"{{resolution}} Transactions\",\n \"tokens.filters.stats.metrics.liquidity\": \"Liquidity ($)\",\n \"tokens.filters.stats.metrics.marketCap\": \"Market Cap ($)\",\n \"tokens.filters.modal.title\": \"Filters\",\n \"tokens.tokenInfo.holders\": \"Holders\",\n \"tokens.tokenInfo.proHolders\": \"Pro Holders\",\n \"tokens.tokenInfo.kolHolders\": \"KOL Holders\",\n \"tokens.tokenInfo.top10HoldingsRatio\": \"Top 10 Holders\",\n \"tokens.tokenInfo.top100HoldingsRatio\": \"Top 100 Holders\",\n \"tokens.tokenInfo.devHoldingsRatio\": \"Dev Holders\",\n \"tokens.tokenInfo.sniperHoldingsRatio\": \"Snipers\",\n \"tokens.tokenInfo.insiderHoldingsRatio\": \"Insiders\",\n \"tokens.tokenInfo.bundleHoldingsRatio\": \"Bundlers\",\n \"tokens.bluechip.explained\":\n \"BlueChip index is the ratio of holders who also own BlueChip tokens\",\n \"tokens.pulse.new\": \"New\",\n \"tokens.pulse.migrated\": \"Migrated\",\n \"tokens.pulse.finalStretch\": \"Final Stretch\",\n \"tokens.pulse.paused\": \"Paused\",\n \"tokens.pulse.vol\": \"Vol\",\n \"tokens.pulse.txs\": \"Txs\",\n};\n","export const trade = {\n // -- Instant Trade --\n \"trade.market\": \"Market\",\n \"trade.balance\": \"Balance:\",\n \"trade.amount\": \"Amount\",\n \"trade.insufficientBalance\": \"Insufficient balance\",\n \"trade.submitBuyAmount\": \"Buy {{amount}} {{symbol}} ({{usd}})\",\n \"trade.submitSellAmount\": \"Sell {{amount}} {{symbol}} ({{usd}})\",\n \"trade.submitBuyAmountNoUsd\": \"Buy {{amount}} {{symbol}}\",\n \"trade.submitSellAmountNoUsd\": \"Sell {{amount}} {{symbol}}\",\n \"trade.preset.label\": \"Preset {{n}}\",\n \"trade.preset.short\": \"P{{n}}\",\n \"trade.instantTradeAmount\": \"Instant trade amount\",\n\n // -- Preset Form --\n \"trade.preset.slippage\": \"Slippage\",\n \"trade.preset.priorityFee\": \"Priority Fee\",\n \"trade.preset.priorityFee.tooltip\":\n \"Extra fee paid to validators to prioritize your transaction.\",\n \"trade.preset.gasFee\": \"Gas Fee\",\n \"trade.preset.gasFee.tooltip\":\n \"Extra fee paid to validators to prioritize your transaction.\",\n \"trade.preset.tipFee\": \"Tip Fee\",\n \"trade.preset.tipFee.tooltip\":\n \"Additional tip sent alongside the transaction (e.g. Jito tip).\",\n \"trade.preset.autoFee\": \"Auto Fee\",\n \"trade.preset.autoFee.tooltip\":\n \"Automatically estimate optimal fee based on network conditions.\",\n \"trade.preset.maxAutoFee\": \"Max Auto Fee\",\n \"trade.preset.antiMev\": \"Anti-MEV\",\n \"trade.preset.antiMev.tooltip\":\n \"MEV protection shields your transaction from sandwich attacks.\",\n \"trade.preset.antiMev.off\": \"Off\",\n \"trade.preset.antiMev.off.desc\": \"No MEV protection. Fastest execution.\",\n \"trade.preset.antiMev.reduced\": \"Reduced\",\n \"trade.preset.antiMev.reduced.desc\":\n \"Basic MEV protection with minimal impact on execution speed.\",\n \"trade.preset.antiMev.secure\": \"Secure\",\n \"trade.preset.antiMev.secure.desc\":\n \"Full MEV protection. May slightly increase execution time.\",\n \"trade.preset.customRpc\": \"Custom RPC\",\n \"trade.preset.presets\": \"Presets\",\n \"trade.preset.instantTradeSettings\": \"Instant Trade Settings\",\n\n // -- Swap --\n \"trade.swap.from\": \"From\",\n \"trade.swap.to\": \"To\",\n \"trade.swap.selectToken\": \"Select token\",\n \"trade.swap.half\": \"Half\",\n \"trade.swap.swap\": \"Swap\",\n \"trade.swap.swapping\": \"Swapping...\",\n \"trade.swap.findingRoute\": \"Finding route...\",\n \"trade.swap.preview\": \"Preview\",\n \"trade.swap.estimatedReceive\": \"Estimated Receive\",\n \"trade.swap.routeDetails\": \"Route Details\",\n \"trade.swap.dex\": \"DEX\",\n \"trade.swap.fee\": \"Fee\",\n \"trade.swap.showMore\": \"Show More\",\n \"trade.swap.showLess\": \"Show Less\",\n};\n","import { channels } from \"./module/channels\";\nimport { common } from \"./module/common\";\nimport { mediaTrack } from \"./module/mediaTrack\";\nimport { portfolio } from \"./module/portfolio\";\nimport { predict } from \"./module/predict\";\nimport { scaffold } from \"./module/scaffold\";\nimport { tokens } from \"./module/tokens\";\nimport { trade } from \"./module/trade\";\n\nexport const en = {\n ...common,\n ...mediaTrack,\n ...predict,\n ...scaffold,\n ...tokens,\n ...channels,\n ...portfolio,\n ...trade,\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 as I18nInstance } from \"i18next\";\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(\n private readonly i18n: I18nInstance,\n private readonly options?: BackendOptions,\n ) {\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 let paths = this.options.loadPath(lang, ns);\n if (typeof paths === \"string\") paths = [paths];\n if (!paths.length) return;\n\n const urls = paths.filter((path) => {\n const loaded = this.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 this.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 | null>(null);\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(i18n, 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 }, []);\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/portfolio.ts","../src/locale/module/predict.ts","../src/locale/module/scaffold.ts","../src/locale/module/tokens.ts","../src/locale/module/trade.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","portfolio","predict","scaffold","tokens","trade","en","i18n","createInstance","LanguageDetector","initReactI18next","i18n_default","Backend","options","url","error","lang","ns","paths","promises","path","data","LocaleContext","createContext","useLocaleContext","context","useContext","getLocalePathFromPathname","pathname","localeCodes","locale","parseI18nLang","defaultLang","regex","match","matchLang","generatePath","params","search","searchUrl","localePath","removeLangPrefix","LocaleProvider","children","resource","resources","backend","supportedLanguages","convertDetectedLanguage","languagesProp","beforeLanguageChange","afterLanguageChange","languages","setLanguages","useState","backendRef","useRef","useEffect","messages","localCode","l","item","beforeLanguageChangeHandler","useCallback","afterLanguageChangeHandler","contextValue","useMemo","jsx","I18nextProvider","useTranslation","I18nContext","_useTranslation","useLocale","localeCode","setLocaleCode","useChangeLocale"],"mappings":"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","file":"index.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.create.eligibility.title\": \"Check Eligibility\",\n \"channels.create.eligibility.description\":\n \"Verify your X (Twitter) account to ensure it meets the requirements for creating a channel.\",\n \"channels.create.eligibility.xConnection\": \"X Account Connection\",\n \"channels.create.eligibility.connected\": \"Connected as\",\n \"channels.create.eligibility.notConnected\": \"No X account connected\",\n \"channels.create.eligibility.connect\": \"Connect X Account\",\n \"channels.create.eligibility.disconnect\": \"Disconnect\",\n \"channels.create.eligibility.verifying\": \"Verifying eligibility...\",\n \"channels.create.eligibility.requirementsTitle\": \"Eligibility Requirements\",\n \"channels.create.eligibility.followersCount\": \"Followers Count\",\n \"channels.create.eligibility.accountAge\": \"Account Age\",\n \"channels.create.eligibility.behaviorScore\": \"Behavior Score\",\n \"channels.create.eligibility.clean\": \"Clean\",\n \"channels.create.eligibility.allPassed\":\n \"All eligibility checks passed! You can now create a channel.\",\n \"channels.create.eligibility.failed\":\n \"Some requirements are not met. Please check your account.\",\n \"channels.update.title\": \"Update Channel\",\n \"channels.update.success\": \"Channel updated successfully\",\n \"channels.update.error\": \"Update channel error\",\n \"channels.info.walletCount\": \"Wallet Count\",\n \"channels.info.subscribeCount\": \"Subscribe Count\",\n \"channels.info.createdAt\": \"created at\",\n \"channels.info.updatedAt\": \"last updated at\",\n \"channels.stats.7dTxs.title\": \"7D TXs\",\n \"channels.stats.7dTxs.hint\": \"7 Days Transactions\",\n \"channels.stats.7dPnl.title\": \"7D PnL\",\n \"channels.stats.7dPnl.hint\": \"7 Days Profit and Loss\",\n \"channels.stats.7dWr.title\": \"7D WR\",\n \"channels.stats.7dWr.hint\": \"7 Days Winning Rate\",\n \"channels.detail.title\": \"Channel Detail\",\n \"channels.detail.notfound\": \"Channel not found\",\n \"channels.events.title\": \"Channel Events\",\n \"channels.events.empty\": \"No events yet\",\n \"channels.events.walletTrade.buy\": \"bought\",\n \"channels.events.walletTrade.sell\": \"sold\",\n \"channels.events.walletTrade.got\": \"got\",\n \"channels.events.walletTrade.cost\": \"cost\",\n \"channels.events.walletTrade.price\": \"price\",\n};\n","export const common = {\n \"common.cancel\": \"Cancel\",\n \"common.confirm\": \"Confirm\",\n \"common.reset\": \"Reset\",\n \"common.apply\": \"Apply\",\n \"common.ok\": \"OK\",\n \"common.yes\": \"Yes\",\n \"common.no\": \"No\",\n \"common.all\": \"All\",\n \"common.buy\": \"Buy\",\n \"common.sell\": \"Sell\",\n \"common.long\": \"Long\",\n \"common.short\": \"Short\",\n \"common.edit\": \"Edit\",\n \"common.save\": \"Save\",\n \"common.add\": \"Add\",\n \"common.delete\": \"Delete\",\n \"common.tips\": \"Tips\",\n \"common.max\": \"Max\",\n \"common.download\": \"Download\",\n \"common.copy\": \"Copy\",\n \"common.copy.failed\": \"Copy failed\",\n \"common.copy.copied\": \"Copied to clipboard\",\n \"common.share\": \"Share\",\n \"common.export\": \"Export\",\n \"common.empty\": \"No data\",\n \"common.unauthenticated\": \"Please sign in to continue\",\n \"common.signIn\": \"Sign In\",\n \"common.signOut\": \"Sign Out\",\n \"common.resolution.1s\": \"1s\",\n \"common.resolution.15s\": \"15s\",\n \"common.resolution.30s\": \"30s\",\n \"common.resolution.1m\": \"1m\",\n \"common.resolution.5m\": \"5m\",\n \"common.resolution.15m\": \"15m\",\n \"common.resolution.30m\": \"30m\",\n \"common.resolution.1h\": \"1h\",\n \"common.resolution.4h\": \"4h\",\n \"common.resolution.12h\": \"12h\",\n \"common.resolution.24h\": \"24h\",\n \"common.upload.submit\": \"Upload\",\n \"common.upload.resubmit\": \"Reupload\",\n \"common.upload.error\": \"Upload error\",\n \"common.loadingMore\": \"Loading more...\",\n \"common.continue\": \"Continue\",\n \"common.months\": \"months\",\n \"common.days\": \"days\",\n};\n","export const mediaTrack = {\n \"mediaTrack.tweets.translate.show\": \"Show Translation\",\n \"mediaTrack.tweets.translate.hide\": \"Hide Translation\",\n \"mediaTrack.tweets.expand\": \"Expand\",\n \"mediaTrack.tweets.collapse\": \"Collapse\",\n};\n","export const portfolio = {\n // Asset Tabs\n \"portfolio.tabs.spot\": \"Spot\",\n \"portfolio.tabs.perps\": \"Perps\",\n \"portfolio.tabs.prediction\": \"Prediction\",\n\n // Address Row\n \"portfolio.address.allWallets\": \"All Wallets\",\n \"portfolio.address.aggregated\": \"Aggregated\",\n \"portfolio.address.copy\": \"Copy Address\",\n \"portfolio.address.copied\": \"Address copied\",\n \"portfolio.address.owner\": \"Owner\",\n \"portfolio.address.viewing\": \"Viewing\",\n \"portfolio.address.search.placeholder\": \"Search wallet address…\",\n \"portfolio.address.search.view\": \"View\",\n \"portfolio.address.search.invalid\": \"Enter a valid address\",\n\n // Balance Row\n \"portfolio.balance.uPnl\": \"uPNL\",\n \"portfolio.balance.realized\": \"Realized\",\n \"portfolio.balance.gas\": \"Gas\",\n\n // Curve Card\n \"portfolio.curve.netWorth\": \"Net Worth\",\n \"portfolio.curve.pnl\": \"PNL\",\n \"portfolio.curve.noData\": \"Not enough data\",\n\n // Distribution Card\n \"portfolio.distribution.title\": \"Distribution\",\n \"portfolio.distribution.other\": \"Other\",\n\n // Viewing Mode\n \"portfolio.viewing.banner\": \"Viewing external portfolio\",\n \"portfolio.viewing.back\": \"Back to My Portfolio\",\n\n // Spot Holdings\n \"portfolio.spot.holdings\": \"Holdings\",\n \"portfolio.spot.history\": \"History\",\n \"portfolio.spot.search.placeholder\": \"Search token…\",\n \"portfolio.spot.hideSmall\": \"Hide small\",\n \"portfolio.spot.group.tokens\": \"Tokens\",\n \"portfolio.spot.header.asset\": \"Asset\",\n \"portfolio.spot.header.balance\": \"Balance\",\n \"portfolio.spot.header.price\": \"Price\",\n \"portfolio.spot.header.value\": \"Value\",\n \"portfolio.spot.header.24h\": \"24h\",\n \"portfolio.spot.empty\": \"No tokens found\",\n \"portfolio.spot.empty.hint\": \"Your spot tokens will appear here\",\n\n // Spot History\n \"portfolio.spot.history.header.type\": \"Type\",\n \"portfolio.spot.history.header.detail\": \"Detail\",\n \"portfolio.spot.history.header.amount\": \"Amount\",\n \"portfolio.spot.history.header.value\": \"Value\",\n \"portfolio.spot.history.header.time\": \"Time\",\n \"portfolio.spot.history.header.txHash\": \"TxHash\",\n \"portfolio.spot.history.type.swap\": \"Swap\",\n \"portfolio.spot.history.type.send\": \"Send\",\n \"portfolio.spot.history.type.receive\": \"Receive\",\n\n // Perps\n \"portfolio.perps.openPositions\": \"Open Positions\",\n \"portfolio.perps.tradeHistory\": \"Trade History\",\n \"portfolio.perps.closeAll\": \"Close All\",\n \"portfolio.perps.close\": \"Close\",\n \"portfolio.perps.closeAll.confirm\":\n \"Close all positions? This will route to each protocol to execute.\",\n \"portfolio.perps.closeAll.confirmBtn\": \"Confirm Close All\",\n \"portfolio.perps.closeAll.cancel\": \"Cancel\",\n \"portfolio.perps.header.pair\": \"Pair / Side\",\n \"portfolio.perps.header.size\": \"Size\",\n \"portfolio.perps.header.entry\": \"Entry\",\n \"portfolio.perps.header.mark\": \"Mark\",\n \"portfolio.perps.header.uPnl\": \"uPNL\",\n \"portfolio.perps.search.placeholder\": \"Search pair…\",\n \"portfolio.perps.empty\": \"No open positions\",\n \"portfolio.perps.empty.hint\": \"Start trading →\",\n \"portfolio.perps.history.header.pair\": \"Pair\",\n \"portfolio.perps.history.header.side\": \"Side\",\n \"portfolio.perps.history.header.size\": \"Size\",\n \"portfolio.perps.history.header.pnl\": \"PNL\",\n \"portfolio.perps.history.header.closePrice\": \"Close Price\",\n \"portfolio.perps.history.header.time\": \"Time\",\n\n // Prediction\n \"portfolio.prediction.activeBets\": \"Active Bets\",\n \"portfolio.prediction.settled\": \"Settled\",\n \"portfolio.prediction.sellAll\": \"Sell All\",\n \"portfolio.prediction.sell\": \"Sell\",\n \"portfolio.prediction.sellAll.confirm\":\n \"Sell all positions? This will route to each platform to execute.\",\n \"portfolio.prediction.sellAll.confirmBtn\": \"Confirm Sell All\",\n \"portfolio.prediction.sellAll.cancel\": \"Cancel\",\n \"portfolio.prediction.header.market\": \"Market / Source\",\n \"portfolio.prediction.header.position\": \"Position\",\n \"portfolio.prediction.header.stake\": \"Stake\",\n \"portfolio.prediction.header.potential\": \"Potential\",\n \"portfolio.prediction.header.status\": \"Status\",\n \"portfolio.prediction.search.placeholder\": \"Search market…\",\n \"portfolio.prediction.empty\": \"No active bets\",\n \"portfolio.prediction.empty.hint\": \"Explore prediction markets →\",\n \"portfolio.prediction.settled.header.market\": \"Market\",\n \"portfolio.prediction.settled.header.source\": \"Source\",\n \"portfolio.prediction.settled.header.position\": \"Position\",\n \"portfolio.prediction.settled.header.stake\": \"Stake\",\n \"portfolio.prediction.settled.header.result\": \"Result\",\n \"portfolio.prediction.settled.header.payout\": \"Payout\",\n\n // Empty / Error states\n \"portfolio.connectWallet\": \"Connect Wallet\",\n \"portfolio.connectWallet.hint\": \"Connect your wallet to view your portfolio\",\n \"portfolio.error.load\": \"Failed to load portfolio data\",\n \"portfolio.error.retry\": \"Retry\",\n};\n","export const predict = {\n // Categories\n \"predict.categories.trending\": \"Trending\",\n \"predict.categories.allMarkets\": \"All Markets\",\n\n // Event status\n \"predict.event.status.closed\": \"Closed\",\n \"predict.event.status.live\": \"Live\",\n \"predict.event.status.pending\": \"Pending\",\n\n // Event detail\n \"predict.event.volume\": \"vol\",\n \"predict.event.endDate\": \"Ends {{date}}\",\n \"predict.event.rules\": \"Rules\",\n \"predict.event.rules.collapse\": \"Collapse\",\n \"predict.event.rules.expand\": \"Expand all\",\n \"predict.event.showMore\": \"Show More\",\n \"predict.event.back\": \"Back\",\n \"predict.event.moreMarkets\": \"+{{count}} more\",\n\n // Markets table\n \"predict.market.table.outcome\": \"Outcome\",\n \"predict.market.table.chance\": \"Chance\",\n \"predict.market.table.actions\": \"Actions\",\n \"predict.market.action.yes\": \"Yes {{price}}¢\",\n \"predict.market.action.no\": \"No {{price}}¢\",\n\n // Market options\n \"predict.market.yes\": \"Yes\",\n \"predict.market.no\": \"No\",\n \"predict.market.sharesYes\": \"{{shares}} Yes\",\n \"predict.market.sharesNo\": \"{{shares}} No\",\n \"predict.market.tradeYes\": \"Trade Yes\",\n \"predict.market.tradeNo\": \"Trade No\",\n \"predict.market.graph\": \"Graph\",\n\n // Trade form\n \"predict.trade.action\": \"Trade\",\n \"predict.trade.buy\": \"Buy\",\n \"predict.trade.sell\": \"Sell\",\n \"predict.trade.yes\": \"Yes\",\n \"predict.trade.no\": \"No\",\n \"predict.trade.limit\": \"Limit\",\n \"predict.trade.market\": \"Market\",\n \"predict.trade.price\": \"Price\",\n \"predict.trade.amount\": \"Amount\",\n \"predict.trade.contracts\": \"Contracts\",\n \"predict.trade.estimatedCost\": \"Est. Cost\",\n \"predict.trade.potentialPayout\": \"Potential Payout\",\n \"predict.trade.potentialProfit\": \"Potential Profit\",\n \"predict.trade.potentialWin\": \"Potential Win\",\n \"predict.trade.estimatedReceive\": \"Est. Receive\",\n \"predict.trade.balance\": \"Available Balance\",\n \"predict.trade.bestBid\": \"Bid\",\n \"predict.trade.bestAsk\": \"Ask\",\n \"predict.trade.priceImpact\": \"Price Impact\",\n \"predict.trade.quoteError\": \"Unable to get quote. Please try again.\",\n \"predict.trade.connectWallet\": \"Connect Wallet\",\n \"predict.trade.submitting\": \"Submitting…\",\n \"predict.trade.submitSuccess\": \"Transaction submitted successfully!\",\n \"predict.trade.submitError\": \"Transaction failed. Please try again.\",\n\n // Order book\n \"predict.orderBook.title\": \"Order Book\",\n \"predict.orderBook.empty\": \"No orders yet\",\n \"predict.orderBook.type\": \"Type\",\n \"predict.orderBook.price\": \"Price\",\n \"predict.orderBook.contracts\": \"Contracts\",\n \"predict.orderBook.qty\": \"Qty\",\n \"predict.orderBook.total\": \"Total\",\n \"predict.orderBook.spread\": \"Spread\",\n\n // Open orders\n \"predict.openOrders.title\": \"Open Orders\",\n \"predict.openOrders.empty\": \"No open orders\",\n \"predict.openOrders.side\": \"Side\",\n \"predict.openOrders.outcome\": \"Outcome\",\n \"predict.openOrders.type\": \"Type\",\n \"predict.openOrders.price\": \"Price\",\n \"predict.openOrders.filled\": \"Filled\",\n \"predict.openOrders.status\": \"Status\",\n \"predict.openOrders.time\": \"Time\",\n \"predict.openOrders.cancel\": \"Cancel\",\n\n // Trade history\n \"predict.tradeHistory.title\": \"Trade History\",\n \"predict.tradeHistory.empty\": \"No trades yet\",\n \"predict.tradeHistory.side\": \"Side\",\n \"predict.tradeHistory.outcome\": \"Outcome\",\n \"predict.tradeHistory.price\": \"Price\",\n \"predict.tradeHistory.qty\": \"Qty\",\n \"predict.tradeHistory.total\": \"Total\",\n \"predict.tradeHistory.fee\": \"Fee\",\n \"predict.tradeHistory.time\": \"Time\",\n\n // Positions\n \"predict.positions.title\": \"Positions\",\n \"predict.positions.empty\": \"No positions\",\n \"predict.positions.market\": \"Market\",\n \"predict.positions.outcome\": \"Outcome\",\n \"predict.positions.qty\": \"Qty\",\n \"predict.positions.avgCost\": \"Avg Cost\",\n \"predict.positions.currentPrice\": \"Price\",\n \"predict.positions.value\": \"Value\",\n \"predict.positions.pnl\": \"P&L\",\n \"predict.positions.totalValue\": \"Total Value\",\n \"predict.positions.unrealizedPnl\": \"Unrealized P&L\",\n \"predict.positions.realizedPnl\": \"Realized P&L\",\n\n // Pagination\n \"predict.pagination.prev\": \"Prev\",\n \"predict.pagination.next\": \"Next\",\n \"predict.pagination.page\": \"Page {{page}}\",\n};\n","export const scaffold = {\n \"scaffold.draggableModal.snapToEdge\": \"Drag to edge to show side panel\",\n \"scaffold.draggablePanel.snapToModal\": \"Drag away to show floating modal\",\n \"scaffold.home\": \"Home\",\n};\n","export const tokens = {\n \"tokens.search.title\": \"Search\",\n \"tokens.search.placeholder\": \"Search by token or CA...\",\n \"tokens.search.history\": \"Search History\",\n \"tokens.search.noResults\": \"No results found\",\n \"tokens.search.hint\": \"Enter token name or contract address to search\",\n \"tokens.copied.address\": \"Token address copied to clipboard\",\n \"tokens.listHeader.token\": \"Token\",\n \"tokens.listHeader.age\": \"Age\",\n \"tokens.listHeader.24hChange\": \"24h%\",\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.mcShort\": \"MC\",\n \"tokens.listHeader.liqShort\": \"Liq\",\n \"tokens.listHeader.volumes\": \"{{resolution}} Volumes\",\n \"tokens.listHeader.txs\": \"{{resolution}} TXNS\",\n \"tokens.listHeader.traders\": \"{{resolution}} Traders\",\n \"tokens.listHeader.bluechip\": \"BlueChip\",\n \"tokens.listHeader.tokenInfo\": \"Token Info\",\n \"tokens.listHeader.actions\": \"Actions\",\n \"tokens.listHeader.filter\": \"Filter\",\n \"tokens.listType.trending\": \"Trending\",\n \"tokens.listType.new\": \"New\",\n \"tokens.listType.stocks\": \"Stocks\",\n \"tokens.filters.protocols.title\": \"Protocols\",\n \"tokens.filters.protocols.selectAll\": \"Select All\",\n \"tokens.filters.protocols.unselectAll\": \"Unselect All\",\n \"tokens.filters.keywords.title\": \"Search Keywords\",\n \"tokens.filters.keywords.exclude.title\": \"Exclude Keywords\",\n \"tokens.filters.keywords.placeholder\": \"keyword1, keyword2...\",\n \"tokens.filters.stats.min\": \"Min\",\n \"tokens.filters.stats.max\": \"Max\",\n \"tokens.filters.stats.audits\": \"Audits\",\n \"tokens.filters.stats.audits.holders\": \"Holders Count\",\n \"tokens.filters.stats.audits.top10HoldingsRatio\": \"Top 10 Holders %\",\n \"tokens.filters.stats.audits.top100HoldingsRatio\": \"Top 100 Holders %\",\n \"tokens.filters.stats.audits.devHoldingsRatio\": \"Dev Holdings %\",\n \"tokens.filters.stats.metrics\": \"Metrics\",\n \"tokens.filters.stats.metrics.volumes\": \"{{resolution}} Volumes ($)\",\n \"tokens.filters.stats.metrics.txns\": \"{{resolution}} Transactions\",\n \"tokens.filters.stats.metrics.liquidity\": \"Liquidity ($)\",\n \"tokens.filters.stats.metrics.marketCap\": \"Market Cap ($)\",\n \"tokens.filters.modal.title\": \"Filters\",\n \"tokens.resolutionSelector.title\": \"Resolution\",\n \"tokens.tokenInfo.holders\": \"Holders\",\n \"tokens.tokenInfo.proHolders\": \"Pro Holders\",\n \"tokens.tokenInfo.kolHolders\": \"KOL Holders\",\n \"tokens.tokenInfo.top10HoldingsRatio\": \"Top 10 Holders\",\n \"tokens.tokenInfo.top100HoldingsRatio\": \"Top 100 Holders\",\n \"tokens.tokenInfo.devHoldingsRatio\": \"Dev Holders\",\n \"tokens.tokenInfo.sniperHoldingsRatio\": \"Snipers\",\n \"tokens.tokenInfo.insiderHoldingsRatio\": \"Insiders\",\n \"tokens.tokenInfo.bundleHoldingsRatio\": \"Bundlers\",\n \"tokens.bluechip.explained\":\n \"BlueChip index is the ratio of holders who also own BlueChip tokens\",\n \"tokens.pulse.new\": \"New\",\n \"tokens.pulse.migrated\": \"Migrated\",\n \"tokens.pulse.finalStretch\": \"Final Stretch\",\n \"tokens.pulse.paused\": \"Paused\",\n \"tokens.pulse.vol\": \"Vol\",\n \"tokens.pulse.txs\": \"Txs\",\n};\n","export const trade = {\n // -- Instant Trade --\n \"trade.market\": \"Market\",\n \"trade.balance\": \"Balance:\",\n \"trade.amount\": \"Amount\",\n \"trade.insufficientBalance\": \"Insufficient balance\",\n \"trade.submitBuyAmount\": \"Buy {{amount}} {{symbol}} ({{usd}})\",\n \"trade.submitSellAmount\": \"Sell {{amount}} {{symbol}} ({{usd}})\",\n \"trade.submitBuyAmountNoUsd\": \"Buy {{amount}} {{symbol}}\",\n \"trade.submitSellAmountNoUsd\": \"Sell {{amount}} {{symbol}}\",\n \"trade.preset.label\": \"Preset {{n}}\",\n \"trade.preset.short\": \"P{{n}}\",\n \"trade.instantTradeAmount\": \"Instant trade amount\",\n\n // -- Preset Form --\n \"trade.preset.slippage\": \"Slippage\",\n \"trade.preset.priorityFee\": \"Priority Fee\",\n \"trade.preset.priorityFee.tooltip\":\n \"Extra fee paid to validators to prioritize your transaction.\",\n \"trade.preset.gasFee\": \"Gas Fee\",\n \"trade.preset.gasFee.tooltip\":\n \"Extra fee paid to validators to prioritize your transaction.\",\n \"trade.preset.tipFee\": \"Tip Fee\",\n \"trade.preset.tipFee.tooltip\":\n \"Additional tip sent alongside the transaction (e.g. Jito tip).\",\n \"trade.preset.autoFee\": \"Auto Fee\",\n \"trade.preset.autoFee.tooltip\":\n \"Automatically estimate optimal fee based on network conditions.\",\n \"trade.preset.maxAutoFee\": \"Max Auto Fee\",\n \"trade.preset.antiMev\": \"Anti-MEV\",\n \"trade.preset.antiMev.tooltip\":\n \"MEV protection shields your transaction from sandwich attacks.\",\n \"trade.preset.antiMev.off\": \"Off\",\n \"trade.preset.antiMev.off.desc\": \"No MEV protection. Fastest execution.\",\n \"trade.preset.antiMev.reduced\": \"Reduced\",\n \"trade.preset.antiMev.reduced.desc\":\n \"Basic MEV protection with minimal impact on execution speed.\",\n \"trade.preset.antiMev.secure\": \"Secure\",\n \"trade.preset.antiMev.secure.desc\":\n \"Full MEV protection. May slightly increase execution time.\",\n \"trade.preset.customRpc\": \"Custom RPC\",\n \"trade.preset.presets\": \"Presets\",\n \"trade.preset.instantTradeSettings\": \"Instant Trade Settings\",\n\n // -- Swap --\n \"trade.swap.from\": \"From\",\n \"trade.swap.to\": \"To\",\n \"trade.swap.selectToken\": \"Select token\",\n \"trade.swap.half\": \"Half\",\n \"trade.swap.swap\": \"Swap\",\n \"trade.swap.swapping\": \"Swapping...\",\n \"trade.swap.findingRoute\": \"Finding route...\",\n \"trade.swap.preview\": \"Preview\",\n \"trade.swap.estimatedReceive\": \"Estimated Receive\",\n \"trade.swap.routeDetails\": \"Route Details\",\n \"trade.swap.dex\": \"DEX\",\n \"trade.swap.fee\": \"Fee\",\n \"trade.swap.showMore\": \"Show More\",\n \"trade.swap.showLess\": \"Show Less\",\n};\n","import { channels } from \"./module/channels\";\nimport { common } from \"./module/common\";\nimport { mediaTrack } from \"./module/mediaTrack\";\nimport { portfolio } from \"./module/portfolio\";\nimport { predict } from \"./module/predict\";\nimport { scaffold } from \"./module/scaffold\";\nimport { tokens } from \"./module/tokens\";\nimport { trade } from \"./module/trade\";\n\nexport const en = {\n ...common,\n ...mediaTrack,\n ...predict,\n ...scaffold,\n ...tokens,\n ...channels,\n ...portfolio,\n ...trade,\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 as I18nInstance } from \"i18next\";\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(\n private readonly i18n: I18nInstance,\n private readonly options?: BackendOptions,\n ) {\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 let paths = this.options.loadPath(lang, ns);\n if (typeof paths === \"string\") paths = [paths];\n if (!paths.length) return;\n\n const urls = paths.filter((path) => {\n const loaded = this.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 this.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 | null>(null);\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(i18n, 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 }, []);\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"]}