@orderly.network/portfolio 2.7.4 → 2.8.0
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.d.mts +3 -2
- package/dist/index.d.ts +3 -2
- package/dist/index.js +18 -18
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +7 -7
- package/dist/index.mjs.map +1 -1
- package/dist/styles.css +1 -1
- package/package.json +18 -18
package/dist/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/layout/context.tsx","../src/pages/overview/assets/assets.script.ts","../src/pages/overview/assets/assetsHeader.tsx","../src/pages/overview/assets/assets.ui.tsx","../src/pages/overview/assets/assets.widget.tsx","../src/pages/overview/assets/index.ts","../src/pages/overview/historyDataGroup/historyDataGroup.script.ts","../src/pages/overview/assetHistory/column.tsx","../src/pages/overview/helper/date.ts","../src/pages/overview/assetHistory/assetHistory.script.ts","../src/pages/overview/assetHistory/assetHistory.ui.tsx","../src/pages/overview/assetHistory/assetHistory.ui.mobile.tsx","../src/pages/overview/assetHistory/assetHistory.widget.tsx","../src/pages/overview/assetHistory/index.tsx","../src/pages/overview/funding/column.tsx","../src/pages/overview/funding/fundingHistory.ui.tsx","../src/pages/overview/funding/fundingHistory.ui.mobile.tsx","../src/pages/overview/funding/useDataSource.script.ts","../src/pages/overview/funding/fundingHistory.widget.tsx","../src/pages/overview/funding/index.tsx","../src/pages/overview/distribution/column.tsx","../src/pages/overview/distribution/distribution.ui.tsx","../src/pages/overview/distribution/distribution.ui.mobile.tsx","../src/pages/overview/distribution/useDataSource.script.ts","../src/pages/overview/distribution/distribution.widget.tsx","../src/pages/overview/distribution/index.tsx","../src/pages/overview/TransferHistory/column.tsx","../src/pages/overview/TransferHistory/transfer.ui.tsx","../src/pages/overview/TransferHistory/useDataSource.script.ts","../src/pages/overview/TransferHistory/transfer.widget.tsx","../src/pages/overview/TransferHistory/index.tsx","../src/pages/overview/VaultsHistory/column.tsx","../src/pages/overview/VaultsHistory/transfer.ui.tsx","../src/pages/overview/VaultsHistory/useDataSource.script.ts","../src/pages/overview/VaultsHistory/vaults.ui.mobile.tsx","../src/pages/overview/VaultsHistory/transfer.widget.tsx","../src/pages/overview/VaultsHistory/index.tsx","../src/pages/overview/historyDataGroup/historyDataGroup.ui.desktop.tsx","../src/hooks/useAccountsData.ts","../src/hooks/useAssetTotalValue.ts","../src/pages/assets/assetsPage/assets.ui.desktop.tsx","../src/hooks/useAccountFilter.ts","../src/hooks/useAssetsAccountFilter.ts","../src/hooks/index.ts","../src/pages/assets/convertPage/convert.script.ts","../src/pages/assets/convertPage/convert.column.tsx","../src/pages/assets/convertPage/convert.ui.desktop.tsx","../src/pages/assets/convertPage/convert.ui.mobile.tsx","../src/pages/assets/convertPage/convert.widget.tsx","../src/pages/overview/historyDataGroup/historyDataGroup.ui.mobile.tsx","../src/pages/overview/historyDataGroup/historyDataGroup.widget.tsx","../src/pages/overview/historyDataGroup/index.ts","../src/pages/overview/provider/overviewContext.tsx","../src/pages/overview/assetChart/assetsChart.script.ts","../src/pages/overview/shared/useAssetHistory.ts","../src/pages/overview/shared/periodHeader.tsx","../src/pages/overview/assetChart/assetsChart.ui.tsx","../src/pages/overview/assetChart/assetsChart.widget.tsx","../src/pages/overview/assetChart/index.ts","../src/pages/overview/performance/performance.ui.tsx","../src/pages/assets/type.ts","../src/pages/overview/performance/performance.script.ts","../src/pages/overview/performance/performance.widget.tsx","../src/pages/overview/performance/index.ts","../src/pages/feeTier/icons/effectiveFee.tsx","../src/pages/feeTier/icons/index.ts","../src/pages/feeTier/feeTierHeader.tsx","../src/pages/api/apiManager.script.tsx","../src/pages/api/dialog/createApiKey.tsx","../src/pages/api/dialog/createdApiKey.tsx","../src/pages/api/dialog/deleteApiKey.tsx","../src/pages/api/dialog/editApiKey.tsx","../src/pages/api/apiManager.ui.tsx","../src/layout/layout.widget.tsx","../src/layout/layout.script.tsx","../src/layout/layout.ui.tsx","../src/layout/layout.ui.mobile.tsx","../src/pages/overview/index.tsx","../src/pages/overview/performanceMobileDialog/performance.ui.tsx","../src/pages/overview/performanceMobileDialog/performance.widget.tsx","../src/pages/overview/provider/overviewProvider.tsx","../src/pages/overview/mobile/useRewardsData.script.ts","../src/pages/overview/main.tsx","../src/pages/overview/mobile/mobile.widget.tsx","../src/pages/overview/portfolioChartsMobile/portfolioChartsMobile.widget.tsx","../src/pages/overview/portfolioChartsMobile/portfolioChartsMobile.script.ts","../src/pages/overview/portfolioChartsMobile/portfolioChartsMobile.ui.tsx","../src/pages/overview/mobile/accountStatus.ui.mobile.tsx","../src/pages/overview/mobile/affiliateCard.ui.mobile.tsx","../src/pages/overview/mobile/portfolioHandle.ui.mobile.tsx","../src/pages/overview/mobile/portfolioVaule.ui.mobile.tsx","../src/pages/overview/mobile/settingRouter.ui.mobile.tsx","../src/pages/overview/mobile/traderCard.ui.mobile.tsx","../src/pages/feeTier/index.tsx","../src/pages/feeTier/feeTier.ui.tsx","../src/pages/feeTier/feeTier.widget.tsx","../src/pages/feeTier/page.tsx","../src/pages/feeTier/feeTier.script.ts","../src/pages/feeTier/column.tsx","../src/pages/feeTier/dataSource.ts","../src/pages/positions/page.tsx","../src/pages/orders/page.tsx","../src/pages/api/index.ts","../src/pages/api/apiManager.widget.tsx","../src/pages/api/apiManager.page.tsx","../src/pages/setting/index.ts","../src/pages/setting/setting.script.tsx","../src/pages/setting/setting.ui.tsx","../src/pages/setting/setting.ui.desktop.tsx","../src/pages/setting/setting.ui.mobile.tsx","../src/pages/setting/setting.widget.tsx","../src/pages/setting/setting.page.tsx","../src/pages/assets/index.tsx","../src/pages/assets/assetsPage/assets.widget.tsx","../src/pages/assets/assetsPage/assets.script.ts","../src/pages/assets/assetsPage/assets.column.tsx","../src/pages/assets/assetsPage/assets.ui.mobile.tsx","../src/pages/assets/page.tsx","../src/pages/history/index.tsx","../src/pages/history/history.page.tsx"],"names":["createContext","useContext","useState","useMemo","jsx","LayoutContext","useLayoutContext","LayoutProvider","init_context","__esmMin","props","routerAdapter","children","sideOpen","setSideOpen","memoizedValue","useCallback","useAccount","useCollateral","useLeverage","useLocalStorage","usePositionStream","useWalletConnector","useAppContext","AccountStatusEnum","modal","useScreen","LeverageWidgetWithDialogId","DepositAndWithdrawWithDialogId","DepositAndWithdrawWithSheetId","TransferDialogId","TransferSheetId","useAssetScript","init_assets_script","connect","namespace","state","isMainAccount","totalValue","freeCollateral","wrongNetwork","disabledConnect","data","curLeverage","visible","setVisible","isMobile","handleDomId","subAccounts","canTrade","onLeverageEdit","onDeposit","onWithdraw","onTransfer","useTranslation","ArrowDownSquareFillIcon","ArrowLeftRightIcon","ArrowUpSquareFillIcon","Button","CardTitle","Flex","jsxs","AssetsHeader","init_assetsHeader","Card","Divider","Grid","Either","Statistic","Text","EyeIcon","gradientTextVariants","EyeCloseIcon","AuthGuard","Fragment","AssetsUI","NoValue","AssetStatistic","init_assets_ui","AssetWidget","init_assets_widget","connectWallet","rest","assets_exports","__export","init_assets","useHistoryDataGroupScript","init_historyDataGroup_script","active","setActive","AssetHistoryStatusEnum","capitalizeFirstLetter","TokenIcon","toast","Decimal","useAssetHistoryColumns","init_column","options","chainsInfo","isDeposit","isWeb3Wallet","t","onCopy","e","txIdColumn","value","record","href","item","accountIdColumn","accountId","recoed","netAmount","differenceInDays","setHours","parseDateRangeForFilter","init_date","dateRange","from","to","getDate","getMonth","getYear","set","useAssetsHistory","useChainInfo","useTokensInfo","useTransferHistory","AssetHistorySideEnum","usePagination","subtractDaysFromCurrentDate","useAssetHistoryScript","init_assetHistory_script","side","today","d","tokensInfo","target","setTarget","setDateRange","page","pageSize","setPage","parsePagination","startTime","endTime","assetData","assetMeta","assetLoading","transferData","transferLoading","transferMeta","onFilter","filter","isLoading","meta","pagination","dataSource","findToken","token","DataFilter","AuthGuardDataTable","AssetHistory","init_assetHistory_ui","queryParameter","columns","Badge","ListView","ArrowRightShortIcon","EmptyDataState","AssetHistoryMobile","init_assetHistory_ui_mobile","loadMore","getStatusText","status","renderHistoryItem","formattedAmount","getTxLink","chainInfo","chain","itemColor","amountView","statusView","timeView","txIdView","accountIdView","AssetHistoryWidget","init_assetHistory_widget","assetHistory_exports","init_assetHistory","useFundingHistoryColumns","index","useSymbolsInfo","FundingHistoryDesktop","init_fundingHistory_ui","symbols","symbol","FundingHistoryMobile","init_fundingHistory_ui_mobile","switchPaymentType","paymentType","useFundingFeeHistory","useFundingHistoryHook","init_useDataSource_script","setSymbol","isValidating","FundingHistoryWidget","init_fundingHistory_widget","funding_exports","init_funding","useColumns","DistributionHistoryDesktop","init_distribution_ui","type","TYPES","DistributionHistoryMobile","init_distribution_ui_mobile","getTypeText","renderItem","useDistributionHistory","useDistributionHistoryHook","setType","DistributionHistoryWidget","init_distribution_widget","distribution_exports","init_distribution","React","capitalizeString","sub","val","subAccount","produce","formatAddress","TransferHistoryUI","init_transfer_ui","selectedAccount","ALL_ACCOUNTS","MAIN_ACCOUNT","memoizedOptions","draft","row","useTransferHistoryHook","date","setAccount","setSide","filteredData","onAccountFilter","TransferHistoryWidget","init_transfer_widget","accountState","TransferHistory_exports","init_TransferHistory","cn","VaultsHistoryUI","useVaultsHistory","useVaultsHistoryHook","onDateRangeFilter","VaultsHistoryMobile","init_vaults_ui_mobile","typeColor","typeText","amountText","VaultsHistoryWidget","VaultsHistory_exports","init_VaultsHistory","useEffect","ArrowLeftRightSquareFill","FeeTierIcon","ServerFillIcon","TabPanel","Tabs","VaultsIcon","LazyAssetHistoryWidget","LazyFundingHistoryWidget","LazyDistributionHistoryWidget","LazyTransferHistoryWidget","LazyVaultsHistoryWidget","HistoryDataGroupDesktop","init_historyDataGroup_ui_desktop","mod","onTabChange","EMPTY_HOLDING","useAccountsData","init_useAccountsData","holding","useIndexPricesStream","isNumber","calculateTotalHolding","useAssetTotalValue","init_useAssetTotalValue","getIndexPrice","total","hol","indexPrice","allAccounts","mainTotalValue","subTotalValue","find","pick","ArrowDownShortIcon","LazyConvertHistoryWidget","TotalValueInfo","DepositAndWithdrawButton","DataFilterSection","AssetsDataTable","AssetsTable","init_assets_ui_desktop","onToggleVisibility","Icon","mergedDisabled","selectedAsset","assetsOptions","ALL_ASSETS","memoizedAssetOptions","dataTableClassNames","classNames","root","scrollRoot","desc","init_useAccountFilter","useAssetsAccountFilter","useAssetsMultiFilter","init_useAssetsAccountFilter","setSelectedAccount","name","setSelectedAsset","accountFiltered","account","filteredChildren","child","init_hooks","useSubAccountQuery","EMPTY_LIST","useConvertScript","init_convert_script","indexPrices","statusFilter","setStatusFilter","convertedAssetFilter","setConvertedAssetFilter","convertedAssetOptions","assetOptions","queryUrl","params","summary","dataRows","totalConversions","totalUSDCReceived","sum","totalFees","detailSum","detail","Tooltip","ConvertedAssetColumn","useConvertColumns","useConvertDetailColumns","init_convert_column","convertedAssets","assets","tooltipContent","asset","onDetailsClick","qty","details","totalHaircut","convertId","haircut","txId","venue","result","DataTable","SimpleDialog","useModal","CONVERT_STATUS_OPTIONS","ConvertDetailsModal","ConvertDesktopUI","init_convert_ui_desktop","onOpenChange","detailColumns","convertState","dataFilter","SimpleSheet","ScrollIndicator","ConvertMobileUI","ConvertMobileField","ConvertMobileItem","ConverHistoryItemDetailsDialog","init_convert_ui_mobile","label","rule","copyable","className","onClick","hide","resolve","reject","convert_widget_exports","ConvertHistoryWidget","init_convert_widget","HistoryDataGroupMobile","init_historyDataGroup_ui_mobile","HistoryDataGroupWidget","init_historyDataGroup_widget","historyDataGroup_exports","init_historyDataGroup","OverviewContext","useOverviewContext","init_overviewContext","useDataTap","useAssetsChartScript","init_assetsChart_script","assetHistory","_data","invisible","useRef","subDays","format","usePrivateQuery","useStatisticsDaily","zero","getUTCStr","year","month","day","PeriodType","useAssetsHistoryData","init_useAssetHistory","localKey","isRealtime","periodTypes","period","setPeriod","convertToUSDCAndOperate","inputs","amount","op","delta","periodLabel","getStartDate","periodValue","startDate","setStartDate","endDate","totalDeposit","transferOutHistory","transferInHistory","allDepositHistory","totalDepositForROI","acc","totalTransferInForROI","onPeriodChange","lastItem","totalTransferIn","totalTransferOut","calculateLastPnl","list","i","calculate","mergeData","calculateData","realtime","calculatedData","aggregateValue","vol","pnl","roi","tail","dataTailIndex","lastAccountValue","createFakeData","start","end","_","periodHeader_exports","PeriodTitle","Select","init_periodHeader","AssetAreaChart","LazyPeriodTitle","AssetsChart","init_assetsChart_ui","AssetsChartWidget","init_assetsChart_widget","assetChart_exports","init_assetChart","PnlAreaChart","PnLBarChart","Box","PerformanceUI","LabelWithHint","PerformancePnL","CumulativePnlChart","init_performance_ui","volumeUpdateDate","curPeriod","hint","ORDERLY_ASSETS_VISIBLE_KEY","init_type","usePerformanceScript","init_performance_script","ctx","PerformanceWidget","init_performance_widget","performance_exports","init_performance","useId","EffectiveFee","init_effectiveFee","ref","linearId","init_icons","feeTierHeader_exports","DesktopHeaderItem","FeeTierHeader","MobileHeaderItem","useFeeState","useScaffoldContext","createElement","isEffective","EffectiveFeeDialog","init_feeTierHeader","interactive","tier","headerDataAdapter","refereeRebate","others","isEffectiveFee","items","mergedData","useApiKeyManager","capitalizeFirstChar","str","useApiManagerScript","init_apiManager_script","filterTags","keyStatus","showCreateDialog","setShowCreateDialog","showCreatedDialog","setShowCreatedDialog","generateKey","setGenerateKey","canCreateApiKey","keys","generateOrderlyKey","setIPRestriction","removeOrderlyKey","resetOrderlyKeyIPRestriction","refresh","error","curPubKey","setCurPubKey","pubKey","onCreateApiKey","onReadApiGuide","hideCreateDialog","doCreate","ipRestriction","scope","createdSuccess","res","ip","key","secretKey","generateKeyRes","err","hideCreatedDialog","onCopyApiKeyInfo","doConfirm","doDelete","curKey","doEdit","future","onCopyAccountId","onCopyApiKey","onCopyApiSecretKey","onCopyIP","keyList","filterTag","filterCurKey","verifyIP","accountStatus","userId","createApiKey_exports","Checkbox","CreateAPIKeyDialog","init_createApiKey","ipText","setIpText","read","setRead","trade","setTrade","setHint","open","scopes","createdApiKey_exports","CreatedAPIKeyDialog","CopyIcon","init_createdApiKey","deleteApiKey_exports","DeleteAPIKeyDialog","Trans","init_deleteApiKey","init_apiManager_ui","setOpen","onDelete","formatKey","editApiKey_exports","EditAPIKeyDialog","init_editApiKey","onUpdate","PlusIcon","AuthGuardEmpty","AuthGuardTooltip","LazyCreateAPIKeyDialog","LazyCreatedAPIKeyDialog","LazyDeleteAPIKeyDialog","LazyEditAPIKeyDialog","APIManager","AccountInfo","Subtitle","KeyList","EditButton","DeleteButton","useMediaQuery","PortfolioLeftSidebarPath","usePortfolioLayoutScript","current","setCurrent","hideSideBar","Scaffold","SideBar","PortfolioLayout","leftSideProps","LeftSidebar","expanded","setExpand","MainNavMobile","BottomNav","PortfolioLayoutMobile","PortfolioLayoutWidget","overview_exports","OverviewPage","OverviewProvider","PerformanceMobileDialogId","PerformanceMobileSheetId","PerformanceMobileUI","PerformanceMobileWidget","AssetLineChart","responsiveProps","i18n","registerSimpleDialog","registerSimpleSheet","useAllBrokers","useConfig","useCurEpochEstimate","useEpochInfo","useGetClaimed","noCacheConfig","DistributionId","TWType","useRewardsData","totalOrderClaimedReward","curEpochEstimate","brokers","mutate","epochList","brokerId","brokerName","lastStete","timerRef","useRewardsDataScript","referralInfo","isSignIn","rewardsData","ENVType","useGetEnv","DepositStatusWidget","usePortfolioChartsState","onPerformanceClick","Area","AreaChart","ChevronRightIcon","PortfolioChartsMobileUI","unrealPnL","unrealROI","colorId","PortfolioChartsMobileWidget","parseJSON","useChains","ChainNamespace","ChainIcon","useCurrentStatus","statusText","EVMChainPopover","chains","MoreIcon","EVMChains","ShowAccount","onCopyAddress","currentNamespace","getLinkDeviceStorage","leftNode","rightNode","bgClass","bg","AccountStatusMobile","description","rootClass","linkDeviceStorage","AffiliateIcon","commifyOptional","AffiliateCardMobile","rebate","CalendarMinusIcon","PortfolioHandleMobile","onGotoHistory","PortfolioValueMobile","SettingFillIcon","SettingRouterMobile","TraderMobileIcon","TraderCardMobile","MobileOverview","portfolioValue","toggleVisible","hasSubAccount","layoutContext","onRouteChange","env","goToClaim","url","navigateToPortfolioHistory","LazyAssetWidget","LazyAssetsChartWidget","LazyPerformanceWidget","LazyHistoryDataGroupWidget","feeTier_exports","FeeTierPage","useFeeTierScript","LazyFeeTierHeader","FeeTierTable","onRow","onCell","internalOnRow","config","internalOnCell","column","isFirstColumn","isLastColumn","FeeTier","FeeTierWidget","useAccountInfo","numberToHumanStyle","textStyle","useFeeTierColumns","volume_min","volume_max","volume_node","findCurrentTier","feeList","futures_taker_fee_rate","futures_maker_fee_rate","takerRate","makerRate","dataAdapter","setTier","cols","volumeStatistics","page_exports","PositionsPage","InfoCircleIcon","LiquidationWidget","PositionHistoryWidget","CombinePositionsWidget","PositionsWidget","tab","setTab","LiquidationTab","OrdersPage","OrdersWidget","sharePnLConfig","ordersRef","onDownload","TooltipIcon","api_exports","APIManagerPage","APIManagerWidget","setting_exports","SettingPage","SettingWidget","useDebouncedCallback","useMutation","useOrderlyContext","ORDERLY_ORDER_SOUND_ALERT_KEY","useSettingScript","update","isMutating","checked","setChecked","notification","soundAlert","setSoundAlert","updateCheckState","setMaintainConfig","maintenance_cancel_order_flag","canTouch","Switch","SettingDesktop","LanguageSwitcherWidget","SettingMobile","Setting","AssetsDataTableWidget","AssetsPage","AssetsTableMobile","AssetsWidget","useAssetsColumns","onConvert","id","useAssetsScript","filtered","enhancedFiltered","accountData","enhancedChildren","tokenInfo","assetValue","collateralRatio","collateralContribution","handleTransfer","handleConvert","showTransfer","assetsColumns","openDepositAndWithdraw","viewName","AccountTag","AssetMobileItem","memoizedAssets","assetsState","history_exports","HistoryPage","HistoryWidget"],"mappings":"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","sourcesContent":["import React, { createContext, useContext, useState, useMemo } from \"react\";\nimport type { RouterAdapter } from \"@orderly.network/ui-scaffold\";\n\ntype LayoutContextValue = {\n sideOpen: boolean;\n onSideOpenChange: (open: boolean) => void;\n routerAdapter?: RouterAdapter;\n};\n\nconst LayoutContext = createContext<LayoutContextValue>({\n sideOpen: true,\n} as LayoutContextValue);\n\nexport const useLayoutContext = () => {\n return useContext(LayoutContext);\n};\n\nexport const LayoutProvider: React.FC<\n React.PropsWithChildren<{ routerAdapter?: RouterAdapter }>\n> = (props) => {\n const { routerAdapter, children } = props;\n const [sideOpen, setSideOpen] = useState(true);\n const memoizedValue = useMemo<LayoutContextValue>(\n () => ({\n sideOpen: sideOpen,\n onSideOpenChange: setSideOpen,\n routerAdapter: routerAdapter,\n }),\n [sideOpen, setSideOpen, routerAdapter],\n );\n return (\n <LayoutContext.Provider value={memoizedValue}>\n {children}\n </LayoutContext.Provider>\n );\n};\n","import { useCallback, useMemo } from \"react\";\nimport {\n useAccount,\n useCollateral,\n useLeverage,\n useLocalStorage,\n usePositionStream,\n useWalletConnector,\n} from \"@orderly.network/hooks\";\nimport { useAppContext } from \"@orderly.network/react-app\";\nimport { AccountStatusEnum } from \"@orderly.network/types\";\nimport { modal, useScreen } from \"@orderly.network/ui\";\nimport { LeverageWidgetWithDialogId } from \"@orderly.network/ui-leverage\";\nimport {\n DepositAndWithdrawWithDialogId,\n DepositAndWithdrawWithSheetId,\n TransferDialogId,\n TransferSheetId,\n} from \"@orderly.network/ui-transfer\";\n\nexport const useAssetScript = () => {\n const { connect, namespace } = useWalletConnector();\n const { state, isMainAccount } = useAccount();\n const { totalValue, freeCollateral } = useCollateral();\n const { wrongNetwork, disabledConnect } = useAppContext();\n const [data] = usePositionStream();\n const { curLeverage } = useLeverage();\n const [visible, setVisible] = useLocalStorage(\"orderly_assets_visible\", true);\n const { isMobile } = useScreen();\n const handleDomId = isMobile\n ? DepositAndWithdrawWithSheetId\n : DepositAndWithdrawWithDialogId;\n const subAccounts = state.subAccounts ?? [];\n\n const canTrade = useMemo(() => {\n return (\n !wrongNetwork &&\n !disabledConnect &&\n (state.status === AccountStatusEnum.EnableTrading ||\n state.status === AccountStatusEnum.EnableTradingWithoutConnected)\n );\n }, [state.status, wrongNetwork, disabledConnect]);\n\n const onLeverageEdit = () => {\n modal.show(LeverageWidgetWithDialogId);\n };\n\n const onDeposit = useCallback(() => {\n modal.show(handleDomId, { activeTab: \"deposit\" });\n }, [handleDomId]);\n\n const onWithdraw = useCallback(() => {\n modal.show(handleDomId, { activeTab: \"withdraw\" });\n }, []);\n\n const onTransfer = useCallback(() => {\n if (isMobile) {\n modal.show(TransferSheetId);\n } else {\n modal.show(TransferDialogId);\n }\n }, [isMobile]);\n\n return {\n canTrade,\n connect,\n portfolioValue: totalValue,\n freeCollateral,\n unrealPnL: data.aggregated.total_unreal_pnl,\n unrealROI: data.totalUnrealizedROI,\n currentLeverage: curLeverage,\n onLeverageEdit,\n visible,\n wrongNetwork,\n toggleVisible: () => setVisible(!visible),\n onDeposit,\n onWithdraw,\n onTransfer,\n namespace,\n isMainAccount,\n hasSubAccount: subAccounts?.length > 0,\n } as const;\n};\n\nexport type AssetScriptReturn = ReturnType<typeof useAssetScript>;\n","import { FC } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n ArrowDownSquareFillIcon,\n ArrowLeftRightIcon,\n ArrowUpSquareFillIcon,\n Button,\n CardTitle,\n Flex,\n} from \"@orderly.network/ui\";\n\ntype Props = {\n disabled: boolean;\n onWithdraw?: () => void;\n onDeposit?: () => void;\n onTransfer?: () => void;\n isMainAccount?: boolean;\n hasSubAccount?: boolean;\n};\n\nexport const AssetsHeader: FC<Props> = (props) => {\n const { t } = useTranslation();\n\n return (\n <Flex justify={\"between\"}>\n <CardTitle>{t(\"common.overview\")}</CardTitle>\n <Flex gap={3}>\n {props.isMainAccount && (\n <Button\n disabled={props.disabled}\n size=\"md\"\n onClick={() => props.onDeposit?.()}\n icon={\n <ArrowDownSquareFillIcon className=\"oui-text-primary-contrast\" />\n }\n data-testid=\"oui-testid-portfolio-assets-deposit-btn\"\n >\n {t(\"common.deposit\")}\n </Button>\n )}\n {props.hasSubAccount && (\n <Button\n disabled={props.disabled}\n size=\"md\"\n color=\"secondary\"\n onClick={() => props.onTransfer?.()}\n icon={<ArrowLeftRightIcon className=\"oui-text-base-contrast\" />}\n >\n {t(\"common.transfer\")}\n </Button>\n )}\n {props.isMainAccount && (\n <Button\n disabled={props.disabled}\n size=\"md\"\n color=\"secondary\"\n onClick={() => props.onWithdraw?.()}\n icon={<ArrowUpSquareFillIcon className=\"oui-text-base-contrast\" />}\n data-testid=\"oui-testid-portfolio-assets-withdraw-btn\"\n >\n {t(\"common.withdraw\")}\n </Button>\n )}\n </Flex>\n </Flex>\n );\n};\n","import React, { FC } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n Card,\n Divider,\n Flex,\n Grid,\n Either,\n Statistic,\n Text,\n EyeIcon,\n gradientTextVariants,\n EditIcon,\n EyeCloseIcon,\n} from \"@orderly.network/ui\";\nimport { AuthGuard } from \"@orderly.network/ui-connector\";\nimport { AssetScriptReturn } from \"./assets.script\";\nimport { AssetsHeader } from \"./assetsHeader\";\n\nexport const AssetsUI: React.FC<\n AssetScriptReturn & { onConnectWallet?: () => void }\n> = (props) => {\n const { t } = useTranslation();\n return (\n <Card\n classNames={{ footer: \"oui-h-[48px]\", root: \"oui-h-[240px]\" }}\n title={\n <AssetsHeader\n disabled={!props.canTrade}\n isMainAccount={props.isMainAccount}\n onDeposit={props.onDeposit}\n onWithdraw={props.onWithdraw}\n onTransfer={props.onTransfer}\n hasSubAccount={props.hasSubAccount}\n />\n }\n >\n <>\n <Statistic\n label={\n <Flex gap={1}>\n <Text intensity={54}>{t(\"common.totalValue\")}</Text>\n <button\n onClick={() => {\n props.toggleVisible();\n }}\n data-testid=\"oui-testid-portfolio-assets-eye-btn\"\n >\n {props.visible ? (\n <EyeIcon size={16} color={\"white\"} />\n ) : (\n <EyeCloseIcon size={16} color={\"white\"} />\n )}\n </button>\n </Flex>\n }\n >\n <Either value={props.canTrade!} left={<NoValue />}>\n <Text.numeral\n visible={props.visible}\n unit=\"USDC\"\n // @ts-ignore\n style={{ \"--oui-gradient-angle\": \"45deg\" }}\n unitClassName=\"oui-text-base oui-text-base-contrast-80 oui-h-9 oui-ml-1\"\n className={gradientTextVariants({\n className: \"oui-font-bold oui-text-3xl\",\n color: \"brand\",\n })}\n >\n {props.portfolioValue ?? \"--\"}\n </Text.numeral>\n </Either>\n </Statistic>\n <Divider className=\"oui-my-4\" intensity={8} />\n <AuthGuard buttonProps={{ size: \"lg\", fullWidth: true }}>\n <AssetStatistic\n unrealROI={props.unrealROI}\n unrealPnL={props.unrealPnL}\n freeCollateral={props.freeCollateral}\n currentLeverage={props.currentLeverage}\n onLeverageEdit={props.onLeverageEdit}\n visible={props.visible}\n />\n </AuthGuard>\n </>\n </Card>\n );\n};\n\nconst NoValue: FC = () => {\n return (\n <Flex gap={1} className={\"oui-h-9\"}>\n <Text.gradient color=\"brand\" weight=\"bold\">\n --\n </Text.gradient>\n <Text>USDC</Text>\n </Flex>\n );\n};\n\ntype AssetStatisticProps = Pick<\n AssetScriptReturn,\n | \"currentLeverage\"\n | \"unrealPnL\"\n | \"unrealROI\"\n | \"freeCollateral\"\n | \"onLeverageEdit\"\n | \"visible\"\n>;\n\nexport const AssetStatistic = (props: AssetStatisticProps) => {\n const { t } = useTranslation();\n\n return (\n <Grid cols={2} className=\"oui-h-12\">\n <Statistic label={t(\"common.unrealizedPnl\")}>\n <Flex>\n <Text.numeral\n coloring\n size=\"lg\"\n weight=\"semibold\"\n visible={props.visible}\n >\n {props.unrealPnL}\n </Text.numeral>\n <Text.numeral\n coloring\n rule=\"percentages\"\n size=\"sm\"\n weight=\"semibold\"\n prefix={\"(\"}\n suffix={\")\"}\n visible={props.visible}\n >\n {props.unrealROI}\n </Text.numeral>\n </Flex>\n </Statistic>\n <Statistic\n label={t(\"portfolio.overview.availableWithdraw\")}\n // @ts-ignore\n align=\"right\"\n // @ts-ignore\n valueProps={{ size: \"lg\", visible: props.visible }}\n >\n {props.freeCollateral}\n </Statistic>\n </Grid>\n );\n};\n","import React from \"react\";\nimport { useAssetScript } from \"./assets.script\";\nimport { AssetsUI } from \"./assets.ui\";\n\nexport const AssetWidget: React.FC = () => {\n const { connect: connectWallet, ...rest } = useAssetScript();\n return (\n <AssetsUI\n // TODO: remove duplicate props\n onConnectWallet={connectWallet}\n connect={connectWallet}\n {...rest}\n />\n );\n};\n","export { useAssetScript } from \"./assets.script\";\nexport { AssetsUI } from \"./assets.ui\";\nexport { AssetWidget } from \"./assets.widget\";\n","import { useState } from \"react\";\n\nexport type TabName =\n | \"deposit\"\n | \"withdraw\"\n | \"funding\"\n | \"distribution\"\n | \"transfer\"\n | \"vaults\";\n\nexport const useHistoryDataGroupScript = () => {\n const [active, setActive] = useState<TabName>(\"deposit\");\n return {\n active,\n onTabChange: setActive as React.Dispatch<React.SetStateAction<string>>,\n } as const;\n};\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { useMemo } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { AssetHistoryStatusEnum } from \"@orderly.network/types\";\nimport {\n capitalizeFirstLetter,\n Text,\n Flex,\n TokenIcon,\n toast,\n type Column,\n} from \"@orderly.network/ui\";\nimport { Decimal } from \"@orderly.network/utils\";\n\ntype Options = {\n chainsInfo: any[];\n isDeposit: boolean;\n isWeb3Wallet: boolean;\n};\n\nexport const useAssetHistoryColumns = (options: Options) => {\n const { chainsInfo, isDeposit, isWeb3Wallet } = options;\n const { t } = useTranslation();\n\n const onCopy = (e: any) => {\n e.preventDefault();\n e.stopPropagation();\n toast.success(t(\"common.copy.copied\"));\n };\n\n const columns = useMemo<Column[]>(() => {\n const txIdColumn: Column = {\n title: t(\"common.txId\"),\n dataIndex: \"tx_id\",\n width: 120,\n render: (value, record) => {\n if (!value) {\n return <div className=\"oui-text-base-contrast-54\">-</div>;\n }\n const chainInfo = chainsInfo?.find(\n (item) => parseInt(record.chain_id) === parseInt(item.chain_id),\n );\n const explorer_base_url = chainInfo?.explorer_base_url;\n const href = `${explorer_base_url}/tx/${value}`;\n return (\n <a href={href} target=\"_blank\" rel=\"noreferrer\">\n {/* <Tooltip content={value} delayDuration={0}> */}\n <Text.formatted\n copyable={!!value}\n rule=\"txId\"\n className=\"oui-underline oui-decoration-line-16 oui-decoration-dashed oui-underline-offset-4\"\n onCopy={onCopy}\n >\n {value}\n </Text.formatted>\n {/* </Tooltip> */}\n </a>\n );\n },\n };\n\n const accountIdColumn: Column = {\n title: t(\"common.accountId\"),\n dataIndex: \"account_id\",\n width: 120,\n render: (value, record) => {\n const accountId = isDeposit\n ? record.from_account_id\n : record.to_account_id;\n\n return (\n <Text.formatted rule=\"address\" copyable={!!accountId} onCopy={onCopy}>\n {accountId}\n </Text.formatted>\n );\n },\n };\n\n return [\n {\n title: t(\"common.token\"),\n dataIndex: \"token\",\n width: 80,\n render: (value) => {\n return (\n <Flex gapX={1}>\n <TokenIcon name={value} size=\"xs\" />\n <span>{value}</span>\n </Flex>\n );\n },\n },\n {\n title: t(\"common.time\"),\n dataIndex: \"created_time\",\n width: 80,\n rule: \"date\",\n },\n isWeb3Wallet ? txIdColumn : accountIdColumn,\n {\n title: t(\"common.status\"),\n dataIndex: \"trans_status\",\n width: 100,\n render: (value, recoed) => {\n value = isWeb3Wallet ? value : recoed.status;\n const statusMap = {\n [AssetHistoryStatusEnum.NEW]: t(\"assetHistory.status.pending\"),\n [AssetHistoryStatusEnum.PENDING]: t(\"assetHistory.status.pending\"),\n [AssetHistoryStatusEnum.CONFIRM]: t(\"assetHistory.status.confirm\"),\n [AssetHistoryStatusEnum.PROCESSING]: t(\n \"assetHistory.status.processing\",\n ),\n [AssetHistoryStatusEnum.COMPLETED]: t(\n \"assetHistory.status.completed\",\n ),\n [AssetHistoryStatusEnum.FAILED]: t(\"assetHistory.status.failed\"),\n };\n return (\n statusMap[value as keyof typeof statusMap] ||\n capitalizeFirstLetter(value?.toLowerCase())\n );\n },\n },\n {\n title: t(\"common.amount\"),\n dataIndex: \"amount\",\n width: 100,\n rule: \"price\",\n render: (value, record) => {\n const netAmount = new Decimal(value).minus(record.fee ?? 0);\n return (\n <Text.numeral\n dp={record.decimals}\n rule=\"price\"\n coloring\n showIdentifier\n padding={false}\n >\n {isDeposit ? netAmount.toNumber() : netAmount.neg().toNumber()}\n </Text.numeral>\n );\n },\n },\n ];\n }, [t, chainsInfo, isDeposit, isWeb3Wallet]);\n\n return columns;\n};\n","import { differenceInDays, setHours } from \"date-fns\";\n\nexport const parseDateRangeForFilter = (dateRange: {\n from: Date;\n to?: Date;\n}) => {\n const { from, to = new Date() } = dateRange;\n\n const diff = differenceInDays(from, to);\n\n if (diff === 0) {\n return [from, setHours(to, 23)];\n }\n\n return [from, to];\n};\n","import { useCallback, useMemo, useState } from \"react\";\nimport { getDate, getMonth, getYear, set } from \"date-fns\";\nimport {\n useAssetsHistory,\n useChainInfo,\n useTokensInfo,\n useTransferHistory,\n} from \"@orderly.network/hooks\";\nimport { AssetHistorySideEnum } from \"@orderly.network/types\";\nimport { modal, usePagination } from \"@orderly.network/ui\";\nimport { DepositAndWithdrawWithSheetId } from \"@orderly.network/ui-transfer\";\nimport { subtractDaysFromCurrentDate } from \"@orderly.network/utils\";\nimport { parseDateRangeForFilter } from \"../helper/date\";\n\nexport enum AssetTarget {\n Web3Wallet = \"Web3Wallet\",\n AccountId = \"AccountId\",\n}\n\nexport type AssetHistoryScriptOptions = {\n side: AssetHistorySideEnum;\n};\n\nexport type AssetHistoryScriptReturn = ReturnType<typeof useAssetHistoryScript>;\n\nexport const useAssetHistoryScript = (options: AssetHistoryScriptOptions) => {\n const { side } = options;\n const isDeposit = side === AssetHistorySideEnum.DEPOSIT;\n\n const [today] = useState(() => {\n const d = new Date();\n return new Date(getYear(d), getMonth(d), getDate(d), 0, 0, 0);\n });\n\n const tokensInfo = useTokensInfo();\n\n const [target, setTarget] = useState<AssetTarget>(AssetTarget.Web3Wallet);\n\n const [dateRange, setDateRange] = useState<Date[]>([\n subtractDaysFromCurrentDate(90, today),\n today,\n ]);\n const { page, pageSize, setPage, parsePagination } = usePagination();\n\n const { startTime, endTime } = useMemo(() => {\n const startTime = dateRange[0].getTime();\n const endTime = set(dateRange[1], {\n hours: 23,\n minutes: 59,\n seconds: 59,\n milliseconds: 0,\n }).getTime();\n\n return { startTime, endTime };\n }, [dateRange]);\n\n const [assetData, { meta: assetMeta, isLoading: assetLoading }] =\n useAssetsHistory(\n {\n startTime,\n endTime,\n page,\n pageSize,\n side,\n },\n {\n shouldUpdateOnWalletChanged: (data) => data.side === side,\n },\n );\n\n const [transferData, { isLoading: transferLoading, meta: transferMeta }] =\n useTransferHistory({\n dataRange: [startTime, endTime],\n side: isDeposit ? \"IN\" : \"OUT\",\n size: pageSize,\n page: page,\n main_sub_only: false,\n });\n\n const { data: chainsInfo } = useChainInfo();\n\n const onFilter = (filter: { name: string; value: any }) => {\n if (filter.name === \"dateRange\") {\n setDateRange(parseDateRangeForFilter(filter.value));\n setPage(1);\n } else if (filter.name === \"target\") {\n setTarget(filter.value);\n setPage(1);\n }\n };\n\n const isLoading = useMemo(() => {\n if (target === AssetTarget.Web3Wallet) {\n return assetLoading;\n }\n return transferLoading;\n }, [target, assetLoading, transferLoading]);\n\n const meta = useMemo(() => {\n if (target === AssetTarget.Web3Wallet) {\n return assetMeta;\n }\n return transferMeta;\n }, [target, assetMeta, transferMeta]);\n\n const pagination = useMemo(\n () => parsePagination(meta),\n [parsePagination, meta],\n );\n\n const dataSource = useMemo(() => {\n return (target === AssetTarget.Web3Wallet ? assetData : transferData).map(\n (item) => {\n const findToken = tokensInfo?.find(({ token }) => token === item.token);\n return {\n ...item,\n decimals: findToken?.decimals ?? 2,\n };\n },\n );\n }, [target, assetData, transferData, tokensInfo]);\n\n const onDeposit = useCallback(() => {\n modal.show(DepositAndWithdrawWithSheetId, { activeTab: \"deposit\" });\n }, []);\n\n const isWeb3Wallet = target === AssetTarget.Web3Wallet;\n\n return {\n dataSource,\n total: meta?.total,\n isLoading,\n queryParameter: {\n target,\n dateRange,\n },\n onFilter,\n pagination,\n onDeposit,\n chainsInfo: chainsInfo as any[],\n isDeposit,\n isWeb3Wallet,\n };\n};\n","import { FC, useMemo } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { DataFilter } from \"@orderly.network/ui\";\nimport { AuthGuardDataTable } from \"@orderly.network/ui-connector\";\nimport {\n AssetTarget,\n type AssetHistoryScriptReturn,\n} from \"./assetHistory.script\";\nimport { useAssetHistoryColumns } from \"./column\";\n\ntype AssetHistoryProps = AssetHistoryScriptReturn;\n\nexport const AssetHistory: FC<AssetHistoryProps> = (props) => {\n const { dataSource, queryParameter, onFilter, isLoading } = props;\n const { dateRange, target } = queryParameter;\n const columns = useAssetHistoryColumns({\n chainsInfo: props.chainsInfo,\n isDeposit: props.isDeposit,\n isWeb3Wallet: props.isWeb3Wallet,\n });\n const { t } = useTranslation();\n\n const options = useMemo(() => {\n return [\n { label: t(\"common.web3Wallet\"), value: AssetTarget.Web3Wallet },\n { label: t(\"common.accountId\"), value: AssetTarget.AccountId },\n ];\n }, [t]);\n\n return (\n <>\n <DataFilter\n items={[\n {\n type: \"select\",\n name: \"target\",\n options: options,\n value: target,\n },\n {\n type: \"range\",\n name: \"dateRange\",\n value: {\n from: dateRange[0],\n to: dateRange[1],\n },\n },\n ]}\n onFilter={(value) => {\n onFilter(value);\n }}\n />\n\n <AuthGuardDataTable\n bordered\n loading={isLoading}\n classNames={{\n root: \"oui-h-[calc(100%_-_49px)]\",\n scroll: \"oui-min-h-[400px]\",\n }}\n columns={columns}\n dataSource={dataSource}\n pagination={props.pagination}\n />\n </>\n );\n};\n","import { FC, useMemo } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { AssetHistoryStatusEnum } from \"@orderly.network/types\";\nimport {\n Badge,\n DataFilter,\n Flex,\n ListView,\n Text,\n capitalizeFirstLetter,\n toast,\n ArrowRightShortIcon,\n EmptyDataState,\n} from \"@orderly.network/ui\";\nimport {\n AssetTarget,\n type AssetHistoryScriptReturn,\n} from \"./assetHistory.script\";\n\ntype AssetHistoryMobileProps = AssetHistoryScriptReturn;\n\nexport const AssetHistoryMobile: FC<AssetHistoryMobileProps> = (props) => {\n const {\n dataSource,\n queryParameter,\n onFilter,\n isLoading,\n pagination,\n onDeposit,\n chainsInfo,\n isDeposit,\n isWeb3Wallet,\n } = props;\n const { dateRange, target } = queryParameter;\n const { t } = useTranslation();\n\n const options = useMemo(() => {\n return [\n { label: t(\"common.web3Wallet\"), value: AssetTarget.Web3Wallet },\n { label: t(\"common.accountId\"), value: AssetTarget.AccountId },\n ];\n }, [t]);\n\n const loadMore = () => {\n if (dataSource.length < (pagination?.count || 0)) {\n pagination?.onPageSizeChange?.(pagination?.pageSize + 50);\n }\n };\n\n const getStatusText = (item: any) => {\n const status = props.isWeb3Wallet ? item.trans_status : item.status;\n const statusMap = {\n [AssetHistoryStatusEnum.NEW]: t(\"assetHistory.status.pending\"),\n [AssetHistoryStatusEnum.PENDING]: t(\"assetHistory.status.pending\"),\n [AssetHistoryStatusEnum.CONFIRM]: t(\"assetHistory.status.confirm\"),\n [AssetHistoryStatusEnum.PROCESSING]: t(\"assetHistory.status.processing\"),\n [AssetHistoryStatusEnum.COMPLETED]: t(\"assetHistory.status.completed\"),\n [AssetHistoryStatusEnum.FAILED]: t(\"assetHistory.status.failed\"),\n };\n return (\n statusMap[status as keyof typeof statusMap] ||\n capitalizeFirstLetter(status?.toLowerCase())\n );\n };\n\n const renderHistoryItem = (item: any) => {\n // Amount formatting\n const formattedAmount = isDeposit\n ? `+${item.amount - (item.fee ?? 0)}`\n : -(item.amount - (item.fee ?? 0));\n\n // Get tx link\n const getTxLink = () => {\n if (!item.tx_id) {\n return undefined;\n }\n\n const chainInfo =\n chainsInfo && Array.isArray(chainsInfo)\n ? chainsInfo.find(\n (chain: any) =>\n parseInt(item.chain_id) === parseInt(chain.chain_id),\n )\n : undefined;\n\n if (chainInfo?.explorer_base_url) {\n return `${chainInfo.explorer_base_url}/tx/${item.tx_id}`;\n }\n\n return undefined;\n };\n\n const onCopy = (e: any) => {\n e.preventDefault();\n e.stopPropagation();\n toast.success(t(\"common.copy.copied\"));\n };\n\n const itemColor = isDeposit ? \"buy\" : \"sell\";\n\n const amountView = (\n <Flex className=\"oui-text-xs\">\n <Text color={itemColor}>{formattedAmount}</Text>\n <Text className=\"oui-ml-1\" intensity={80}>\n {item.token}\n </Text>\n {isWeb3Wallet && (\n <Badge color={itemColor} className=\"oui-ml-2\">\n {isDeposit ? t(\"common.deposit\") : t(\"common.withdraw\")}\n </Badge>\n )}\n </Flex>\n );\n\n const statusView = (\n <Text intensity={isWeb3Wallet ? 80 : 36} size=\"xs\">\n {getStatusText(item)}\n </Text>\n );\n\n const timeView = (\n <Text.formatted rule=\"date\" intensity={36} size=\"2xs\">\n {item.created_time}\n </Text.formatted>\n );\n\n const txIdView = item.tx_id ? (\n <a href={getTxLink()} target=\"_blank\" rel=\"noreferrer\">\n <Text.formatted\n copyable={!!item.tx_id}\n className=\"oui-underline oui-decoration-line-16 oui-decoration-dashed oui-underline-offset-4\"\n rule=\"txId\"\n onCopy={onCopy}\n intensity={36}\n size=\"xs\"\n >\n {item.tx_id}\n </Text.formatted>\n </a>\n ) : (\n <Text intensity={54}>-</Text>\n );\n\n const accountId = isDeposit ? item.from_account_id : item.to_account_id;\n\n const accountIdView = (\n <Flex gapX={1}>\n <Text intensity={36} size=\"xs\">\n {isDeposit\n ? t(\"transfer.internalTransfer.from\")\n : t(\"transfer.internalTransfer.to\")}\n </Text>\n <Text.formatted\n rule=\"address\"\n copyable={!!accountId}\n onCopy={onCopy}\n intensity={80}\n size=\"xs\"\n >\n {accountId}\n </Text.formatted>\n </Flex>\n );\n\n return (\n <Flex\n p={2}\n direction=\"column\"\n gapY={1}\n intensity={900}\n r=\"xl\"\n className=\"oui-font-semibold\"\n >\n <Flex justify=\"between\" width=\"100%\" height=\"18px\">\n {isWeb3Wallet ? (\n <>\n {amountView}\n {statusView}\n </>\n ) : (\n <>\n {accountIdView}\n {amountView}\n </>\n )}\n </Flex>\n\n <Flex justify=\"between\" width=\"100%\" height=\"18px\">\n {timeView}\n {isWeb3Wallet ? txIdView : statusView}\n </Flex>\n </Flex>\n );\n };\n\n return (\n <>\n <DataFilter\n items={[\n {\n type: \"picker\",\n name: \"target\",\n options: options,\n value: target,\n size: \"md\",\n },\n {\n type: \"range\",\n name: \"dateRange\",\n value: {\n from: dateRange[0],\n to: dateRange[1],\n },\n },\n ]}\n onFilter={(value) => {\n onFilter(value);\n }}\n className=\"oui-sticky oui-top-[44px] oui-z-10 oui-border-none oui-bg-base-10 oui-px-3 oui-py-2\"\n />\n\n <ListView\n dataSource={dataSource}\n renderItem={renderHistoryItem}\n contentClassName=\"!oui-space-y-1\"\n loadMore={loadMore}\n isLoading={isLoading}\n className=\"oui-px-1\"\n emptyView={\n <Flex\n direction={\"column\"}\n height={\"100%\"}\n itemAlign={\"center\"}\n justify={\"center\"}\n mt={3}\n >\n <EmptyDataState />\n {dataSource?.length == 0 && (\n <Flex\n direction=\"row\"\n itemAlign=\"center\"\n justify=\"center\"\n onClick={onDeposit}\n className=\"oui-mt-2 oui-h-4 oui-w-full oui-text-secondary\"\n >\n <Text color=\"primary\" size=\"2xs\">\n {t(\"common.deposit\")}\n </Text>\n <ArrowRightShortIcon\n className=\"oui-ml-0.5 oui-size-4 oui-text-primary oui-opacity-100\"\n color=\"primary\"\n size={16}\n opacity={100}\n />\n </Flex>\n )}\n </Flex>\n }\n />\n </>\n );\n};\n","import React from \"react\";\nimport { AssetHistorySideEnum } from \"@orderly.network/types\";\nimport { useScreen } from \"@orderly.network/ui\";\nimport { useAssetHistoryScript } from \"./assetHistory.script\";\nimport { AssetHistory } from \"./assetHistory.ui\";\nimport { AssetHistoryMobile } from \"./assetHistory.ui.mobile\";\n\ntype AssetHistoryWidgetProps = {\n side: AssetHistorySideEnum;\n};\n\nexport const AssetHistoryWidget: React.FC<AssetHistoryWidgetProps> = (\n props,\n) => {\n const state = useAssetHistoryScript({ side: props.side });\n const { isMobile } = useScreen();\n if (isMobile) {\n return <AssetHistoryMobile {...state} />;\n }\n return <AssetHistory {...state} />;\n};\n","export { useAssetHistoryColumns } from \"./column\";\nexport { useAssetHistoryScript } from \"./assetHistory.script\";\nexport { AssetHistory } from \"./assetHistory.ui\";\nexport { AssetHistoryWidget } from \"./assetHistory.widget\";\n","import { useMemo } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { API } from \"@orderly.network/types\";\nimport { Flex, Text, type Column } from \"@orderly.network/ui\";\n\nexport const useFundingHistoryColumns = () => {\n const { t } = useTranslation();\n\n const columns = useMemo(() => {\n return [\n {\n title: t(\"common.symbol\"),\n dataIndex: \"symbol\",\n width: 80,\n rule: \"symbol\",\n textProps: {\n showIcon: true,\n },\n },\n {\n title: t(\"common.time\"),\n dataIndex: \"created_time\",\n width: 120,\n rule: \"date\",\n },\n {\n title: `${t(\"funding.fundingRate\")} / ${t(\"funding.annualRate\")}`,\n dataIndex: \"funding_rate\",\n width: 80,\n render: (value: any, record) => {\n return (\n <Flex gap={1}>\n {/* <span>{`${record.funding_rate * 100}%`}</span> */}\n <Text.numeral rule={\"percentages\"} dp={6}>\n {record.funding_rate}\n </Text.numeral>\n <span>/</span>\n {/* <span>{`${record.annual_rate * 10}%`}</span> */}\n <Text.numeral rule={\"percentages\"} dp={6}>\n {record.annual_rate}\n </Text.numeral>\n </Flex>\n );\n },\n },\n {\n title: t(\"funding.paymentType\"),\n dataIndex: \"payment_type\",\n width: 80,\n render: (value: any) => {\n switch (value) {\n case \"Pay\":\n case \"Paid\":\n return t(\"funding.paymentType.paid\");\n case \"Receive\":\n case \"Received\":\n return t(\"funding.paymentType.received\");\n default:\n return value;\n }\n },\n },\n {\n title: `${t(\"funding.fundingFee\")} (USDC)`,\n dataIndex: \"funding_fee\",\n width: 80,\n rule: \"price\",\n formatter(value, record, index) {\n return Number(value) * -1;\n },\n numeralProps: {\n coloring: true,\n showIdentifier: true,\n ignoreDP: true,\n },\n },\n ] as Column<API.FundingFeeRow & { annual_rate: number }>[];\n }, [t]);\n\n return columns;\n};\n","import { FC, useMemo } from \"react\";\nimport { useSymbolsInfo } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { DataFilter } from \"@orderly.network/ui\";\nimport { AuthGuardDataTable } from \"@orderly.network/ui-connector\";\nimport { useFundingHistoryColumns } from \"./column\";\nimport { type UseFundingHistoryReturn } from \"./useDataSource.script\";\n\ntype FundingHistoryProps = {} & UseFundingHistoryReturn;\n\nexport const FundingHistoryDesktop: FC<FundingHistoryProps> = (props) => {\n const { dataSource, queryParameter, onFilter, isLoading } = props;\n const columns = useFundingHistoryColumns();\n const symbols = useSymbolsInfo();\n const { symbol, dateRange } = queryParameter;\n const { t } = useTranslation();\n\n const options = useMemo(() => {\n return [\n {\n label: t(\"common.all\"),\n value: \"All\",\n },\n ...Object.keys(symbols).map((symbol) => {\n const s = symbol.split(\"_\")[1];\n return {\n label: s,\n value: symbol,\n };\n }),\n ];\n }, [t, symbols]);\n\n return (\n <>\n <DataFilter\n items={[\n {\n type: \"select\",\n name: \"symbol\",\n isCombine: true,\n options,\n value: symbol,\n valueFormatter: (value) => {\n const option = options.find((item) => item.value === value);\n return option?.label || value;\n },\n },\n {\n type: \"range\",\n name: \"dateRange\",\n value: {\n from: dateRange[0],\n to: dateRange[1],\n },\n },\n ]}\n onFilter={(value) => {\n onFilter(value);\n }}\n />\n <AuthGuardDataTable\n bordered\n columns={columns}\n dataSource={dataSource}\n loading={isLoading}\n generatedRowKey={(record) => `${record.updated_time}`}\n classNames={{ root: \"oui-h-[calc(100%_-_49px)]\" }}\n pagination={props.pagination}\n />\n </>\n );\n};\n","import { FC } from \"react\";\nimport { useSymbolsInfo } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { DataFilter, Flex, ListView, Text, Badge } from \"@orderly.network/ui\";\nimport { type UseFundingHistoryReturn } from \"./useDataSource.script\";\n\ntype FundingHistoryProps = {} & UseFundingHistoryReturn;\n\nexport const FundingHistoryMobile: FC<FundingHistoryProps> = (props) => {\n const { dataSource, queryParameter, onFilter, isLoading, pagination } = props;\n const symbols = useSymbolsInfo();\n const { symbol, dateRange } = queryParameter;\n const { t } = useTranslation();\n\n const switchPaymentType = (paymentType: string) => {\n switch (paymentType) {\n case \"Pay\":\n case \"Paid\":\n return t(\"funding.paymentType.paid\");\n case \"Receive\":\n case \"Received\":\n return t(\"funding.paymentType.received\");\n default:\n return paymentType;\n }\n };\n\n const loadMore = () => {\n if (dataSource && dataSource.length < (pagination?.count || 0)) {\n pagination?.onPageSizeChange?.(pagination?.pageSize + 50);\n }\n };\n\n const renderHistoryItem = (item: any) => {\n return (\n <Flex\n p={2}\n direction=\"column\"\n gapY={2}\n className=\"oui-rounded-xl oui-bg-base-9 oui-font-semibold\"\n >\n <Flex direction=\"row\" justify=\"between\" width=\"100%\" height=\"20px\">\n <Text.formatted\n rule=\"symbol\"\n className=\"oui-text-base-contrast oui-mr-1 oui-text-sm\"\n >\n {item.symbol}\n </Text.formatted>\n <Badge color=\"neutral\" size=\"xs\">\n {switchPaymentType(item.payment_type)}\n </Badge>\n <Text.formatted\n rule=\"date\"\n className=\"oui-text-base-contrast-36 oui-text-2xs oui-ml-auto\"\n >\n {item.created_time}\n </Text.formatted>\n </Flex>\n <div className=\"oui-w-full oui-h-[1px] oui-bg-base-6\" />\n <Flex direction=\"row\" justify=\"between\" width=\"100%\">\n <Flex direction=\"column\">\n <Text className=\"oui-text-base-contrast-36 oui-text-2xs\">\n {t(\"funding.fundingRate\")}\n </Text>\n <Text.numeral\n rule={\"percentages\"}\n dp={6}\n className=\"oui-text-base-contrast-80 oui-text-xs\"\n >\n {item.funding_rate}\n </Text.numeral>\n </Flex>\n <Flex direction=\"column\">\n <Text className=\"oui-text-base-contrast-36 oui-text-2xs\">\n {t(\"funding.annualRate\")}\n </Text>\n <Text.numeral\n rule={\"percentages\"}\n dp={6}\n className=\"oui-text-base-contrast-80 oui-text-xs\"\n >\n {item.annual_rate}\n </Text.numeral>\n </Flex>\n <Flex direction=\"column\">\n <Text className=\"oui-text-base-contrast-36 oui-text-2xs\">\n {t(\"funding.fundingFee\")}{\" \"}\n <Text className=\"oui-text-base-contrast-20\">(USDC)</Text>\n </Text>\n <Text.numeral\n dp={6}\n ignoreDP={true}\n coloring={true}\n showIdentifier={true}\n className=\"oui-text-xs oui-self-end\"\n >\n {Number(item.funding_fee) * -1}\n </Text.numeral>\n </Flex>\n </Flex>\n </Flex>\n );\n };\n\n return (\n <>\n <DataFilter\n items={[\n {\n type: \"select\",\n name: \"symbol\",\n isCombine: true,\n options: [\n {\n label: \"All\",\n value: \"All\",\n },\n ...Object.keys(symbols).map((symbol) => {\n const s = symbol.split(\"_\")[1];\n return {\n label: s,\n value: symbol,\n };\n }),\n ],\n value: symbol,\n valueFormatter: (value) => {\n if (value === \"All\") {\n return \"All\";\n }\n return value.split(\"_\")[1];\n },\n },\n {\n type: \"range\",\n name: \"dateRange\",\n value: {\n from: dateRange[0],\n to: dateRange[1],\n },\n },\n ]}\n onFilter={(value) => {\n onFilter(value);\n }}\n className=\"oui-px-3 oui-py-2 oui-sticky oui-top-[44px] oui-z-10 oui-bg-base-10\"\n />\n <ListView\n dataSource={dataSource}\n renderItem={renderHistoryItem}\n contentClassName=\"!oui-space-y-1\"\n loadMore={loadMore}\n isLoading={isLoading}\n className=\"oui-px-1\"\n />\n </>\n );\n};\n","import { useFundingFeeHistory } from \"@orderly.network/hooks\";\nimport { usePagination } from \"@orderly.network/ui\";\nimport { subtractDaysFromCurrentDate } from \"@orderly.network/utils\";\nimport { useMemo, useState } from \"react\";\nimport { parseDateRangeForFilter } from \"../helper/date\";\nimport { getDate, getMonth, getYear, set } from \"date-fns\";\n\nexport const useFundingHistoryHook = () => {\n // const today = useRef(setMinutes(setHours(new Date(), 23), 59));\n\n const [today] = useState(() => {\n const d = new Date();\n\n return new Date(getYear(d), getMonth(d), getDate(d), 0, 0, 0);\n });\n\n const [dateRange, setDateRange] = useState<Date[]>([\n subtractDaysFromCurrentDate(90, today),\n today,\n ]);\n\n const [symbol, setSymbol] = useState<string>(\"All\");\n const { page, pageSize, setPage, parsePagination } = usePagination();\n\n const [data, { isLoading, meta, isValidating }] = useFundingFeeHistory(\n {\n // dataRange: dateRange.map((date) => date.getTime()),\n dataRange: [\n dateRange[0].getTime(),\n set(dateRange[1], {\n hours: 23,\n minutes: 59,\n seconds: 59,\n milliseconds: 0,\n })\n // addDays(dateRange[1], 1)\n .getTime(),\n ],\n symbol,\n page,\n pageSize,\n },\n {\n keepPreviousData: true,\n }\n );\n\n const onFilter = (filter: { name: string; value: any }) => {\n if (filter.name === \"symbol\") {\n setSymbol(filter.value);\n setPage(1);\n }\n\n if (filter.name === \"dateRange\") {\n // setDateRange([filter.value.from, filter.value.to]);\n setDateRange(parseDateRangeForFilter(filter.value));\n setPage(1);\n }\n };\n\n const pagination = useMemo(\n () => parsePagination(meta),\n [parsePagination, meta]\n );\n\n return {\n dataSource: data,\n isLoading,\n isValidating,\n // onDateRangeChange,\n queryParameter: {\n symbol,\n dateRange,\n },\n onFilter,\n pagination,\n } as const;\n};\n\nexport type UseFundingHistoryReturn = ReturnType<typeof useFundingHistoryHook>;\n","import React from \"react\";\nimport { useScreen } from \"@orderly.network/ui\";\nimport { FundingHistoryDesktop } from \"./fundingHistory.ui\";\nimport { FundingHistoryMobile } from \"./fundingHistory.ui.mobile\";\nimport { useFundingHistoryHook } from \"./useDataSource.script\";\n\nexport const FundingHistoryWidget: React.FC = () => {\n const state = useFundingHistoryHook();\n const { isMobile } = useScreen();\n if (isMobile) {\n return <FundingHistoryMobile {...state} />;\n }\n return <FundingHistoryDesktop {...state} />;\n};\n","export { FundingHistoryWidget } from \"./fundingHistory.widget\";\nexport { FundingHistoryDesktop } from \"./fundingHistory.ui\";\nexport { FundingHistoryMobile } from \"./fundingHistory.ui.mobile\";\nexport { useFundingHistoryColumns } from \"./column\";\nexport { useFundingHistoryHook } from \"./useDataSource.script\";\n","import { useMemo } from \"react\";\nimport { useTranslation, i18n } from \"@orderly.network/i18n\";\nimport { API } from \"@orderly.network/types\";\nimport { Flex, type Column, TokenIcon } from \"@orderly.network/ui\";\n\nexport const useColumns = () => {\n const { t } = useTranslation();\n\n const columns = useMemo(() => {\n return [\n {\n title: t(\"common.token\"),\n dataIndex: \"token\",\n width: 80,\n // rule: \"symbol\",\n render: (value, record) => {\n return (\n <Flex gapX={2}>\n <TokenIcon name={value} size=\"xs\" />\n <span>{value}</span>\n </Flex>\n );\n },\n },\n {\n title: t(\"common.time\"),\n dataIndex: \"updated_time\",\n width: 120,\n rule: \"date\",\n },\n {\n title: t(\"common.status\"),\n dataIndex: \"status\",\n width: 120,\n formatter(value, record, index) {\n switch (value) {\n case \"CREATED\":\n case \"SPLIT\":\n return t(\"assetHistory.status.processing\");\n case \"COMPLETED\":\n default:\n return t(\"assetHistory.status.completed\");\n }\n },\n },\n\n {\n title: t(\"common.type\"),\n dataIndex: \"type\",\n width: 80,\n formatter: (value: any) => {\n switch (value) {\n case \"REFERRER_REBATE\":\n return t(\n \"portfolio.overview.distribution.type.referralCommission\",\n );\n case \"REFEREE_REBATE\":\n return t(\"portfolio.overview.distribution.type.refereeRebate\");\n case \"BROKER_FEE\":\n return t(\"portfolio.overview.distribution.type.brokerFee\");\n default:\n return \"-\";\n }\n },\n },\n {\n title: t(\"common.amount\"),\n dataIndex: \"amount\",\n width: 80,\n // rule: \"price\",\n },\n ] as Column<API.FundingFeeRow & { annual_rate: number }>[];\n }, [t]);\n\n return columns;\n};\n","import { FC, useMemo } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { DataFilter } from \"@orderly.network/ui\";\nimport { AuthGuardDataTable } from \"@orderly.network/ui-connector\";\nimport { useColumns } from \"./column\";\nimport { type useDistributionHistoryHookReturn } from \"./useDataSource.script\";\n\ntype FundingHistoryProps = {} & useDistributionHistoryHookReturn;\n\nexport const DistributionHistoryDesktop: FC<FundingHistoryProps> = (props) => {\n const { dataSource, queryParameter, onFilter, isLoading, isValidating } =\n props;\n const columns = useColumns();\n const { type, dateRange } = queryParameter;\n const { t } = useTranslation();\n\n const TYPES = useMemo(() => {\n return [\n { label: t(\"common.all\"), value: \"All\" },\n {\n label: t(\"portfolio.overview.distribution.type.referralCommission\"),\n value: \"REFERRER_REBATE\",\n },\n {\n label: t(\"portfolio.overview.distribution.type.refereeRebate\"),\n value: \"REFEREE_REBATE\",\n },\n {\n label: t(\"portfolio.overview.distribution.type.brokerFee\"),\n value: \"BROKER_FEE\",\n },\n ];\n }, [t]);\n\n return (\n <>\n <DataFilter\n items={[\n {\n type: \"select\",\n name: \"type\",\n options: TYPES,\n value: type,\n },\n {\n type: \"range\",\n name: \"dateRange\",\n value: {\n from: dateRange[0],\n to: dateRange[1],\n },\n },\n ]}\n onFilter={(value) => {\n onFilter(value);\n }}\n />\n <AuthGuardDataTable\n bordered\n columns={columns}\n dataSource={dataSource}\n loading={isLoading}\n // isValidating={isValidating}\n className=\"oui-font-semibold\"\n classNames={{\n root: \"oui-h-[calc(100%_-_49px)]\",\n }}\n pagination={props.pagination}\n />\n </>\n );\n};\n","import { FC, useMemo } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { DataFilter, Flex, Text, TokenIcon } from \"@orderly.network/ui\";\nimport { ListView } from \"@orderly.network/ui\";\nimport { type useDistributionHistoryHookReturn } from \"./useDataSource.script\";\n\ntype FundingHistoryProps = {} & useDistributionHistoryHookReturn;\n\nexport const DistributionHistoryMobile: FC<FundingHistoryProps> = (props) => {\n const { dataSource, queryParameter, onFilter, isLoading, pagination } = props;\n const { type, dateRange } = queryParameter;\n const { t } = useTranslation();\n\n const TYPES = useMemo(() => {\n return [\n { label: t(\"common.all\"), value: \"All\" },\n {\n label: t(\"portfolio.overview.distribution.type.referralCommission\"),\n value: \"REFERRER_REBATE\",\n },\n {\n label: t(\"portfolio.overview.distribution.type.refereeRebate\"),\n value: \"REFEREE_REBATE\",\n },\n {\n label: t(\"portfolio.overview.distribution.type.brokerFee\"),\n value: \"BROKER_FEE\",\n },\n ];\n }, [t]);\n\n const getStatusText = (status: string) => {\n switch (status) {\n case \"CREATED\":\n case \"SPLIT\":\n return t(\"assetHistory.status.processing\") as string;\n case \"COMPLETED\":\n default:\n return t(\"assetHistory.status.completed\") as string;\n }\n };\n\n const getTypeText = (type: string) => {\n switch (type) {\n case \"REFERRER_REBATE\":\n return t(\"portfolio.overview.distribution.type.referralCommission\");\n case \"REFEREE_REBATE\":\n return t(\"portfolio.overview.distribution.type.refereeRebate\");\n case \"BROKER_FEE\":\n return t(\"portfolio.overview.distribution.type.brokerFee\");\n default:\n return \"-\";\n }\n };\n\n const renderItem = (item: any) => {\n return (\n <Flex\n p={2}\n direction=\"column\"\n gapY={2}\n className=\"oui-rounded-xl oui-bg-base-9 oui-font-semibold\"\n >\n <Flex direction=\"row\" justify=\"between\" width=\"100%\" height=\"20px\">\n <Text.formatted\n rule=\"date\"\n className=\"oui-text-2xs oui-text-base-contrast-36\"\n >\n {item.created_time}\n </Text.formatted>\n <Text className=\"oui-text-sm oui-text-base-contrast-80\">\n {getStatusText(item.status)}\n </Text>\n </Flex>\n <div className=\"oui-h-px oui-w-full oui-bg-base-6\" />\n <Flex direction=\"row\" justify=\"between\" width=\"100%\">\n <Flex direction=\"column\">\n <Text className=\"oui-text-2xs oui-text-base-contrast-36\">\n {t(\"common.token\")}\n </Text>\n <Flex gapX={2}>\n <TokenIcon name={item.token} size=\"xs\" />\n <span className=\"oui-text-xs oui-text-base-contrast-80\">\n {item.token}\n </span>\n </Flex>\n </Flex>\n <Flex direction=\"column\">\n <Text className=\"oui-text-2xs oui-text-base-contrast-36\">\n {t(\"common.type\")}\n </Text>\n <Text className=\"oui-text-xs oui-text-base-contrast-80\">\n {getTypeText(item.type)}\n </Text>\n </Flex>\n <Flex direction=\"column\">\n <Text className=\"oui-text-2xs oui-text-base-contrast-36\">\n {t(\"common.amount\")}\n </Text>\n <Text className=\"oui-text-xs oui-text-base-contrast-80\">\n {item.amount}\n </Text>\n </Flex>\n </Flex>\n </Flex>\n );\n };\n\n const loadMore = () => {\n if (dataSource.length < (pagination?.count || 0)) {\n pagination?.onPageSizeChange &&\n pagination.onPageSizeChange(pagination?.pageSize + 50);\n }\n };\n\n return (\n <>\n <DataFilter\n items={[\n {\n type: \"picker\",\n name: \"type\",\n options: TYPES,\n value: type,\n size: \"md\",\n },\n {\n type: \"range\",\n name: \"dateRange\",\n value: {\n from: dateRange[0],\n to: dateRange[1],\n },\n },\n ]}\n onFilter={(value) => {\n onFilter(value);\n }}\n className=\"oui-px-3 oui-py-2 oui-sticky oui-top-[44px] oui-z-10 oui-bg-base-10\"\n />\n <ListView\n dataSource={dataSource}\n renderItem={renderItem}\n contentClassName=\"oui-space-y-1\"\n loadMore={loadMore}\n isLoading={isLoading}\n className=\"oui-px-1\"\n />\n </>\n );\n};\n","import { useDistributionHistory } from \"@orderly.network/hooks\";\nimport { subtractDaysFromCurrentDate } from \"@orderly.network/utils\";\nimport { useMemo, useState } from \"react\";\nimport { usePagination } from \"@orderly.network/ui\";\nimport { parseDateRangeForFilter } from \"../helper/date\";\nimport { getDate, getMonth, getYear, set } from \"date-fns\";\n\nexport const useDistributionHistoryHook = () => {\n // const today = useRef(setMinutes(setHours(new Date(), 23), 59));\n\n const [today] = useState(() => {\n const d = new Date();\n\n return new Date(getYear(d), getMonth(d), getDate(d), 0, 0, 0);\n });\n\n const [dateRange, setDateRange] = useState<Date[]>([\n subtractDaysFromCurrentDate(90, today),\n today,\n ]);\n const [type, setType] = useState<string>(\"All\");\n const { page, pageSize, setPage, parsePagination } = usePagination();\n\n const [data, { isLoading, meta, isValidating }] = useDistributionHistory({\n // dataRange: dateRange.map((date) => date.getTime()),\n dataRange: [\n dateRange[0].getTime(),\n set(dateRange[1], {\n hours: 23,\n minutes: 59,\n seconds: 59,\n milliseconds: 0,\n }).getTime(),\n ],\n type,\n pageSize,\n page,\n });\n\n // console.log(\"----\", isLoading, isValidating);\n\n // const res = useQuery(\"v1/public/info/funding_period\");\n\n const onFilter = (filter: { name: string; value: any }) => {\n if (filter.name === \"type\") {\n setType(filter.value);\n setPage(1);\n }\n\n if (filter.name === \"dateRange\") {\n // setDateRange([filter.value.from, filter.value.to]);\n setDateRange(parseDateRangeForFilter(filter.value));\n setPage(1);\n }\n };\n\n const pagination = useMemo(\n () => parsePagination(meta),\n [parsePagination, meta]\n );\n\n return {\n dataSource: data,\n isLoading,\n isValidating,\n // onDateRangeChange,\n queryParameter: {\n type,\n dateRange,\n },\n onFilter,\n pagination,\n } as const;\n};\n\nexport type useDistributionHistoryHookReturn = ReturnType<\n typeof useDistributionHistoryHook\n>;\n","import React from \"react\";\nimport { useScreen } from \"@orderly.network/ui\";\nimport { DistributionHistoryDesktop } from \"./distribution.ui\";\nimport { DistributionHistoryMobile } from \"./distribution.ui.mobile\";\nimport { useDistributionHistoryHook } from \"./useDataSource.script\";\n\nexport const DistributionHistoryWidget: React.FC = () => {\n const state = useDistributionHistoryHook();\n const { isMobile } = useScreen();\n if (isMobile) {\n return <DistributionHistoryMobile {...state} />;\n }\n return <DistributionHistoryDesktop {...state} />;\n};\n","export { DistributionHistoryWidget } from \"./distribution.widget\";\nexport { DistributionHistoryMobile } from \"./distribution.ui.mobile\";\nexport { DistributionHistoryDesktop } from \"./distribution.ui\";\n","import React from \"react\";\nimport { useAccount } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { API, EMPTY_LIST } from \"@orderly.network/types\";\nimport { Flex, TokenIcon, Text, toast, Badge } from \"@orderly.network/ui\";\nimport type { Column } from \"@orderly.network/ui\";\nimport { capitalizeString } from \"@orderly.network/utils\";\n\nexport const useColumns = () => {\n const { t } = useTranslation();\n const onCopy = () => {\n toast.success(t(\"common.copy.copied\"));\n };\n const { state } = useAccount();\n const sub = state.subAccounts ?? [];\n const columns = React.useMemo<Column<API.TransferHistoryRow>[]>(() => {\n return [\n {\n title: t(\"common.token\"),\n dataIndex: \"token\",\n width: 80,\n render(val: string) {\n return (\n <Flex gapX={2}>\n <TokenIcon name={val} size=\"xs\" />\n <span>{val}</span>\n </Flex>\n );\n },\n },\n {\n title: t(\"common.time\"),\n dataIndex: \"updated_time\",\n width: 120,\n rule: \"date\",\n },\n {\n title: `${t(\"transfer.internalTransfer.from\")} (Account ID)`,\n dataIndex: \"from_account_id\",\n render(val: string) {\n const isMainAccount = val === state.mainAccountId;\n const subAccount = sub.find((item) => item.id === val);\n return (\n <Flex itemAlign=\"start\" py={2} gap={1} direction=\"column\">\n <Text.formatted onCopy={onCopy} copyable rule=\"address\">\n {val}\n </Text.formatted>\n <Badge className=\"oui-select-none\" color=\"neutral\" size=\"xs\">\n {isMainAccount\n ? t(\"common.mainAccount\")\n : subAccount?.description || t(\"common.subAccount\")}\n </Badge>\n </Flex>\n );\n },\n },\n {\n title: `${t(\"transfer.internalTransfer.to\")} (Account ID)`,\n dataIndex: \"to_account_id\",\n render(val: string) {\n const isMainAccount = val === state.mainAccountId;\n const subAccount = sub.find((item) => item.id === val);\n return (\n <Flex itemAlign=\"start\" py={2} gap={1} direction=\"column\">\n <Text.formatted onCopy={onCopy} copyable rule=\"address\">\n {val}\n </Text.formatted>\n <Badge className=\"oui-select-none\" color=\"neutral\" size=\"xs\">\n {isMainAccount\n ? t(\"common.mainAccount\")\n : subAccount?.description || t(\"common.subAccount\")}\n </Badge>\n </Flex>\n );\n },\n },\n {\n title: t(\"common.status\"),\n dataIndex: \"status\",\n width: 120,\n render(val: string) {\n return capitalizeString(val);\n },\n },\n {\n title: t(\"common.amount\"),\n dataIndex: \"amount\",\n width: 80,\n },\n ];\n }, [t, state.mainAccountId, sub]);\n return columns;\n};\n","import React, { useMemo } from \"react\";\nimport { produce } from \"immer\";\nimport { useAccount } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport type { API } from \"@orderly.network/types\";\nimport { DataFilter, formatAddress } from \"@orderly.network/ui\";\nimport { AuthGuardDataTable } from \"@orderly.network/ui-connector\";\nimport type { SelectOption } from \"@orderly.network/ui/src/select/withOptions\";\nimport { useColumns } from \"./column\";\nimport type { useTransferHistoryHookReturn } from \"./useDataSource.script\";\n\ntype HistoryProps = useTransferHistoryHookReturn;\n\nexport enum AccountType {\n ALL = \"All accounts\",\n MAIN = \"Main accounts\",\n}\n\nexport const TransferHistoryUI: React.FC<\n Readonly<HistoryProps & ReturnType<typeof useAccount>>\n> = (props) => {\n const {\n dataSource,\n queryParameter,\n state,\n isMainAccount,\n isLoading,\n selectedAccount,\n onFilter,\n } = props;\n const { side, dateRange } = queryParameter;\n\n const { t } = useTranslation();\n\n const ALL_ACCOUNTS: SelectOption = {\n label: t(\"common.allAccount\"),\n value: AccountType.ALL,\n };\n\n const MAIN_ACCOUNT: SelectOption = {\n label: t(\"common.mainAccount\"),\n value: AccountType.MAIN,\n };\n\n const subAccounts = state.subAccounts ?? [];\n\n const memoizedOptions = useMemo(() => {\n if (Array.isArray(subAccounts) && subAccounts.length) {\n return [\n ALL_ACCOUNTS,\n MAIN_ACCOUNT,\n ...subAccounts.map<SelectOption>((value) => ({\n value: value.id,\n label: value?.description || formatAddress(value?.id),\n })),\n ];\n }\n return [ALL_ACCOUNTS, MAIN_ACCOUNT];\n }, [subAccounts]);\n\n const columns = useColumns();\n\n return (\n <>\n <DataFilter\n onFilter={onFilter}\n items={produce(\n [\n {\n type: \"select\",\n name: \"side\",\n value: side,\n options: [\n { value: \"OUT\", label: \"Outflow\" },\n { value: \"IN\", label: \"Inflow\" },\n ],\n },\n {\n type: \"range\",\n name: \"dateRange\",\n value: {\n from: dateRange[0],\n to: dateRange[1],\n },\n },\n ],\n (draft) => {\n if (isMainAccount) {\n draft.unshift({\n type: \"select\",\n name: \"account\",\n value: selectedAccount as any,\n options: memoizedOptions,\n });\n }\n },\n )}\n />\n <AuthGuardDataTable<API.TransferHistoryRow>\n bordered\n columns={columns}\n dataSource={dataSource}\n loading={isLoading}\n // isValidating={isValidating}\n className=\"oui-font-semibold\"\n classNames={{ root: \"oui-h-[calc(100%_-_49px)]\" }}\n pagination={props.pagination}\n generatedRowKey={(row) => row.id}\n />\n </>\n );\n};\n","import React from \"react\";\nimport { getDate, getMonth, getYear, set } from \"date-fns\";\nimport { useAccount, useTransferHistory } from \"@orderly.network/hooks\";\nimport { usePagination } from \"@orderly.network/ui\";\nimport type { PaginationMeta } from \"@orderly.network/ui\";\nimport { subtractDaysFromCurrentDate } from \"@orderly.network/utils\";\nimport { parseDateRangeForFilter } from \"../helper/date\";\nimport { AccountType } from \"./transfer.ui\";\n\nexport const useTransferHistoryHook = () => {\n // const today = useRef(setMinutes(setHours(new Date(), 23), 59));\n\n const today = React.useMemo<Date>(() => {\n const date = new Date();\n return new Date(getYear(date), getMonth(date), getDate(date), 0, 0, 0);\n }, []);\n\n const [dateRange, setDateRange] = React.useState<Date[]>([\n subtractDaysFromCurrentDate(90, today),\n today,\n ]);\n\n const { page, pageSize, setPage, parsePagination } = usePagination();\n\n const { state } = useAccount();\n\n const [selectedAccount, setAccount] = React.useState<string>(AccountType.ALL);\n\n const [side, setSide] = React.useState<\"IN\" | \"OUT\">(\"OUT\");\n\n const [data, { isLoading, meta }] = useTransferHistory({\n dataRange: [\n dateRange[0]?.getTime(),\n set(dateRange[1], {\n hours: 23,\n minutes: 59,\n seconds: 59,\n milliseconds: 0,\n })?.getTime(),\n ],\n side: side,\n size: pageSize,\n page: page,\n main_sub_only: true,\n });\n\n const filteredData = React.useMemo(() => {\n return data.filter((item) => {\n if (!selectedAccount || selectedAccount === AccountType.ALL) {\n return true;\n }\n if (selectedAccount === AccountType.MAIN) {\n return (\n item.from_account_id === state.mainAccountId ||\n item.to_account_id === state.mainAccountId\n );\n } else {\n return (\n item.from_account_id === selectedAccount ||\n item.to_account_id === selectedAccount\n );\n }\n });\n }, [data, selectedAccount]);\n\n const onAccountFilter = React.useCallback(\n (filter: { value: string; name: string }) => {\n if (filter.name === \"account\") {\n setAccount(filter.value);\n }\n if (filter.name === \"side\") {\n setSide(filter.value as \"IN\" | \"OUT\");\n }\n if (filter.name === \"dateRange\") {\n setDateRange(parseDateRangeForFilter(filter.value as any));\n }\n setPage(1);\n },\n [setPage],\n );\n\n const pagination = React.useMemo<PaginationMeta>(\n () => parsePagination(meta),\n [parsePagination, meta],\n );\n\n return {\n dataSource: filteredData,\n isLoading,\n // onDateRangeChange,\n queryParameter: {\n side,\n dateRange,\n },\n selectedAccount,\n onFilter: onAccountFilter,\n pagination,\n } as const;\n};\n\nexport type useTransferHistoryHookReturn = ReturnType<\n typeof useTransferHistoryHook\n>;\n","import React from \"react\";\nimport { useAccount } from \"@orderly.network/hooks\";\nimport { TransferHistoryUI } from \"./transfer.ui\";\nimport { useTransferHistoryHook } from \"./useDataSource.script\";\n\nexport const TransferHistoryWidget: React.FC = () => {\n const state = useTransferHistoryHook();\n const accountState = useAccount();\n return <TransferHistoryUI {...state} {...accountState} />;\n};\n","export { TransferHistoryWidget } from \"./transfer.widget\";\nexport { TransferHistoryUI } from \"./transfer.ui\";\n","import React from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport type { API } from \"@orderly.network/types\";\nimport { Flex, TokenIcon, Text, cn } from \"@orderly.network/ui\";\nimport type { Column } from \"@orderly.network/ui\";\nimport { capitalizeString } from \"@orderly.network/utils\";\n\nexport const useColumns = () => {\n const { t } = useTranslation();\n const columns = React.useMemo<Column<API.StrategyVaultHistoryRow>[]>(() => {\n return [\n {\n title: t(\"common.type\"),\n dataIndex: \"type\",\n className: (record) => {\n if (record?.type === \"deposit\") {\n return \"oui-text-success\";\n }\n if (record?.type === \"withdrawal\") {\n return \"oui-text-danger\";\n }\n return \"\";\n },\n render(val: string) {\n if (val === \"deposit\") {\n return t(\"common.deposit\");\n }\n if (val === \"withdrawal\") {\n return t(\"common.withdraw\");\n }\n return null;\n },\n },\n {\n title: t(\"portfolio.overview.vaultName\"),\n dataIndex: \"vaultName\",\n },\n {\n title: t(\"common.token\"),\n dataIndex: \"token\",\n render(val: string) {\n return (\n <Flex justify=\"start\" itemAlign=\"center\" gap={2}>\n <TokenIcon name={val} />\n {val}\n </Flex>\n );\n },\n },\n {\n title: t(\"common.time\"),\n dataIndex: \"created_time\",\n rule: \"date\",\n },\n {\n title: t(\"common.status\"),\n dataIndex: \"status\",\n render(val: string) {\n return capitalizeString(val);\n },\n },\n {\n title: t(\"common.amount\"),\n dataIndex: \"amount_change\",\n render(val: number) {\n return (\n <Text.numeral\n showIdentifier\n className={cn(\n \"oui-select-none\",\n val >= 0 ? \"oui-text-success\" : \"oui-text-danger\",\n )}\n >\n {val}\n </Text.numeral>\n );\n },\n },\n ];\n }, [t]);\n return columns;\n};\n","import React from \"react\";\nimport type { API } from \"@orderly.network/types\";\nimport { DataFilter } from \"@orderly.network/ui\";\nimport { AuthGuardDataTable } from \"@orderly.network/ui-connector\";\nimport { useColumns } from \"./column\";\nimport type { useVaultsHistoryHookReturn } from \"./useDataSource.script\";\n\ntype HistoryProps = useVaultsHistoryHookReturn;\n\nexport const VaultsHistoryUI: React.FC<Readonly<HistoryProps>> = (props) => {\n const { dataSource, dateRange, isLoading, onFilter } = props;\n\n const columns = useColumns();\n\n return (\n <>\n <DataFilter\n onFilter={onFilter}\n items={[\n {\n type: \"range\",\n name: \"dateRange\",\n value: {\n from: dateRange[0],\n to: dateRange[1],\n },\n },\n ]}\n />\n <AuthGuardDataTable<API.StrategyVaultHistoryRow>\n bordered\n columns={columns}\n dataSource={dataSource}\n loading={isLoading}\n className=\"oui-font-semibold\"\n classNames={{ root: \"oui-h-[calc(100%_-_49px)]\" }}\n pagination={props.pagination}\n generatedRowKey={(row) => row.id}\n />\n </>\n );\n};\n","import React from \"react\";\nimport { getDate, getMonth, getYear, set } from \"date-fns\";\nimport { useVaultsHistory } from \"@orderly.network/hooks\";\nimport type { API } from \"@orderly.network/types\";\nimport { usePagination } from \"@orderly.network/ui\";\nimport type { PaginationMeta } from \"@orderly.network/ui\";\nimport { subtractDaysFromCurrentDate } from \"@orderly.network/utils\";\nimport { parseDateRangeForFilter } from \"../helper/date\";\n\nexport const useVaultsHistoryHook = () => {\n const today = React.useMemo<Date>(() => {\n const date = new Date();\n return new Date(getYear(date), getMonth(date), getDate(date), 0, 0, 0);\n }, []);\n\n const [dateRange, setDateRange] = React.useState<Date[]>([\n subtractDaysFromCurrentDate(90, today),\n today,\n ]);\n\n const { page, pageSize, setPage, parsePagination } = usePagination();\n\n const [data, { isLoading, meta }] = useVaultsHistory({\n dataRange: [\n dateRange[0]?.getTime(),\n set(dateRange[1], {\n hours: 23,\n minutes: 59,\n seconds: 59,\n milliseconds: 0,\n })?.getTime(),\n ],\n size: pageSize,\n page: page,\n });\n\n const dataSource = React.useMemo(() => {\n if (!Array.isArray(data) || !data.length) {\n return [];\n }\n return data.map<API.StrategyVaultHistoryRow>((item) => ({\n ...item,\n token: \"USDC\", // need to hard code for now\n vaultName: \"Orderly OmniVault\",\n amount_change:\n item.type === \"withdrawal\" ? -item.amount_change : item.amount_change,\n }));\n }, [data]);\n\n const onDateRangeFilter = React.useCallback(\n (filter: { value: string; name: string }) => {\n if (filter.name === \"dateRange\") {\n setDateRange(parseDateRangeForFilter(filter.value as any));\n }\n setPage(1);\n },\n [setPage],\n );\n\n const pagination = React.useMemo<PaginationMeta>(\n () => parsePagination(meta),\n [parsePagination, meta],\n );\n\n return {\n dataSource: dataSource,\n isLoading,\n dateRange,\n onFilter: onDateRangeFilter,\n pagination,\n } as const;\n};\n\nexport type useVaultsHistoryHookReturn = ReturnType<\n typeof useVaultsHistoryHook\n>;\n","import { useTranslation } from \"@orderly.network/i18n\";\nimport { Divider } from \"@orderly.network/ui\";\nimport { DataFilter, TokenIcon, ListView, Text } from \"@orderly.network/ui\";\nimport { useVaultsHistoryHookReturn } from \"./useDataSource.script\";\n\nexport const VaultsHistoryMobile = (props: useVaultsHistoryHookReturn) => {\n const { dateRange, onFilter, dataSource, isLoading, pagination } = props;\n const { t } = useTranslation();\n\n const loadMore = () => {\n if (dataSource.length < (pagination?.count || 0)) {\n pagination?.onPageSizeChange?.(pagination?.pageSize + 50);\n }\n };\n\n const renderHistoryItem = (item: any) => {\n const typeColor = item.type === \"deposit\" ? \"buy\" : \"sell\";\n const typeText =\n item.type === \"deposit\" ? t(\"common.deposit\") : t(\"common.withdraw\");\n const amountText = item.amount_change ? Math.abs(item.amount_change) : \"-\";\n return (\n <div className=\"oui-flex oui-flex-col oui-rounded-xl oui-bg-base-9 oui-p-2 oui-font-semibold\">\n <div className=\"oui-flex oui-items-center oui-justify-between oui-text-sm oui-text-base-contrast-80\">\n <div>{item.vaultName}</div>\n <div>\n {item.status?.slice(0, 1).toUpperCase() + item.status?.slice(1)}\n </div>\n </div>\n <Text.formatted rule=\"date\" intensity={36} size=\"2xs\">\n {item.created_time}\n </Text.formatted>\n <Divider className=\"oui-my-2\" />\n <div className=\"oui-flex oui-items-center [&>div]:oui-flex-1 [&>div]:oui-text-2xs [&>div]:oui-text-base-contrast-36\">\n <div>\n <div>{t(\"common.token\")}</div>\n <div className=\"oui-flex oui-items-center oui-gap-1 oui-text-xs oui-text-base-contrast-80\">\n <TokenIcon name={\"USDC\"} size=\"2xs\" />\n <Text>USDC</Text>\n </div>\n </div>\n <div>\n <div>{t(\"common.type\")}</div>\n <Text color={typeColor} className=\"oui-text-xs\">\n {typeText}\n </Text>\n </div>\n <div className=\"oui-text-right\">\n <div>{t(\"common.amount\")}</div>\n <div className=\"oui-text-xs oui-text-base-contrast-80\">\n {amountText}\n </div>\n </div>\n </div>\n </div>\n );\n };\n\n return (\n <>\n <DataFilter\n items={[\n {\n type: \"range\",\n name: \"dateRange\",\n value: {\n from: dateRange[0],\n to: dateRange[1],\n },\n },\n ]}\n onFilter={(value) => {\n onFilter(value);\n }}\n className=\"oui-sticky oui-top-[44px] oui-z-10 oui-border-none oui-bg-base-10 oui-px-3 oui-py-2\"\n />\n <ListView\n dataSource={dataSource}\n renderItem={renderHistoryItem}\n contentClassName=\"!oui-space-y-1\"\n loadMore={loadMore}\n isLoading={isLoading}\n className=\"oui-px-1\"\n />\n </>\n );\n};\n","import React from \"react\";\nimport { useScreen } from \"@orderly.network/ui\";\nimport { VaultsHistoryUI } from \"./transfer.ui\";\nimport { useVaultsHistoryHook } from \"./useDataSource.script\";\nimport { VaultsHistoryMobile } from \"./vaults.ui.mobile\";\n\nexport const VaultsHistoryWidget: React.FC = () => {\n const state = useVaultsHistoryHook();\n const { isMobile } = useScreen();\n if (isMobile) {\n return <VaultsHistoryMobile {...state} />;\n }\n return <VaultsHistoryUI {...state} />;\n};\n","export { VaultsHistoryWidget } from \"./transfer.widget\";\nexport { VaultsHistoryUI } from \"./transfer.ui\";\n","import React, { useEffect } from \"react\";\nimport { useAccount } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { AssetHistorySideEnum } from \"@orderly.network/types\";\nimport {\n ArrowDownSquareFillIcon,\n ArrowLeftRightSquareFill,\n ArrowUpSquareFillIcon,\n Card,\n FeeTierIcon,\n ServerFillIcon,\n TabPanel,\n Tabs,\n VaultsIcon,\n} from \"@orderly.network/ui\";\nimport type { TabName } from \"./historyDataGroup.script\";\n\nconst LazyAssetHistoryWidget = React.lazy(() =>\n import(\"../assetHistory\").then((mod) => {\n return { default: mod.AssetHistoryWidget };\n }),\n);\n\nconst LazyFundingHistoryWidget = React.lazy(() =>\n import(\"../funding\").then((mod) => {\n return { default: mod.FundingHistoryWidget };\n }),\n);\n\nconst LazyDistributionHistoryWidget = React.lazy(() =>\n import(\"../distribution\").then((mod) => {\n return { default: mod.DistributionHistoryWidget };\n }),\n);\n\nconst LazyTransferHistoryWidget = React.lazy(() =>\n import(\"../TransferHistory\").then((mod) => {\n return { default: mod.TransferHistoryWidget };\n }),\n);\n\nconst LazyVaultsHistoryWidget = React.lazy(() =>\n import(\"../VaultsHistory\").then((mod) => {\n return { default: mod.VaultsHistoryWidget };\n }),\n);\n\nexport const HistoryDataGroupDesktop: React.FC<{\n active?: TabName;\n onTabChange: (tab: string) => void;\n}> = (props) => {\n const { active = \"deposit\", onTabChange } = props;\n const { t } = useTranslation();\n const { isMainAccount } = useAccount();\n useEffect(() => {\n if (active === \"vaults\" && !isMainAccount) {\n onTabChange(\"deposit\");\n }\n }, [active, isMainAccount]);\n return (\n <Card>\n <Tabs\n value={active}\n onValueChange={onTabChange}\n variant=\"contained\"\n size=\"xl\"\n >\n <TabPanel\n title={t(\"common.deposits\")}\n icon={<ArrowDownSquareFillIcon />}\n value={\"deposit\"}\n >\n <React.Suspense fallback={null}>\n <LazyAssetHistoryWidget side={AssetHistorySideEnum.DEPOSIT} />\n </React.Suspense>\n </TabPanel>\n <TabPanel\n title={t(\"common.withdrawals\")}\n icon={<ArrowUpSquareFillIcon />}\n value={\"withdraw\"}\n >\n <React.Suspense fallback={null}>\n <LazyAssetHistoryWidget side={AssetHistorySideEnum.WITHDRAW} />\n </React.Suspense>\n </TabPanel>\n <TabPanel\n title={t(\"common.funding\")}\n icon={<FeeTierIcon />}\n value={\"funding\"}\n >\n <React.Suspense fallback={null}>\n <LazyFundingHistoryWidget />\n </React.Suspense>\n </TabPanel>\n <TabPanel\n title={t(\"portfolio.overview.distribution\")}\n icon={<ServerFillIcon />}\n value={\"distribution\"}\n >\n <React.Suspense fallback={null}>\n <LazyDistributionHistoryWidget />\n </React.Suspense>\n </TabPanel>\n <TabPanel\n title={t(\"portfolio.overview.transferHistory\")}\n icon={<ArrowLeftRightSquareFill />}\n value={\"transfer\"}\n >\n <React.Suspense fallback={null}>\n <LazyTransferHistoryWidget />\n </React.Suspense>\n </TabPanel>\n {isMainAccount && (\n <TabPanel\n value={\"vaults\"}\n icon={<VaultsIcon />}\n title={t(\"portfolio.overview.vaults\")}\n >\n <React.Suspense fallback={null}>\n <LazyVaultsHistoryWidget />\n </React.Suspense>\n </TabPanel>\n )}\n </Tabs>\n </Card>\n );\n};\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { useMemo } from \"react\";\nimport { produce } from \"immer\";\nimport { useAccount, useCollateral } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport type { API } from \"@orderly.network/types\";\n\nconst EMPTY_HOLDING: Partial<API.Holding> = {\n token: \"USDC\",\n holding: 0,\n frozen: 0,\n};\n\n// Account data structure used in assets display\nexport interface AccountWithChildren {\n account_id: string;\n id?: string;\n description?: string;\n children: Array<API.Holding & { account_id: string }>;\n}\n\n// Hook to transform raw account data into display format\nexport const useAccountsData = (): AccountWithChildren[] => {\n const { t } = useTranslation();\n const { state, isMainAccount } = useAccount();\n const { holding = [] } = useCollateral();\n const subAccounts = state.subAccounts ?? [];\n\n return useMemo(() => {\n return produce<any[]>(subAccounts, (draft) => {\n // Process sub accounts\n for (const sub of draft) {\n sub.account_id = sub.id;\n if (Array.isArray(sub.holding) && sub.holding.length) {\n sub.children = sub.holding.map((item: API.Holding) => ({\n ...item,\n account_id: sub.id,\n }));\n } else {\n sub.children = [{ ...EMPTY_HOLDING, account_id: sub.id }];\n }\n // Remove original holding to avoid confusion\n Reflect.deleteProperty(sub, \"holding\");\n }\n\n // Add main account at the beginning if user is main account\n if (isMainAccount) {\n draft.unshift({\n account_id: state.mainAccountId!,\n description: t(\"common.mainAccount\"),\n children:\n Array.isArray(holding) && holding.length\n ? holding.map((item: API.Holding) => ({\n ...item,\n account_id: state.mainAccountId!,\n }))\n : [\n {\n ...EMPTY_HOLDING,\n account_id: state.mainAccountId!,\n },\n ],\n });\n }\n });\n }, [holding, subAccounts, isMainAccount, state.mainAccountId, t]);\n};\n","import { useMemo } from \"react\";\nimport {\n useAccount,\n useCollateral,\n useIndexPricesStream,\n} from \"@orderly.network/hooks\";\nimport { SubAccount } from \"@orderly.network/hooks\";\nimport { Decimal } from \"@orderly.network/utils\";\nimport { useAccountsData } from \"./useAccountsData\";\n\nconst isNumber = (val: unknown): val is number => {\n return typeof val === \"number\" && !Number.isNaN(val);\n};\n\nexport const calculateTotalHolding = (\n data: SubAccount[] | SubAccount[\"holding\"],\n getIndexPrice: (token: string) => number,\n) => {\n let total = new Decimal(0);\n for (const item of data) {\n if (Array.isArray(item.holding)) {\n for (const hol of item.holding) {\n if (isNumber(hol.holding)) {\n const indexPrice = getIndexPrice(hol.token);\n total = total.plus(new Decimal(hol.holding).mul(indexPrice));\n }\n }\n } else if (isNumber(item.holding) && \"token\" in item) {\n const indexPrice = getIndexPrice(item.token);\n total = total.plus(new Decimal(item.holding).mul(indexPrice));\n }\n }\n return total;\n};\n\nexport const useAssetTotalValue = () => {\n const { state, isMainAccount } = useAccount();\n const { holding = [] } = useCollateral();\n const { getIndexPrice } = useIndexPricesStream();\n const allAccounts = useAccountsData();\n\n const subAccounts = state.subAccounts ?? [];\n\n // Calculate main account total value\n const mainTotalValue = useMemo<Decimal>(\n () => calculateTotalHolding(holding, getIndexPrice),\n [holding, getIndexPrice],\n );\n\n // Calculate sub accounts total value\n const subTotalValue = useMemo<Decimal>(\n () => calculateTotalHolding(subAccounts, getIndexPrice),\n [subAccounts, getIndexPrice],\n );\n\n // Calculate final total value\n const totalValue = useMemo<number>(() => {\n if (isMainAccount) {\n return mainTotalValue.plus(subTotalValue).toNumber();\n } else {\n const find = allAccounts.find((item) => item.id === state.accountId);\n if (Array.isArray(find?.children)) {\n return calculateTotalHolding(find.children, getIndexPrice).toNumber();\n }\n return 0;\n }\n }, [\n isMainAccount,\n mainTotalValue,\n subTotalValue,\n allAccounts,\n state.accountId,\n getIndexPrice,\n ]);\n\n return totalValue;\n};\n","import React, { useMemo } from \"react\";\nimport pick from \"ramda/es/pick\";\nimport { SubAccount } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { useAppContext } from \"@orderly.network/react-app\";\nimport {\n Text,\n Card,\n Flex,\n gradientTextVariants,\n EyeIcon,\n EyeCloseIcon,\n cn,\n DataFilter,\n formatAddress,\n Tabs,\n TabPanel,\n ArrowDownShortIcon,\n Button,\n DataTableClassNames,\n} from \"@orderly.network/ui\";\nimport { AuthGuardDataTable } from \"@orderly.network/ui-connector\";\nimport type { SelectOption } from \"@orderly.network/ui/src/select/withOptions\";\nimport type { useAssetsScriptReturn } from \"./assets.script\";\nimport type {\n AssetsDataTableWidgetProps,\n AssetsWidgetProps,\n} from \"./assets.widget\";\n\nconst LazyConvertHistoryWidget = React.lazy(() =>\n import(\"../convertPage/convert.widget\").then((mod) => {\n return { default: mod.ConvertHistoryWidget };\n }),\n);\n\nexport type AssetsProps = useAssetsScriptReturn;\n\nexport enum AccountType {\n ALL = \"All accounts\",\n MAIN = \"Main accounts\",\n}\n\nconst TotalValueInfo: React.FC<\n Readonly<\n Pick<AssetsWidgetProps, \"totalValue\" | \"visible\" | \"onToggleVisibility\">\n >\n> = (props) => {\n const { totalValue, visible, onToggleVisibility } = props;\n const { t } = useTranslation();\n const Icon = visible ? EyeIcon : EyeCloseIcon;\n return (\n <Flex direction=\"column\" gap={1} className=\"oui-text-2xs\" itemAlign=\"start\">\n <Flex gap={1} justify=\"start\" itemAlign=\"center\">\n <Text size=\"2xs\" color=\"neutral\" weight=\"semibold\">\n {t(\"common.totalValue\")}\n </Text>\n <button onClick={onToggleVisibility}>\n <Icon size={18} className={cn(\"oui-text-base-contrast-54\")} />\n </button>\n </Flex>\n <Flex justify={\"start\"} itemAlign=\"end\" gap={1}>\n <Text.numeral\n visible={visible}\n weight=\"bold\"\n size=\"2xl\"\n className={gradientTextVariants({ color: \"brand\" })}\n as=\"div\"\n padding={false}\n dp={2}\n >\n {totalValue ?? \"--\"}\n </Text.numeral>\n <Text as=\"div\" weight=\"bold\">\n USDC\n </Text>\n </Flex>\n </Flex>\n );\n};\n\nconst DepositAndWithdrawButton: React.FC<\n Readonly<\n Pick<AssetsWidgetProps, \"isMainAccount\" | \"onWithdraw\" | \"onDeposit\">\n >\n> = (props) => {\n const { t } = useTranslation();\n const { isMainAccount, onWithdraw, onDeposit } = props;\n const { wrongNetwork, disabledConnect } = useAppContext();\n if (!isMainAccount) {\n return null;\n }\n const mergedDisabled = wrongNetwork || disabledConnect;\n return (\n <Flex\n className=\"oui-text-2xs oui-text-base-contrast-54\"\n itemAlign=\"center\"\n gap={3}\n >\n <Button\n disabled={mergedDisabled}\n data-testid=\"oui-testid-assetView-deposit-button\"\n fullWidth\n size=\"md\"\n onClick={onDeposit}\n >\n <ArrowDownShortIcon\n color=\"white\"\n opacity={mergedDisabled ? 0.4 : 1}\n className=\"oui-rotate-0 oui-text-primary-contrast\"\n />\n <Text>{t(\"common.deposit\")}</Text>\n </Button>\n <Button\n fullWidth\n disabled={mergedDisabled}\n color=\"secondary\"\n size=\"md\"\n onClick={onWithdraw}\n data-testid=\"oui-testid-assetView-withdraw-button\"\n >\n <ArrowDownShortIcon\n color=\"white\"\n opacity={mergedDisabled ? 0.4 : 1}\n className=\"oui-rotate-180 oui-text-base-contrast\"\n />\n <Text>{t(\"common.withdraw\")}</Text>\n </Button>\n </Flex>\n );\n};\n\nconst DataFilterSection: React.FC<\n Pick<\n AssetsWidgetProps,\n | \"isMainAccount\"\n | \"onFilter\"\n | \"selectedAccount\"\n | \"selectedAsset\"\n | \"assetsOptions\"\n | \"state\"\n >\n> = (props) => {\n const { t } = useTranslation();\n const {\n isMainAccount,\n onFilter,\n selectedAccount,\n selectedAsset,\n assetsOptions,\n state,\n } = props;\n\n const ALL_ACCOUNTS: SelectOption = {\n label: t(\"common.allAccount\"),\n value: AccountType.ALL,\n };\n\n const MAIN_ACCOUNT: SelectOption = {\n label: t(\"common.mainAccount\"),\n value: AccountType.MAIN,\n };\n\n const ALL_ASSETS: SelectOption = {\n label: t(\"common.allAssets\", \"All assets\"),\n value: \"all\",\n };\n\n const subAccounts = useMemo<SubAccount[]>(() => {\n return state.subAccounts ?? [];\n }, [state.subAccounts]);\n\n const memoizedOptions = useMemo(() => {\n if (Array.isArray(subAccounts) && subAccounts.length) {\n return [\n ALL_ACCOUNTS,\n MAIN_ACCOUNT,\n ...subAccounts.map<SelectOption>((value) => ({\n value: value?.id,\n label: value?.description || formatAddress(value?.id),\n })),\n ];\n }\n return [ALL_ACCOUNTS, MAIN_ACCOUNT];\n }, [ALL_ACCOUNTS, MAIN_ACCOUNT, subAccounts]);\n\n const memoizedAssetOptions = useMemo(() => {\n return [ALL_ASSETS, ...assetsOptions];\n }, [ALL_ASSETS, assetsOptions]);\n\n if (!isMainAccount) {\n return null;\n }\n\n return (\n <DataFilter\n className=\"oui-border-none oui-py-0\"\n onFilter={onFilter}\n items={[\n {\n type: \"select\",\n name: \"account\",\n value: selectedAccount,\n options: memoizedOptions,\n },\n {\n type: \"select\",\n name: \"asset\",\n value: selectedAsset,\n options: memoizedAssetOptions,\n },\n ]}\n />\n );\n};\n\nexport const AssetsDataTable: React.FC<\n Pick<\n AssetsWidgetProps,\n | \"columns\"\n | \"dataSource\"\n | \"isMainAccount\"\n | \"onFilter\"\n | \"selectedAccount\"\n | \"selectedAsset\"\n | \"assetsOptions\"\n | \"state\"\n > &\n AssetsDataTableWidgetProps\n> = (props) => {\n const { columns, dataSource, dataTableClassNames, classNames } = props;\n const { root, scrollRoot, desc } = classNames ?? {};\n return (\n <Flex width=\"100%\" height=\"100%\" direction={\"column\"} className={root}>\n <DataFilterSection\n {...pick(\n [\n \"isMainAccount\",\n \"onFilter\",\n \"selectedAccount\",\n \"selectedAsset\",\n \"assetsOptions\",\n \"state\",\n ],\n props,\n )}\n />\n {dataSource.map((item, index) => {\n return (\n <Flex\n key={`item-${index}`}\n className={cn(\"oui-rounded-xl oui-bg-base-9 oui-p-6\", scrollRoot)}\n direction={\"column\"}\n itemAlign={\"start\"}\n justify={\"between\"}\n my={4}\n >\n <Text\n className={cn(\"oui-mb-4\", desc)}\n intensity={98}\n weight=\"semibold\"\n size=\"lg\"\n >\n {item?.description || formatAddress(item?.id ?? \"\")}\n </Text>\n <AuthGuardDataTable\n bordered\n className=\"oui-font-semibold\"\n classNames={{\n root: \"oui-bg-transparent\",\n scroll: \"oui-min-h-0\",\n ...dataTableClassNames,\n }}\n columns={columns}\n dataSource={item.children}\n />\n </Flex>\n );\n })}\n </Flex>\n );\n};\n\nexport const AssetsTable: React.FC<AssetsWidgetProps> = (props) => {\n const { t } = useTranslation();\n return (\n <Card\n className={\"oui-bg-transparent oui-p-0\"}\n classNames={{ content: \"!oui-pt-0\" }}\n >\n <Tabs\n defaultValue=\"assets\"\n variant=\"contained\"\n classNames={{ tabsList: \"\" }}\n size=\"lg\"\n >\n <TabPanel value=\"assets\" className=\"\" title={t(\"common.assets\")}>\n <Flex\n className=\"oui-rounded-xl oui-bg-base-9 oui-p-6\"\n direction={\"row\"}\n itemAlign={\"center\"}\n justify={\"between\"}\n my={4}\n >\n <TotalValueInfo\n {...pick([\"totalValue\", \"visible\", \"onToggleVisibility\"], props)}\n />\n <DepositAndWithdrawButton\n {...pick([\"isMainAccount\", \"onDeposit\", \"onWithdraw\"], props)}\n />\n </Flex>\n <AssetsDataTable\n {...pick(\n [\n \"columns\",\n \"dataSource\",\n \"isMainAccount\",\n \"onFilter\",\n \"selectedAccount\",\n \"selectedAsset\",\n \"assetsOptions\",\n \"state\",\n ],\n props,\n )}\n classNames={{\n scrollRoot:\n \"oui-max-h-[700px] oui-overflow-y-auto oui-custom-scrollbar oui-w-full\",\n }}\n />\n </TabPanel>\n <TabPanel\n value=\"convertHistory\"\n className=\"oui-rounded-xl oui-bg-base-9 oui-px-6\"\n title={t(\"portfolio.overview.tab.convert.history\")}\n >\n <React.Suspense fallback={null}>\n <LazyConvertHistoryWidget />\n </React.Suspense>\n </TabPanel>\n </Tabs>\n </Card>\n );\n};\n","import { useMemo } from \"react\";\nimport { useAccount } from \"@orderly.network/hooks\";\nimport { AccountType } from \"../pages/assets/assetsPage/assets.ui.desktop\";\n\n// Account filter function type\nexport type AccountFilterFunction<T = any> = (\n data: T[],\n selectedAccount: string,\n accountState: ReturnType<typeof useAccount>,\n) => T[];\n\n// Generic account filter utility\nexport const createAccountFilter = <T extends { account_id?: string }>(\n getAccountId?: (item: T) => string | undefined,\n): AccountFilterFunction<T> => {\n return (data, selectedAccount, accountState) => {\n const { state, isMainAccount } = accountState;\n\n return data.filter((item) => {\n const accountId = getAccountId ? getAccountId(item) : item.account_id;\n\n if (isMainAccount) {\n if (!selectedAccount || selectedAccount === AccountType.ALL) {\n return true;\n }\n if (selectedAccount === AccountType.MAIN) {\n return accountId === state.mainAccountId;\n } else {\n return accountId === selectedAccount;\n }\n } else {\n return accountId === state.accountId;\n }\n });\n };\n};\n\n// Hook for standard account-based data filtering\nexport const useAccountFilter = <T extends { account_id?: string }>(\n data: T[],\n selectedAccount: string,\n getAccountId?: (item: T) => string | undefined,\n): T[] => {\n const accountState = useAccount();\n\n return useMemo(() => {\n const { state, isMainAccount } = accountState;\n\n return data.filter((item) => {\n const accountId = getAccountId ? getAccountId(item) : item.account_id;\n\n if (isMainAccount) {\n if (!selectedAccount || selectedAccount === AccountType.ALL) {\n return true;\n }\n if (selectedAccount === AccountType.MAIN) {\n return accountId === state.mainAccountId;\n } else {\n return accountId === selectedAccount;\n }\n } else {\n return accountId === state.accountId;\n }\n });\n }, [data, selectedAccount, accountState, getAccountId]);\n};\n\n// Hook specifically for transfer history filtering\nexport const useTransferHistoryAccountFilter = <\n T extends { from_account_id?: string; to_account_id?: string },\n>(\n data: T[],\n selectedAccount: string,\n): T[] => {\n const accountState = useAccount();\n\n return useMemo(() => {\n const { state, isMainAccount } = accountState;\n\n return data.filter((item) => {\n if (isMainAccount) {\n if (!selectedAccount || selectedAccount === AccountType.ALL) {\n return true;\n }\n if (selectedAccount === AccountType.MAIN) {\n return (\n item.from_account_id === state.mainAccountId ||\n item.to_account_id === state.mainAccountId\n );\n } else {\n return (\n item.from_account_id === selectedAccount ||\n item.to_account_id === selectedAccount\n );\n }\n } else {\n return (\n item.from_account_id === state.accountId ||\n item.to_account_id === state.accountId\n );\n }\n });\n }, [data, selectedAccount, accountState]);\n};\n\n// Pre-defined account filters for common use cases\nexport const AccountFilters = {\n // Standard account filter factory\n standard: <T extends { account_id?: string }>() => createAccountFilter<T>(),\n\n // Transfer history filter factory\n transferHistory:\n <T extends { from_account_id?: string; to_account_id?: string }>() =>\n (\n data: T[],\n selectedAccount: string,\n accountState: ReturnType<typeof useAccount>,\n ): T[] => {\n const { state, isMainAccount } = accountState;\n\n return data.filter((item) => {\n if (isMainAccount) {\n if (!selectedAccount || selectedAccount === AccountType.ALL) {\n return true;\n }\n if (selectedAccount === AccountType.MAIN) {\n return (\n item.from_account_id === state.mainAccountId ||\n item.to_account_id === state.mainAccountId\n );\n } else {\n return (\n item.from_account_id === selectedAccount ||\n item.to_account_id === selectedAccount\n );\n }\n } else {\n return (\n item.from_account_id === state.accountId ||\n item.to_account_id === state.accountId\n );\n }\n });\n },\n\n // Custom account ID filter factory\n customAccountId: <T extends Record<string, any>>(accountIdKey: keyof T) =>\n createAccountFilter<T>((item) => item[accountIdKey] as string),\n};\n","import React, { useMemo } from \"react\";\nimport { useAccount } from \"@orderly.network/hooks\";\nimport { AccountType } from \"../pages/assets/assetsPage/assets.ui.desktop\";\n\n// Account filter hook for assets-like data structures\nexport const useAssetsAccountFilter = <T extends { account_id?: string }>(\n data: T[],\n) => {\n const { state, isMainAccount } = useAccount();\n const [selectedAccount, setSelectedAccount] = React.useState<string>(\n AccountType.ALL,\n );\n\n // Filter data based on selected account\n const filteredData = useMemo(() => {\n return data.filter((item) => {\n if (isMainAccount) {\n if (!selectedAccount || selectedAccount === AccountType.ALL) {\n return true;\n }\n if (selectedAccount === AccountType.MAIN) {\n return item.account_id === state.mainAccountId;\n } else {\n return item.account_id === selectedAccount;\n }\n } else {\n return item.account_id === state.accountId;\n }\n });\n }, [data, selectedAccount, isMainAccount, state]);\n\n // Handle filter changes\n const onAccountFilter = React.useCallback(\n (filter: { name: string; value: string }) => {\n const { name, value } = filter;\n if (name === \"account\") {\n setSelectedAccount(value);\n }\n },\n [],\n );\n\n return {\n selectedAccount,\n filteredData,\n onAccountFilter,\n setSelectedAccount,\n };\n};\n\n// Enhanced account and asset combined filter hook\nexport const useAssetsMultiFilter = <\n T extends {\n account_id?: string;\n children?: Array<{ token: string; [key: string]: any }>;\n },\n>(\n data: T[],\n) => {\n const { state, isMainAccount } = useAccount();\n const [selectedAccount, setSelectedAccount] = React.useState<string>(\n AccountType.ALL,\n );\n const [selectedAsset, setSelectedAsset] = React.useState<string>(\"all\");\n\n // Filter data based on both account and asset\n const filteredData = useMemo(() => {\n let accountFiltered = data;\n\n // First apply account filter\n if (isMainAccount) {\n if (selectedAccount && selectedAccount !== AccountType.ALL) {\n if (selectedAccount === AccountType.MAIN) {\n accountFiltered = data.filter(\n (item) => item.account_id === state.mainAccountId,\n );\n } else {\n accountFiltered = data.filter(\n (item) => item.account_id === selectedAccount,\n );\n }\n }\n } else {\n accountFiltered = data.filter(\n (item) => item.account_id === state.accountId,\n );\n }\n\n // Then apply asset filter\n if (selectedAsset && selectedAsset !== \"all\") {\n accountFiltered = accountFiltered\n .map((account) => {\n if (account.children) {\n const filteredChildren = account.children.filter(\n (child) => child.token === selectedAsset,\n );\n // Only include accounts that have the selected asset\n return filteredChildren.length > 0\n ? { ...account, children: filteredChildren }\n : null;\n }\n return account;\n })\n .filter(Boolean) as T[];\n }\n\n return accountFiltered;\n }, [data, selectedAccount, selectedAsset, isMainAccount, state]);\n\n // Handle combined filter changes\n const onFilter = React.useCallback(\n (filter: { name: string; value: string }) => {\n const { name, value } = filter;\n if (name === \"account\") {\n setSelectedAccount(value);\n } else if (name === \"asset\") {\n setSelectedAsset(value);\n }\n },\n [],\n );\n\n return {\n selectedAccount,\n selectedAsset,\n filteredData,\n onFilter,\n setSelectedAccount,\n setSelectedAsset,\n };\n};\n\n// Generic account filter function that can be used standalone\nexport const filterByAccount = <T extends { account_id?: string }>(\n data: T[],\n selectedAccount: string,\n accountState: {\n isMainAccount: boolean;\n state: {\n mainAccountId?: string;\n accountId?: string;\n };\n },\n): T[] => {\n const { isMainAccount, state } = accountState;\n\n return data.filter((item) => {\n if (isMainAccount) {\n if (!selectedAccount || selectedAccount === AccountType.ALL) {\n return true;\n }\n if (selectedAccount === AccountType.MAIN) {\n return item.account_id === state.mainAccountId;\n } else {\n return item.account_id === selectedAccount;\n }\n } else {\n return item.account_id === state.accountId;\n }\n });\n};\n","export * from \"./useAssetTotalValue\";\nexport * from \"./useAccountFilter\";\nexport * from \"./useAssetsAccountFilter\";\nexport * from \"./useAccountsData\";\n","import React, { useMemo, useState } from \"react\";\nimport { getDate, getMonth, getYear, set } from \"date-fns\";\nimport {\n useAccount,\n useCollateral,\n useIndexPricesStream,\n useSubAccountQuery,\n useTokensInfo,\n useChainInfo,\n} from \"@orderly.network/hooks\";\nimport { EMPTY_LIST } from \"@orderly.network/types\";\nimport { usePagination } from \"@orderly.network/ui\";\nimport { subtractDaysFromCurrentDate } from \"@orderly.network/utils\";\nimport { useAccountsData, useAssetsAccountFilter } from \"../../../hooks\";\nimport { parseDateRangeForFilter } from \"../../overview/helper/date\";\nimport type { ConvertRecord } from \"../type\";\n\nexport const useConvertScript = () => {\n const { isMainAccount, state } = useAccount();\n const { holding = [] } = useCollateral();\n const { data: indexPrices } = useIndexPricesStream();\n\n const { data: chainsInfo } = useChainInfo();\n\n // Pagination\n const { page, pageSize, setPage, parsePagination } = usePagination({\n page: 1,\n pageSize: 20,\n });\n\n // Use the same account data structure as assets\n const allAccounts = useAccountsData();\n\n const tokensInfo = useTokensInfo();\n\n // Use the same account filter logic as assets\n const { selectedAccount, onAccountFilter } =\n useAssetsAccountFilter(allAccounts);\n\n // Simple date range handling like other scripts\n const [today] = useState(() => {\n const d = new Date();\n return new Date(getYear(d), getMonth(d), getDate(d), 0, 0, 0);\n });\n\n const [dateRange, setDateRange] = useState<Date[]>([\n subtractDaysFromCurrentDate(90, today),\n today,\n ]);\n\n // Filter states (matching API fields)\n const [statusFilter, setStatusFilter] = useState<string>(\"all\");\n const [convertedAssetFilter, setConvertedAssetFilter] =\n useState<string>(\"all\");\n\n // Create asset options from holding data - similar to assets script\n const convertedAssetOptions = useMemo(() => {\n // Create options array\n const assetOptions =\n tokensInfo?.map((item) => ({\n value: item.token,\n label: item.token,\n })) || [];\n\n return [{ label: \"All assets\", value: \"all\" }, ...assetOptions];\n }, [tokensInfo]);\n\n // Handle all filters (including account filter and date range)\n const onFilter = React.useCallback(\n (filter: { name: string; value: string | { from: Date; to: Date } }) => {\n const { name, value } = filter;\n\n // Delegate account filter to the hook\n if (name === \"account\") {\n onAccountFilter(filter as { name: string; value: string });\n } else if (name === \"status\") {\n setStatusFilter(value as string);\n setPage(1); // Reset to first page when filter changes\n } else if (name === \"converted_asset\") {\n setConvertedAssetFilter(value as string);\n setPage(1);\n } else if (name === \"time\" || name === \"dateRange\") {\n setDateRange(\n parseDateRangeForFilter(value as { from: Date; to: Date }),\n );\n setPage(1);\n }\n },\n [onAccountFilter, setPage],\n );\n\n // Build query URL with parameters\n const queryUrl = React.useMemo(() => {\n const params = new URLSearchParams();\n\n // Add pagination parameters\n params.set(\"page\", page.toString());\n params.set(\"size\", pageSize.toString());\n\n // Add date range parameters\n if (dateRange[0]) {\n params.set(\"start_t\", dateRange[0].getTime().toString());\n }\n if (dateRange[1]) {\n params.set(\n \"end_t\",\n set(dateRange[1], {\n hours: 23,\n minutes: 59,\n seconds: 59,\n milliseconds: 0,\n })\n .getTime()\n .toString(),\n );\n }\n\n // Add filter parameters (only if not \"all\")\n if (statusFilter !== \"all\") {\n params.set(\"status\", statusFilter);\n }\n\n if (convertedAssetFilter !== \"all\") {\n params.set(\"converted_asset\", convertedAssetFilter);\n }\n\n return `/v1/asset/convert_history?${params.toString()}`;\n }, [page, pageSize, dateRange, statusFilter, convertedAssetFilter]);\n\n // Query convert history with all parameters\n const { data, isLoading } = useSubAccountQuery<{\n rows: ConvertRecord[];\n meta: {\n total: number;\n current_page: number;\n records_per_page: number;\n };\n }>(queryUrl, {\n accountId: isMainAccount ? state.mainAccountId : state.accountId,\n formatter: (data) => {\n return data;\n },\n });\n\n // Parse pagination from API response meta\n const pagination = useMemo(() => {\n if (data?.meta) {\n return parsePagination(data.meta);\n }\n return {\n page,\n pageSize,\n onPageChange: setPage,\n onPageSizeChange: () => {\n // Handle page size change if needed\n },\n };\n }, [data?.meta, parsePagination, page, pageSize, setPage]);\n\n // Calculate summary\n const summary = useMemo(() => {\n const dataRows = data?.rows || [];\n\n const totalConversions = dataRows.length;\n const totalUSDCReceived = dataRows.reduce(\n (sum, record) => sum + record.received_qty,\n 0,\n );\n const totalFees = dataRows.reduce(\n (sum, record) =>\n sum +\n record.details.reduce(\n (detailSum, detail) => detailSum + detail.haircut,\n 0,\n ),\n 0,\n );\n\n return {\n totalConversions,\n totalUSDCReceived,\n totalFees,\n };\n }, [data]);\n\n return {\n // Data\n dataSource: data?.rows || EMPTY_LIST,\n summary,\n pagination,\n\n // Filter state and handlers (compatible with assets)\n selectedAccount,\n onFilter,\n\n // Query parameters (consistent with other scripts)\n dateRange,\n\n // Filter states\n statusFilter,\n convertedAssetFilter,\n convertedAssetOptions,\n\n // State\n isMainAccount,\n isLoading,\n holding,\n\n // Index prices\n indexPrices,\n chainsInfo,\n };\n};\n\nexport type UseConvertScriptReturn = ReturnType<typeof useConvertScript>;\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport React, { useMemo } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n Button,\n Flex,\n Text,\n TokenIcon,\n Tooltip,\n toast,\n} from \"@orderly.network/ui\";\nimport type { Column } from \"@orderly.network/ui\";\nimport type { ConvertRecord, ConvertTransaction } from \"../type\";\n\nexport interface ConvertColumnsOptions {\n onDetailsClick?: (convertId: number) => void;\n}\n\nexport interface ConvertDetailColumnsOptions {\n onTxClick?: (txId: string) => void;\n indexPrices: Record<string, number>;\n chainsInfo: any[];\n}\n\nexport const ConvertedAssetColumn = ({\n convertedAssets,\n}: {\n convertedAssets: Record<string, number>;\n}) => {\n const { t } = useTranslation();\n const assets = useMemo(() => {\n return Object.keys(convertedAssets);\n }, [convertedAssets]);\n\n const tooltipContent = useMemo(() => {\n return (\n <Flex\n direction=\"column\"\n gap={2}\n className=\"oui-w-[275px] oui-font-semibold oui-text-base-contrast-80\"\n >\n <Flex\n itemAlign=\"center\"\n justify=\"between\"\n className=\"oui-w-full oui-text-2xs oui-text-base-contrast-36\"\n >\n <div>{t(\"common.assets\")}</div>\n <div>{t(\"common.qty\")}</div>\n </Flex>\n {assets.map((asset) => (\n <Flex\n key={asset}\n itemAlign=\"center\"\n justify=\"between\"\n className=\"oui-w-full\"\n >\n <Flex itemAlign=\"center\" gap={1}>\n <TokenIcon size=\"xs\" name={asset} />\n <Text.formatted>{asset}</Text.formatted>\n </Flex>\n <div>\n <Text.formatted>{convertedAssets[asset]}</Text.formatted>\n </div>\n </Flex>\n ))}\n </Flex>\n );\n }, [assets]);\n\n return (\n <Flex itemAlign=\"center\" gap={2}>\n <div className=\"oui-relative oui-flex\">\n {assets.slice(0, 3).map((asset, index) => (\n <div\n key={asset}\n className=\"oui-relative\"\n style={{\n marginLeft: index > 0 ? \"-8px\" : \"0\",\n zIndex: assets.length + index,\n }}\n >\n <TokenIcon size=\"xs\" name={asset} />\n </div>\n ))}\n </div>\n <Tooltip content={tooltipContent}>\n <Text.formatted className=\"oui-cursor-pointer oui-underline oui-decoration-line-16 oui-decoration-dashed oui-underline-offset-4\">\n {assets.slice(0, 3).join(\", \")}{\" \"}\n {assets.length > 3 && `+${assets.length - 3}`}\n </Text.formatted>\n </Tooltip>\n </Flex>\n );\n};\n\nexport const useConvertColumns = (options: ConvertColumnsOptions) => {\n const { onDetailsClick } = options;\n const { t } = useTranslation();\n const onCopy = (e: any) => {\n e.preventDefault();\n e.stopPropagation();\n toast.success(t(\"common.copy.copied\"));\n };\n\n const columns = React.useMemo<Column[]>(() => {\n return [\n {\n title: t(\"portfolio.overview.column.convert.convertedAsset\"),\n dataIndex: \"converted_asset\",\n align: \"left\",\n width: 200,\n maxWidth: 200,\n render(convertedAssets: Record<string, number>) {\n return <ConvertedAssetColumn convertedAssets={convertedAssets} />;\n },\n },\n {\n title: t(\"portfolio.overview.column.convert.usdcAmount\"),\n dataIndex: \"received_qty\",\n align: \"left\",\n width: 150,\n render(qty: number) {\n return (\n <Text.numeral dp={6} padding={false}>\n {qty}\n </Text.numeral>\n );\n },\n },\n {\n title: t(\"common.fee\"),\n dataIndex: \"details\",\n align: \"left\",\n width: 120,\n render(details: ConvertRecord[\"details\"]) {\n const totalHaircut = details.reduce(\n (sum, detail) => sum + detail.haircut,\n 0,\n );\n return (\n <Text.numeral dp={6} padding={false}>\n {totalHaircut}\n </Text.numeral>\n );\n },\n },\n {\n title: t(\"common.type\"),\n dataIndex: \"type\",\n align: \"left\",\n width: 150,\n render(type: string) {\n return <Text>{type.charAt(0).toUpperCase() + type.slice(1)}</Text>;\n },\n },\n {\n title: t(\"portfolio.overview.column.convert.convertId\"),\n dataIndex: \"convert_id\",\n align: \"left\",\n width: 150,\n render(convertId: number) {\n return (\n <Text.formatted onCopy={onCopy} copyable>\n {convertId}\n </Text.formatted>\n );\n },\n },\n {\n title: t(\"common.time\"),\n dataIndex: \"created_time\",\n align: \"left\",\n width: 160,\n rule: \"date\",\n },\n {\n title: t(\"common.status\"),\n dataIndex: \"status\",\n align: \"left\",\n width: 150,\n render(status: string) {\n return (\n <Text>{status.charAt(0).toUpperCase() + status.slice(1)}</Text>\n );\n },\n },\n {\n title: \"\",\n dataIndex: \"updated_time\",\n align: \"center\",\n width: 80,\n render(convertId: number, record: ConvertRecord) {\n return (\n <Button\n size=\"sm\"\n variant=\"text\"\n className=\"oui-text-primary\"\n onClick={() => onDetailsClick?.(record.convert_id)}\n >\n {t(\"portfolio.overview.column.convert.details\")}\n </Button>\n );\n },\n },\n ];\n }, [onDetailsClick]);\n\n return columns;\n};\n\n// Converted asset, Qty., USDC amount, Fee, TxID, Network, Status\nexport const useConvertDetailColumns = (\n options: ConvertDetailColumnsOptions,\n) => {\n const { t } = useTranslation();\n const onCopy = (e: any) => {\n e.preventDefault();\n e.stopPropagation();\n toast.success(t(\"common.copy.copied\"));\n };\n const columns = React.useMemo<Column[]>(() => {\n return [\n {\n title: t(\"portfolio.overview.column.convert.convertedAsset\"),\n dataIndex: \"converted_asset\",\n align: \"left\",\n width: 150,\n render(asset: string) {\n return (\n <Flex itemAlign=\"center\" gap={2}>\n <TokenIcon name={asset} />\n {asset}\n </Flex>\n );\n },\n },\n {\n title: t(\"common.qty\"),\n dataIndex: \"converted_qty\",\n align: \"left\",\n width: 100,\n render(qty: number) {\n return (\n <Text.numeral dp={6} padding={false}>\n {qty}\n </Text.numeral>\n );\n },\n },\n {\n title: t(\"portfolio.overview.column.convert.usdcAmount\"),\n dataIndex: \"received_qty\",\n align: \"left\",\n width: 100,\n render(qty: number) {\n return (\n <Text.numeral dp={6} padding={false}>\n {qty}\n </Text.numeral>\n );\n },\n },\n {\n title: t(\"common.fee\"),\n dataIndex: \"haircut\",\n align: \"left\",\n width: 100,\n render(haircut: number) {\n return (\n <Text.numeral dp={6} padding={false}>\n {haircut}\n </Text.numeral>\n );\n },\n },\n {\n title: t(\"common.txId\"),\n dataIndex: \"tx_id\",\n align: \"left\",\n width: 150,\n render(txId: string, record: ConvertTransaction) {\n if (!txId) return <Text intensity={54}>-</Text>;\n const chainInfo = (options.chainsInfo as any[])?.find(\n (item) => record.chain_id === parseInt(item.chain_id),\n );\n const explorer_base_url = chainInfo?.explorer_base_url;\n const href = `${explorer_base_url}/tx/${txId}`;\n return (\n <a href={href} target=\"_blank\" rel=\"noreferrer\">\n <Text.formatted\n onCopy={onCopy}\n rule=\"txId\"\n copyable={!!txId}\n className=\"oui-cursor-pointer oui-underline oui-decoration-line-16 oui-decoration-dashed oui-underline-offset-4\"\n >\n {txId}\n </Text.formatted>\n </a>\n );\n },\n },\n {\n title: t(\"transfer.network\"),\n dataIndex: \"chain_id\",\n align: \"left\",\n width: 150,\n render(venue: string, record: ConvertTransaction) {\n return (\n <Text>\n {options.chainsInfo.find(\n (item) => item.chain_id == record.chain_id,\n )?.name || \"-\"}\n </Text>\n );\n },\n },\n {\n title: t(\"common.result\"),\n dataIndex: \"result\",\n align: \"left\",\n width: 100,\n render(result: string) {\n return (\n <Text>{result?.charAt(0).toUpperCase() + result?.slice(1)}</Text>\n );\n },\n },\n ];\n }, []);\n\n return columns;\n};\n","import { useMemo } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n DataFilter,\n Flex,\n DataTable,\n modal,\n SimpleDialog,\n Divider,\n} from \"@orderly.network/ui\";\nimport { useModal } from \"@orderly.network/ui\";\nimport type { ConvertRecord } from \"../type\";\nimport { useConvertColumns, useConvertDetailColumns } from \"./convert.column\";\nimport { useConvertScript } from \"./convert.script\";\n\ntype ConvertDesktopUIProps = {\n convertState: ReturnType<typeof useConvertScript>;\n};\n\nexport const CONVERT_STATUS_OPTIONS = [\n {\n label: \"All status\",\n value: \"all\",\n },\n {\n label: \"Completed\",\n value: \"completed\",\n },\n {\n label: \"Pending\",\n value: \"pending\",\n },\n];\n\n// Convert Details Modal Component\nconst ConvertDetailsModal = modal.create<{\n record: ConvertRecord;\n indexPrices: Record<string, number>;\n chainsInfo: any[];\n}>((props) => {\n const { t } = useTranslation();\n const { visible, onOpenChange } = useModal();\n // console.log(props);\n\n const detailColumns = useConvertDetailColumns({\n indexPrices: props.indexPrices,\n chainsInfo: props.chainsInfo,\n });\n\n return (\n <SimpleDialog\n open={visible}\n onOpenChange={onOpenChange}\n title={t(\"portfolio.overview.convert.dialog.title.details\")}\n size=\"lg\"\n closable\n classNames={{\n content: \"oui-max-w-4xl\",\n }}\n >\n <DataTable\n columns={detailColumns}\n dataSource={props.record.details}\n bordered\n className=\"oui-w-full\"\n classNames={{\n header: \"oui-h-10\",\n root: \"oui-bg-base-8 oui-max-h-[60vh] oui-overflow-y-scroll\",\n }}\n onRow={() => ({\n className: \"oui-h-[40px]\",\n })}\n generatedRowKey={(record) =>\n record.transaction_id || Math.random().toString()\n }\n />\n </SimpleDialog>\n );\n});\n\nexport const ConvertDesktopUI: React.FC<ConvertDesktopUIProps> = ({\n convertState,\n}) => {\n const handleDetailsClick = (convertId: number) => {\n // Find the convert record by ID\n const record = convertState.dataSource.find(\n (item) => item.convert_id === convertId,\n );\n if (record) {\n modal.show(ConvertDetailsModal, {\n record,\n indexPrices: convertState.indexPrices,\n chainsInfo: convertState.chainsInfo as any,\n });\n }\n };\n\n const columns = useConvertColumns({\n onDetailsClick: handleDetailsClick,\n });\n\n const {\n convertedAssetFilter,\n statusFilter,\n dateRange,\n onFilter,\n convertedAssetOptions,\n } = convertState;\n\n const dataFilter = useMemo(() => {\n return (\n <DataFilter\n className=\"\"\n onFilter={onFilter}\n items={[\n // {\n // type: \"select\",\n // name: \"account\",\n // value: selectedAccount,\n // options: memoizedOptions,\n // },\n {\n type: \"select\",\n name: \"converted_asset\",\n value: convertedAssetFilter,\n options: convertedAssetOptions,\n },\n {\n type: \"select\",\n name: \"status\",\n value: statusFilter,\n options: CONVERT_STATUS_OPTIONS,\n },\n {\n type: \"range\",\n name: \"time\",\n value: {\n from: dateRange?.[0],\n to: dateRange?.[1],\n },\n },\n ]}\n />\n );\n }, [\n convertedAssetFilter,\n statusFilter,\n dateRange,\n onFilter,\n convertedAssetOptions,\n ]);\n\n return (\n <Flex direction=\"column\" mt={4} itemAlign=\"center\" className=\"oui-w-full\">\n <Divider className=\"oui-w-full oui-border-b oui-border-line-4 oui-pt-6\" />\n <Flex direction=\"row\" className=\"oui-w-full\">\n {dataFilter}\n </Flex>\n <DataTable\n columns={columns}\n dataSource={convertState.dataSource}\n loading={convertState.isLoading}\n bordered\n pagination={convertState.pagination}\n manualPagination\n className=\"oui-mt-4 oui-w-full\"\n classNames={{\n root: \"oui-h-[calc(100vh_-_200px)]\",\n header: \"oui-h-12\",\n }}\n onRow={() => ({\n className: \"oui-h-[48px] oui-cursor-pointer\",\n })}\n generatedRowKey={(record) => {\n return record.convert_id.toString();\n }}\n />\n </Flex>\n );\n};\n","import { useMemo } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n useModal,\n modal,\n Text,\n Divider,\n TokenIcon,\n Flex,\n DataFilter,\n SimpleSheet,\n toast,\n ScrollIndicator,\n} from \"@orderly.network/ui\";\nimport { ConvertRecord, ConvertTransaction } from \"../type\";\nimport { ConvertedAssetColumn } from \"./convert.column\";\nimport { useConvertScript } from \"./convert.script\";\nimport { CONVERT_STATUS_OPTIONS } from \"./convert.ui.desktop\";\n\ntype ConvertMobileUIProps = {\n convertState: ReturnType<typeof useConvertScript>;\n};\n\ntype ConvertMobileItemProps = {\n item?: any;\n chainsInfo: any[];\n};\n\ntype ConvertMobileFieldProps = {\n label: string;\n value?: string | number;\n className?: string;\n copyable?: boolean;\n rule?: \"address\" | \"txId\";\n onClick?: () => void;\n};\n\nexport const ConvertMobileUI: React.FC<ConvertMobileUIProps> = ({\n convertState,\n}) => {\n const { t } = useTranslation();\n\n const {\n convertedAssetFilter,\n statusFilter,\n dateRange,\n onFilter,\n convertedAssetOptions,\n } = convertState;\n\n const dataFilter = useMemo(() => {\n return (\n <DataFilter\n onFilter={onFilter}\n items={[\n // {\n // size: \"sm\",\n // type: \"picker\",\n // name: \"account\",\n // value: selectedAccount,\n // options: memoizedOptions,\n // },\n {\n size: \"md\",\n type: \"picker\",\n name: \"converted_asset\",\n value: convertedAssetFilter,\n options: convertedAssetOptions,\n className: \"oui-whitespace-nowrap\",\n },\n {\n size: \"md\",\n type: \"picker\",\n name: \"status\",\n value: statusFilter,\n options: CONVERT_STATUS_OPTIONS,\n className: \"oui-whitespace-nowrap\",\n },\n {\n type: \"range\",\n name: \"time\",\n value: {\n from: dateRange?.[0],\n to: dateRange?.[1],\n },\n },\n ]}\n />\n );\n }, [\n convertedAssetFilter,\n statusFilter,\n dateRange,\n onFilter,\n convertedAssetOptions,\n ]);\n\n return (\n <div className=\"oui-flex oui-flex-col oui-gap-1 oui-px-3\">\n <ScrollIndicator className=\"oui-pr-5\">\n <Flex direction=\"row\">{dataFilter}</Flex>\n </ScrollIndicator>\n {convertState.dataSource.map((item) => (\n <ConvertMobileItem\n key={item.convert_id}\n item={item}\n chainsInfo={convertState.chainsInfo as any}\n />\n ))}\n </div>\n );\n};\n\nconst ConvertMobileField: React.FC<ConvertMobileFieldProps> = ({\n label,\n value,\n rule,\n copyable = false,\n className = \"\",\n onClick,\n}) => {\n const { t } = useTranslation();\n const onCopy = (e: any) => {\n e.preventDefault();\n e.stopPropagation();\n toast.success(t(\"common.copy.copied\"));\n };\n return (\n <div\n className={`oui-text-2xs oui-font-semibold oui-text-base-contrast-80 [&_p]:oui-text-base-contrast-36 ${className}`}\n onClick={onClick}\n >\n <p>{label}</p>\n <Text.formatted rule={rule} copyable={copyable} onCopy={onCopy}>\n {value || \"-\"}\n </Text.formatted>\n </div>\n );\n};\n\nconst ConvertMobileItem: React.FC<ConvertMobileItemProps> = (props) => {\n const { item } = props;\n const { t } = useTranslation();\n\n if (!item) {\n return null;\n }\n\n const totalHaircut = item.details.reduce(\n (sum: number, detail: ConvertTransaction) => sum + detail.haircut,\n 0,\n );\n\n return (\n <div className=\"oui-flex oui-flex-col oui-gap-2 oui-rounded-xl oui-bg-base-9 oui-p-2\">\n <div className=\"oui-flex oui-justify-between\">\n <div className=\"oui-flex oui-items-center oui-text-xs oui-font-semibold oui-text-base-contrast-80\">\n <ConvertedAssetColumn convertedAssets={item.converted_asset} />\n <div\n className=\"oui-ml-2 oui-text-primary\"\n onClick={() => {\n modal.show(ConverHistoryItemDetailsDialog, {\n item,\n chainsInfo: props.chainsInfo,\n });\n }}\n >\n {t(\"portfolio.overview.column.convert.details\")}\n </div>\n </div>\n <Text.formatted\n className=\"oui-text-2xs oui-text-base-contrast-36\"\n rule=\"date\"\n >\n {item.created_time}\n </Text.formatted>\n </div>\n\n {/* 5 fields in grid container: 3 per row, wrap to next line */}\n <div className=\"oui-grid oui-grid-cols-3 oui-gap-2\">\n <ConvertMobileField\n label={t(\"portfolio.overview.column.convert.usdcAmount\")}\n value={item.received_qty}\n />\n <ConvertMobileField label={t(\"common.fee\")} value={totalHaircut} />\n <ConvertMobileField\n label={t(\"portfolio.overview.column.convert.convertId\")}\n value={item.convert_id}\n copyable={true}\n />\n <ConvertMobileField\n label={t(\"common.type\")}\n value={item.type?.charAt(0).toUpperCase() + item.type?.slice(1)}\n />\n <ConvertMobileField\n label={t(\"common.status\")}\n value={item.status?.charAt(0).toUpperCase() + item.status?.slice(1)}\n />\n </div>\n </div>\n );\n};\n\ntype ConvertHistoryItemDetailsDialogProps = {\n item: ConvertRecord;\n chainsInfo: any[];\n};\n\nconst ConverHistoryItemDetailsDialog =\n modal.create<ConvertHistoryItemDetailsDialogProps>((props) => {\n const { item, chainsInfo } = props;\n const { t } = useTranslation();\n const { visible, hide, resolve, reject, onOpenChange } = useModal();\n\n return (\n <SimpleSheet\n title={t(\"portfolio.overview.convert.dialog.title.details\")}\n open={visible}\n onOpenChange={onOpenChange}\n >\n <div className=\"oui-flex oui-h-[300px] oui-flex-col oui-gap-3 oui-overflow-y-auto oui-rounded-lg oui-bg-base-7 oui-p-2\">\n {item.details.map((detail, index) => (\n <>\n <div className=\"oui-flex oui-flex-col oui-gap-2\">\n <div className=\"oui-flex oui-items-center oui-gap-1\">\n <TokenIcon name={detail.converted_asset} size=\"xs\" />\n <div className=\"oui-text-xs oui-text-base-contrast-80\">\n {detail.converted_asset}\n </div>\n </div>\n <div className=\"oui-grid oui-grid-cols-3 oui-gap-2\">\n <ConvertMobileField\n label={t(\"common.qty\")}\n value={detail.converted_qty}\n />\n <ConvertMobileField\n label={t(\"portfolio.overview.column.convert.usdcAmount\")}\n value={detail.received_qty}\n />\n <ConvertMobileField label=\"Fee\" value={detail.haircut} />\n <ConvertMobileField\n label={t(\"common.txId\")}\n copyable={!!detail.tx_id}\n rule=\"txId\"\n value={detail.tx_id}\n onClick={() => {\n if (detail.tx_id) {\n const chainInfo = chainsInfo.find(\n (item) => item.chain_id == detail.chain_id,\n );\n if (chainInfo?.explorer_base_url) {\n window.open(\n `${chainInfo.explorer_base_url}/tx/${detail.tx_id}`,\n \"_blank\",\n );\n }\n }\n }}\n />\n <ConvertMobileField\n label={t(\"transfer.network\")}\n value={\n chainsInfo.find(\n (item) => item.chain_id == detail.chain_id,\n )?.name || \"-\"\n }\n />\n <ConvertMobileField\n label={t(\"common.result\")}\n value={\n detail.result\n ? detail.result.charAt(0).toUpperCase() +\n detail.result.slice(1)\n : \"-\"\n }\n />\n </div>\n </div>\n {index < item.details.length - 1 && <Divider />}\n </>\n ))}\n </div>\n </SimpleSheet>\n );\n });\n","import React from \"react\";\nimport { useScreen } from \"@orderly.network/ui\";\nimport { useConvertScript } from \"./convert.script\";\nimport { ConvertDesktopUI } from \"./convert.ui.desktop\";\nimport { ConvertMobileUI } from \"./convert.ui.mobile\";\n\nexport const ConvertHistoryWidget: React.FC = () => {\n const convertState = useConvertScript();\n const { isMobile } = useScreen();\n if (isMobile) {\n return <ConvertMobileUI convertState={convertState} />;\n }\n return <ConvertDesktopUI convertState={convertState} />;\n};\n","import React from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { AssetHistorySideEnum } from \"@orderly.network/types\";\nimport { TabPanel, Tabs } from \"@orderly.network/ui\";\nimport { ConvertHistoryWidget } from \"../../assets/convertPage/convert.widget\";\nimport { VaultsHistoryWidget } from \"../VaultsHistory/transfer.widget\";\nimport { AssetHistoryWidget } from \"../assetHistory\";\nimport { DistributionHistoryWidget } from \"../distribution\";\nimport { FundingHistoryWidget } from \"../funding\";\nimport { TabName } from \"./historyDataGroup.script\";\n\nexport const HistoryDataGroupMobile: React.FC<{\n active?: TabName;\n onTabChange: (tab: string) => void;\n}> = (props) => {\n const { active = \"deposit\", onTabChange } = props;\n const { t } = useTranslation();\n\n return (\n <Tabs\n value={active}\n onValueChange={onTabChange}\n variant=\"contained\"\n size=\"lg\"\n classNames={{\n tabsList: \"oui-px-3 oui-py-2\",\n scrollIndicator: \"oui-pr-3\",\n }}\n showScrollIndicator\n >\n <TabPanel title={t(\"common.deposits\")} value={\"deposit\"}>\n <AssetHistoryWidget side={AssetHistorySideEnum.DEPOSIT} />\n </TabPanel>\n <TabPanel title={t(\"common.withdrawals\")} value={\"withdraw\"}>\n <AssetHistoryWidget side={AssetHistorySideEnum.WITHDRAW} />\n </TabPanel>\n <TabPanel title={t(\"common.funding\")} value={\"funding\"}>\n <FundingHistoryWidget />\n </TabPanel>\n <TabPanel\n title={t(\"portfolio.overview.distribution\")}\n value={\"distribution\"}\n >\n <DistributionHistoryWidget />\n </TabPanel>\n <TabPanel\n title={t(\"portfolio.overview.tab.convert.history\")}\n value={\"convert\"}\n >\n <ConvertHistoryWidget />\n </TabPanel>\n <TabPanel title={t(\"common.vaults\")} value={\"vaults\"}>\n <VaultsHistoryWidget />\n </TabPanel>\n </Tabs>\n );\n};\n","import { useScreen } from \"@orderly.network/ui\";\nimport { useHistoryDataGroupScript } from \"./historyDataGroup.script\";\nimport { HistoryDataGroupDesktop } from \"./historyDataGroup.ui.desktop\";\nimport { HistoryDataGroupMobile } from \"./historyDataGroup.ui.mobile\";\n\nexport const HistoryDataGroupWidget: React.FC = () => {\n const state = useHistoryDataGroupScript();\n const { isMobile } = useScreen();\n if (isMobile) {\n return <HistoryDataGroupMobile {...state} />;\n }\n return <HistoryDataGroupDesktop {...state} />;\n};\n","export { HistoryDataGroupWidget } from \"./historyDataGroup.widget\";\n","import { createContext, useContext } from \"react\";\nimport { TWType } from \"@orderly.network/hooks\";\nimport { UseRewardsDataReturn } from \"../mobile/useRewardsData.script\";\nimport { useAssetsHistoryDataReturn } from \"../shared/useAssetHistory\";\n\nexport type OverviewContextState = {\n // period: PeriodType;\n type?: TWType;\n} & useAssetsHistoryDataReturn &\n UseRewardsDataReturn;\n\nexport const OverviewContext = createContext<OverviewContextState>(\n {} as OverviewContextState,\n);\n\nexport const useOverviewContext = () => {\n return useContext(OverviewContext);\n};\n","import { useMemo } from \"react\";\nimport { useAccount } from \"@orderly.network/hooks\";\nimport { useAppContext, useDataTap } from \"@orderly.network/react-app\";\nimport { AccountStatusEnum } from \"@orderly.network/types\";\nimport { useOverviewContext } from \"../provider/overviewContext\";\n\nexport const useAssetsChartScript = () => {\n const assetHistory = useOverviewContext();\n\n const { wrongNetwork, disabledConnect } = useAppContext();\n const { state } = useAccount();\n\n const filteredData = useDataTap(assetHistory.data, {\n accountStatus:\n state.status === AccountStatusEnum.EnableTradingWithoutConnected\n ? AccountStatusEnum.EnableTradingWithoutConnected\n : AccountStatusEnum.EnableTrading,\n fallbackData: assetHistory.createFakeData(\n { account_value: 0 },\n { account_value: 500 },\n ),\n });\n\n const _data = useMemo(() => {\n if (filteredData?.length) {\n return filteredData;\n }\n return assetHistory.createFakeData(\n { account_value: 0 },\n { account_value: 500 },\n );\n }, [filteredData, assetHistory]);\n\n const invisible =\n wrongNetwork || disabledConnect || !assetHistory.data.length;\n\n return {\n ...assetHistory,\n data: _data,\n invisible,\n } as const;\n};\n\nexport type useAssetsChartScriptReturn = ReturnType<\n typeof useAssetsChartScript\n>;\n","import { useCallback, useMemo, useRef, useState } from \"react\";\nimport { subDays, format } from \"date-fns\";\nimport {\n useAccount,\n useAssetsHistory,\n useCollateral,\n useIndexPricesStream,\n useLocalStorage,\n usePrivateQuery,\n useStatisticsDaily,\n} from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { API } from \"@orderly.network/types\";\nimport { Decimal, zero } from \"@orderly.network/utils\";\n\nexport enum PeriodType {\n WEEK = \"7D\",\n MONTH = \"30D\",\n QUARTER = \"90D\",\n}\n\nexport const useAssetsHistoryData = (\n localKey: string,\n options?: { isRealtime?: boolean },\n) => {\n const [today] = useState(() => new Date());\n\n const { getIndexPrice } = useIndexPricesStream();\n // const { account } = useAccount();\n\n const { t } = useTranslation();\n\n const { isRealtime = false } = options || {};\n const periodTypes = Object.values(PeriodType);\n\n const [period, setPeriod] = useLocalStorage<PeriodType>(\n localKey,\n PeriodType.WEEK,\n );\n\n const convertToUSDCAndOperate = useCallback(\n (inputs: {\n token: string;\n amount: string | number;\n value: Decimal;\n op?: \"add\" | \"sub\";\n }): Decimal => {\n const { token, amount, value, op = \"sub\" } = inputs;\n if (token.toUpperCase() === \"USDC\") {\n return op === \"add\" ? value.add(amount) : value.sub(amount);\n } else {\n const indexPrice = getIndexPrice(token);\n if (indexPrice) {\n const delta = new Decimal(amount).mul(indexPrice);\n return op === \"add\" ? value.add(delta) : value.sub(delta);\n }\n return value;\n }\n },\n [getIndexPrice],\n );\n\n const periodLabel = useMemo<Record<PeriodType, string>>(() => {\n return {\n [PeriodType.WEEK]: t(\"common.select.7d\"),\n [PeriodType.MONTH]: t(\"common.select.30d\"),\n [PeriodType.QUARTER]: t(\"common.select.90d\"),\n };\n }, [t]);\n\n const { totalValue } = useCollateral();\n\n const getStartDate = (value: PeriodType) => {\n switch (value) {\n case PeriodType.MONTH:\n return subDays(today, 35);\n case PeriodType.QUARTER:\n return subDays(today, 95);\n default:\n return subDays(today, 10);\n }\n };\n\n const periodValue = useMemo(() => {\n switch (period) {\n case PeriodType.WEEK:\n return 7;\n case PeriodType.MONTH:\n return 30;\n case PeriodType.QUARTER:\n return 90;\n default:\n return 7;\n }\n }, [period]);\n\n const [startDate, setStartDate] = useState(getStartDate(period));\n // const nowStamp = useRef(new Date().getTime().toString());\n // const now = useRef(new Date());\n\n // const endDate = useMemo(() => addDays(today, 1), [today]);\n const endDate = today;\n\n const totalDeposit = useRef<Decimal>(zero);\n\n // get transfer history\n const { data: transferOutHistory } = usePrivateQuery<API.TransferHistory>(\n `/v1/internal_transfer_history?page=1&size=200&side=OUT&main_sub_only=true&start_t=${startDate.getTime()}&end_t=${endDate.getTime()}`,\n {\n revalidateOnFocus: false,\n },\n );\n const { data: transferInHistory } = usePrivateQuery<API.TransferHistory>(\n `/v1/internal_transfer_history?page=1&size=200&side=IN&main_sub_only=true&start_t=${startDate.getTime()}&end_t=${endDate.getTime()}`,\n {\n revalidateOnFocus: false,\n },\n );\n\n const [data] = useStatisticsDaily(\n {\n startDate: startDate.toISOString().split(\"T\")[0],\n endDate: endDate.toISOString().split(\"T\")[0],\n },\n {\n ignoreAggregation: true,\n },\n );\n\n // get deposit & withdraw records to calculate the current PNL\n const [assetHistory] = useAssetsHistory({\n startTime: subDays(today, 2).getTime(),\n endTime: endDate.getTime(),\n pageSize: 50,\n });\n\n // get all deposit records to calculate the ROI\n const [allDepositHistory] = useAssetsHistory({\n side: \"DEPOSIT\",\n startTime: subDays(today, periodValue).getTime(),\n endTime: endDate.getTime(),\n pageSize: 200,\n });\n\n const totalDepositForROI = useMemo(() => {\n return allDepositHistory\n ?.filter((item) => item.trans_status === \"COMPLETED\")\n .reduce((acc, item) => {\n return acc.add(\n // item.amount\n convertToUSDCAndOperate({\n token: item.token,\n amount: item.amount,\n value: zero,\n op: \"add\",\n }),\n );\n }, zero);\n }, [allDepositHistory, convertToUSDCAndOperate]);\n\n const totalTransferInForROI = useMemo(() => {\n if (!Array.isArray(transferInHistory)) {\n return zero;\n }\n return transferInHistory\n ?.filter((item) => item.status === \"COMPLETED\")\n .reduce((acc, item) => {\n return acc.add(\n convertToUSDCAndOperate({\n token: item.token,\n amount: item.amount,\n value: zero,\n op: \"add\",\n }),\n );\n }, zero);\n }, [transferInHistory, convertToUSDCAndOperate]);\n\n const onPeriodChange = (value: PeriodType) => {\n setStartDate(getStartDate(value));\n setPeriod(value);\n };\n\n // const lastItem = data[data.length - 1];\n\n const lastItem = useMemo(() => {\n return data.length > 0 ? data[data.length - 1] : null;\n }, [data]);\n\n const totalTransferIn = useMemo(() => {\n if (!Array.isArray(transferInHistory)) {\n return null;\n }\n if (\n lastItem == null ||\n transferInHistory?.length === 0 ||\n typeof lastItem.snapshot_time === \"undefined\"\n ) {\n return zero;\n }\n const list = transferInHistory?.filter((item) => {\n return (\n item.status === \"COMPLETED\" &&\n item.created_time > lastItem?.snapshot_time\n );\n });\n return list?.reduce((acc, item) => {\n return acc.add(\n convertToUSDCAndOperate({\n token: item.token,\n amount: item.amount,\n value: zero,\n op: \"add\",\n }),\n );\n }, zero);\n }, [transferInHistory, lastItem, convertToUSDCAndOperate]);\n\n const totalTransferOut = useMemo(() => {\n if (!Array.isArray(transferOutHistory)) {\n return null;\n }\n if (\n lastItem == null ||\n transferOutHistory?.length === 0 ||\n typeof lastItem.snapshot_time === \"undefined\"\n ) {\n return zero;\n }\n const list = transferOutHistory?.filter((item) => {\n return (\n item.status === \"COMPLETED\" &&\n item.created_time > lastItem?.snapshot_time\n );\n });\n return list?.reduce((acc, item) => {\n return acc.add(\n convertToUSDCAndOperate({\n token: item.token,\n amount: item.amount,\n value: zero,\n op: \"add\",\n }),\n );\n }, zero);\n }, [transferOutHistory, lastItem, convertToUSDCAndOperate]);\n\n const calculateLastPnl = (inputs: {\n lastItem: API.DailyRow;\n assetHistory: ReadonlyArray<API.AssetHistoryRow> | API.AssetHistoryRow[];\n transferHistory: {\n OUT: Decimal;\n IN: Decimal;\n };\n totalValue: number | null;\n }) => {\n if (totalValue == null) {\n return null;\n }\n // today daily pnl = totalValue - lastItem.account_value - deposit + withdraw\n let value = new Decimal(totalValue).sub(inputs.lastItem.account_value);\n\n // subtraction of deposit and withdraw\n if (\n Array.isArray(inputs.assetHistory) &&\n inputs.assetHistory.length > 0 &&\n typeof inputs.lastItem.snapshot_time !== \"undefined\"\n ) {\n // find a list with the timestamp greater than the last item timestamp and trans_status = success;\n const list = [];\n\n for (let i = 0; i < inputs.assetHistory.length; i++) {\n const item = inputs.assetHistory[i];\n if (item.created_time > inputs.lastItem.snapshot_time) {\n list.push(item);\n }\n }\n\n // calculate the sum of deposit and withdraw\n for (let i = 0; i < list.length; i++) {\n const item = list[i];\n if (item.side === \"DEPOSIT\") {\n if (item.trans_status === \"COMPLETED\") {\n value = convertToUSDCAndOperate({\n token: item.token,\n amount: item.amount,\n value,\n op: \"sub\",\n });\n\n totalDeposit.current = convertToUSDCAndOperate({\n token: item.token,\n amount: item.amount,\n value: totalDeposit.current,\n op: \"add\",\n });\n }\n } else if (item.side === \"WITHDRAW\") {\n if (item.trans_status !== \"FAILED\") {\n value = convertToUSDCAndOperate({\n token: item.token,\n amount: item.amount,\n value,\n op: \"add\",\n });\n }\n }\n }\n }\n\n value = value\n .sub(inputs.transferHistory.IN)\n .add(inputs.transferHistory.OUT);\n\n return value.toNumber();\n };\n\n const calculate = (\n data: API.DailyRow[],\n totalValue: number | null,\n totalTransferIn: Decimal,\n totalTransferOut: Decimal,\n ) => {\n const lastItem = data[data.length - 1];\n\n return {\n ...lastItem,\n date: getUTCStr(today),\n perp_volume: 0,\n account_value:\n totalValue !== null ? totalValue : (lastItem?.account_value ?? 0),\n pnl:\n calculateLastPnl({\n lastItem,\n assetHistory,\n totalValue,\n transferHistory: {\n OUT: totalTransferOut,\n IN: totalTransferIn,\n },\n }) ?? 0,\n __isCalculated: true,\n };\n };\n\n const mergeData = (\n data: ReadonlyArray<API.DailyRow> | API.DailyRow[],\n totalValue: number | null,\n totalTransferIn: Decimal,\n totalTransferOut: Decimal,\n ) => {\n if (!Array.isArray(data) || data.length === 0) {\n return data;\n }\n\n if (data[data.length - 1].date === getUTCStr(today)) {\n return data;\n }\n\n return data.concat([\n calculate(data, totalValue, totalTransferIn, totalTransferOut),\n ]);\n };\n\n const calculateData = (\n data: ReadonlyArray<API.DailyRow> | API.DailyRow[],\n realtime: boolean,\n totalValue: number | null,\n totalTransferIn: Decimal,\n totalTransferOut: Decimal,\n ) => {\n const _data = !realtime\n ? data\n : mergeData(data, totalValue, totalTransferIn, totalTransferOut);\n\n return _data.slice(Math.max(0, _data.length - periodValue));\n };\n\n const calculatedData = useMemo(() => {\n /**\n * need the totalValue and data are all ready, else return null;\n */\n if (totalValue === null) {\n return [];\n }\n // if the transferOutHistory or transferInHistory is not ready, return null;\n\n if (totalTransferOut === null || totalTransferIn === null) {\n return [];\n }\n return calculateData(\n data,\n isRealtime,\n totalValue,\n totalTransferIn,\n totalTransferOut,\n );\n }, [\n data,\n totalValue,\n assetHistory,\n isRealtime,\n getIndexPrice,\n // transferOutHistory,\n // transferInHistory,\n totalTransferIn,\n totalTransferOut,\n ]);\n\n const aggregateValue = useMemo(() => {\n let vol = zero;\n let pnl = zero;\n let roi = zero;\n\n if (Array.isArray(calculatedData) && calculatedData.length) {\n calculatedData.forEach((d) => {\n // vol = vol.add(d.perp_volume);\n pnl = pnl.add(d.pnl);\n });\n\n const tail = calculatedData[0];\n\n const dataTailIndex = data.findIndex((d) => d.date === tail.date);\n\n const lastAccountValue = data[dataTailIndex - 1]?.account_value;\n\n // console.log(data, calculatedData, tail, dataTailIndex);\n\n if (typeof lastAccountValue === \"undefined\" || lastAccountValue === 0) {\n roi = zero;\n } else {\n roi = pnl.div(\n totalTransferInForROI.add(lastAccountValue).add(totalDepositForROI),\n );\n }\n }\n\n if (data.length > 0) {\n for (let i = 0; i < periodValue; i++) {\n const item = data[data.length - 1 - i];\n\n if (item) {\n vol = vol.add(item.perp_volume ?? 0);\n }\n }\n }\n\n // console.log(\"---------------------------\");\n\n return { vol: vol.toNumber(), pnl: pnl.toNumber(), roi: roi.toNumber() };\n }, [\n calculatedData,\n data,\n periodValue,\n totalTransferInForROI,\n totalDepositForROI,\n ]);\n\n const createFakeData = (\n start: Partial<API.DailyRow>,\n end: Partial<API.DailyRow>,\n ) => {\n return Array.from({ length: 2 }, (_, i) => {\n const date = format(i === 0 ? startDate : new Date(), \"yyyy-MM-dd\");\n return { date, ...(i === 0 ? start : end) };\n });\n };\n\n return {\n periodTypes,\n period: period as PeriodType,\n onPeriodChange: onPeriodChange,\n periodLabel: periodLabel,\n curPeriod: periodLabel[period as PeriodType],\n // data: calculatedDataUpdateByIndexPrice, // calculatedData,\n data: calculatedData, // calculatedData,\n aggregateValue,\n createFakeData,\n volumeUpdateDate: data?.[data.length - 1]?.date ?? \"\",\n } as const;\n};\n\nexport type useAssetsHistoryDataReturn = ReturnType<\n typeof useAssetsHistoryData\n>;\n\nfunction getUTCStr(date: Date) {\n const year = date.getUTCFullYear();\n const month = `0${date.getUTCMonth() + 1}`.slice(-2);\n const day = `0${date.getUTCDate()}`.slice(-2);\n\n return `${year}-${month}-${day}`;\n}\n","import React, { useMemo } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { CardTitle, Flex, Select } from \"@orderly.network/ui\";\nimport { PeriodType } from \"./useAssetHistory\";\n\nexport const PeriodTitle: React.FC<{\n onPeriodChange: (period: PeriodType) => void;\n periodTypes: string[];\n period: PeriodType;\n title: string;\n}> = (props) => {\n const { t } = useTranslation();\n\n const periodLabel = useMemo(() => {\n return {\n [PeriodType.WEEK]: t(\"common.select.7d\"),\n [PeriodType.MONTH]: t(\"common.select.30d\"),\n [PeriodType.QUARTER]: t(\"common.select.90d\"),\n };\n }, [t]);\n\n return (\n <Flex itemAlign={\"center\"} justify={\"between\"}>\n <CardTitle>{props.title}</CardTitle>\n <div className={\"oui-min-w-14\"}>\n <Select.options\n size={\"xs\"}\n value={props.period}\n onValueChange={props.onPeriodChange}\n options={props.periodTypes.map((item) => ({\n value: item,\n label: periodLabel[item as PeriodType],\n }))}\n />\n </div>\n </Flex>\n );\n};\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport React from \"react\";\nimport { AssetAreaChart } from \"@orderly.network/chart\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { Card } from \"@orderly.network/ui\";\nimport { useAssetsChartScriptReturn } from \"./assetsChart.script\";\n\nconst LazyPeriodTitle = React.lazy(() =>\n import(\"../shared/periodHeader\").then((mod) => {\n return { default: mod.PeriodTitle };\n }),\n);\n\nexport type AssetsLineChartProps = {} & useAssetsChartScriptReturn;\n\nexport const AssetsChart: React.FC<AssetsLineChartProps> = (props) => {\n const { onPeriodChange, data, periodTypes, period } = props;\n const { t } = useTranslation();\n return (\n <Card\n title={\n <React.Suspense fallback={null}>\n <LazyPeriodTitle\n onPeriodChange={onPeriodChange}\n periodTypes={periodTypes}\n period={period}\n title={t(\"common.assets\")}\n />\n </React.Suspense>\n }\n id=\"portfolio-overview-assets-chart\"\n classNames={{ content: \"oui-h-[168px] oui-pb-0\" }}\n >\n <React.Suspense fallback={null}>\n <AssetAreaChart data={data as any} invisible={props.invisible} />\n </React.Suspense>\n </Card>\n );\n};\n","import React from \"react\";\nimport { useAssetsChartScript } from \"./assetsChart.script\";\nimport { AssetsChart } from \"./assetsChart.ui\";\n\nexport const AssetsChartWidget: React.FC = () => {\n const state = useAssetsChartScript();\n return <AssetsChart {...state} />;\n};\n","export { AssetsChartWidget } from \"./assetsChart.widget\";\nexport { useAssetsChartScript } from \"./assetsChart.script\";\nexport { AssetsChart } from \"./assetsChart.ui\";\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport React from \"react\";\nimport { PnlAreaChart, PnLBarChart } from \"@orderly.network/chart\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { EMPTY_LIST } from \"@orderly.network/types\";\nimport {\n Card,\n Grid,\n Box,\n Statistic,\n Text,\n Flex,\n Tooltip,\n cn,\n} from \"@orderly.network/ui\";\nimport type { UsePerformanceScriptReturn } from \"./performance.script\";\n\nconst LazyPeriodTitle = React.lazy(() =>\n import(\"../shared/periodHeader\").then((mod) => {\n return { default: mod.PeriodTitle };\n }),\n);\n\nexport type PerformanceUIProps = {\n // periodTypes: string[];\n // period: string;\n // onPeriodChange: (period: string) => void;\n} & UsePerformanceScriptReturn;\n\nexport const PerformanceUI: React.FC<PerformanceUIProps> = (props) => {\n const {\n periodTypes,\n period,\n onPeriodChange,\n aggregateValue,\n invisible,\n visible,\n volumeUpdateDate,\n curPeriod,\n } = props;\n const { t } = useTranslation();\n\n return (\n <Card\n title={\n <React.Suspense fallback={null}>\n <LazyPeriodTitle\n onPeriodChange={onPeriodChange}\n periodTypes={periodTypes}\n period={period}\n title={t(\"portfolio.overview.performance\")}\n />\n </React.Suspense>\n }\n id=\"portfolio-overview-performance\"\n >\n <Grid cols={3} gap={4}>\n <Box\n gradient=\"neutral\"\n r=\"md\"\n px={4}\n py={2}\n angle={184}\n border\n borderColor={6}\n >\n <Statistic\n label={\n <LabelWithHint\n label={t(\"portfolio.overview.performance.roi\", {\n period: curPeriod,\n })}\n hint={t(\"portfolio.overview.performance.roi.tooltip\")}\n />\n }\n valueProps={{ rule: \"percentages\", coloring: true, visible }}\n >\n {invisible ? \"--\" : aggregateValue.roi}\n </Statistic>\n </Box>\n <Box\n gradient=\"neutral\"\n r=\"md\"\n px={4}\n py={2}\n angle={184}\n border\n borderColor={6}\n >\n <Statistic\n label={\n <LabelWithHint\n label={t(\"portfolio.overview.performance.pnl\", {\n period: curPeriod,\n })}\n hint={t(\"portfolio.overview.performance.pnl.tooltip\")}\n />\n }\n valueProps={{ coloring: true, showIdentifier: true, visible }}\n >\n {invisible ? \"--\" : aggregateValue.pnl}\n </Statistic>\n </Box>\n <Box\n gradient=\"neutral\"\n r=\"md\"\n px={4}\n py={2}\n angle={184}\n border\n borderColor={6}\n >\n <Statistic\n classNames={{\n label: \"oui-w-full\",\n }}\n label={\n <Flex justify={\"between\"}>\n <span>\n <LabelWithHint\n label={t(\"portfolio.overview.performance.volume\", {\n period: curPeriod,\n })}\n hint={t(\"portfolio.overview.performance.volume.tooltip\")}\n />\n </span>\n <span>{volumeUpdateDate}</span>\n </Flex>\n }\n valueProps={{ visible }}\n >\n {invisible ? \"--\" : aggregateValue.vol}\n </Statistic>\n </Box>\n </Grid>\n <Grid cols={2} gap={4}>\n <PerformancePnL\n data={props.data ?? EMPTY_LIST}\n invisible={props.invisible}\n />\n <CumulativePnlChart\n data={props.data ?? EMPTY_LIST}\n invisible={props.invisible || (props.data?.length ?? 0) <= 2}\n />\n </Grid>\n </Card>\n );\n};\n\ntype LabelWithHintProps = {\n label: string;\n hint?: React.ReactNode;\n};\n\nconst LabelWithHint: React.FC<LabelWithHintProps> = (props) => {\n const { label, hint } = props;\n return (\n <Tooltip\n open={hint ? undefined : false}\n content={hint}\n className=\"oui-max-w-[240px] oui-bg-base-6 \"\n arrow={{ className: \"oui-fill-base-6\" }}\n delayDuration={300}\n >\n <Text\n size=\"xs\"\n intensity={36}\n className={cn(\n hint &&\n \"oui-cursor-pointer oui-border-b oui-border-dashed oui-border-line-12\",\n )}\n >\n {label}\n </Text>\n </Tooltip>\n );\n};\n\nexport const PerformancePnL: React.FC<{\n data: ReadonlyArray<any> | any[];\n invisible: boolean;\n}> = (props) => {\n const { t } = useTranslation();\n return (\n <Box mt={4} height={\"188px\"}>\n <Text as=\"div\" size=\"sm\" className=\"oui-mb-3\">\n {t(\"portfolio.overview.performance.dailyPnl\")}\n </Text>\n <Box r=\"md\" className=\"oui-h-[188px] oui-border oui-border-line-4\">\n <PnLBarChart\n data={props.data}\n invisible={props.invisible || (props.data?.length ?? 0) <= 2}\n />\n </Box>\n </Box>\n );\n};\n\nexport const CumulativePnlChart: React.FC<{\n data: ReadonlyArray<any> | any[];\n invisible: boolean;\n}> = (props) => {\n const { t } = useTranslation();\n return (\n <Box mt={4}>\n <Text as=\"div\" size=\"sm\" className=\"oui-mb-3\">\n {t(\"portfolio.overview.performance.cumulativePnl\")}\n </Text>\n <Box r=\"md\" className=\"oui-h-[188px] oui-border oui-border-line-4\">\n <PnlAreaChart\n data={props.data}\n invisible={props.invisible || (props.data?.length ?? 0) <= 2}\n />\n </Box>\n </Box>\n );\n};\n","// Asset conversion types\nexport interface ConvertedAssets {\n [asset: string]: number;\n}\n\nexport interface ConvertTransaction {\n transaction_id: number;\n venue: \"on_chain\" | \"internal_fund\";\n converted_asset: string;\n received_asset: string;\n converted_qty: number;\n received_qty: number;\n haircut: number;\n chain_id?: number; // Optional, only for on_chain venue\n tx_id?: string; // Optional, only for on_chain venue\n result?: string;\n}\n\nexport interface ConvertRecord {\n convert_id: number;\n converted_asset: ConvertedAssets;\n received_asset: string;\n received_qty: number;\n type: \"auto\" | \"manual\";\n status: \"completed\" | \"pending\" | \"failed\" | \"cancelled\";\n created_time: number;\n updated_time: number;\n details: ConvertTransaction[];\n}\n\n// Additional utility types\nexport type ConvertType = \"auto\" | \"manual\";\n\nexport type ConvertStatus = \"completed\" | \"pending\" | \"failed\" | \"cancelled\";\n\nexport type VenueType = \"on_chain\" | \"internal_fund\";\n\nexport const ORDERLY_ASSETS_VISIBLE_KEY = \"orderly_assets_visible\";\n","import { useMemo } from \"react\";\nimport { useAccount, useLocalStorage } from \"@orderly.network/hooks\";\nimport { useAppContext, useDataTap } from \"@orderly.network/react-app\";\nimport { AccountStatusEnum } from \"@orderly.network/types\";\nimport { ORDERLY_ASSETS_VISIBLE_KEY } from \"../../assets/type\";\nimport { useOverviewContext } from \"../provider/overviewContext\";\n\nexport const usePerformanceScript = () => {\n const ctx = useOverviewContext();\n const [visible, setVisible] = useLocalStorage<boolean>(\n ORDERLY_ASSETS_VISIBLE_KEY,\n true,\n );\n\n const { wrongNetwork, disabledConnect } = useAppContext();\n const { state } = useAccount();\n const filteredData = useDataTap(ctx?.data, {\n accountStatus:\n state.status === AccountStatusEnum.EnableTradingWithoutConnected\n ? AccountStatusEnum.EnableTradingWithoutConnected\n : AccountStatusEnum.EnableTrading,\n fallbackData: ctx?.createFakeData?.(\n { account_value: 0, pnl: 0 },\n { account_value: 500, pnl: 500 },\n ),\n });\n\n const _data = useMemo(() => {\n if (filteredData?.length) {\n return filteredData;\n }\n return ctx?.createFakeData?.(\n { account_value: 0, pnl: 0 },\n { account_value: 500, pnl: 500 },\n );\n }, [ctx, filteredData]);\n\n const invisible =\n wrongNetwork ||\n disabledConnect ||\n (state.status < AccountStatusEnum.EnableTrading &&\n state.status !== AccountStatusEnum.EnableTradingWithoutConnected);\n\n return {\n ...ctx,\n data: _data as ReadonlyArray<any>,\n invisible,\n visible: visible as boolean,\n setVisible: setVisible,\n };\n};\n\nexport type UsePerformanceScriptReturn = ReturnType<\n typeof usePerformanceScript\n>;\n","import React from \"react\";\nimport { usePerformanceScript } from \"./performance.script\";\nimport { PerformanceUI } from \"./performance.ui\";\n\nexport const PerformanceWidget: React.FC = () => {\n const state = usePerformanceScript();\n return <PerformanceUI {...state} />;\n};\n","export { PerformanceUI } from \"./performance.ui\";\nexport { PerformanceWidget } from \"./performance.widget\";\nexport { usePerformanceScript } from \"./performance.script\";\n","import React, { useId } from \"react\";\n\nexport const EffectiveFee = React.forwardRef<\n SVGSVGElement,\n React.SVGAttributes<SVGSVGElement>\n>((props, ref) => {\n const linearId = useId();\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width={14}\n height={14}\n viewBox=\"0 0 14 14\"\n fill=\"currentColor\"\n ref={ref}\n focusable={false}\n {...props}\n >\n <path\n d=\"M6.16411 1.53106C6.61974 1.07566 7.35888 1.07551 7.81442 1.53106L8.48833 2.20496C8.6797 2.39624 8.93064 2.51452 9.19755 2.54106L9.3132 2.54676H10.2662C10.9104 2.54691 11.4328 3.06926 11.4329 3.71343V4.66647C11.4329 4.97589 11.5559 5.27312 11.7747 5.49191L12.4492 6.16582C12.9047 6.62142 12.9047 7.36054 12.4492 7.81613L11.7753 8.49004L11.6972 8.57549C11.5272 8.78302 11.433 9.04426 11.4329 9.31491V10.2685L11.4272 10.3876C11.3715 10.9366 10.9348 11.373 10.3859 11.4289L10.2662 11.4352H9.3132L9.19755 11.4409C8.93066 11.4674 8.67969 11.5857 8.48833 11.777L7.81442 12.4509L7.72555 12.5306C7.29789 12.8795 6.68066 12.8794 6.25297 12.5306L6.16411 12.4509L5.4902 11.777C5.29887 11.5857 5.04786 11.4675 4.78097 11.4409L4.66533 11.4352H3.71171L3.59265 11.4289C3.04358 11.3731 2.60705 10.9367 2.55131 10.3876L2.54505 10.2685V9.31491C2.54499 9.04416 2.45089 8.78306 2.28072 8.57549L2.20325 8.49004L1.52934 7.81613C1.10213 7.38905 1.07534 6.71297 1.44902 6.25469L1.52934 6.16582L2.20382 5.49191C2.42248 5.27314 2.54505 4.97579 2.54505 4.66647V3.71343C2.54513 3.10945 3.00442 2.61221 3.59265 2.55246L3.71171 2.54676H4.66533L4.78097 2.54106C5.00968 2.51826 5.22694 2.4281 5.40475 2.28244L5.4902 2.20496L6.16411 1.53106ZM6.31507 3.02983C5.87756 3.46727 5.28401 3.71336 4.66533 3.71343H3.71171V4.66647C3.71171 5.28521 3.46614 5.87922 3.02869 6.31678L2.35421 6.99069L3.02812 7.6646C3.46577 8.10214 3.71164 8.69607 3.71171 9.31491V10.2685H4.66533C5.28396 10.2686 5.87757 10.5142 6.31507 10.9515L6.98898 11.6255L7.66289 10.9515C8.10045 10.5141 8.69446 10.2685 9.3132 10.2685H10.2662V9.31491C10.2663 8.69604 10.5127 8.10214 10.9504 7.6646L11.6243 6.99069L10.9498 6.31678C10.5122 5.8792 10.2662 5.28531 10.2662 4.66647V3.71343H9.3132C8.69438 3.71343 8.10047 3.46739 7.66289 3.02983L6.98898 2.35592L6.31507 3.02983ZM8.52934 4.64255C8.7571 4.41479 9.12639 4.41489 9.35421 4.64255C9.58202 4.87035 9.58202 5.23961 9.35421 5.46742L5.4657 9.35593C5.2379 9.58372 4.86863 9.58373 4.64083 9.35593C4.41318 9.12811 4.41308 8.75881 4.64083 8.53106L8.52934 4.64255ZM8.66435 7.83265C9.1245 7.83272 9.49777 8.2059 9.49777 8.66607C9.49769 9.12616 9.12445 9.49941 8.66435 9.49948C8.20419 9.49948 7.83101 9.12621 7.83094 8.66607C7.83094 8.20586 8.20415 7.83265 8.66435 7.83265ZM5.33126 4.49956C5.79141 4.49963 6.16468 4.87282 6.16468 5.33298C6.1646 5.79307 5.79136 6.16575 5.33126 6.16582C4.87111 6.16582 4.49793 5.79311 4.49785 5.33298C4.49785 4.87277 4.87106 4.49956 5.33126 4.49956Z\"\n fill={`url(#${linearId})`}\n />\n <defs>\n <linearGradient\n id={linearId}\n x1=\"12.7908\"\n y1=\"6.99084\"\n x2=\"1.1875\"\n y2=\"6.99084\"\n gradientUnits=\"userSpaceOnUse\"\n >\n <stop stopColor=\"rgb(var(--oui-gradient-brand-end))\" />\n <stop stopColor=\"rgb(var(--oui-gradient-brand-start))\" offset={1} />\n </linearGradient>\n </defs>\n </svg>\n );\n});\n\nif (process.env.NODE_ENV !== \"production\") {\n EffectiveFee.displayName = \"EffectiveFee\";\n}\n","export * from \"./effectiveFee\";\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { useMemo } from \"react\";\nimport { useFeeState } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n Box,\n Flex,\n modal,\n Text,\n Tooltip,\n useModal,\n useScreen,\n} from \"@orderly.network/ui\";\nimport {\n RouterAdapter,\n useScaffoldContext,\n} from \"@orderly.network/ui-scaffold\";\nimport { Decimal } from \"@orderly.network/utils\";\nimport { useLayoutContext } from \"../../layout/context\";\nimport { EffectiveFee } from \"./icons\";\n\nexport type FeeTierHeaderItemProps = {\n label: string;\n value: React.ReactNode;\n interactive?: boolean;\n};\n\nexport type FeeTierHeaderProps = {\n tier?: number | null;\n vol?: number | null;\n headerDataAdapter?: (original: any[]) => any[];\n};\n\nconst isEffective = (val?: unknown) =>\n typeof val !== \"undefined\" && val !== null;\n\nconst EffectiveFeeDialog: React.FC<{\n routerAdapter: RouterAdapter | undefined;\n}> = (props) => {\n const { routerAdapter } = props;\n const { t } = useTranslation();\n const { hide } = useModal();\n return (\n <Text size=\"2xs\" className=\"oui-whitespace-normal oui-break-words\">\n {t(\"portfolio.feeTier.effectiveFee.tooltip\")}{\" \"}\n <a\n href=\"/rewards/affiliate\"\n onClick={(e) => {\n e.preventDefault();\n routerAdapter?.onRouteChange({\n href: \"/rewards/affiliate\",\n name: t(\"portfolio.feeTier.effectiveFee.tooltipLink\"),\n });\n hide();\n }}\n className=\"oui-cursor-pointer oui-border-none oui-bg-transparent oui-p-0 oui-text-2xs oui-underline hover:oui-text-base-contrast-80\"\n >\n {t(\"portfolio.feeTier.effectiveFee.tooltipLink\")}\n </a>\n </Text>\n );\n};\n\nexport const MobileHeaderItem: React.FC<FeeTierHeaderItemProps> = (props) => {\n const { label, value, interactive } = props;\n const { t } = useTranslation();\n const { routerAdapter } = useLayoutContext();\n return (\n <Flex justify=\"between\" itemAlign=\"center\" width=\"100%\">\n <Text\n as=\"div\"\n intensity={36}\n size=\"xs\"\n weight=\"semibold\"\n className=\"oui-leading-[18px]\"\n >\n {label}\n </Text>\n <Flex className=\"oui-gap-1.5\" itemAlign=\"center\" justify=\"between\">\n <Text size=\"xs\" intensity={80} className=\"oui-leading-[24px]\">\n {value}\n </Text>\n {interactive && (\n <Flex\n gap={1}\n justify=\"center\"\n itemAlign=\"center\"\n className=\"oui-cursor-pointer oui-rounded oui-bg-gradient-to-r oui-from-[rgb(var(--oui-gradient-brand-start)_/_0.12)] oui-to-[rgb(var(--oui-gradient-brand-end)_/_0.12)] oui-px-1\"\n onClick={() => {\n modal.dialog({\n size: \"sm\",\n title: t(\"common.tips\"),\n content: <EffectiveFeeDialog routerAdapter={routerAdapter} />,\n });\n }}\n >\n <EffectiveFee />\n <Text.gradient\n className=\"oui-select-none\"\n color={\"brand\"}\n size=\"3xs\"\n weight=\"regular\"\n >\n {t(\"common.effectiveFee\")}\n </Text.gradient>\n </Flex>\n )}\n </Flex>\n </Flex>\n );\n};\n\nexport const DesktopHeaderItem: React.FC<FeeTierHeaderItemProps> = (props) => {\n const { label, value, interactive } = props;\n const { t } = useTranslation();\n const { routerAdapter } = useScaffoldContext();\n return (\n <Box\n gradient=\"neutral\"\n r=\"lg\"\n px={4}\n py={2}\n angle={184}\n width=\"100%\"\n border\n borderColor={6}\n >\n <Text\n as=\"div\"\n intensity={36}\n size=\"2xs\"\n weight=\"semibold\"\n className=\"oui-leading-[18px]\"\n >\n {label}\n </Text>\n <Flex\n className=\"oui-mt-1 oui-w-full\"\n itemAlign=\"center\"\n justify=\"between\"\n >\n <Text size=\"base\" intensity={80} className=\"oui-leading-[24px]\">\n {value}\n </Text>\n {interactive && (\n <Tooltip\n content={\n <Text\n size=\"2xs\"\n className=\"oui-whitespace-normal oui-break-words\"\n >\n {t(\"portfolio.feeTier.effectiveFee.tooltip\")}{\" \"}\n <a\n href=\"/rewards/affiliate\"\n onClick={(e) => {\n e.preventDefault();\n routerAdapter?.onRouteChange({\n href: \"/rewards/affiliate\",\n name: t(\"portfolio.feeTier.effectiveFee.tooltipLink\"),\n });\n }}\n className=\"oui-cursor-pointer oui-border-none oui-bg-transparent oui-p-0 oui-text-2xs oui-underline hover:oui-text-base-contrast-80\"\n >\n {t(\"portfolio.feeTier.effectiveFee.tooltipLink\")}\n </a>\n </Text>\n }\n className=\"oui-p-1.5 oui-text-base-contrast-54\"\n >\n <Flex\n gap={1}\n justify=\"center\"\n itemAlign=\"center\"\n className=\"oui-cursor-pointer oui-rounded oui-bg-gradient-to-r oui-from-[rgb(var(--oui-gradient-brand-start)_/_0.12)] oui-to-[rgb(var(--oui-gradient-brand-end)_/_0.12)] oui-px-1\"\n >\n <EffectiveFee />\n <Text.gradient\n className=\"oui-select-none\"\n color={\"brand\"}\n size=\"xs\"\n weight=\"regular\"\n >\n {t(\"common.effectiveFee\")}\n </Text.gradient>\n </Flex>\n </Tooltip>\n )}\n </Flex>\n </Box>\n );\n};\n\nexport const FeeTierHeader: React.FC<FeeTierHeaderProps> = (props) => {\n const { t } = useTranslation();\n const { tier, vol, headerDataAdapter } = props;\n const { isMobile } = useScreen();\n const { refereeRebate, ...others } = useFeeState();\n const isEffectiveFee = isEffective(refereeRebate);\n const items: FeeTierHeaderItemProps[] = [\n {\n label: t(\"portfolio.feeTier.header.yourTier\"),\n interactive: false,\n value: (\n <Text.gradient\n color={\"brand\"}\n angle={270}\n size={isMobile ? \"xs\" : \"base\"}\n >\n {tier || \"--\"}\n </Text.gradient>\n ),\n },\n {\n label: `${t(\"portfolio.feeTier.header.30dVolume\")} (USDC)`,\n interactive: false,\n value: (\n <Text.numeral\n rule=\"price\"\n dp={2}\n rm={Decimal.ROUND_DOWN}\n size={isMobile ? \"xs\" : \"base\"}\n >\n {vol !== undefined && vol !== null ? `${vol}` : \"-\"}\n </Text.numeral>\n ),\n },\n {\n label: t(\"portfolio.feeTier.header.takerFeeRate\"),\n interactive: isEffectiveFee,\n value: (\n <Text.gradient\n color={\"brand\"}\n angle={270}\n size={isMobile ? \"xs\" : \"base\"}\n >\n {isEffectiveFee\n ? others.effectiveTakerFee || \"--\"\n : others.takerFee || \"--\"}\n </Text.gradient>\n ),\n },\n {\n label: t(\"portfolio.feeTier.header.makerFeeRate\"),\n interactive: isEffectiveFee,\n value: (\n <Text.gradient\n color={\"brand\"}\n angle={270}\n size={isMobile ? \"xs\" : \"base\"}\n >\n {isEffectiveFee\n ? others.effectiveMakerFee || \"--\"\n : others.makerFee || \"--\"}\n </Text.gradient>\n ),\n },\n ];\n\n const mergedData = useMemo<FeeTierHeaderItemProps[]>(() => {\n if (typeof headerDataAdapter === \"function\") {\n return headerDataAdapter(items);\n }\n return items;\n }, [headerDataAdapter, items]);\n\n if (!Array.isArray(mergedData)) {\n return null;\n }\n\n if (isMobile) {\n return (\n <Flex\n className=\"oui-rounded-xl oui-bg-base-9 oui-p-3\"\n direction=\"column\"\n gap={2}\n itemAlign={\"stretch\"}\n >\n {mergedData.map((item, index) => (\n <MobileHeaderItem {...item} key={`mobile-item-${index}`} />\n ))}\n </Flex>\n );\n }\n\n return (\n <Flex className=\"\" direction=\"row\" gapX={4} my={4} itemAlign={\"stretch\"}>\n {mergedData.map((item, index) => (\n <DesktopHeaderItem {...item} key={`desktop-item-${index}`} />\n ))}\n </Flex>\n );\n};\n","import { useEffect, useMemo, useState } from \"react\";\nimport {\n APIKeyItem,\n ScopeType,\n useAccount,\n useApiKeyManager,\n} from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { useAppContext, useDataTap } from \"@orderly.network/react-app\";\nimport { AccountStatusEnum } from \"@orderly.network/types\";\nimport { toast, usePagination } from \"@orderly.network/ui\";\n\nexport type GenerateKeyInfo = {\n key: string;\n screctKey: string;\n ip?: string;\n permissions?: string;\n};\n\nexport const useApiManagerScript = (props?: {\n filterTags?: [string];\n keyStatus?: string;\n}) => {\n const { filterTags, keyStatus } = props ?? {};\n const [showCreateDialog, setShowCreateDialog] = useState(false);\n const [showCreatedDialog, setShowCreatedDialog] = useState(false);\n const [generateKey, setGenerateKey] = useState<GenerateKeyInfo | undefined>();\n const { wrongNetwork, disabledConnect } = useAppContext();\n const { state, account } = useAccount();\n const { t } = useTranslation();\n\n const canCreateApiKey =\n !wrongNetwork &&\n !disabledConnect &&\n (state.status === AccountStatusEnum.EnableTrading ||\n state.status === AccountStatusEnum.EnableTradingWithoutConnected);\n\n const [\n keys,\n {\n generateOrderlyKey,\n setIPRestriction,\n removeOrderlyKey,\n resetOrderlyKeyIPRestriction,\n refresh,\n isLoading,\n error,\n },\n ] = useApiKeyManager({\n keyInfo: { key_status: keyStatus },\n });\n\n const [curPubKey, setCurPubKey] = useState<string | undefined>(undefined);\n\n useEffect(() => {\n account.keyStore\n .getOrderlyKey()\n ?.getPublicKey()\n .then((pubKey) => {\n setCurPubKey(pubKey);\n });\n }, [account, state]);\n\n const onCreateApiKey = () => {\n setShowCreateDialog(true);\n };\n const onReadApiGuide = () => {\n window.open(\n \"https://orderly.network/docs/build-on-omnichain/evm-api/api-authentication#api-authentication\",\n \"_blank\",\n );\n };\n\n const hideCreateDialog = () => {\n setShowCreateDialog(false);\n };\n\n const doCreate = async (\n ipRestriction?: string,\n scope?: ScopeType,\n ): Promise<number> => {\n try {\n const createdSuccess = (\n res: {\n key: string;\n secretKey: string;\n },\n ip?: string,\n ) => {\n const { key, secretKey } = res;\n hideCreateDialog();\n setGenerateKey({\n key: key,\n screctKey: secretKey,\n ip: ip,\n permissions: scope\n ?.split(\",\")\n ?.map((e) => capitalizeFirstChar(e))\n .join(\", \"),\n });\n setShowCreatedDialog(true);\n };\n\n const generateKeyRes = await generateOrderlyKey(scope);\n\n toast.success(t(\"portfolio.apiKey.created\"));\n console.log(\"xxx generateKeyRes\", generateKeyRes);\n\n if ((ipRestriction?.length || 0) > 0) {\n const key = generateKeyRes.key.startsWith(\"ed25519:\")\n ? generateKeyRes.key\n : `ed25519:${generateKeyRes.key}`;\n const res = await setIPRestriction(key, ipRestriction!);\n console.log(\"set ip res\", res);\n if (res.success) {\n createdSuccess(\n generateKeyRes,\n res.data.ip_restriction_list?.join(\",\"),\n );\n }\n } else {\n createdSuccess(generateKeyRes, undefined);\n }\n } catch (err: any) {\n if (err?.message) toast.error(err?.message);\n }\n\n return Promise.resolve(0);\n };\n\n const hideCreatedDialog = () => {\n setShowCreatedDialog(false);\n refresh();\n };\n\n const onCopyApiKeyInfo = () => {\n navigator.clipboard.writeText(JSON.stringify(generateKey));\n toast.success(t(\"portfolio.apiKey.apiInfo.copied\"));\n };\n const doConfirm = () => {\n hideCreatedDialog();\n };\n\n const doDelete = (item: APIKeyItem): Promise<any> => {\n return new Promise(async (resolve) => {\n await removeOrderlyKey(item.orderly_key)\n .then(\n async (data) => {\n if (data?.success) {\n toast.success(t(\"portfolio.apiKey.deleted\"));\n refresh();\n // delete current api key, wiil disconnect\n const curKey = await account.keyStore\n .getOrderlyKey()\n ?.getPublicKey();\n if (item.orderly_key === curKey) {\n account.destroyOrderlyKey();\n }\n }\n resolve(1);\n },\n (reject) => {},\n )\n .catch((err) => {});\n });\n };\n\n const doEdit = async (item: APIKeyItem, ip?: string): Promise<void> => {\n let future;\n if ((ip?.length || 0) === 0) {\n future = resetOrderlyKeyIPRestriction(item.orderly_key, \"ALLOW_ALL_IPS\");\n } else {\n future = setIPRestriction(item.orderly_key, ip!);\n }\n\n const data = await future;\n\n if (data.success) {\n toast.success(t(\"portfolio.apiKey.updated\"));\n refresh();\n return Promise.resolve();\n } else {\n toast.error(data.message);\n }\n return Promise.reject();\n };\n\n const onCopyAccountId = () =>\n toast.success(t(\"portfolio.apiKey.accountId.copied\"));\n const onCopyApiKey = (key?: string) => {\n if (typeof key !== \"undefined\") {\n navigator.clipboard.writeText(key.replace(\"ed25519:\", \"\"));\n }\n toast.success(t(\"portfolio.apiKey.column.apiKey.copy\"));\n };\n const onCopyApiSecretKey = () =>\n toast.success(t(\"portfolio.apiKey.secretKey.copied\"));\n const onCopyIP = () =>\n toast.success(t(\"portfolio.apiKey.column.restrictedIP.copy\"));\n\n const keyList = useMemo(() => {\n return keys?.filter((e) => {\n const filterTag = filterTags ? filterTags?.includes(e.tag) : true;\n const filterCurKey = curPubKey\n ? !e.orderly_key.includes(curPubKey)\n : true;\n return filterTag && filterCurKey;\n });\n }, [keys, filterTags, curPubKey]);\n\n const verifyIP = (ip: string) => {\n const ipRegex =\n /^((25[0-5]|2[0-4][0-9]|1[0-9]{2}|[1-9]?[0-9])\\.){3}(25[0-5]|2[0-4][0-9]|1[0-9]{2}|[1-9]?[0-9])(,((25[0-5]|2[0-4][0-9]|1[0-9]{2}|[1-9]?[0-9])\\.){3}(25[0-5]|2[0-4][0-9]|1[0-9]{2}|[1-9]?[0-9]))*$/;\n return ipRegex.test(ip)\n ? \"\"\n : \"The IP restriction format is incorrect. Please use the correct format: [xx.xx.xxx.x],[xx.xxx.xxx.xxx]\";\n };\n\n const accountStatus =\n state.status === AccountStatusEnum.EnableTradingWithoutConnected\n ? AccountStatusEnum.EnableTradingWithoutConnected\n : AccountStatusEnum.EnableTrading;\n\n const accountId = useDataTap(state.accountId, {\n accountStatus,\n });\n\n const userId = useDataTap(state.userId, {\n accountStatus,\n });\n\n const { pagination } = usePagination();\n\n return {\n accountId: accountId ?? \"--\",\n userId: userId ?? \"--\",\n onCreateApiKey,\n onReadApiGuide,\n showCreateDialog,\n hideCreateDialog,\n doCreate,\n showCreatedDialog,\n hideCreatedDialog,\n onCopyApiKeyInfo,\n doConfirm,\n doDelete,\n doEdit,\n canCreateApiKey,\n status: state.status,\n keys: keyList,\n generateKey,\n onCopyAccountId,\n wrongNetwork,\n onCopyApiKey,\n onCopyApiSecretKey,\n onCopyIP,\n verifyIP,\n isLoading,\n pagination,\n };\n};\n\nexport function capitalizeFirstChar(str: string): string {\n return str.charAt(0).toUpperCase() + str.slice(1);\n}\n\nexport type ApiManagerScriptReturns = ReturnType<typeof useApiManagerScript>;\n","import { FC, useEffect, useState } from \"react\";\nimport { ScopeType } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { cn, Flex, SimpleDialog, Statistic, Text } from \"@orderly.network/ui\";\nimport { ApiManagerScriptReturns } from \"../apiManager.script\";\n\nexport const CreateAPIKeyDialog: FC<ApiManagerScriptReturns> = (props) => {\n const [ipText, setIpText] = useState(\"\");\n const [read, setRead] = useState(true);\n const [trade, setTrade] = useState(true);\n const [hint, setHint] = useState(\"\");\n const { t } = useTranslation();\n\n useEffect(() => {\n if (!props.showCreateDialog) {\n setIpText(\"\");\n setRead(true);\n setTrade(true);\n setHint(\"\");\n }\n }, [props.showCreateDialog]);\n\n useEffect(() => {\n if (ipText.length === 0) setHint(\"\");\n }, [ipText]);\n\n return (\n <SimpleDialog\n size=\"sm\"\n open={props.showCreateDialog}\n onOpenChange={(open) => {\n props.hideCreateDialog?.();\n }}\n title={t(\"portfolio.apiKey.create.dialog.title\")}\n actions={{\n primary: {\n label: t(\"common.confirm\"),\n className: \"oui-w-[120px] lg:oui-w-[154px]\",\n \"data-testid\": \"oui-testid-apiKey-createApiKey-dialog-comfirm-btn\",\n onClick: async () => {\n if (ipText.length > 0) {\n const hint = props.verifyIP(ipText);\n setHint(hint);\n if (hint.length > 0) {\n return;\n }\n }\n\n const scopes: string[] = [];\n if (read) {\n scopes.push(\"read\");\n }\n if (trade) {\n scopes.push(\"trading\");\n }\n await props.doCreate(ipText, scopes.join(\",\") as ScopeType);\n },\n disabled: !trade && !read,\n size: \"md\",\n },\n }}\n classNames={{\n footer: \"oui-justify-center\",\n content:\n \"oui-bg-base-8 oui-w-[300px] lg:oui-w-[360px] oui-font-semibold\",\n }}\n >\n <Flex direction={\"column\"} gap={6}>\n <Flex direction={\"column\"} gap={1} width={\"100%\"} itemAlign={\"start\"}>\n <Text intensity={54} size=\"2xs\">\n {t(\"portfolio.apiKey.create.ipRestriction\")}\n </Text>\n <textarea\n data-testid=\"oui-testid-apiKey-createApiKey-dialog-textarea\"\n placeholder={t(\"portfolio.apiKey.create.ipRestriction.placeholder\")}\n className={cn(\n \"oui-h-[100px] oui-w-full oui-rounded-xl oui-bg-base-6 oui-p-3 oui-text-sm oui-text-base-contrast-80\",\n \"oui-border-0 oui-outline-none focus:oui-border-2 focus:oui-border-primary-darken\",\n \"oui-placeholder-base-contrast-20\",\n hint.length > 0 &&\n \"oui-outline-1 oui-outline-danger focus:oui-outline-none\",\n )}\n value={ipText}\n onChange={(e) => {\n setIpText(e.target.value);\n }}\n style={{\n resize: \"none\",\n }}\n />\n {hint.length > 0 && (\n <Flex gap={1} className=\"oui-relative\">\n <div\n className={cn(\n \"oui-absolute oui-top-[10px]\",\n \"oui-size-1 oui-rounded-full oui-bg-danger\",\n )}\n />\n <Text color=\"danger\" size=\"xs\" className=\"oui-ml-2\">\n {hint}\n </Text>\n </Flex>\n )}\n </Flex>\n <Statistic\n label={\n <Text size=\"xs\" intensity={54}>\n {t(\"portfolio.apiKey.permissions\")}\n </Text>\n }\n className=\"oui-w-full\"\n >\n <Flex\n direction={\"row\"}\n gap={6}\n itemAlign={\"start\"}\n className=\"oui-mt-2\"\n >\n <Checkbox\n size={18}\n checked={read}\n onCheckedChange={(e) => setRead(e as boolean)}\n label={t(\"portfolio.apiKey.permissions.read\")}\n testid=\"oui-testid-apiKey-createApiKey-dialog-read-checkbox\"\n />\n <Checkbox\n size={18}\n checked={trade}\n onCheckedChange={(e) => setTrade(e as boolean)}\n label={t(\"portfolio.apiKey.permissions.trading\")}\n testid=\"oui-testid-apiKey-createApiKey-dialog-trading-checkbox\"\n />\n </Flex>\n </Statistic>\n </Flex>\n </SimpleDialog>\n );\n};\n\nexport const Checkbox: FC<{\n size?: number;\n checked: boolean;\n onCheckedChange: (checked?: boolean) => void;\n disabled?: boolean;\n label: string;\n testid?: string;\n}> = (props) => {\n return (\n <button\n disabled={props.disabled}\n onClick={(e) => {\n props.onCheckedChange(!props.checked);\n }}\n className={\n \"oui-flex oui-items-center oui-gap-2 disabled:oui-cursor-not-allowed disabled:oui-opacity-50\"\n }\n data-testid={props.testid}\n >\n {props.checked ? (\n <svg\n width={\"props.size\"}\n height={props.size}\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M6.99072 2.92981C4.78172 2.92981 2.99072 4.72071 2.99072 6.92981V16.9298C2.99072 19.1389 4.78172 20.9298 6.99072 20.9298H16.9907C19.1997 20.9298 20.9907 19.1389 20.9907 16.9298V6.92981C20.9907 4.72071 19.1997 2.92981 16.9907 2.92981H6.99072ZM16.9853 7.31211C17.2125 7.09537 17.5236 7 17.8218 7C18.1201 7 18.4312 7.09537 18.6584 7.31211C19.1139 7.74546 19.1139 8.47384 18.6584 8.9072L10.5077 16.675C10.0534 17.1083 9.28909 17.1083 8.83472 16.675L5.34077 13.3459C4.88641 12.9126 4.88641 12.1841 5.34077 11.7508C5.79631 11.3175 6.56057 11.3175 7.01493 11.7508L9.67122 14.2822L16.9853 7.31211Z\"\n fill=\"white\"\n fillOpacity=\"0.54\"\n />\n </svg>\n ) : (\n <svg\n width={props.size}\n height={props.size}\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M6.99072 2.92981C4.78172 2.92981 2.99072 4.72071 2.99072 6.92981V16.9298C2.99072 19.1389 4.78172 20.9298 6.99072 20.9298H16.9907C19.1997 20.9298 20.9907 19.1389 20.9907 16.9298V6.92981C20.9907 4.72071 19.1997 2.92981 16.9907 2.92981H6.99072ZM6.99072 4.92981H16.9907C18.0957 4.92981 18.9907 5.82521 18.9907 6.92981V16.9298C18.9907 18.0344 18.0957 18.9298 16.9907 18.9298H6.99072C5.88572 18.9298 4.99072 18.0344 4.99072 16.9298V6.92981C4.99072 5.82521 5.88572 4.92981 6.99072 4.92981Z\"\n fill=\"white\"\n fillOpacity=\"0.54\"\n />\n </svg>\n )}\n\n <Text\n intensity={54}\n size=\"sm\"\n className=\"oui-whitespace-nowrap oui-break-normal\"\n >\n {props.label}\n </Text>\n </button>\n );\n};\n","import { FC } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n Box,\n CopyIcon,\n Flex,\n SimpleDialog,\n Statistic,\n Text,\n} from \"@orderly.network/ui\";\nimport { ApiManagerScriptReturns } from \"../apiManager.script\";\n\nexport const CreatedAPIKeyDialog: FC<ApiManagerScriptReturns> = (props) => {\n const ip = props.generateKey?.ip ?? \"--\";\n const { t } = useTranslation();\n return (\n <SimpleDialog\n size=\"sm\"\n open={props.showCreatedDialog}\n onOpenChange={(open) => {\n props.hideCreatedDialog?.();\n }}\n title={t(\"portfolio.apiKey.created\")}\n actions={{\n primary: {\n label: t(\"common.ok\"),\n \"data-testid\": \"oui-testid-apiKey-createdApiKey-dialog-ok-btn\",\n className:\n \"oui-w-[120px] lg:oui-w-[154px] oui-bg-base-2 hover:oui-bg-base-3\",\n size: \"md\",\n onClick: async () => {\n return props.doConfirm();\n },\n },\n secondary: {\n label: t(\"portfolio.apiKey.created.button.copyApiInfo\"),\n \"data-testid\": \"oui-testid-apiKey-createdApiKey-dialog-copy-btn\",\n className:\n \"oui-w-[120px] lg:oui-w-[154px] oui-bg-primary-darken hover:oui-opacity-80\",\n size: \"md\",\n onClick: async () => {\n return props.onCopyApiKeyInfo();\n },\n },\n }}\n classNames={{\n footer: \"oui-justify-center\",\n content:\n \"oui-bg-base-8 oui-w-[300px] lg:oui-w-[360px] oui-font-semibold\",\n body: \"oui-py-0 oui-pt-5\",\n }}\n >\n <Flex direction={\"column\"} gap={4} itemAlign={\"start\"}>\n <Statistic label={t(\"common.accountId\")}>\n <Text.formatted\n size=\"sm\"\n intensity={80}\n copyable\n copyIconSize={16}\n className=\"oui-break-all\"\n onCopy={props.onCopyAccountId}\n data-testid=\"oui-testid-apiKey-createdApiKey-dialog-key-span\"\n >\n {props.accountId}\n </Text.formatted>\n </Statistic>\n <Statistic label={t(\"portfolio.apiKey.column.apiKey\")}>\n <Text.formatted\n size=\"sm\"\n intensity={80}\n copyable\n copyIconSize={16}\n className=\"oui-break-all\"\n onCopy={() => props.onCopyApiKey(props.generateKey?.key)}\n data-testid=\"oui-testid-apiKey-createdApiKey-dialog-key-span\"\n >\n {props.generateKey?.key}\n </Text.formatted>\n </Statistic>\n <Statistic label={t(\"portfolio.apiKey.secretKey\")}>\n <Text.formatted\n size=\"sm\"\n intensity={80}\n copyable\n copyIconSize={16}\n className=\"oui-break-all\"\n onCopy={props.onCopyApiSecretKey}\n >\n {props.generateKey?.screctKey}\n </Text.formatted>{\" \"}\n </Statistic>\n <Statistic label={t(\"portfolio.apiKey.ip\")}>\n <Flex\n width={320}\n gap={1}\n itemAlign={\"center\"}\n className=\"oui-text-base-contrast-80 oui-text-sm\"\n >\n <Box className=\"oui-max-h-[100px] oui-flex-1 oui-overflow-hidden oui-text-ellipsis oui-line-clamp-5 oui-break-all\">\n {ip}\n </Box>\n {ip !== \"--\" && (\n <Box\n width={16}\n height={16}\n className=\"oui-cursor-pointer oui-flex-shrink-0\"\n >\n <CopyIcon\n color=\"white\"\n opacity={0.54}\n size={16}\n onClick={(e) => {\n if (props.generateKey?.ip)\n navigator.clipboard.writeText(props.generateKey?.ip);\n props?.onCopyIP();\n }}\n />\n </Box>\n )}\n </Flex>\n </Statistic>\n <Statistic label={t(\"portfolio.apiKey.permissions\")}>\n <Text\n size=\"sm\"\n intensity={80}\n data-testid=\"oui-testid-apiKey-createdApiKey-dialog-permissions-span\"\n >\n {props.generateKey?.permissions}\n </Text>\n </Statistic>\n <div></div>\n <Text color=\"warning\" size=\"xs\" className=\"oui-text-center\">\n {t(\"portfolio.apiKey.created.warning\")}\n </Text>\n </Flex>\n </SimpleDialog>\n );\n};\n","import { FC } from \"react\";\nimport { Flex, SimpleDialog, Text } from \"@orderly.network/ui\";\nimport { APIKeyItem } from \"@orderly.network/hooks\";\nimport { formatKey } from \"../apiManager.ui\";\nimport { useTranslation, Trans } from \"@orderly.network/i18n\";\n\nexport const DeleteAPIKeyDialog: FC<{\n item: APIKeyItem;\n open: boolean;\n setOpen?: any;\n onDelete?: (item: APIKeyItem) => Promise<void>;\n}> = (props) => {\n const { item, open, setOpen, onDelete } = props;\n const { t } = useTranslation();\n return (\n <SimpleDialog\n size=\"sm\"\n open={open}\n onOpenChange={setOpen}\n title={t(\"portfolio.apiKey.delete.dialog.title\")}\n actions={{\n primary: {\n label: t(\"common.confirm\"),\n \"data-testid\": \"oui-testid-apiKey-deleteApiKey-dialog-confirm-btn\",\n className: \"oui-w-[120px] lg:oui-w-[154px]\",\n size: \"md\",\n onClick: async () => {\n await props.onDelete?.(item);\n setOpen(false);\n },\n },\n secondary: {\n label: t(\"common.cancel\"),\n className: \"oui-w-[120px] lg:oui-w-[154px]\",\n size: \"md\",\n onClick: async () => {\n setOpen(false);\n },\n },\n }}\n classNames={{\n footer: \"oui-justify-center\",\n content:\n \"oui-bg-base-8 oui-w-[300px] lg:oui-w-[360px] oui-font-semibold\",\n }}\n >\n <Flex className=\"oui-text-xs\">\n {/* @ts-ignore */}\n <Trans\n i18nKey=\"portfolio.apiKey.delete.dialog.description\"\n values={{ apiKey: formatKey(item?.orderly_key) }}\n components={[<Text color=\"primary\" className=\"oui-px-1\" />]}\n />\n </Flex>\n </SimpleDialog>\n );\n};\n","import { FC, useEffect, useState } from \"react\";\nimport { APIKeyItem } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { cn, Flex, SimpleDialog, Statistic, Text } from \"@orderly.network/ui\";\nimport { Checkbox } from \"./createApiKey\";\n\nexport const EditAPIKeyDialog: FC<{\n item: APIKeyItem;\n open: boolean;\n setOpen?: any;\n onUpdate?: (item: APIKeyItem, ip?: string) => Promise<void>;\n verifyIP: (ip: string) => string;\n}> = (props) => {\n const { item, open, setOpen, onUpdate } = props;\n const [ipText, setIpText] = useState(item.ip_restriction_list?.join(\",\"));\n const [read, setRead] = useState(true);\n const [trade, setTrade] = useState(true);\n const [hint, setHint] = useState(\"\");\n const { t } = useTranslation();\n\n useEffect(() => {\n setIpText(item.ip_restriction_list.join(\",\"));\n const scope = item.scope?.toLocaleLowerCase() || \"\";\n\n setRead(scope.includes(\"read\"));\n setTrade(scope.includes(\"trading\"));\n }, [item]);\n\n useEffect(() => {\n if (ipText.length === 0) setHint(\"\");\n }, [ipText]);\n\n return (\n <SimpleDialog\n size=\"sm\"\n open={open}\n onOpenChange={setOpen}\n title={t(\"portfolio.apiKey.edit.dialog.title\")}\n actions={{\n primary: {\n label: t(\"common.confirm\"),\n \"data-testid\": \"oui-testid-apiKey-editApiKey-dialog-confirm-btn\",\n className: \"oui-w-[120px] lg:oui-w-[154px]\",\n onClick: async () => {\n if (ipText.length > 0) {\n const hint = props.verifyIP(ipText);\n setHint(hint);\n if (hint.length > 0) {\n return;\n }\n }\n await props.onUpdate?.(item, ipText);\n setOpen(false);\n },\n disabled: item.ip_restriction_list.join(\",\") === ipText,\n size: \"md\",\n fullWidth: true,\n },\n }}\n classNames={{\n footer: \"oui-justify-center\",\n content:\n \"oui-bg-base-8 oui-w-[300px] lg:oui-w-[360px] oui-font-semibold\",\n }}\n >\n <Flex direction={\"column\"} gap={6}>\n {/* <TextField label={\"IP restriction (optional)\"} rows={5} className=\"oui-w-full oui-h-auto\" classNames={{\n input: \"oui-h-[100px]\",\n root: \"oui-h-[100px]\"\n }}/> */}\n <Flex direction={\"column\"} gap={1} width={\"100%\"} itemAlign={\"start\"}>\n <Text intensity={54} size=\"2xs\">\n {t(\"portfolio.apiKey.create.ipRestriction\")}\n </Text>\n <textarea\n data-testid=\"oui-testid-apiKey-editApiKey-dialog-textarea\"\n placeholder={t(\"portfolio.apiKey.create.ipRestriction.placeholder\")}\n className={cn(\n \"oui-h-[100px] oui-w-full oui-rounded-xl oui-bg-base-6 oui-p-3 oui-text-sm oui-text-base-contrast-80\",\n \"oui-border-0 oui-outline-none focus:oui-border-2 focus:oui-border-primary-darken\",\n \"oui-placeholder-base-contrast-20\",\n hint.length > 0 &&\n \"oui-outline-1 oui-outline-danger focus:oui-outline-none\",\n )}\n value={ipText}\n onChange={(e) => {\n setIpText(e.target.value);\n }}\n style={{\n resize: \"none\",\n }}\n />\n {hint.length > 0 && (\n <Flex gap={1} className=\"oui-relative\">\n <div\n className={cn(\n \"oui-absolute oui-top-[10px]\",\n \"oui-size-1 oui-rounded-full oui-bg-danger\",\n )}\n />\n <Text color=\"danger\" size=\"xs\" className=\"oui-ml-2\">\n {hint}\n </Text>\n </Flex>\n )}\n </Flex>\n <Statistic\n label={\n <Text size=\"xs\" intensity={54}>\n {t(\"portfolio.apiKey.permissions\")}\n </Text>\n }\n className=\"oui-w-full\"\n >\n <Flex\n direction={\"row\"}\n gap={6}\n itemAlign={\"start\"}\n className=\"oui-mt-2\"\n >\n <Checkbox\n disabled\n size={18}\n checked={read}\n onCheckedChange={(e) => setRead(e as boolean)}\n label={t(\"portfolio.apiKey.permissions.read\")}\n />\n <Checkbox\n disabled\n size={18}\n checked={trade}\n onCheckedChange={(e) => setTrade(e as boolean)}\n label={t(\"portfolio.apiKey.permissions.trading\")}\n />\n </Flex>\n </Statistic>\n </Flex>\n </SimpleDialog>\n );\n};\n","import React, { useState } from \"react\";\nimport { APIKeyItem } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n Box,\n Button,\n Card,\n CopyIcon,\n Flex,\n PlusIcon,\n Column,\n Text,\n Tooltip,\n} from \"@orderly.network/ui\";\nimport {\n AuthGuardEmpty,\n AuthGuardDataTable,\n AuthGuardTooltip,\n} from \"@orderly.network/ui-connector\";\nimport {\n type ApiManagerScriptReturns,\n capitalizeFirstChar,\n} from \"./apiManager.script\";\n\nconst LazyCreateAPIKeyDialog = React.lazy(() =>\n import(\"./dialog/createApiKey\").then((mod) => {\n return { default: mod.CreateAPIKeyDialog };\n }),\n);\n\nconst LazyCreatedAPIKeyDialog = React.lazy(() =>\n import(\"./dialog/createdApiKey\").then((mod) => {\n return { default: mod.CreatedAPIKeyDialog };\n }),\n);\n\nconst LazyDeleteAPIKeyDialog = React.lazy(() =>\n import(\"./dialog/deleteApiKey\").then((mod) => {\n return { default: mod.DeleteAPIKeyDialog };\n }),\n);\n\nconst LazyEditAPIKeyDialog = React.lazy(() =>\n import(\"./dialog/editApiKey\").then((mod) => {\n return { default: mod.EditAPIKeyDialog };\n }),\n);\n\nexport const APIManager: React.FC<ApiManagerScriptReturns> = (props) => {\n const { t } = useTranslation();\n return (\n <Card\n title={t(\"portfolio.apiKeys\")}\n id=\"portfolio-apikey-manager\"\n className=\"oui-bg-base-9 oui-font-semibold\"\n >\n <Flex\n direction={\"column\"}\n gap={4}\n width={\"100%\"}\n className=\"oui-font-semibold\"\n >\n <AccountInfo {...props} />\n <Subtitle {...props} />\n </Flex>\n <div>\n <KeyList {...props} />\n <React.Suspense fallback={null}>\n <LazyCreateAPIKeyDialog {...props} />\n </React.Suspense>\n <React.Suspense fallback={null}>\n <LazyCreatedAPIKeyDialog {...props} />\n </React.Suspense>\n </div>\n </Card>\n );\n};\n\nconst AccountInfo: React.FC<ApiManagerScriptReturns> = (props) => {\n const { t } = useTranslation();\n return (\n <Flex\n width={\"100%\"}\n gap={4}\n className=\"oui-border-t-2 oui-border-line-6 oui-pt-4\"\n >\n <Flex\n py={2}\n px={4}\n direction={\"column\"}\n itemAlign={\"start\"}\n r=\"xl\"\n gradient=\"neutral\"\n angle={27}\n border\n className=\"oui-w-1/2\"\n >\n <Text size=\"xs\" intensity={36}>\n {t(\"common.accountId\")}\n </Text>\n <Text.formatted\n size=\"base\"\n inlist={80}\n rule={\"address\"}\n copyable={props.accountId !== \"--\"}\n copyIconSize={16}\n onCopy={props.onCopyAccountId}\n copyIconTestid=\"oui-testid-apiKey-accountInfo-accountId-copy-btn\"\n >\n {props.accountId}\n </Text.formatted>\n </Flex>\n <Flex\n py={2}\n px={4}\n direction={\"column\"}\n itemAlign={\"start\"}\n r=\"xl\"\n gradient=\"neutral\"\n angle={27}\n border\n className=\"oui-w-1/2\"\n >\n <Text size=\"xs\" intensity={36}>\n {t(\"portfolio.apiKey.uid\")}\n </Text>\n <Text size=\"base\" inlist={80}>\n {props.userId}\n </Text>\n </Flex>\n </Flex>\n );\n};\n\nconst Subtitle: React.FC<ApiManagerScriptReturns> = (props) => {\n const { t } = useTranslation();\n return (\n <Flex\n width={\"100%\"}\n direction={\"row\"}\n className=\"oui-text-sm oui-border-b-2 oui-border-line-6 oui-pb-4\"\n >\n <Flex direction={\"column\"} itemAlign={\"start\"} width={\"100%\"} gap={1}>\n <Text intensity={54}>{t(\"portfolio.apiKey.description\")}</Text>\n <Flex\n itemAlign={\"center\"}\n className=\"oui-text-primary-light oui-fill-primary-light hover:oui-text-primary-darken oui-cursor-pointer oui-text-2xs md:oui-text-xs xl:oui-text-sm\"\n onClick={props.onReadApiGuide}\n >\n <Text>{t(\"portfolio.apiKey.readApiGuide\")}</Text>\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"currentColor\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path d=\"M4.008 7.995c0-.368.298-.666.666-.666H9.71L7.733 5.331l.937-.936 3.143 3.122c.13.13.195.304.195.479a.67.67 0 0 1-.195.478L8.67 11.596l-.937-.937 1.978-1.998H4.674a.666.666 0 0 1-.666-.666\" />\n </svg>\n </Flex>\n </Flex>\n <AuthGuardTooltip\n side=\"top\"\n tooltip={{\n connectWallet: t(\"portfolio.apiKey.create.connectWallet.tooltip\"),\n signIn: t(\"portfolio.apiKey.create.createAccount.tooltip\"),\n enableTrading: t(\"portfolio.apiKey.create.enableTrading.tooltip\"),\n wrongNetwork: t(\"portfolio.apiKey.create.wrongNetwork.tooltip\"),\n }}\n >\n <Button\n size=\"md\"\n icon={<PlusIcon />}\n variant=\"contained\"\n color=\"primary\"\n onClick={props.onCreateApiKey}\n disabled={!props.canCreateApiKey}\n // className=\"disabled:oui-cursor-default\"\n data-testid=\"oui-testid-apiKey-createApiKey-btn\"\n >\n {t(\"portfolio.apiKey.create.dialog.title\")}\n </Button>\n </AuthGuardTooltip>\n </Flex>\n );\n};\n\nconst KeyList: React.FC<ApiManagerScriptReturns> = (props) => {\n const { t } = useTranslation();\n const columns: Column<APIKeyItem>[] = [\n {\n title: t(\"portfolio.apiKey.column.apiKey\"),\n dataIndex: \"orderly_key\",\n render: (value) => {\n return (\n <Text.formatted\n rule={\"\"}\n copyable\n copyIconSize={16}\n onCopy={() => {\n props.onCopyApiKey?.(value);\n }}\n >\n {formatKey(value)}\n </Text.formatted>\n );\n },\n },\n {\n title: t(\"portfolio.apiKey.column.permissionType\"),\n dataIndex: \"scope\",\n render: (value) =>\n value\n ?.split(\",\")\n .map((e: any) => capitalizeFirstChar(`${e}`))\n .join(\", \"),\n },\n {\n title: t(\"portfolio.apiKey.column.restrictedIP\"),\n dataIndex: \"ip_restriction_list\",\n render: (value) => {\n let ip = value.join(\",\");\n if (ip.length === 0) {\n ip = \"--\";\n }\n return (\n <Tooltip content={ip} className=\"oui-max-w-[200px] oui-break-all\">\n <Flex gap={1}>\n <div className=\" oui-overflow-ellipsis oui-overflow-hidden\">\n {ip}\n </div>\n {ip !== \"--\" && (\n <Box width={16} height={16} className=\"oui-cursor-pointer\">\n <CopyIcon\n color=\"white\"\n opacity={0.54}\n size={16}\n onClick={(e) => {\n navigator.clipboard.writeText(ip);\n props?.onCopyIP();\n }}\n />\n </Box>\n )}\n </Flex>\n </Tooltip>\n );\n },\n },\n {\n title: t(\"portfolio.apiKey.column.expirationDate\"),\n dataIndex: \"expiration\",\n render: (value) => (\n <Text.formatted rule={\"date\"} formatString=\"yyyy-MM-dd\">\n {value}\n </Text.formatted>\n ),\n },\n {\n title: \"\",\n type: \"action\",\n dataIndex: \"action\",\n width: 120,\n render: (_, item) => {\n return (\n <Flex direction={\"row\"} gap={2}>\n <EditButton\n item={item}\n onUpdate={props.doEdit}\n verifyIP={props.verifyIP}\n />\n <DeleteButton item={item} onDelete={props.doDelete} />\n </Flex>\n );\n },\n },\n ];\n return (\n <AuthGuardDataTable\n bordered\n columns={columns}\n loading={props.isLoading}\n dataSource={props.keys}\n emptyView={<AuthGuardEmpty />}\n classNames={{}}\n pagination={props.pagination}\n manualPagination={false}\n />\n );\n};\n\nconst EditButton: React.FC<{\n item: APIKeyItem;\n onUpdate: (item: APIKeyItem, ip?: string) => Promise<void>;\n verifyIP: (ip: string) => string;\n}> = (props) => {\n const { item, onUpdate, verifyIP } = props;\n const [open, setOpen] = useState(false);\n const { t } = useTranslation();\n\n return (\n <>\n <Button\n size=\"xs\"\n color=\"primary\"\n variant=\"contained\"\n onClick={(e) => {\n e.stopPropagation();\n setOpen(true);\n }}\n data-testid=\"oui-testid-apiKey-keyList-edit-btn\"\n >\n {t(\"common.edit\")}\n </Button>\n {open && (\n <React.Suspense fallback={null}>\n <LazyEditAPIKeyDialog\n item={item}\n open={open}\n setOpen={setOpen}\n onUpdate={onUpdate}\n verifyIP={verifyIP}\n />\n </React.Suspense>\n )}\n </>\n );\n};\n\nconst DeleteButton: React.FC<{\n item: APIKeyItem;\n onDelete: (item: APIKeyItem) => Promise<void>;\n}> = (props) => {\n const { item, onDelete } = props;\n const [open, setOpen] = useState(false);\n const { t } = useTranslation();\n return (\n <>\n <Button\n size=\"xs\"\n color=\"gray\"\n variant=\"contained\"\n onClick={(e) => {\n e.stopPropagation();\n setOpen(true);\n }}\n data-testid=\"oui-testid-apiKey-keyList-delete-btn\"\n >\n {t(\"common.delete\")}\n </Button>\n {open && (\n <React.Suspense fallback={null}>\n <LazyDeleteAPIKeyDialog\n item={item}\n open={open}\n setOpen={setOpen}\n onDelete={onDelete}\n />\n </React.Suspense>\n )}\n </>\n );\n};\n\nexport function formatKey(value: string): string {\n if (typeof value === \"undefined\") {\n return \"-\";\n }\n const key = `${value}`.replace(\"ed25519:\", \"\").slice(0, 6);\n return `${key}*****`;\n}\n","import { FC, PropsWithChildren } from \"react\";\nimport { useScreen } from \"@orderly.network/ui\";\nimport { usePortfolioLayoutScript } from \"./layout.script\";\nimport { PortfolioLayout, PortfolioLayoutProps } from \"./layout.ui\";\nimport { PortfolioLayoutMobile } from \"./layout.ui.mobile\";\n\nexport type PortfolioLayoutWidgetProps = PortfolioLayoutProps;\n\nexport const PortfolioLayoutWidget: FC<\n PropsWithChildren<PortfolioLayoutWidgetProps>\n> = (props) => {\n const state = usePortfolioLayoutScript({\n current: props.leftSideProps?.current,\n });\n const { isMobile } = useScreen();\n\n return (\n <>\n {isMobile ? (\n // @ts-ignore\n <PortfolioLayoutMobile {...state} {...props} />\n ) : (\n <PortfolioLayout {...state} {...props} />\n )}\n </>\n );\n};\n","import { useEffect, useMemo, useState } from \"react\";\nimport { useMediaQuery } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { SideMenuItem, useScaffoldContext } from \"@orderly.network/ui-scaffold\";\n\nexport enum PortfolioLeftSidebarPath {\n Overview = \"/portfolio\",\n Positions = \"/portfolio/positions\",\n Orders = \"/portfolio/orders\",\n Assets = \"/portfolio/assets\",\n FeeTier = \"/portfolio/feeTier\",\n ApiKey = \"/portfolio/apiKey\",\n Setting = \"/portfolio/setting\",\n History = \"/portfolio/history\",\n}\n\nexport type UseLayoutBuilderOptions = {\n current?: string;\n};\n\nexport const usePortfolioLayoutScript = (props: UseLayoutBuilderOptions) => {\n const { routerAdapter } = useScaffoldContext();\n const [current, setCurrent] = useState(\n props.current ?? routerAdapter?.currentPath ?? \"/portfolio\",\n );\n const { t } = useTranslation();\n\n useEffect(() => {\n if (props.current || routerAdapter?.currentPath) {\n setCurrent(props.current || routerAdapter?.currentPath || \"/portfolio\");\n }\n }, [props.current, routerAdapter?.currentPath]);\n\n const items = useMemo(() => {\n return [\n {\n name: t(\"common.overview\"),\n href: PortfolioLeftSidebarPath.Overview,\n icon: (\n <svg\n width=\"18\"\n height=\"18\"\n viewBox=\"0 0 18 18\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M5.24316 2.19727C3.58641 2.19727 2.24316 3.54044 2.24316 5.19727V12.6973C2.24316 14.3541 3.58641 15.6973 5.24316 15.6973H12.7432C14.3999 15.6973 15.7432 14.3541 15.7432 12.6973V5.19727C15.7432 3.54044 14.3999 2.19727 12.7432 2.19727H5.24316ZM5.24316 3.69727H12.7432C13.5719 3.69727 14.2432 4.36882 14.2432 5.19727V12.6973C14.2432 13.2484 13.9319 13.734 13.4894 13.9947C13.3454 12.2235 11.4427 11.1973 8.99316 11.1973C6.54366 11.1973 4.60341 12.251 4.48566 13.9997C4.04241 13.739 3.74316 13.2484 3.74316 12.6973V5.19727C3.74316 4.36882 4.41441 3.69727 5.24316 3.69727ZM8.99316 5.19727C7.54341 5.19727 6.36816 6.37252 6.36816 7.82227C6.36816 9.27202 7.54341 10.4473 8.99316 10.4473C10.4429 10.4473 11.6182 9.27202 11.6182 7.82227C11.6182 6.37252 10.4429 5.19727 8.99316 5.19727Z\"\n className=\"oui-fill-current group-data-[actived=true]:oui-fill-[url(#side-menu-gradient)]\"\n />\n </svg>\n ),\n },\n {\n name: t(\"common.positions\"),\n href: PortfolioLeftSidebarPath.Positions,\n icon: (\n <svg\n width=\"18\"\n height=\"18\"\n viewBox=\"0 0 18 18\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M4.51 3.021a3 3 0 0 0-3 3v6a3 3 0 0 0 3 3h9a3 3 0 0 0 3-3v-6a3 3 0 0 0-3-3zm2.25 3a.76.76 0 0 1 .54.211.77.77 0 0 1 0 1.078l-.75.75a.77.77 0 0 1-.54.211h-.75a.75.75 0 0 1 0-1.5h.422l.54-.539a.76.76 0 0 1 .539-.21m3 .75h3a.75.75 0 0 1 0 1.5h-3a.75.75 0 0 1 0-1.5m-3 2.25a.76.76 0 0 1 .54.211.77.77 0 0 1 0 1.079l-.75.75a.77.77 0 0 1-.54.21h-.75a.75.75 0 0 1 0-1.5h.422l.54-.539a.76.76 0 0 1 .539-.21m3 .75h3a.75.75 0 0 1 0 1.5h-3a.75.75 0 0 1 0-1.5\"\n className=\"oui-fill-current group-data-[actived=true]:oui-fill-[url(#side-menu-gradient)]\"\n />\n </svg>\n ),\n },\n {\n name: t(\"common.orders\"),\n href: PortfolioLeftSidebarPath.Orders,\n icon: (\n <svg\n width=\"18\"\n height=\"18\"\n viewBox=\"0 0 18 18\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M5.693 1.5C4.229 1.5 3.02 2.61 3.02 4.006v9.984c0 1.398 1.208 2.508 2.672 2.508h6.657c1.463 0 2.671-1.11 2.671-2.508V6.726c0-2.672-2.579-5.227-5.25-5.227zm4.828 1.593c1.33.352 2.562 1.58 2.906 2.906h-1.734c-.667 0-1.172-.472-1.172-1.008zm-3.75 2.906h.75a.75.75 0 0 1 0 1.5h-.75a.75.75 0 0 1 0-1.5m0 3h4.5a.75.75 0 0 1 0 1.5h-4.5a.75.75 0 0 1 0-1.5m0 3h4.5a.75.75 0 0 1 0 1.5h-4.5a.75.75 0 0 1 0-1.5\"\n className=\"oui-fill-current group-data-[actived=true]:oui-fill-[url(#side-menu-gradient)]\"\n />\n </svg>\n ),\n },\n {\n name: t(\"common.assets\"),\n href: PortfolioLeftSidebarPath.Assets,\n icon: (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"18\"\n height=\"18\"\n viewBox=\"0 0 18 18\"\n fill=\"none\"\n >\n <path\n d=\"M9 1.5C4.85 1.5 1.5 4.85 1.5 9C1.5 13.15 4.85 16.5 9 16.5C13.15 16.5 16.5 13.15 16.5 9C16.5 4.85 13.15 1.5 9 1.5ZM8.17529 3.75H9.67529V4.94971L10.125 5.17529C10.35 5.32529 10.5756 5.47471 10.7256 5.69971C10.8756 5.92471 11.0256 6.14971 11.1006 6.44971C11.1756 6.74971 11.25 7.05029 11.25 7.42529H9.82471C9.82471 6.97529 9.75059 6.67471 9.60059 6.44971C9.45059 6.22471 9.3 6.14941 9 6.14941C8.85 6.14941 8.7 6.15059 8.625 6.22559L8.39941 6.44971C8.32441 6.52471 8.325 6.675 8.25 6.75C8.175 6.825 8.17529 6.975 8.17529 7.125C8.17529 7.275 8.25 7.35 8.25 7.5C8.25 7.65 8.32441 7.72529 8.39941 7.80029C8.47441 7.95029 8.54971 8.02559 8.69971 8.10059C8.77471 8.17559 8.92441 8.24971 9.14941 8.32471C9.44941 8.47471 9.75059 8.62441 9.97559 8.77441C10.2756 8.92441 10.4994 9.07529 10.6494 9.30029C10.8744 9.52529 11.0256 9.75059 11.1006 9.97559C11.1756 10.2006 11.25 10.5 11.25 10.875C11.25 11.25 11.1756 11.5494 11.1006 11.7744C11.0256 12.0744 10.8756 12.2247 10.7256 12.4497C10.5756 12.5997 10.35 12.7494 10.125 12.8994C9.975 12.9744 9.9 13.0503 9.75 13.0503V14.25H8.25V12.9756C8.1 12.9006 7.95029 12.8997 7.80029 12.8247C7.50029 12.7497 7.35 12.6 7.125 12.375C6.975 12.225 6.82529 11.925 6.67529 11.625C6.60029 11.25 6.52441 10.8753 6.52441 10.4253H8.02441C8.02441 10.6503 8.02559 10.8756 8.10059 11.1006C8.17559 11.3256 8.24971 11.4753 8.32471 11.5503C8.39971 11.6253 8.475 11.6994 8.625 11.7744C8.775 11.8494 8.85 11.8506 9 11.8506C9.15 11.8506 9.225 11.8494 9.375 11.7744C9.525 11.6994 9.60029 11.6253 9.67529 11.5503C9.75029 11.4753 9.74971 11.4 9.82471 11.25C9.89971 11.175 9.89941 11.025 9.89941 10.875C9.89941 10.725 9.82471 10.575 9.82471 10.5C9.82471 10.425 9.75029 10.2747 9.67529 10.1997C9.60029 10.0497 9.525 9.97441 9.375 9.89941L8.92529 9.67529C8.62529 9.52529 8.32559 9.37559 8.10059 9.22559C7.80059 9.07559 7.57529 8.92471 7.42529 8.69971C7.20029 8.54971 7.05059 8.32441 6.97559 8.02441C6.90059 7.79941 6.82471 7.5 6.82471 7.125C6.82471 6.825 6.82441 6.52529 6.89941 6.30029C7.04941 6.07529 7.12559 5.85 7.35059 5.625C7.50059 5.4 7.65029 5.25029 7.80029 5.17529C7.95029 5.10029 8.02529 5.02441 8.17529 5.02441V3.75Z\"\n className=\"oui-fill-current group-data-[actived=true]:oui-fill-[url(#side-menu-gradient)]\"\n />\n </svg>\n ),\n },\n {\n name: t(\"portfolio.feeTier\"),\n href: PortfolioLeftSidebarPath.FeeTier,\n icon: (\n <svg\n width=\"18\"\n height=\"18\"\n viewBox=\"0 0 18 18\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M5.99829 1.51062C4.34154 1.51062 2.99829 2.85387 2.99829 4.51062V13.5106C2.99829 15.1674 4.34154 16.5106 5.99829 16.5106H11.9983C13.655 16.5106 14.9983 15.1674 14.9983 13.5106V4.51062C14.9983 2.85387 13.655 1.51062 11.9983 1.51062H5.99829ZM5.99829 3.76062H11.9983C12.4123 3.76062 12.7483 4.09662 12.7483 4.51062V6.01062C12.7483 6.42462 12.4123 6.76062 11.9983 6.76062H5.99829C5.58429 6.76062 5.24829 6.42462 5.24829 6.01062V4.51062C5.24829 4.09662 5.58429 3.76062 5.99829 3.76062ZM5.99829 8.26062C6.41229 8.26062 6.74829 8.59662 6.74829 9.01062C6.74829 9.42462 6.41229 9.76062 5.99829 9.76062C5.58429 9.76062 5.24829 9.42462 5.24829 9.01062C5.24829 8.59662 5.58429 8.26062 5.99829 8.26062ZM8.99829 8.26062C9.41229 8.26062 9.74829 8.59662 9.74829 9.01062C9.74829 9.42462 9.41229 9.76062 8.99829 9.76062C8.58429 9.76062 8.24829 9.42462 8.24829 9.01062C8.24829 8.59662 8.58429 8.26062 8.99829 8.26062ZM11.9983 8.26062C12.4123 8.26062 12.7483 8.59662 12.7483 9.01062C12.7483 9.42462 12.4123 9.76062 11.9983 9.76062C11.5843 9.76062 11.2483 9.42462 11.2483 9.01062C11.2483 8.59662 11.5843 8.26062 11.9983 8.26062ZM5.99829 10.5106C6.41229 10.5106 6.74829 10.8466 6.74829 11.2606C6.74829 11.6746 6.41229 12.0106 5.99829 12.0106C5.58429 12.0106 5.24829 11.6746 5.24829 11.2606C5.24829 10.8466 5.58429 10.5106 5.99829 10.5106ZM8.99829 10.5106C9.41229 10.5106 9.74829 10.8466 9.74829 11.2606C9.74829 11.6746 9.41229 12.0106 8.99829 12.0106C8.58429 12.0106 8.24829 11.6746 8.24829 11.2606C8.24829 10.8466 8.58429 10.5106 8.99829 10.5106ZM11.9983 10.5106C12.4123 10.5106 12.7483 10.8466 12.7483 11.2606V13.5106C12.7483 13.9246 12.4123 14.2606 11.9983 14.2606C11.5843 14.2606 11.2483 13.9246 11.2483 13.5106V11.2606C11.2483 10.8466 11.5843 10.5106 11.9983 10.5106ZM5.99829 12.7606C6.41229 12.7606 6.74829 13.0966 6.74829 13.5106C6.74829 13.9246 6.41229 14.2606 5.99829 14.2606C5.58429 14.2606 5.24829 13.9246 5.24829 13.5106C5.24829 13.0966 5.58429 12.7606 5.99829 12.7606ZM8.99829 12.7606C9.41229 12.7606 9.74829 13.0966 9.74829 13.5106C9.74829 13.9246 9.41229 14.2606 8.99829 14.2606C8.58429 14.2606 8.24829 13.9246 8.24829 13.5106C8.24829 13.0966 8.58429 12.7606 8.99829 12.7606Z\"\n className=\"oui-fill-current group-data-[actived=true]:oui-fill-[url(#side-menu-gradient)]\"\n />\n </svg>\n ),\n },\n {\n name: t(\"portfolio.apiKeys\"),\n href: PortfolioLeftSidebarPath.ApiKey,\n icon: (\n <svg\n width=\"18\"\n height=\"18\"\n viewBox=\"0 0 18 18\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M9.02124 1.49915C7.77849 1.49915 6.77124 2.5064 6.77124 3.74915C6.77124 4.70015 7.40049 5.55517 8.26974 5.86942L8.27124 8.24915H5.27124C4.85724 8.24915 4.52124 8.58515 4.52124 8.99915L4.52048 12.1304C3.65723 12.4274 3.02124 13.2981 3.02124 14.2491C3.02124 15.4919 4.02849 16.4991 5.27124 16.4991C6.51399 16.4991 7.52124 15.4919 7.52124 14.2491C7.52124 13.2981 6.92499 12.4596 6.02949 12.1206L6.02124 9.74915H9.02124H12.0212L12.0265 12.1319C11.1257 12.4446 10.5212 13.2981 10.5212 14.2491C10.5212 15.4919 11.5285 16.4991 12.7712 16.4991C14.014 16.4991 15.0212 15.4919 15.0212 14.2491C15.0212 13.2981 14.407 12.4611 13.5272 12.1281L13.5212 8.99915C13.5212 8.58515 13.1852 8.24915 12.7712 8.24915H9.77124L9.76899 5.86639C10.642 5.55814 11.2712 4.70015 11.2712 3.74915C11.2712 2.5064 10.264 1.49915 9.02124 1.49915Z\"\n className=\"oui-fill-current group-data-[actived=true]:oui-fill-[url(#side-menu-gradient)]\"\n />\n </svg>\n ),\n },\n {\n name: t(\"portfolio.setting\"),\n href: PortfolioLeftSidebarPath.Setting,\n icon: (\n <svg\n width=\"18\"\n height=\"18\"\n viewBox=\"0 0 18 18\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M6.72601 1.84159C5.66251 2.17834 4.74527 2.7296 3.93677 3.48185C3.68702 3.7151 3.61052 4.09534 3.77252 4.39609C4.37327 5.50684 3.74476 6.69484 2.39026 6.76309C2.05801 6.78034 1.76477 7.02559 1.68677 7.34884C1.55252 7.90759 1.49927 8.37559 1.49927 8.98984C1.49927 9.50509 1.55476 10.0878 1.66351 10.6068C1.73101 10.9308 2.01302 11.1641 2.34302 11.1933C3.70652 11.3111 4.38152 12.3506 3.77252 13.6773C3.63752 13.9721 3.69902 14.3246 3.93677 14.5443C4.73327 15.2816 5.64826 15.8006 6.72601 16.1381C7.03351 16.2348 7.38076 16.1186 7.56976 15.8568C8.40376 14.7033 9.61352 14.6988 10.4055 15.8568C10.5923 16.1298 10.9343 16.2611 11.2493 16.1613C12.2895 15.8343 13.2585 15.2771 14.0618 14.5443C14.3093 14.3193 14.3745 13.9541 14.226 13.6541C13.602 12.3948 14.3198 11.2383 15.6083 11.2166C15.9503 11.2106 16.2548 10.9856 16.335 10.6541C16.4648 10.1163 16.4993 9.64759 16.4993 8.98984C16.4993 8.42434 16.4325 7.86709 16.3118 7.32559C16.2353 6.98359 15.936 6.74059 15.585 6.73984C14.3168 6.73759 13.6058 5.49109 14.226 4.39609C14.3985 4.09084 14.3445 3.71735 14.085 3.48185C13.2675 2.73935 12.2708 2.15959 11.226 1.84159C10.905 1.74409 10.5638 1.86409 10.3823 2.14609C9.65776 3.27109 8.30477 3.29135 7.59302 2.16935C7.41077 1.8821 7.05001 1.73809 6.72601 1.84159ZM8.99927 5.98984C10.656 5.98984 11.9993 7.33309 11.9993 8.98984C11.9993 10.6466 10.656 11.9898 8.99927 11.9898C7.34252 11.9898 5.99927 10.6466 5.99927 8.98984C5.99927 7.33309 7.34252 5.98984 8.99927 5.98984Z\"\n className=\"oui-fill-current group-data-[actived=true]:oui-fill-[url(#side-menu-gradient)]\"\n />\n </svg>\n ),\n },\n {\n name: t(\"trading.history\"),\n href: PortfolioLeftSidebarPath.History,\n hide: true,\n },\n ];\n }, [t]);\n\n const hideSideBar = useMediaQuery(\"(max-width: 768px)\");\n\n return {\n items,\n current,\n hideSideBar,\n onItemSelect: (item: SideMenuItem) => {\n if (typeof item.href === \"undefined\") {\n console.warn(\"Item href is not defined\");\n return;\n }\n setCurrent(item.href!);\n routerAdapter?.onRouteChange({\n href: item.href,\n name: item.name,\n });\n },\n };\n};\n\nexport const useCustomSidebarHook = () => {\n const { expanded, setExpand } = useScaffoldContext();\n\n return {\n open: expanded,\n onOpenChange: (open: boolean) => {\n setExpand(open);\n },\n };\n};\n\nexport type usePortfolioLayoutScriptType = ReturnType<\n typeof usePortfolioLayoutScript\n>;\n","import { FC, PropsWithChildren } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { cn } from \"@orderly.network/ui\";\nimport {\n ScaffoldProps,\n RouterAdapter,\n Scaffold,\n SideBar,\n SideBarProps,\n useScaffoldContext,\n} from \"@orderly.network/ui-scaffold\";\n\nexport type PortfolioLayoutProps = ScaffoldProps & {\n hideSideBar?: boolean;\n items?: SideBarProps[\"items\"];\n};\n\nexport const PortfolioLayout: FC<PropsWithChildren<PortfolioLayoutProps>> = (\n props,\n) => {\n const { children, leftSideProps, classNames, ...rest } = props;\n\n return (\n <Scaffold\n leftSidebar={\n props.hideSideBar ? null : (\n <LeftSidebar\n current={props.routerAdapter?.currentPath}\n routerAdapter={props.routerAdapter}\n items={props.items}\n {...leftSideProps}\n />\n )\n }\n routerAdapter={props.routerAdapter}\n classNames={{\n ...classNames,\n content: cn(\"oui-my-6 oui-px-3\", classNames?.content),\n topNavbar: cn(\"oui-bg-base-9\", classNames?.topNavbar),\n leftSidebar: cn(\n \"oui-rounded-xl oui-bg-base-9\",\n \"oui-m-3 oui-p-4\",\n \"oui-border oui-border-line\",\n classNames?.leftSidebar,\n ),\n }}\n {...rest}\n >\n {children}\n </Scaffold>\n );\n};\n\ntype LeftSidebarProps = SideBarProps & {\n routerAdapter?: RouterAdapter;\n};\n\nconst LeftSidebar: FC<LeftSidebarProps> = (props) => {\n const { expanded, setExpand } = useScaffoldContext();\n const { t } = useTranslation();\n return (\n <SideBar\n title={t(\"common.portfolio\")}\n {...props}\n open={expanded}\n onOpenChange={(open) => setExpand(open)}\n onItemSelect={(e) => {\n props.onItemSelect?.(e);\n props.routerAdapter?.onRouteChange?.({\n href: e.href || \"\",\n name: e.name,\n });\n }}\n />\n );\n};\n","import { FC, PropsWithChildren } from \"react\";\nimport { Flex, Box } from \"@orderly.network/ui\";\nimport {\n MainNavMobile,\n BottomNav,\n type ScaffoldProps,\n} from \"@orderly.network/ui-scaffold\";\nimport { LayoutProvider } from \"./context\";\nimport { usePortfolioLayoutScriptType } from \"./layout.script\";\n\nexport const PortfolioLayoutMobile: FC<\n PropsWithChildren<\n ScaffoldProps & usePortfolioLayoutScriptType & { current?: string }\n >\n> = (props) => {\n return (\n <LayoutProvider {...props}>\n <Flex\n direction={\"column\"}\n width={\"100%\"}\n height={\"100%\"}\n className=\"oui-h-full-screen oui-bg-base-10\"\n >\n <header className=\"oui-scaffold-topNavbar oui-sticky oui-top-0 oui-z-10 oui-w-full oui-bg-base-10\">\n <MainNavMobile\n {...props.mainNavProps}\n current={props?.current}\n subItems={props?.items}\n routerAdapter={props.routerAdapter}\n />\n </header>\n <Box className=\"oui-scaffold-container oui-min-h-[calc(100vh-44px-64px-env(safe-area-inset-bottom))] oui-w-full\">\n {props.children}\n </Box>\n <footer className=\"oui-scaffold-bottomNav oui-fixed oui-bottom-0 oui-z-10 oui-w-full oui-bg-base-9 oui-pb-[calc(env(safe-area-inset-bottom))]\">\n <BottomNav\n mainMenus={props.bottomNavProps?.mainMenus}\n current={props?.current}\n onRouteChange={props.routerAdapter?.onRouteChange}\n />\n </footer>\n </Flex>\n </LayoutProvider>\n );\n};\n","export { AssetWidget, AssetsUI } from \"./assets\";\nexport { HistoryDataGroupWidget } from \"./historyDataGroup\";\n\nexport * from \"./assetChart\";\nexport * from \"./assetHistory\";\n\nexport {\n PerformanceUI,\n PerformanceWidget,\n usePerformanceScript,\n} from \"./performance\";\n\nexport * from \"./performanceMobileDialog\";\n\nexport {\n FundingHistoryWidget,\n useFundingHistoryColumns,\n useFundingHistoryHook,\n} from \"./funding\";\n\nexport {\n DistributionHistoryWidget,\n DistributionHistoryMobile,\n DistributionHistoryDesktop,\n} from \"./distribution\";\n\nexport { OverviewPage } from \"./main\";\n\nexport { OverviewProvider } from \"./provider/overviewProvider\";\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport React from \"react\";\nimport {\n AssetLineChart,\n PnlAreaChart,\n PnLBarChart,\n PnlLineChartProps,\n} from \"@orderly.network/chart\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { Tabs, TabPanel, Flex, Text } from \"@orderly.network/ui\";\nimport type { UsePerformanceScriptReturn } from \"../performance/performance.script\";\nimport {\n PeriodType,\n useAssetsHistoryDataReturn,\n} from \"../shared/useAssetHistory\";\n\nconst responsiveProps: PnlLineChartProps[\"responsiveContainerProps\"] = {\n width: \"100%\",\n minHeight: 144,\n aspect: 2.5,\n};\n\nexport const PerformanceMobileUI: React.FC<\n Pick<\n useAssetsHistoryDataReturn & UsePerformanceScriptReturn,\n | \"data\"\n | \"curPeriod\"\n | \"aggregateValue\"\n | \"onPeriodChange\"\n | \"invisible\"\n | \"visible\"\n | \"createFakeData\"\n | \"period\"\n >\n> = (props) => {\n const { t } = useTranslation();\n const {\n data,\n aggregateValue,\n visible,\n invisible,\n curPeriod,\n period,\n onPeriodChange,\n createFakeData,\n } = props;\n\n const mergedData = data.length\n ? data\n : (createFakeData?.(\n { account_value: 0, pnl: 0 },\n { account_value: 500, pnl: 500 },\n ) as any[]);\n\n return (\n <div>\n <Tabs\n value={period}\n defaultValue={PeriodType.WEEK}\n classNames={{ tabsList: \"oui-justify-between\", trigger: \"oui-w-1/3\" }}\n onValueChange={(value) => onPeriodChange(value as PeriodType)}\n >\n <TabPanel\n title={t(\"common.select.7d\")}\n value={PeriodType.WEEK}\n className=\"oui-min-h-40\"\n >\n <AssetLineChart\n data={mergedData}\n invisible={invisible || (mergedData?.length ?? 0) <= 2}\n responsiveContainerProps={responsiveProps}\n />\n </TabPanel>\n <TabPanel\n title={t(\"common.select.30d\")}\n value={PeriodType.MONTH}\n className=\"oui-min-h-40\"\n >\n <AssetLineChart\n data={mergedData}\n invisible={invisible || (mergedData?.length ?? 0) <= 2}\n responsiveContainerProps={responsiveProps}\n />\n </TabPanel>\n <TabPanel\n title={t(\"common.select.90d\")}\n value={PeriodType.QUARTER}\n className=\"oui-min-h-40\"\n >\n <AssetLineChart\n data={mergedData}\n invisible={invisible || (mergedData?.length ?? 0) <= 2}\n responsiveContainerProps={responsiveProps}\n />\n </TabPanel>\n </Tabs>\n <Flex justify=\"between\" itemAlign=\"center\" gap={2} my={4}>\n <Flex\n gap={1}\n direction=\"column\"\n itemAlign=\"start\"\n className=\"oui-w-1/3 oui-rounded-lg oui-bg-base-7 oui-px-2 oui-py-1.5\"\n >\n <Text className=\"oui-truncate\" intensity={36} size=\"2xs\">\n {t(\"portfolio.overview.performance.roi\", { period: curPeriod })}\n </Text>\n <Text.numeral size=\"sm\" visible={visible} rule=\"percentages\" coloring>\n {invisible ? \"--\" : aggregateValue.roi}\n </Text.numeral>\n </Flex>\n <Flex\n gap={1}\n direction=\"column\"\n itemAlign=\"start\"\n className=\"oui-w-1/3 oui-rounded-lg oui-bg-base-7 oui-px-2 oui-py-1.5\"\n >\n <Text className=\"oui-truncate\" intensity={36} size=\"2xs\">\n {t(\"portfolio.overview.performance.pnl\", { period: curPeriod })}\n </Text>\n <Text.numeral size=\"sm\" visible={visible} coloring showIdentifier>\n {invisible ? \"--\" : aggregateValue.pnl}\n </Text.numeral>\n </Flex>\n <Flex\n gap={1}\n direction=\"column\"\n itemAlign=\"start\"\n className=\"oui-w-1/3 oui-rounded-lg oui-bg-base-7 oui-px-2 oui-py-1.5\"\n >\n <Text className=\"oui-truncate\" intensity={36} size=\"2xs\">\n {t(\"portfolio.overview.performance.volume\", { period: curPeriod })}\n </Text>\n <Text.numeral size=\"sm\" visible={visible} coloring={false}>\n {invisible ? \"--\" : aggregateValue.vol}\n </Text.numeral>\n </Flex>\n </Flex>\n <Tabs defaultValue={\"dailyPnl\"}>\n <TabPanel\n value={\"dailyPnl\"}\n title={t(\"portfolio.overview.performance.dailyPnl\")}\n className=\"oui-min-h-40\"\n >\n <PnLBarChart\n data={mergedData}\n invisible={invisible || (mergedData?.length ?? 0) <= 2}\n responsiveContainerProps={responsiveProps}\n />\n </TabPanel>\n <TabPanel\n value={\"cumulativePnl\"}\n title={t(\"portfolio.overview.performance.cumulativePnl\")}\n className=\"oui-min-h-40\"\n >\n <PnlAreaChart\n data={mergedData}\n invisible={invisible || (mergedData?.length ?? 0) <= 2}\n responsiveContainerProps={responsiveProps}\n />\n </TabPanel>\n </Tabs>\n </div>\n );\n};\n","import React from \"react\";\nimport { pick } from \"ramda\";\nimport { i18n } from \"@orderly.network/i18n\";\nimport { registerSimpleDialog, registerSimpleSheet } from \"@orderly.network/ui\";\nimport { usePerformanceScript } from \"..\";\nimport { localKey } from \"../provider/overviewProvider\";\nimport { useAssetsHistoryData } from \"../shared/useAssetHistory\";\nimport { PerformanceMobileUI } from \"./performance.ui\";\n\nexport const PerformanceMobileWidget: React.FC = () => {\n const state = useAssetsHistoryData(localKey, { isRealtime: true });\n const { visible, invisible } = usePerformanceScript();\n return (\n <PerformanceMobileUI\n {...pick(\n [\n \"data\",\n \"curPeriod\",\n \"aggregateValue\",\n \"onPeriodChange\",\n \"createFakeData\",\n \"period\",\n ],\n state,\n )}\n visible={visible}\n invisible={invisible}\n />\n );\n};\n\nexport const PerformanceMobileSheetId = \"PerformanceMobileSheetId\";\n\nexport const PerformanceMobileDialogId = \"PerformanceMobileDialogId\";\n\nregisterSimpleSheet(PerformanceMobileSheetId, PerformanceMobileWidget, {\n title: () => i18n.t(\"portfolio.overview.performance\"),\n});\n\nregisterSimpleDialog(PerformanceMobileDialogId, PerformanceMobileWidget, {\n title: () => i18n.t(\"portfolio.overview.performance\"),\n classNames: {\n content: \"oui-w-[420px]\",\n },\n});\n","import { FC, PropsWithChildren, useMemo } from \"react\";\nimport { TWType } from \"@orderly.network/hooks\";\nimport { useRewardsData } from \"../mobile/useRewardsData.script\";\nimport { useAssetsHistoryData } from \"../shared/useAssetHistory\";\nimport { OverviewContext, OverviewContextState } from \"./overviewContext\";\n\nexport const localKey = \"portfolio_performance_period\";\n\nexport const OverviewProvider: FC<PropsWithChildren<{ type?: TWType }>> = (\n props,\n) => {\n const { type, children } = props;\n const state = useAssetsHistoryData(localKey, { isRealtime: true });\n const rewardsData = useRewardsData({ type: type });\n\n const memoizedValue = useMemo<OverviewContextState>(() => {\n return {\n ...state,\n type: type,\n ...rewardsData,\n };\n }, [state, type, rewardsData]);\n\n return (\n <OverviewContext.Provider value={memoizedValue}>\n {children}\n </OverviewContext.Provider>\n );\n};\n","import { useMemo, useRef, useEffect } from \"react\";\nimport {\n useAllBrokers,\n useConfig,\n useCurEpochEstimate,\n useEpochInfo,\n useGetClaimed,\n useAccount,\n RefferalAPI,\n usePrivateQuery,\n noCacheConfig,\n} from \"@orderly.network/hooks\";\nimport { DistributionId, TWType } from \"@orderly.network/hooks\";\nimport { useAppContext } from \"@orderly.network/react-app\";\nimport { AccountStatusEnum } from \"@orderly.network/types\";\nimport { useOverviewContext } from \"../provider/overviewContext\";\n\nexport const useRewardsData = ({ type = TWType.normal }: { type?: TWType }) => {\n const totalOrderClaimedReward = useGetClaimed(\n type === TWType.mm ? DistributionId.mmOrder : DistributionId.order,\n );\n const [curEpochEstimate] = useCurEpochEstimate(type);\n const [brokers] = useAllBrokers();\n const { state } = useAccount();\n const { data, mutate } = usePrivateQuery<RefferalAPI.ReferralInfo>(\n \"/v1/referral/info\",\n { revalidateOnFocus: true, errorRetryCount: 3, ...noCacheConfig },\n );\n\n const epochList = useEpochInfo(type as TWType);\n const brokerId = useConfig(\"brokerId\");\n\n const brokerName = useMemo(() => {\n return brokers?.[brokerId];\n }, [brokerId, brokers]);\n\n const lastStete = useRef<AccountStatusEnum>(AccountStatusEnum.NotConnected);\n\n const timerRef = useRef<ReturnType<typeof setTimeout> | null>(null);\n\n useEffect(() => {\n if (lastStete.current !== state.status) {\n lastStete.current = state.status;\n timerRef.current = setTimeout(() => {\n mutate();\n }, 1000);\n }\n return () => {\n if (timerRef.current) {\n clearTimeout(timerRef.current);\n }\n };\n }, [state.status]);\n\n return {\n totalOrderClaimedReward,\n curEpochEstimate,\n epochList,\n brokerName,\n referralInfo: data,\n };\n};\n\nexport const useRewardsDataScript = () => {\n const {\n totalOrderClaimedReward,\n curEpochEstimate,\n epochList,\n brokerName,\n referralInfo,\n } = useOverviewContext();\n const { state } = useAccount();\n const { wrongNetwork } = useAppContext();\n const isSignIn =\n state.status === AccountStatusEnum.EnableTrading ||\n state.status === AccountStatusEnum.EnableTradingWithoutConnected;\n\n return {\n totalOrderClaimedReward,\n curEpochEstimate,\n epochList,\n brokerName,\n isSignIn,\n referralInfo,\n wrongNetwork,\n };\n};\n\nexport type UseRewardsDataReturn = ReturnType<typeof useRewardsData>;\n","import React from \"react\";\nimport { Grid, useScreen } from \"@orderly.network/ui\";\nimport { MobileOverview } from \"./mobile\";\nimport { OverviewProvider } from \"./provider/overviewProvider\";\n\nconst LazyAssetWidget = React.lazy(() =>\n import(\"./assets\").then((mod) => {\n return { default: mod.AssetWidget };\n }),\n);\n\nconst LazyAssetsChartWidget = React.lazy(() =>\n import(\"./assetChart\").then((mod) => {\n return { default: mod.AssetsChartWidget };\n }),\n);\n\nconst LazyPerformanceWidget = React.lazy(() =>\n import(\"./performance\").then((mod) => {\n return { default: mod.PerformanceWidget };\n }),\n);\n\nconst LazyHistoryDataGroupWidget = React.lazy(() =>\n import(\"./historyDataGroup\").then((mod) => {\n return { default: mod.HistoryDataGroupWidget };\n }),\n);\n\nexport const OverviewPage: React.FC = () => {\n const { isMobile } = useScreen();\n return (\n <OverviewProvider>\n {isMobile ? (\n <MobileOverview />\n ) : (\n <Grid cols={2} gap={4}>\n <React.Suspense fallback={null}>\n <LazyAssetWidget />\n </React.Suspense>\n <React.Suspense fallback={null}>\n <LazyAssetsChartWidget />\n </React.Suspense>\n <Grid.span colSpan={2}>\n <React.Suspense fallback={null}>\n <LazyPerformanceWidget />\n </React.Suspense>\n </Grid.span>\n <Grid.span colSpan={2}>\n <React.Suspense fallback={null}>\n <LazyHistoryDataGroupWidget />\n </React.Suspense>\n </Grid.span>\n </Grid>\n )}\n </OverviewProvider>\n );\n};\n","import React from \"react\";\nimport { ENVType, useGetEnv } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { useAppContext } from \"@orderly.network/react-app\";\nimport { Flex } from \"@orderly.network/ui\";\nimport { DepositStatusWidget } from \"@orderly.network/ui-transfer\";\nimport { useLayoutContext } from \"../../../layout/context\";\nimport { useAssetScript } from \"../assets\";\nimport { PortfolioChartsMobileWidget } from \"../portfolioChartsMobile\";\nimport { AccountStatusMobile } from \"./accountStatus.ui.mobile\";\nimport { AffiliateCardMobile } from \"./affiliateCard.ui.mobile\";\nimport { PortfolioHandleMobile } from \"./portfolioHandle.ui.mobile\";\nimport { PortfolioValueMobile } from \"./portfolioVaule.ui.mobile\";\nimport { SettingRouterMobile } from \"./settingRouter.ui.mobile\";\nimport { TraderCardMobile } from \"./traderCard.ui.mobile\";\n// import { TradingRewardsCardMobile } from \"./tradingRewardsCard.ui.mobile\";\nimport { useRewardsDataScript } from \"./useRewardsData.script\";\n\nexport const MobileOverview: React.FC = () => {\n const {\n canTrade,\n onWithdraw,\n onDeposit,\n portfolioValue,\n unrealPnL,\n unrealROI,\n visible,\n namespace,\n toggleVisible,\n onTransfer,\n isMainAccount,\n hasSubAccount,\n } = useAssetScript();\n const { t } = useTranslation();\n const rewardsData = useRewardsDataScript();\n const layoutContext = useLayoutContext();\n const { onRouteChange } = useAppContext();\n const env = useGetEnv();\n\n const goToClaim = () => {\n const url = `https://${\n env !== ENVType.prod ? `${env}-` : \"\"\n }app.orderly.network/tradingRewards`;\n window.open(url, \"_blank\");\n };\n\n const navigateToPortfolioHistory =\n typeof onRouteChange === \"function\"\n ? () => {\n onRouteChange({\n href: \"/portfolio/history\",\n name: t(\"trading.history\"),\n });\n }\n : undefined;\n\n // console.log('rewards data', rewardsData, layoutContext, props);\n\n return (\n <>\n <div className=\"oui-my-1 oui-px-3\">\n <AccountStatusMobile />\n </div>\n <Flex\n direction={\"column\"}\n width={\"100%\"}\n height={\"100%\"}\n className=\"oui-gap-5 oui-px-3\"\n >\n <Flex direction=\"column\" width=\"100%\" gapY={2}>\n <PortfolioValueMobile\n toggleVisible={toggleVisible}\n portfolioValue={portfolioValue}\n unrealPnL={unrealPnL}\n unrealROI={unrealROI}\n visible={visible}\n canTrade={canTrade}\n namespace={namespace}\n routerAdapter={layoutContext?.routerAdapter}\n />\n <DepositStatusWidget onClick={navigateToPortfolioHistory} />\n <PortfolioChartsMobileWidget />\n </Flex>\n <PortfolioHandleMobile\n disabled={!canTrade}\n onWithdraw={onWithdraw}\n onDeposit={onDeposit}\n onTransfer={onTransfer}\n isMainAccount={isMainAccount}\n routerAdapter={layoutContext?.routerAdapter}\n hasSubAccount={hasSubAccount}\n />\n <Flex\n direction={\"row\"}\n width={\"100%\"}\n height={\"100%\"}\n className=\"oui-gap-3\"\n >\n {/* Disable trading rewards card for now. Set to row */}\n <Flex direction=\"row\" className=\"oui-flex-1 oui-gap-3\">\n <AffiliateCardMobile\n referralInfo={rewardsData.referralInfo}\n routerAdapter={layoutContext?.routerAdapter}\n />\n <TraderCardMobile\n referralInfo={rewardsData.referralInfo}\n routerAdapter={layoutContext?.routerAdapter}\n />\n </Flex>\n {/* <Flex direction=\"column\" className=\"oui-flex-1\">\n <TradingRewardsCardMobile {...rewardsData} goToClaim={goToClaim} />\n </Flex> */}\n </Flex>\n <SettingRouterMobile routerAdapter={layoutContext?.routerAdapter} />\n </Flex>\n </>\n );\n};\n","import React from \"react\";\nimport { EMPTY_LIST } from \"@orderly.network/types\";\nimport { useAssetsChartScript } from \"../assetChart\";\nimport { usePortfolioChartsState } from \"./portfolioChartsMobile.script\";\nimport { PortfolioChartsMobileUI } from \"./portfolioChartsMobile.ui\";\n\nexport const PortfolioChartsMobileWidget: React.FC = () => {\n const { data, invisible } = useAssetsChartScript();\n const state = usePortfolioChartsState();\n return (\n <PortfolioChartsMobileUI\n data={data || EMPTY_LIST}\n invisible={invisible}\n {...state}\n />\n );\n};\n","import { useCallback } from \"react\";\nimport { useLocalStorage, usePositionStream } from \"@orderly.network/hooks\";\nimport { modal } from \"@orderly.network/ui\";\nimport { ORDERLY_ASSETS_VISIBLE_KEY } from \"../../assets/type\";\nimport { PerformanceMobileSheetId } from \"../performanceMobileDialog\";\n\nexport const usePortfolioChartsState = () => {\n const [data] = usePositionStream();\n const [visible, setVisible] = useLocalStorage<boolean>(\n ORDERLY_ASSETS_VISIBLE_KEY,\n true,\n );\n const onPerformanceClick = useCallback(() => {\n return modal.show(PerformanceMobileSheetId);\n }, []);\n return {\n unrealPnL: data?.aggregated.total_unreal_pnl,\n unrealROI: data?.totalUnrealizedROI,\n visible: visible as boolean,\n setVisible: setVisible,\n onPerformanceClick: onPerformanceClick,\n } as const;\n};\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport React, { useId } from \"react\";\nimport { Area, AreaChart } from \"@orderly.network/chart\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { EMPTY_LIST } from \"@orderly.network/types\";\nimport { ChevronRightIcon, cn, Flex, Text } from \"@orderly.network/ui\";\nimport { usePortfolioChartsState } from \".\";\n\nexport const PortfolioChartsMobileUI: React.FC<\n ReturnType<typeof usePortfolioChartsState> & {\n data: any[];\n invisible?: boolean;\n }\n> = (props) => {\n const { data, invisible, unrealPnL, unrealROI, visible, onPerformanceClick } =\n props;\n const { t } = useTranslation();\n const colorId = useId();\n return (\n <Flex\n p={4}\n width={\"100%\"}\n itemAlign=\"center\"\n justify=\"between\"\n className={cn(\n \"oui-relative oui-overflow-hidden oui-rounded-2xl oui-border oui-border-solid oui-border-line-12 oui-bg-base-9\",\n )}\n >\n <Flex\n width={\"100%\"}\n justify={\"center\"}\n itemAlign={\"start\"}\n direction={\"column\"}\n gap={2}\n >\n <Text size=\"xs\" intensity={54}>\n {t(\"common.unrealizedPnl\")}\n </Text>\n <Flex justify={\"start\"} itemAlign={\"center\"}>\n <Text.numeral\n coloring\n size=\"base\"\n weight=\"semibold\"\n visible={visible}\n >\n {unrealPnL}\n </Text.numeral>\n <Text.numeral\n coloring\n rule=\"percentages\"\n size=\"sm\"\n weight=\"semibold\"\n prefix={\"(\"}\n suffix={\")\"}\n visible={visible}\n >\n {unrealROI}\n </Text.numeral>\n </Flex>\n <Text\n size=\"xs\"\n intensity={54}\n className=\"oui-flex oui-items-center oui-justify-start oui-gap-1\"\n onClick={onPerformanceClick}\n >\n {t(\"portfolio.overview.performance\")}\n <ChevronRightIcon className=\"oui-text-base-contrast-54\" />\n </Text>\n </Flex>\n <Flex\n width={\"100%\"}\n justify={\"center\"}\n itemAlign={\"center\"}\n direction={\"column\"}\n >\n <AreaChart data={data || EMPTY_LIST} width={160} height={52}>\n {!invisible && (\n <>\n <defs>\n <linearGradient id={colorId} x1=\"0\" y1=\"0\" x2=\"0\" y2=\"1\">\n <stop stopColor=\"#00B49E\" offset=\"0%\" stopOpacity={0.5} />\n <stop stopColor=\"#00B49E\" offset=\"100%\" stopOpacity={0} />\n </linearGradient>\n </defs>\n <Area\n type=\"natural\"\n dataKey=\"account_value\"\n stroke={\"rgb(41, 233, 169)\"}\n strokeWidth={1.5}\n dot={false}\n isAnimationActive={false}\n fill={`url(#${colorId})`}\n />\n </>\n )}\n </AreaChart>\n </Flex>\n </Flex>\n );\n};\n","import { FC, SVGProps, useCallback, useMemo } from \"react\";\nimport {\n parseJSON,\n useAccount,\n useChains,\n useLocalStorage,\n useWalletConnector,\n} from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { useAppContext } from \"@orderly.network/react-app\";\nimport { AccountStatusEnum, ChainNamespace } from \"@orderly.network/types\";\nimport {\n cn,\n modal,\n toast,\n formatAddress,\n Flex,\n CopyIcon,\n ChainIcon,\n} from \"@orderly.network/ui\";\n\ninterface StatusInfo {\n title: string;\n description: string;\n titleColor?: any;\n titleClsName?: string;\n}\n\nconst useCurrentStatus = () => {\n const { state, account } = useAccount();\n const { wrongNetwork, disabledConnect, connectWallet } = useAppContext();\n const { t } = useTranslation();\n\n const statusText = {\n wrongNetwork: {\n description: t(\"connector.wrongNetwork.tooltip\"),\n rootClass: \"oui-bg-[linear-gradient(15deg,#D25F00_0%,transparent_30%)]\",\n },\n connectWallet: {\n description: t(\"connector.trade.connectWallet.tooltip\"),\n rootClass: \"oui-bg-[linear-gradient(15deg,#27FDFE_0%,transparent_30%)]\",\n },\n notSignedIn: {\n description: t(\"connector.trade.createAccount.tooltip\"),\n rootClass: \"oui-bg-[linear-gradient(15deg,#335FFC_0%,transparent_30%)]\",\n },\n disabledTrading: {\n description: t(\"connector.trade.enableTrading.tooltip\"),\n rootClass: \"oui-bg-[linear-gradient(15deg,#335FFC_0%,transparent_30%)]\",\n },\n default: {\n description: \"\",\n rootClass: \"\",\n arrowIconClass: \"\",\n textClass: \"\",\n },\n };\n\n return useMemo(() => {\n if (disabledConnect) {\n return statusText.connectWallet;\n }\n\n if (wrongNetwork) {\n return statusText.wrongNetwork;\n }\n\n switch (state.status) {\n case AccountStatusEnum.NotConnected:\n return statusText.connectWallet;\n case AccountStatusEnum.NotSignedIn:\n return statusText.notSignedIn;\n case AccountStatusEnum.DisabledTrading:\n return statusText.disabledTrading;\n default:\n return statusText.default;\n }\n }, [state.status, wrongNetwork]);\n};\n\nexport function EVMChainPopover({ children }: { children: React.ReactNode }) {\n // const [chains] = useState(getChainsByNetwork(\"mainnet\"));\n const [chains] = useChains(\"mainnet\", {\n pick: \"network_infos\",\n });\n const { t } = useTranslation();\n\n const showDialog = () => {\n modal.dialog({\n title: t(\"connector.privy.supportedEvmChain\"),\n size: \"xs\",\n content: (\n <div>\n <div className=\"oui-p-1 oui-grid oui-grid-cols-2 oui-gap-x-2 oui-gap-y-3 oui-text-2xs oui-text-base-contrast-54\">\n {chains.map((item, key) => (\n <div\n key={key}\n className=\"oui-flex oui-items-center oui-justify-start oui-gap-1\"\n >\n <ChainIcon chainId={item.chain_id} size=\"2xs\" />\n <div>{item.name}</div>\n </div>\n ))}\n </div>\n </div>\n ),\n });\n };\n\n return <button onClick={showDialog}>{children}</button>;\n}\n\nexport const MoreIcon: FC<SVGProps<SVGSVGElement>> = (props) => (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"currentColor\"\n {...props}\n >\n <path d=\"M8.00521 6.66797C8.74161 6.66797 9.33854 7.26464 9.33854 8.0013C9.33854 8.73797 8.74161 9.33464 8.00521 9.33464C7.26881 9.33464 6.67188 8.73797 6.67188 8.0013C6.67188 7.26464 7.26881 6.66797 8.00521 6.66797Z\" />\n <path d=\"M3.33333 6.66797C4.06973 6.66797 4.66667 7.26464 4.66667 8.0013C4.66667 8.73797 4.06973 9.33464 3.33333 9.33464C2.59693 9.33464 2 8.73797 2 8.0013C2 7.26464 2.59693 6.66797 3.33333 6.66797Z\" />\n <path d=\"M12.6666 6.66797C13.403 6.66797 14 7.26464 14 8.0013C14 8.73797 13.403 9.33464 12.6666 9.33464C11.9302 9.33464 11.3333 8.73797 11.3333 8.0013C11.3333 7.26464 11.9302 6.66797 12.6666 6.66797Z\" />\n </svg>\n);\n\nconst EVMChains = () => {\n return (\n <div className=\"oui-relative oui-flex oui-items-center oui-justify-center\">\n <div className=\"oui-flex oui-h-[18px] oui-items-center oui-justify-center \">\n <img\n src=\"https://oss.orderly.network/static/sdk/portfolio/chains.png\"\n className=\"oui-relative oui-z-0 oui-h-[18px] oui-w-[49px]\"\n />\n </div>\n <div className=\"oui-relative oui-left-[-9px] oui-flex oui-items-center oui-justify-center oui-gap-1\">\n <div className=\"oui-flex oui-size-[18px] oui-items-center oui-justify-center oui-rounded-full oui-bg-[#282e3a]\">\n <EVMChainPopover>\n <MoreIcon\n className=\"oui-relative oui-z-10 oui-size-3 oui-text-base-contrast-54 hover:oui-text-base-contrast\"\n style={{ zIndex: 1 }}\n />\n </EVMChainPopover>\n </div>\n <div className=\"oui-text-2xs oui-font-semibold oui-text-base-contrast\">\n Evm\n </div>\n </div>\n </div>\n );\n};\n\nconst ShowAccount: FC = () => {\n const { state, account } = useAccount();\n const { namespace } = useWalletConnector();\n const { t } = useTranslation();\n const onCopyAddress = () => {\n navigator.clipboard.writeText(state.address ?? \"\");\n toast.success(t(\"common.copy.copied\"));\n };\n\n const currentNamespace = useMemo(() => {\n if (namespace) {\n return namespace;\n }\n if (state.status === AccountStatusEnum.EnableTradingWithoutConnected) {\n return getLinkDeviceStorage()?.chainNamespace;\n }\n return null;\n }, [namespace, state.status]);\n\n const leftNode = useMemo(() => {\n if (!state.address) {\n return;\n }\n return (\n <Flex className=\"oui-text-base oui-text-base-contrast\" gapX={2}>\n {formatAddress(state.address ?? \"\")}\n <button\n className=\"oui-cursor-pointer\"\n onClick={() => {\n onCopyAddress();\n }}\n >\n <CopyIcon\n size={18}\n className=\"oui-text-base-contrast-80\"\n opacity={1}\n />\n </button>\n </Flex>\n );\n }, [state.address]);\n const rightNode = useMemo(() => {\n if (currentNamespace === ChainNamespace.evm) {\n return <EVMChains />;\n }\n\n return (\n <Flex gapX={1} itemAlign={\"center\"} className=\"oui-text-2xs\">\n <img\n src=\"https://oss.orderly.network/static/sdk/solana-logo.png\"\n className=\"oui-w-[15px]\"\n />\n Solana\n </Flex>\n );\n }, [currentNamespace]);\n\n const bgClass = useMemo(() => {\n let bg = \"\";\n if (currentNamespace == ChainNamespace.evm) {\n bg =\n \"oui-bg-[linear-gradient(15deg,#283BEE_-11%,transparent_30%,transparent_77%,#A53411_100%)]\";\n } else if (currentNamespace == ChainNamespace.solana) {\n bg =\n \"oui-bg-[linear-gradient(15deg,#7400D0_-11%,transparent_30%,transparent_77%,#009A7E_100%)]\";\n }\n return bg;\n }, [currentNamespace]);\n return (\n <div\n className={cn([\n \"oui-flex oui-h-[44px] oui-w-full oui-items-center oui-justify-between oui-rounded-[10px] oui-px-3 oui-py-[10px]\",\n bgClass,\n ])}\n >\n {leftNode}\n {rightNode}\n </div>\n );\n};\n\nexport const AccountStatusMobile: FC = () => {\n const { state } = useAccount();\n const { wrongNetwork } = useAppContext();\n const { description, rootClass } = useCurrentStatus();\n\n const alreadyShowAccount = useMemo(() => {\n if (state.status === AccountStatusEnum.EnableTradingWithoutConnected) {\n return true;\n }\n if (wrongNetwork) {\n return false;\n }\n return state.status >= AccountStatusEnum.EnableTrading;\n }, [state.status, wrongNetwork]);\n\n if (alreadyShowAccount) {\n return <ShowAccount />;\n }\n\n return (\n <div\n className={cn([\n \"oui-flex oui-h-[44px] oui-w-full oui-items-center oui-justify-center oui-rounded-[10px] oui-px-3 oui-py-[10px]\",\n rootClass,\n // \"oui-bg-linear-65\",\n // \"oui-from-[-20%]\",\n // \"oui-to-[40%]\",\n // \" oui-from-[#FF7B00]\",\n // \" oui-to-[#FFEA00]\",\n ])}\n >\n <div\n className={cn(\n \"oui-flex oui-items-center oui-justify-end oui-rounded-[10px] oui-text-xs oui-font-semibold\",\n \"oui-text-base-contrast-54\",\n )}\n >\n {description}\n </div>\n </div>\n );\n};\ntype LinkDeviceStorage = { chainId: number; chainNamespace: ChainNamespace };\n\nfunction getLinkDeviceStorage() {\n try {\n const linkDeviceStorage = localStorage.getItem(\"orderly_link_device\");\n const json = linkDeviceStorage ? parseJSON(linkDeviceStorage) : null;\n return json as LinkDeviceStorage;\n } catch (err) {\n console.error(\"getLinkDeviceStorage\", err);\n }\n}\n","import { FC } from \"react\";\nimport { RefferalAPI as API } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n Flex,\n Text,\n AffiliateIcon,\n ChevronRightIcon,\n cn,\n} from \"@orderly.network/ui\";\nimport { RouterAdapter } from \"@orderly.network/ui-scaffold\";\nimport { commifyOptional } from \"@orderly.network/utils\";\n\nconst isNumber = (val: unknown): val is number => {\n return typeof val === \"number\" && !Number.isNaN(val);\n};\n\ntype AffiliateCardMobileProps = {\n referralInfo?: API.ReferralInfo;\n routerAdapter?: RouterAdapter;\n};\n\nexport const AffiliateCardMobile: FC<AffiliateCardMobileProps> = (props) => {\n const { t } = useTranslation();\n const { referralInfo, routerAdapter } = props;\n const rebate = referralInfo?.referrer_info?.[\"30d_referrer_rebate\"];\n return (\n <Flex\n className=\"\n oui-via-21.6% \n oui-via-83.23% \n oui-relative \n oui-h-[112px] \n oui-w-full \n oui-flex-col \n oui-items-start \n oui-rounded-xl \n oui-border \n oui-border-solid \n oui-border-[rgba(var(--oui-gradient-primary-start)/0.36)] \n oui-bg-gradient-to-r\n oui-from-[rgba(var(--oui-gradient-primary-end)/0.12)]\n oui-to-[rgba(var(--oui-gradient-primary-start)/0.12)]\n oui-p-3\n \"\n >\n <Flex className=\"oui-w-full oui-flex-row oui-justify-between oui-items-center\">\n <Flex className=\"oui-flex-col oui-items-start\">\n <Text className=\"oui-text-base-contrast oui-text-base oui-font-semibold\">\n {t(\"affiliate.asAffiliate.affilates\")}\n </Text>\n <Text className=\"oui-text-2xs oui-font-normal oui-text-base-contrast-54\">\n {t(\"affiliate.commission\")}\n </Text>\n </Flex>\n <AffiliateIcon />\n </Flex>\n <Flex className=\"oui-mt-auto oui-w-full oui-flex-row oui-items-center oui-gap-1\">\n <img\n src=\"https://oss.orderly.network/static/symbol_logo/USDC.png\"\n alt=\"USDC\"\n className=\"oui-size-5\"\n />\n <Text\n className={cn(\n \"oui-text-xs oui-font-semibold\",\n isNumber(rebate) && rebate !== 0\n ? \"oui-text-base-contrast\"\n : \"oui-text-base-contrast-36\",\n )}\n >\n {commifyOptional(rebate, { fix: 2, fallback: \"--\" })}\n </Text>\n <Text className=\"oui-text-xs oui-font-semibold oui-text-base-contrast-36\">\n (30D)\n </Text>\n <ChevronRightIcon\n size={18}\n color=\"white\"\n className=\"oui-ml-auto\"\n onClick={() => {\n routerAdapter?.onRouteChange({\n href: \"/rewards/affiliate?tab=affiliate\",\n name: t(\"tradingRewards.rewards\"),\n });\n }}\n />\n </Flex>\n </Flex>\n );\n};\n","import { FC } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n Flex,\n Text,\n ArrowDownSquareFillIcon,\n ArrowUpSquareFillIcon,\n CalendarMinusIcon,\n ArrowLeftRightIcon,\n} from \"@orderly.network/ui\";\nimport { RouterAdapter } from \"@orderly.network/ui-scaffold\";\nimport { PortfolioLeftSidebarPath } from \"../../../layout\";\n\ntype Props = {\n disabled: boolean;\n onWithdraw?: () => void;\n onDeposit?: () => void;\n onTransfer?: () => void;\n isMainAccount?: boolean;\n routerAdapter?: RouterAdapter;\n hasSubAccount?: boolean;\n};\n\nexport const PortfolioHandleMobile: FC<Props> = (props) => {\n const { t } = useTranslation();\n\n const onGotoHistory = () => {\n props.routerAdapter?.onRouteChange({\n href: PortfolioLeftSidebarPath.History,\n name: t(\"trading.history\"),\n });\n };\n\n return (\n <Flex\n direction={\"row\"}\n width={\"100%\"}\n height={\"71px\"}\n className=\"oui-gap-3 oui-bg-transparent\"\n >\n {props.isMainAccount && (\n <Flex\n direction=\"column\"\n gapY={2}\n itemAlign={\"center\"}\n className=\"oui-flex-1 oui-cursor-pointer\"\n onClick={props?.onDeposit}\n >\n <div className=\"oui-flex oui-size-[48px] oui-items-center oui-justify-center oui-rounded-xl oui-bg-base-9\">\n <ArrowDownSquareFillIcon size={28} color=\"white\" opacity={1} />\n </div>\n <Text className=\"oui-text-base-80 oui-text-2xs\">\n {t(\"common.deposit\")}\n </Text>\n </Flex>\n )}\n {props.hasSubAccount && (\n <Flex\n direction=\"column\"\n gapY={2}\n itemAlign={\"center\"}\n className=\"oui-flex-1 oui-cursor-pointer\"\n onClick={props?.onTransfer}\n >\n <div className=\"oui-flex oui-size-[48px] oui-items-center oui-justify-center oui-rounded-xl oui-bg-base-9\">\n <ArrowLeftRightIcon size={28} color=\"white\" opacity={1} />\n </div>\n <Text className=\"oui-text-base-80 oui-text-2xs\">\n {t(\"common.transfer\")}\n </Text>\n </Flex>\n )}\n {props.isMainAccount && (\n <Flex\n direction=\"column\"\n gapY={2}\n itemAlign={\"center\"}\n className=\"oui-flex-1 oui-cursor-pointer\"\n onClick={props?.onWithdraw}\n >\n <div className=\"oui-flex oui-size-[48px] oui-items-center oui-justify-center oui-rounded-xl oui-bg-base-9\">\n <ArrowUpSquareFillIcon size={28} color=\"white\" opacity={1} />\n </div>\n <Text className=\"oui-text-base-80 oui-text-2xs\">\n {t(\"common.withdraw\")}\n </Text>\n </Flex>\n )}\n <Flex\n direction=\"column\"\n gapY={2}\n itemAlign={\"center\"}\n className=\"oui-flex-1 oui-cursor-pointer\"\n >\n <div\n className=\"oui-flex oui-size-[48px] oui-items-center oui-justify-center oui-rounded-xl oui-bg-base-9\"\n onClick={onGotoHistory}\n >\n <CalendarMinusIcon\n size={28}\n color=\"white\"\n opacity={1}\n viewBox=\"0 0 28 28\"\n className=\"oui-w-[28px] oui-h-[28px]\"\n />\n </div>\n <Text className=\"oui-text-base-80 oui-text-2xs\">\n {t(\"trading.history\")}\n </Text>\n </Flex>\n </Flex>\n );\n};\n","import { FC, useMemo } from \"react\";\nimport { parseJSON, useAccount } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { AccountStatusEnum, ChainNamespace } from \"@orderly.network/types\";\nimport {\n Flex,\n Text,\n cn,\n ArrowRightShortIcon,\n EyeIcon,\n} from \"@orderly.network/ui\";\nimport { RouterAdapter } from \"@orderly.network/ui-scaffold\";\nimport { PortfolioLeftSidebarPath } from \"../../../layout\";\n\ntype Props = {\n portfolioValue: number | null;\n unrealPnL: number;\n unrealROI: number;\n visible: boolean;\n namespace: string | null;\n toggleVisible: () => void;\n canTrade: boolean;\n routerAdapter?: RouterAdapter;\n};\n\nexport const PortfolioValueMobile: FC<Props> = (props) => {\n const { t } = useTranslation();\n const { state } = useAccount();\n\n const currentNamespace = useMemo(() => {\n if (props.namespace) {\n return props.namespace;\n }\n if (state.status === AccountStatusEnum.EnableTradingWithoutConnected) {\n return getLinkDeviceStorage()?.chainNamespace;\n }\n return null;\n }, [props.namespace, state.status]);\n return (\n <Flex\n direction={\"column\"}\n width={\"100%\"}\n height={\"100%\"}\n className={cn([\n \"oui-relative oui-items-start oui-overflow-hidden oui-rounded-2xl oui-bg-base-9\",\n currentNamespace === ChainNamespace.evm && \"oui-bg-[#283BEE]\",\n currentNamespace === ChainNamespace.solana && \"oui-bg-[#630EAD]\",\n ])}\n p={4}\n >\n <Flex direction=\"row\" gapX={1} itemAlign={\"center\"}>\n <Text className=\"oui-text-sm oui-text-base-contrast-54\">\n {t(\"portfolio.overview.handle.title\")}\n </Text>\n <EyeIcon\n size={16}\n className={cn(\n props.canTrade ? \"oui-text-base-contrast-54\" : \"oui-hidden\",\n )}\n onClick={props.toggleVisible}\n />\n </Flex>\n <Flex\n direction=\"row\"\n gapX={1}\n itemAlign={\"baseline\"}\n className=\"oui-mt-1\"\n >\n <Text.numeral\n visible={props.visible}\n className=\"oui-text-3xl oui-font-bold oui-text-base-contrast\"\n >\n {props.portfolioValue ?? \"--\"}\n </Text.numeral>\n <Text className=\"oui-text-base oui-font-bold oui-text-base-contrast-80\">\n USDC\n </Text>\n </Flex>\n <Flex\n direction=\"row\"\n gapX={1}\n itemAlign={\"center\"}\n className=\"oui-text-sm oui-text-base-contrast\"\n >\n <Text.numeral visible={props.visible}>\n {props.unrealPnL ?? \"--\"}\n </Text.numeral>\n <Text.numeral\n visible={props.visible}\n rule=\"percentages\"\n prefix={\"(\"}\n suffix={\")\"}\n >\n {props.unrealROI ?? \"--\"}\n </Text.numeral>\n </Flex>\n <div\n className=\"oui-absolute oui-right-0 oui-top-0 oui-flex oui-h-full oui-items-center oui-justify-center oui-px-4\"\n onClick={() =>\n props.routerAdapter?.onRouteChange({\n href: PortfolioLeftSidebarPath.Assets,\n name: \"Assets\",\n })\n }\n >\n <ArrowRightShortIcon size={18} color=\"white\" opacity={0.54} />\n </div>\n </Flex>\n );\n};\n\ntype LinkDeviceStorage = { chainId: number; chainNamespace: ChainNamespace };\n\nfunction getLinkDeviceStorage() {\n try {\n const linkDeviceStorage = localStorage.getItem(\"orderly_link_device\");\n const json = linkDeviceStorage ? parseJSON(linkDeviceStorage) : null;\n return json as LinkDeviceStorage;\n } catch (err) {\n console.error(\"getLinkDeviceStorage\", err);\n }\n}\n","import { FC } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n Flex,\n Text,\n SettingFillIcon,\n ChevronRightIcon,\n} from \"@orderly.network/ui\";\nimport { RouterAdapter } from \"@orderly.network/ui-scaffold\";\nimport { PortfolioLeftSidebarPath } from \"../../../layout\";\n\ntype Props = {\n routerAdapter?: RouterAdapter;\n};\n\nexport const SettingRouterMobile: FC<Props> = (props) => {\n const { t } = useTranslation();\n return (\n <Flex\n direction={\"row\"}\n width={\"100%\"}\n className=\"oui-cursor-pointer oui-items-center oui-gap-2 oui-rounded-xl oui-bg-base-9 oui-p-4 oui-mb-3\"\n onClick={() =>\n props?.routerAdapter?.onRouteChange({\n href: PortfolioLeftSidebarPath.Setting,\n name: t(\"portfolio.setting\"),\n })\n }\n >\n <SettingFillIcon size={18} opacity={0.98} color=\"white\" />\n <Text className=\"oui-text-base oui-font-semibold oui-text-base-contrast-80\">\n {t(\"portfolio.setting\")}\n </Text>\n <ChevronRightIcon\n className=\"oui-ml-auto\"\n size={18}\n opacity={0.36}\n color=\"white\"\n />\n </Flex>\n );\n};\n","import { FC } from \"react\";\nimport { RefferalAPI as API } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n Flex,\n Text,\n TraderMobileIcon,\n ChevronRightIcon,\n cn,\n} from \"@orderly.network/ui\";\nimport { RouterAdapter } from \"@orderly.network/ui-scaffold\";\nimport { commifyOptional } from \"@orderly.network/utils\";\n\nconst isNumber = (val: unknown): val is number => {\n return typeof val === \"number\" && !Number.isNaN(val);\n};\n\ntype TraderCardMobileProps = {\n referralInfo?: API.ReferralInfo;\n routerAdapter?: RouterAdapter;\n};\n\nexport const TraderCardMobile: FC<TraderCardMobileProps> = (props) => {\n const { t } = useTranslation();\n const { referralInfo, routerAdapter } = props;\n const rebate = referralInfo?.referee_info?.[\"30d_referee_rebate\"];\n return (\n <Flex\n className=\"\n oui-via-21.6% \n oui-via-83.23% \n oui-relative \n oui-h-[112px] \n oui-w-full \n oui-flex-col \n oui-items-start \n oui-rounded-xl \n oui-border\n oui-border-solid \n oui-border-[rgba(var(--oui-gradient-success-start)/0.36)]\n oui-bg-gradient-to-r\n oui-from-[rgba(var(--oui-gradient-success-end)/0.12)]\n oui-to-[rgba(var(--oui-gradient-success-start)/0.12)]\n oui-p-3\n \"\n >\n <Flex className=\"oui-w-full oui-flex-row oui-justify-between oui-items-center\">\n <Flex className=\"oui-flex-col oui-items-start\">\n <Text className=\"oui-text-base-contrast oui-text-base oui-font-semibold\">\n {t(\"affiliate.trader.rebates\")}\n </Text>\n <Text className=\"oui-text-2xs oui-font-normal oui-text-base-contrast-54\">\n {t(\"affiliate.trader.tradingRebates\")}\n </Text>\n </Flex>\n <TraderMobileIcon />\n </Flex>\n\n <Flex\n className={cn(\n \"oui-mt-auto oui-w-full oui-flex-row oui-items-center oui-gap-1\",\n )}\n >\n <img\n src=\"https://oss.orderly.network/static/symbol_logo/USDC.png\"\n alt=\"USDC\"\n className=\"oui-size-5\"\n />\n <Text\n className={cn(\n \"oui-text-xs oui-font-semibold\",\n isNumber(rebate) && rebate !== 0\n ? \"oui-text-base-contrast\"\n : \"oui-text-base-contrast-36\",\n )}\n >\n {commifyOptional(rebate, { fix: 2, fallback: \"--\" })}\n </Text>\n <Text className=\"oui-text-xs oui-font-semibold oui-text-base-contrast-36\">\n (30D)\n </Text>\n <ChevronRightIcon\n size={18}\n color=\"white\"\n className=\"oui-ml-auto\"\n onClick={() => {\n routerAdapter?.onRouteChange({\n href: \"/rewards/affiliate?tab=trader\",\n name: t(\"tradingRewards.rewards\"),\n });\n }}\n />\n </Flex>\n </Flex>\n );\n};\n","export { FeeTierPage } from \"./page\";\nexport { useFeeTierScript } from \"./feeTier.script\";\nexport type { FeeDataType, UseFeeTierScriptOptions } from \"./feeTier.script\";\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport React, { useCallback } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n Box,\n Flex,\n Text,\n Card,\n Divider,\n DataTable,\n Column,\n useScreen,\n cn,\n TanstackColumn,\n} from \"@orderly.network/ui\";\nimport type { FeeDataType, useFeeTierScriptReturn } from \"./feeTier.script\";\n\nconst LazyFeeTierHeader = React.lazy(() =>\n import(\"./feeTierHeader\").then((mod) => {\n return { default: mod.FeeTierHeader };\n }),\n);\n\nexport type FeeTierProps = useFeeTierScriptReturn;\n\nexport type FeeTierHeaderProps = {\n tier?: number;\n vol?: number;\n};\n\ntype FeeTierTableProps = {\n columns: Column<any>[];\n dataSource?: any[];\n page?: number;\n pageSize?: number;\n dataCount?: number;\n tier?: number | null;\n vol?: number | null;\n onRow?: (\n record: any,\n index: number,\n ) => {\n normal?: any;\n active?: any;\n };\n onCell?: (\n column: TanstackColumn<any>,\n record: any,\n index: number,\n ) => {\n normal?: any;\n active?: any;\n };\n};\n\nexport const FeeTierTable: React.FC<FeeTierTableProps> = (props) => {\n const { isMobile } = useScreen();\n\n const { tier, columns, dataSource, onRow, onCell } = props;\n\n const internalOnRow = useCallback(\n (record: FeeDataType, index: number) => {\n const config =\n typeof onRow === \"function\"\n ? onRow(record, index)\n : { normal: undefined, active: undefined };\n const active = tier !== undefined && tier !== null && tier === index + 1;\n if (active) {\n return {\n \"data-state\": \"active\",\n className: cn(\n \"oui-pointer-events-none oui-h-[54px] oui-text-[rgba(0,0,0,0.88)] oui-gradient-brand\",\n ),\n ...config.active,\n };\n } else {\n return {\n \"data-state\": \"none\",\n className: cn(\"oui-h-[54px]\"),\n ...config.normal,\n };\n }\n },\n [tier, onRow],\n );\n\n const internalOnCell = useCallback(\n (\n column: TanstackColumn<FeeDataType>,\n record: FeeDataType,\n index: number,\n ) => {\n const config =\n typeof onCell === \"function\"\n ? onCell(column, record, index)\n : { normal: undefined, active: undefined };\n const active = tier !== undefined && tier !== null && tier === index + 1;\n const isFirstColumn = column.getIsFirstColumn();\n const isLastColumn = column.getIsLastColumn();\n if (active) {\n return {\n className: cn(\n isFirstColumn && \"oui-rounded-l-lg\",\n isLastColumn && \"oui-rounded-r-lg\",\n ),\n ...config.active,\n };\n } else {\n return {\n className: \"\",\n ...config.normal,\n };\n }\n },\n [tier, onCell],\n );\n\n return (\n <Box\n className={cn(\n \"oui-relative oui-border-b oui-border-line-4\",\n isMobile ? \"oui-mt-2 oui-rounded-xl oui-bg-base-9\" : undefined,\n )}\n >\n <DataTable\n bordered\n className=\"oui-font-semibold\"\n classNames={{ root: \"oui-bg-transparent\" }}\n onRow={internalOnRow}\n onCell={internalOnCell}\n columns={columns}\n dataSource={dataSource}\n />\n </Box>\n );\n};\n\nconst CardTitle: React.FC = () => {\n const { t } = useTranslation();\n const { isMobile } = useScreen();\n if (isMobile) {\n return (\n <Flex itemAlign={\"center\"} justify={\"center\"} gap={2}>\n <Text size=\"xs\" intensity={54}>\n {t(\"portfolio.feeTier.updatedDailyBy\")}\n </Text>\n <Text size=\"xs\" intensity={80}>\n ~2:15 UTC\n </Text>\n </Flex>\n );\n }\n return (\n <Flex itemAlign={\"center\"} justify={\"between\"}>\n <Text size={\"lg\"}>{t(\"portfolio.feeTier\")}</Text>\n <Flex itemAlign={\"center\"} justify={\"center\"} gap={1}>\n <Text size=\"xs\" intensity={54}>\n {t(\"portfolio.feeTier.updatedDailyBy\")}\n </Text>\n <Text size=\"xs\" intensity={80}>\n ~2:15 UTC\n </Text>\n </Flex>\n </Flex>\n );\n};\n\nexport const FeeTier: React.FC<FeeTierProps> = (props) => {\n const { columns, dataSource, tier, vol, headerDataAdapter, onRow, onCell } =\n props;\n const { isMobile } = useScreen();\n return (\n <Card\n title={<CardTitle />}\n id=\"oui-portfolio-fee-tier\"\n className=\"w-full\"\n classNames={{\n root: isMobile ? \"oui-bg-transparent oui-p-2\" : \"oui-bg-base-9\",\n }}\n >\n {!isMobile && <Divider />}\n <React.Suspense fallback={null}>\n <LazyFeeTierHeader\n vol={vol}\n tier={tier}\n headerDataAdapter={headerDataAdapter}\n />\n </React.Suspense>\n <FeeTierTable\n dataSource={dataSource}\n columns={columns}\n vol={vol}\n tier={tier}\n onRow={onRow}\n onCell={onCell}\n />\n </Card>\n );\n};\n","import React from \"react\";\nimport { useFeeTierScript, type UseFeeTierScriptOptions } from \".\";\nimport { FeeTier } from \"./feeTier.ui\";\n\nexport type FeeTierWidgetProps = UseFeeTierScriptOptions;\n\nexport const FeeTierWidget: React.FC<FeeTierWidgetProps> = (props) => {\n const state = useFeeTierScript(props);\n return <FeeTier {...state} />;\n};\n","import React from \"react\";\nimport { FeeTierWidget, FeeTierWidgetProps } from \"./feeTier.widget\";\n\nexport type FeeTierPageProps = FeeTierWidgetProps;\n\nexport const FeeTierPage: React.FC<FeeTierPageProps> = (props) => {\n return <FeeTierWidget {...props} />;\n};\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport React, { useEffect, useMemo, useState } from \"react\";\nimport { on } from \"events\";\nimport {\n useAccount,\n useAccountInfo,\n usePrivateQuery,\n} from \"@orderly.network/hooks\";\nimport { useDataTap } from \"@orderly.network/react-app\";\nimport { AccountStatusEnum, API } from \"@orderly.network/types\";\nimport type { Column, TanstackColumn } from \"@orderly.network/ui\";\nimport { Decimal } from \"@orderly.network/utils\";\nimport { useFeeTierColumns } from \"./column\";\nimport { dataSource as defaultDataSource } from \"./dataSource\";\n\nexport type useFeeTierScriptReturn = ReturnType<typeof useFeeTierScript>;\n\nexport type UseFeeTierScriptOptions = {\n dataAdapter?: (\n columns: Column<any>[],\n dataSource: any[],\n context?: {\n tier?: number;\n },\n ) => {\n columns: Column<any>[];\n dataSource: any[];\n };\n headerDataAdapter?: (original: any[]) => any[];\n onRow?: (\n record: any,\n index: number,\n ) => {\n normal?: any;\n active?: any;\n };\n onCell?: (\n column: TanstackColumn<any>,\n record: any,\n index: number,\n ) => {\n normal?: any;\n active?: any;\n };\n};\n\nexport interface FeeDataType {\n tier: number | null;\n volume_min?: number | null;\n volume_max?: number | null;\n volume_node?: React.ReactNode;\n or?: string | null;\n maker_fee: string;\n taker_fee: string;\n}\n\nconst findCurrentTier = (feeList: FeeDataType[], data: API.AccountInfo) => {\n const { futures_taker_fee_rate = 0, futures_maker_fee_rate = 0 } = data;\n const takerRate = new Decimal(futures_taker_fee_rate).mul(0.01);\n const makerRate = new Decimal(futures_maker_fee_rate).mul(0.01);\n const findItem = feeList.find(\n (item) =>\n item.taker_fee === `${takerRate.toNumber()}%` &&\n item.maker_fee === `${makerRate.toNumber()}%`,\n );\n return findItem?.tier;\n};\n\nexport const useFeeTierScript = (options?: UseFeeTierScriptOptions) => {\n const { dataAdapter, headerDataAdapter, onRow, onCell } = options || {};\n const [tier, setTier] = useState<number | null>();\n const { data, isLoading } = useAccountInfo();\n const { state } = useAccount();\n\n const cols = useFeeTierColumns();\n\n const { data: volumeStatistics } = usePrivateQuery<{\n perp_volume_last_30_days: number;\n }>(\"/v1/volume/user/stats\");\n\n const { columns, dataSource } = useMemo(() => {\n return typeof dataAdapter === \"function\"\n ? dataAdapter(cols, defaultDataSource, { tier: tier! })\n : { columns: cols, dataSource: defaultDataSource };\n }, [dataAdapter, cols, tier]);\n\n useEffect(() => {\n if (!data || isLoading) {\n return;\n }\n setTier(findCurrentTier(dataSource, data));\n }, [data, isLoading, dataSource]);\n\n const authData = useDataTap(\n {\n tier: tier,\n vol: volumeStatistics?.perp_volume_last_30_days,\n },\n {\n accountStatus:\n state.status === AccountStatusEnum.EnableTradingWithoutConnected\n ? AccountStatusEnum.EnableTradingWithoutConnected\n : AccountStatusEnum.EnableTrading,\n },\n );\n\n return {\n ...authData,\n columns: columns,\n dataSource: dataSource,\n onRow: onRow,\n onCell: onCell,\n headerDataAdapter: headerDataAdapter,\n };\n};\n","import React, { useMemo } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport type { Column } from \"@orderly.network/ui\";\nimport { numberToHumanStyle } from \"@orderly.network/utils\";\nimport type { FeeDataType } from \"./feeTier.script\";\n\nconst textStyle: React.CSSProperties = {\n fontVariantLigatures: \"none\",\n};\n\nexport const useFeeTierColumns = () => {\n const { t } = useTranslation();\n return useMemo<Column<FeeDataType>[]>(() => {\n return [\n {\n title: t(\"portfolio.feeTier.column.tier\"),\n dataIndex: \"tier\",\n align: \"left\",\n width: 100,\n },\n {\n title: `${t(\"portfolio.feeTier.column.30dVolume\")} (USDC)`,\n dataIndex: \"volume\",\n align: \"center\",\n width: 180,\n render: (val, record) => {\n const { volume_min, volume_max, volume_node } = record;\n if (volume_node) {\n return volume_node;\n }\n if (!volume_min && !volume_max) {\n return <div style={textStyle}>--</div>;\n }\n if (volume_min && !volume_max) {\n return t(\"portfolio.feeTier.column.30dVolume.above\", {\n volume: numberToHumanStyle(\n volume_min,\n volume_min === 2500000 ? 1 : 0,\n ),\n });\n }\n return (\n <div>\n {volume_min &&\n numberToHumanStyle(volume_min, volume_min === 2500000 ? 1 : 0)}\n {` - `}\n {volume_max &&\n numberToHumanStyle(volume_max, volume_max === 2500000 ? 1 : 0)}\n </div>\n );\n },\n },\n {\n title: t(\"portfolio.feeTier.column.maker\"),\n dataIndex: \"maker_fee\",\n align: \"right\",\n width: 100,\n },\n {\n title: t(\"portfolio.feeTier.column.taker\"),\n dataIndex: \"taker_fee\",\n align: \"right\",\n width: 100,\n },\n ];\n }, [t]);\n};\n","import type { FeeDataType } from \"./feeTier.script\";\n\nexport const dataSource: FeeDataType[] = [\n {\n tier: 1,\n volume_min: 0,\n volume_max: 500000,\n maker_fee: \"0.025%\",\n taker_fee: \"0.04%\",\n },\n {\n tier: 2,\n volume_min: 500000,\n volume_max: 1000000,\n maker_fee: \"0.02%\",\n taker_fee: \"0.035%\",\n },\n {\n tier: 3,\n volume_min: 1000000,\n volume_max: 5000000,\n maker_fee: \"0.018%\",\n taker_fee: \"0.03%\",\n },\n {\n tier: 4,\n volume_min: 5000000,\n volume_max: 20000000,\n maker_fee: \"0.012%\",\n taker_fee: \"0.025%\",\n },\n {\n tier: 5,\n volume_min: 20000000,\n volume_max: 50000000,\n or: \"/\",\n maker_fee: \"0.009%\",\n taker_fee: \"0.022%\",\n },\n {\n tier: 6,\n volume_min: 50000000,\n volume_max: 100000000,\n or: \"/\",\n maker_fee: \"0.005%\",\n taker_fee: \"0.018%\",\n },\n {\n tier: 7,\n volume_min: 100000000,\n volume_max: undefined,\n or: \"/\",\n maker_fee: \"0%\",\n taker_fee: \"0.015%\",\n },\n];\n","import { useMemo, useState } from \"react\";\nimport React from \"react\";\nimport { useAccount } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n Flex,\n Text,\n Divider,\n Box,\n Tabs,\n TabPanel,\n DataFilter,\n formatAddress,\n Tooltip,\n InfoCircleIcon,\n} from \"@orderly.network/ui\";\nimport {\n LiquidationWidget,\n PositionHistoryWidget,\n PositionsProps,\n CombinePositionsWidget,\n PositionsWidget,\n} from \"@orderly.network/ui-positions\";\nimport type { SelectOption } from \"@orderly.network/ui/src/select/withOptions\";\nimport { AccountType } from \"../assets/assetsPage/assets.ui.desktop\";\n\nenum TabsType {\n positions = \"Positions\",\n positionHistory = \"Position history\",\n liquidation = \"Liquidation\",\n}\n\nexport const PositionsPage: React.FC<PositionsProps> = (props) => {\n const [tab, setTab] = useState(TabsType.positions);\n const { t } = useTranslation();\n const { state, isMainAccount } = useAccount();\n\n const subAccounts = state.subAccounts ?? [];\n\n const [selectedAccount, setAccount] = React.useState<string>(AccountType.ALL);\n\n const onAccountFilter = React.useCallback(\n (filter: { name: string; value: string }) => {\n const { name, value } = filter;\n if (name === \"account\") {\n setAccount(value);\n }\n },\n [],\n );\n\n const ALL_ACCOUNTS: SelectOption = {\n label: t(\"common.allAccount\"),\n value: AccountType.ALL,\n };\n\n const MAIN_ACCOUNT: SelectOption = {\n label: t(\"common.mainAccount\"),\n value: AccountType.MAIN,\n };\n\n const memoizedOptions = useMemo(() => {\n if (Array.isArray(subAccounts) && subAccounts.length) {\n return [\n ALL_ACCOUNTS,\n MAIN_ACCOUNT,\n ...subAccounts.map<SelectOption>((value) => ({\n value: value.id,\n label: value?.description || formatAddress(value?.id),\n })),\n ];\n }\n return [ALL_ACCOUNTS, MAIN_ACCOUNT];\n }, [subAccounts]);\n\n return (\n <Flex\n // p={6}\n direction={\"column\"}\n itemAlign={\"start\"}\n gap={4}\n width=\"100%\"\n height=\"100%\"\n >\n <Flex>\n <Text size=\"lg\">{t(\"common.positions\")}</Text>\n </Flex>\n <Divider className=\"oui-w-full\" />\n {/* 26(title height) + 1(divider) + 32 (padding) */}\n <Box width=\"100%\" className=\"oui-h-[calc(100%_-_59px)]\">\n <Tabs\n value={tab}\n onValueChange={(e) => setTab(e as any)}\n classNames={{\n tabsList: \"!oui-border-none oui-pb-1\",\n tabsContent: \"oui-h-[calc(100%_-_28px)]\",\n trigger: \"oui-group\",\n }}\n className=\"oui-h-full\"\n >\n <TabPanel value={TabsType.positions} title={t(\"common.positions\")}>\n {isMainAccount ? (\n <>\n <DataFilter\n onFilter={onAccountFilter}\n items={[\n {\n type: \"select\",\n name: \"account\",\n value: selectedAccount,\n options: memoizedOptions,\n },\n ]}\n />\n <CombinePositionsWidget\n selectedAccount={selectedAccount}\n {...props}\n />\n </>\n ) : (\n <PositionsWidget {...props} enableSortingStorage={false} />\n )}\n </TabPanel>\n <TabPanel\n value={TabsType.positionHistory}\n title={t(\"positions.positionHistory\")}\n >\n <PositionHistoryWidget {...props} enableSortingStorage={false} />\n </TabPanel>\n <TabPanel value={TabsType.liquidation} title={<LiquidationTab />}>\n <LiquidationWidget />\n </TabPanel>\n </Tabs>\n </Box>\n </Flex>\n );\n};\n\nconst LiquidationTab: React.FC = () => {\n const { t } = useTranslation();\n return (\n <div className=\"oui-flex oui-space-x-1\">\n <span>{t(\"positions.liquidation\")}</span>\n <Tooltip\n className=\"oui-max-w-[275px] oui-bg-base-6\"\n content={\n <div>\n <div className=\"oui-text-pretty\">\n {t(\"positions.Liquidation.tooltip.liquidation\")}\n </div>\n <div>\n <a\n href=\"https://orderly.network/docs/introduction/trade-on-orderly/perpetual-futures/liquidations\"\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n className=\"oui-text-primary\"\n >\n {t(\"positions.Liquidation.tooltip.viewMore\")}\n </a>\n </div>\n </div>\n }\n arrow={{\n className: \"oui-fill-base-6\",\n }}\n >\n <button className=\"oui-hidden group-data-[state=active]:oui-block\">\n <InfoCircleIcon />\n </button>\n </Tooltip>\n </div>\n );\n};\n","import { FC, SVGProps, useRef } from \"react\";\nimport React from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { Box, Button, Divider, Flex, Text, Tooltip } from \"@orderly.network/ui\";\nimport { OrderListInstance, OrdersWidget } from \"@orderly.network/ui-orders\";\nimport { SharePnLConfig } from \"@orderly.network/ui-share\";\n\nexport const OrdersPage: React.FC<{ sharePnLConfig?: SharePnLConfig }> = (\n props,\n) => {\n const { sharePnLConfig } = props;\n const { t } = useTranslation();\n\n const ordersRef = useRef<OrderListInstance>(null);\n\n const onDownload = () => {\n ordersRef.current?.download?.();\n };\n\n return (\n <Flex\n // p={6}\n direction={\"column\"}\n itemAlign={\"start\"}\n gap={4}\n width=\"100%\"\n height=\"100%\"\n >\n <Flex width=\"100%\" justify=\"between\">\n <Text size=\"lg\">{t(\"common.orders\")}</Text>\n <Tooltip content={t(\"orders.download.tooltip\")}>\n <Button\n color=\"gray\"\n size=\"sm\"\n className=\"oui-bg-base-4\"\n onClick={onDownload}\n >\n {t(\"common.download\")}\n <TooltipIcon className=\"oui-text-base-contrast-36 oui-ml-[5px]\" />\n </Button>\n </Tooltip>\n </Flex>\n <Divider className=\"oui-w-full\" />\n {/* 26(title height) + 1(divider) + 32 (padding) */}\n <Box width=\"100%\" className=\"oui-h-[calc(100%_-_59px)]\">\n <OrdersWidget ref={ordersRef} sharePnLConfig={sharePnLConfig} />\n </Box>\n </Flex>\n );\n};\n\nconst TooltipIcon = React.forwardRef<SVGSVGElement, SVGProps<SVGSVGElement>>(\n (props, ref) => {\n return (\n <svg\n width=\"12\"\n height=\"12\"\n viewBox=\"0 0 12 12\"\n fill=\"currentColor\"\n xmlns=\"http://www.w3.org/2000/svg\"\n ref={ref}\n {...props}\n >\n <path d=\"M5.999 1.007a5 5 0 1 0 0 10 5 5 0 0 0 0-10m0 2.5a.5.5 0 1 1 0 1 .5.5 0 0 1 0-1m0 1.5a.5.5 0 0 1 .5.5v2.5a.5.5 0 0 1-1 0v-2.5a.5.5 0 0 1 .5-.5\" />\n </svg>\n );\n },\n);\n","export { APIManagerWidget } from \"./apiManager.widget\";\nexport { APIManagerPage } from \"./apiManager.page\";\n","import { APIManager } from \"./apiManager.ui\";\nimport { useApiManagerScript } from \"./apiManager.script\";\n\n\nexport const APIManagerWidget = (props?: {\n filterTags?: [string];\n keyStatus?: string;\n}) => {\n const state = useApiManagerScript(props);\n return <APIManager {...state} />;\n};\n","import { APIManagerWidget } from \"./apiManager.widget\";\n\n/**\n * API key manager page\n * @param filterTags filterTags\n * @param keyStatus filterTags default is \"ACTIVE\"\n * @returns\n */\nexport const APIManagerPage = (props: {\n filterTags?: [string];\n keyStatus?: string;\n}) => {\n const { filterTags, keyStatus = \"ACTIVE\" } = props;\n return <APIManagerWidget filterTags={filterTags} keyStatus={keyStatus}/>;\n};\n","export { SettingWidget } from \"./setting.widget\";\nexport { SettingPage } from \"./setting.page\";\n","import { useEffect, useState } from \"react\";\nimport {\n useAccount,\n useAccountInfo,\n useDebouncedCallback,\n useMutation,\n useLocalStorage,\n useOrderlyContext,\n} from \"@orderly.network/hooks\";\nimport { useAppContext } from \"@orderly.network/react-app\";\nimport { AccountStatusEnum } from \"@orderly.network/types\";\nimport { toast } from \"@orderly.network/ui\";\n\nconst ORDERLY_ORDER_SOUND_ALERT_KEY = \"orderly_order_sound_alert\";\n\nexport type SettingScriptReturns = {\n maintenance_cancel_orders?: boolean;\n setMaintainConfig: (maintenance_cancel_order_flag: boolean) => void;\n isSetting: boolean;\n canTouch: boolean;\n soundAlert: boolean;\n setSoundAlert: (value: boolean) => void;\n hasOrderFilledMedia: boolean;\n};\n\nexport const useSettingScript = (): SettingScriptReturns => {\n const { data, mutate: refresh } = useAccountInfo();\n const { wrongNetwork, disabledConnect } = useAppContext();\n const [update, { isMutating }] = useMutation(\"/v1/client/maintenance_config\");\n const [checked, setChecked] = useState(false);\n const { notification } = useOrderlyContext();\n\n const [soundAlert, setSoundAlert] = useLocalStorage<boolean>(\n ORDERLY_ORDER_SOUND_ALERT_KEY,\n notification?.orderFilled?.defaultOpen ?? false,\n );\n\n useEffect(() => {\n setChecked(data?.maintenance_cancel_orders || false);\n }, [data]);\n\n const updateCheckState = useDebouncedCallback((value: boolean) => {\n // if (value === data?.maintenance_cancel_orders) return;\n update({\n maintenance_cancel_order_flag: value,\n }).then((data) => {\n if (data.success) {\n toast.success(value ? \"Opened\" : \"Closed\");\n } else {\n setChecked(!value);\n }\n });\n }, 300);\n\n const setMaintainConfig = (maintenance_cancel_order_flag: boolean) => {\n setChecked(maintenance_cancel_order_flag);\n updateCheckState(maintenance_cancel_order_flag);\n };\n const { state } = useAccount();\n\n const canTouch =\n !wrongNetwork &&\n !disabledConnect &&\n (state.status === AccountStatusEnum.EnableTrading ||\n state.status === AccountStatusEnum.EnableTradingWithoutConnected);\n\n return {\n maintenance_cancel_orders: checked, //data?.maintenance_cancel_orders,\n setMaintainConfig,\n isSetting: false,\n canTouch,\n soundAlert,\n setSoundAlert,\n hasOrderFilledMedia: Boolean(notification?.orderFilled?.media),\n };\n};\n","import { FC } from \"react\";\nimport { useScreen } from \"@orderly.network/ui\";\nimport { SettingScriptReturns } from \"./setting.script\";\nimport { SettingDesktop } from \"./setting.ui.desktop\";\nimport { SettingMobile } from \"./setting.ui.mobile\";\n\nexport const Setting: FC<SettingScriptReturns> = (props) => {\n const { isMobile } = useScreen();\n if (isMobile) {\n return (\n <div className=\"oui-px-3\">\n <SettingMobile {...props} />\n </div>\n );\n }\n return <SettingDesktop {...props} />;\n};\n","import { FC } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { Card, Flex, Switch, Text } from \"@orderly.network/ui\";\nimport { AuthGuardTooltip } from \"@orderly.network/ui-connector\";\nimport type { SettingScriptReturns } from \"./setting.script\";\n\nexport const SettingDesktop: FC<SettingScriptReturns> = (props) => {\n const { t } = useTranslation();\n\n return (\n <>\n <Card\n title={t(\"portfolio.setting.systemUpgrade\")}\n id=\"portfolio-apikey-manager\"\n className=\"oui-bg-base-9 oui-font-semibold\"\n >\n <Flex\n direction={\"row\"}\n gap={4}\n width={\"100%\"}\n itemAlign={\"center\"}\n pt={4}\n className=\"oui-border-t-2 oui-border-line-6 oui-font-semibold\"\n >\n <Flex direction={\"column\"} itemAlign={\"start\"} className=\"oui-flex-1\">\n <Text intensity={80} size=\"base\">\n {t(\"portfolio.setting.cancelOpenOrders\")}\n </Text>\n <Text intensity={54} size=\"sm\">\n {t(\"portfolio.setting.cancelOpenOrders.description\")}\n </Text>\n </Flex>\n\n <AuthGuardTooltip align=\"end\">\n <Switch\n checked={props.maintenance_cancel_orders}\n onCheckedChange={(e) => {\n props.setMaintainConfig(e);\n }}\n disabled={props.isSetting || !props.canTouch}\n data-testid=\"oui-testid-setting-switch-btn\"\n />\n </AuthGuardTooltip>\n </Flex>\n </Card>\n\n {props.hasOrderFilledMedia && (\n <Card\n title={t(\"portfolio.setting.soundAlerts\")}\n id=\"portfolio-sound-alert-setting\"\n className=\"oui-bg-base-9 oui-font-semibold oui-mt-3\"\n >\n <Flex\n direction={\"row\"}\n gap={4}\n width={\"100%\"}\n itemAlign={\"center\"}\n pt={4}\n className=\"oui-border-t-2 oui-border-line-6 oui-font-semibold\"\n >\n <Flex\n direction={\"column\"}\n itemAlign={\"start\"}\n className=\"oui-flex-1\"\n >\n <Text intensity={54} size=\"sm\">\n {t(\"portfolio.setting.soundAlerts.description\")}\n </Text>\n </Flex>\n\n <AuthGuardTooltip align=\"end\">\n <Switch\n checked={props.soundAlert}\n onCheckedChange={(checked) => props.setSoundAlert(checked)}\n data-testid=\"oui-testid-setting-sound-switch-btn\"\n />\n </AuthGuardTooltip>\n </Flex>\n </Card>\n )}\n </>\n );\n};\n","import { FC, useState } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n Card,\n Flex,\n Switch,\n Text,\n ChevronRightIcon,\n} from \"@orderly.network/ui\";\nimport { AuthGuardTooltip } from \"@orderly.network/ui-connector\";\nimport { LanguageSwitcherWidget } from \"@orderly.network/ui-scaffold\";\nimport type { SettingScriptReturns } from \"./setting.script\";\n\nexport const SettingMobile: FC<SettingScriptReturns> = (props) => {\n const { t } = useTranslation();\n const [open, setOpen] = useState<boolean>(false);\n const onLanguageChange = () => {\n setOpen(true);\n };\n\n return (\n <>\n <Flex mt={1} p={4} intensity={900} r=\"xl\" itemAlign=\"center\">\n <LanguageSwitcherWidget open={open} onOpenChange={setOpen} />\n <Flex\n className=\"oui-cursor-pointer\"\n itemAlign=\"center\"\n width=\"100%\"\n onClick={onLanguageChange}\n >\n <Text\n size=\"base\"\n weight=\"semibold\"\n intensity={80}\n className=\"oui-ml-2\"\n >\n {t(\"languageSwitcher.language\")}\n </Text>\n <ChevronRightIcon\n size={18}\n className=\"oui-ml-auto oui-text-base-contrast-36\"\n />\n </Flex>\n </Flex>\n\n <Card\n // @ts-ignore\n title={\n <div className=\"oui-text-sm\">\n {t(\"portfolio.setting.systemUpgrade\")}\n </div>\n }\n id=\"portfolio-apikey-manager\"\n className=\"oui-bg-base-9 oui-font-semibold oui-mt-2\"\n classNames={{ root: \"oui-p-4\", content: \"!oui-pt-3\" }}\n >\n <Flex\n direction={\"row\"}\n gap={4}\n width={\"100%\"}\n itemAlign={\"center\"}\n pt={3}\n className=\"oui-font-semibold oui-border-t-2 oui-border-line-6\"\n >\n <Flex\n direction={\"column\"}\n itemAlign={\"start\"}\n className=\"oui-flex-1 oui-gap-2\"\n >\n <Text intensity={80} size=\"xs\">\n {t(\"portfolio.setting.cancelOpenOrders\")}\n </Text>\n <Text intensity={36} size=\"2xs\" className=\"oui-font-normal\">\n {t(\"portfolio.setting.cancelOpenOrders.description\")}\n </Text>\n <AuthGuardTooltip>\n <Switch\n className=\"oui-mt-1\"\n checked={props.maintenance_cancel_orders}\n onCheckedChange={(e) => {\n props.setMaintainConfig(e);\n }}\n disabled={props.isSetting || !props.canTouch}\n data-testid=\"oui-testid-setting-switch-btn\"\n />\n </AuthGuardTooltip>\n </Flex>\n </Flex>\n </Card>\n\n {props.hasOrderFilledMedia && (\n <Card\n // @ts-ignore\n title={\n <div className=\"oui-text-sm\">\n {t(\"portfolio.setting.soundAlerts\")}\n </div>\n }\n id=\"portfolio-sound-alert-setting\"\n className=\"oui-bg-base-9 oui-font-semibold oui-mt-2\"\n classNames={{ root: \"oui-p-4\", content: \"!oui-pt-3\" }}\n >\n <Flex\n direction={\"row\"}\n gap={4}\n width={\"100%\"}\n itemAlign={\"center\"}\n pt={3}\n className=\"oui-font-semibold oui-border-t-2 oui-border-line-6\"\n >\n <Flex\n direction={\"column\"}\n itemAlign={\"start\"}\n className=\"oui-flex-1 oui-gap-2\"\n >\n <Text intensity={36} size=\"2xs\" className=\"oui-font-normal\">\n {t(\"portfolio.setting.soundAlerts.description\")}\n </Text>\n <AuthGuardTooltip>\n <Switch\n className=\"oui-mt-1\"\n checked={props.soundAlert}\n onCheckedChange={(e) => {\n props.setSoundAlert(e);\n }}\n data-testid=\"oui-testid-setting-sound-switch-btn\"\n />\n </AuthGuardTooltip>\n </Flex>\n </Flex>\n </Card>\n )}\n </>\n );\n};\n","import React from \"react\";\nimport { useSettingScript } from \"./setting.script\";\nimport { Setting } from \"./setting.ui\";\n\nexport const SettingWidget: React.FC = () => {\n const state = useSettingScript();\n return <Setting {...state} />;\n};\n","import React from \"react\";\nimport { SettingWidget } from \"./setting.widget\";\n\nexport const SettingPage: React.FC = () => {\n return <SettingWidget />;\n};\n","export { AssetsPage } from \"./page\";\nexport {\n AssetsWidget,\n AssetsDataTableWidget,\n} from \"./assetsPage/assets.widget\";\nexport type { AssetsWidgetProps } from \"./assetsPage/assets.widget\";\nexport { AssetsTable, AssetsDataTable } from \"./assetsPage/assets.ui.desktop\";\nexport { AssetsTableMobile } from \"./assetsPage/assets.ui.mobile\";\n","import React from \"react\";\nimport { useAccount } from \"@orderly.network/hooks\";\nimport { DataTableClassNames, useScreen } from \"@orderly.network/ui\";\nimport { useAssetsScript } from \"./assets.script\";\nimport type { useAssetsScriptReturn } from \"./assets.script\";\nimport { AssetsDataTable, AssetsTable } from \"./assets.ui.desktop\";\nimport { AssetsTableMobile } from \"./assets.ui.mobile\";\n\nexport type AssetsWidgetProps = useAssetsScriptReturn;\n\nexport type AssetsDataTableWidgetProps = {\n classNames?: {\n root?: string;\n desc?: string;\n scrollRoot?: string;\n };\n tbClassName?: string;\n dataTableClassNames?: DataTableClassNames;\n};\n\nexport const AssetsDataTableWidget: React.FC<AssetsDataTableWidgetProps> = (\n props,\n) => {\n const assetsState = useAssetsScript();\n const accountState = useAccount();\n return <AssetsDataTable {...assetsState} {...accountState} {...props} />;\n};\n\nexport const AssetsWidget: React.FC = () => {\n const assetsState = useAssetsScript();\n const accountState = useAccount();\n const { isMobile } = useScreen();\n if (isMobile) {\n return <AssetsTableMobile {...assetsState} {...accountState} />;\n }\n return <AssetsTable {...assetsState} {...accountState} />;\n};\n","import { useCallback, useEffect, useMemo } from \"react\";\nimport {\n useAccount,\n useCollateral,\n useLocalStorage,\n useIndexPricesStream,\n useTokensInfo,\n} from \"@orderly.network/hooks\";\nimport { account } from \"@orderly.network/perp\";\nimport { EMPTY_LIST } from \"@orderly.network/types\";\nimport { modal } from \"@orderly.network/ui\";\nimport {\n DepositAndWithdrawWithDialogId,\n TransferDialogId,\n} from \"@orderly.network/ui-transfer\";\nimport { Decimal, zero } from \"@orderly.network/utils\";\nimport { useAccountsData, useAssetsMultiFilter } from \"../../../hooks\";\nimport { useAssetTotalValue } from \"../../../hooks/useAssetTotalValue\";\nimport { ORDERLY_ASSETS_VISIBLE_KEY } from \"../type\";\nimport { useAssetsColumns } from \"./assets.column\";\n\nexport const useAssetsScript = () => {\n const [visible, setVisible] = useLocalStorage<boolean>(\n ORDERLY_ASSETS_VISIBLE_KEY,\n true,\n );\n\n const { state, subAccount, isMainAccount } = useAccount();\n const { holding = [] } = useCollateral();\n const { getIndexPrice } = useIndexPricesStream();\n\n const tokensInfo = useTokensInfo();\n\n const subAccounts = state.subAccounts ?? [];\n\n useEffect(() => {\n if (holding.length > 0) {\n subAccount.refresh();\n }\n }, [holding]);\n\n // Use the extracted total value hook\n const totalValue = useAssetTotalValue();\n\n const toggleVisible = () => {\n // @ts-ignore\n setVisible((visible: boolean) => !visible);\n };\n\n const assetsOptions = useMemo(() => {\n return tokensInfo?.map((item) => ({\n label: item.token,\n value: item.token,\n }));\n }, [tokensInfo]);\n\n // Use the extracted accounts data hook\n const allAccounts = useAccountsData();\n\n // Use the extracted account and asset filter hook\n const {\n selectedAccount,\n selectedAsset,\n filteredData: filtered,\n onFilter,\n } = useAssetsMultiFilter(allAccounts);\n\n // Enhanced filtered data with additional calculations for children\n const enhancedFiltered = useMemo(() => {\n return filtered.map((accountData) => {\n // Enhance each child (holding) with calculated fields\n const enhancedChildren =\n accountData.children?.map((holding) => {\n const tokenInfo = tokensInfo?.find(\n (item) => item.token === holding.token,\n );\n\n // Use extracted function for index price calculation\n const indexPrice = getIndexPrice(holding.token);\n\n // Use extracted function for asset value calculation\n const assetValue = new Decimal(holding.holding)\n .mul(indexPrice)\n .toNumber();\n\n // Calculate collateral ratio for this token\n const collateralRatio = tokenInfo\n ? account.collateralRatio({\n baseWeight: tokenInfo.base_weight ?? 0,\n discountFactor: tokenInfo.discount_factor ?? 0,\n collateralQty: holding.holding,\n collateralCap: tokenInfo?.user_max_qty ?? holding.holding,\n indexPrice: indexPrice,\n })\n : zero;\n\n // Calculate collateral contribution for this token\n const collateralContribution = account.collateralContribution({\n collateralQty: holding.holding,\n collateralCap: tokenInfo?.user_max_qty ?? holding.holding,\n collateralRatio: collateralRatio.toNumber(),\n indexPrice: indexPrice,\n });\n\n return {\n ...holding,\n indexPrice,\n assetValue,\n collateralRatio,\n collateralContribution,\n };\n }) || [];\n\n return {\n ...accountData,\n children: enhancedChildren,\n };\n });\n }, [filtered, getIndexPrice, tokensInfo]);\n\n const handleTransfer = useCallback((accountId: string, token: string) => {\n if (!accountId) {\n return;\n }\n modal.show(TransferDialogId, {\n toAccountId: accountId,\n token,\n });\n }, []);\n\n const handleConvert = (accountId: string, token: string) => {\n modal.show(\"ConvertDialogId\", {\n accountId,\n token,\n });\n };\n\n const showTransfer = isMainAccount ? subAccounts.length > 0 : true;\n\n const assetsColumns = useAssetsColumns({\n onTransfer: showTransfer ? handleTransfer : undefined,\n onConvert: handleConvert,\n });\n\n const openDepositAndWithdraw = useCallback(\n (viewName: \"deposit\" | \"withdraw\") => {\n modal.show(DepositAndWithdrawWithDialogId, {\n activeTab: viewName,\n });\n },\n [],\n );\n\n const onDeposit = useCallback(() => {\n openDepositAndWithdraw(\"deposit\");\n }, []);\n\n const onWithdraw = useCallback(() => {\n openDepositAndWithdraw(\"withdraw\");\n }, []);\n\n return {\n columns: assetsColumns,\n dataSource: enhancedFiltered, // Use enhanced filtered data with calculated children\n visible: visible as boolean,\n onToggleVisibility: toggleVisible,\n selectedAccount,\n selectedAsset,\n onFilter,\n totalValue,\n hasSubAccount: subAccounts.length > 0,\n onDeposit,\n onWithdraw,\n holding,\n assetsOptions: assetsOptions ?? EMPTY_LIST,\n };\n};\n\nexport type useAssetsScriptReturn = ReturnType<typeof useAssetsScript> &\n ReturnType<typeof useAccount>;\n","import React from \"react\";\nimport { useTokensInfo } from \"@orderly.network/hooks\";\nimport { useWalletConnector } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { ChainNamespace } from \"@orderly.network/types\";\nimport { Button, Flex, Text, TokenIcon } from \"@orderly.network/ui\";\nimport type { Column } from \"@orderly.network/ui\";\n\nexport interface ColumnsOptions {\n onTransfer?: (accountId: string, token: string) => void;\n onConvert?: (accountId: string, token: string) => void;\n}\n\n// Define the enhanced holding interface with calculated fields\ninterface EnhancedHolding {\n token: string;\n holding: number;\n indexPrice: number;\n assetValue: number;\n collateralRatio: number;\n collateralContribution: number;\n account_id: string;\n}\n\nexport const useAssetsColumns = (options: ColumnsOptions) => {\n const { t } = useTranslation();\n const tokensInfo = useTokensInfo();\n const { namespace } = useWalletConnector();\n const { onTransfer, onConvert } = options;\n const columns = React.useMemo<Column[]>(() => {\n return [\n {\n title: t(\"portfolio.overview.column.token\"),\n dataIndex: \"token\",\n align: \"left\",\n width: 150,\n render(val: string) {\n return (\n <Flex itemAlign=\"center\" gap={2}>\n <TokenIcon name={val} />\n {val}\n </Flex>\n );\n },\n },\n {\n title: t(\"portfolio.overview.column.qty\"),\n dataIndex: \"holding\",\n align: \"left\",\n width: 140,\n render(val: number, record) {\n const findToken = tokensInfo?.find(\n ({ token }) => token === record.token,\n );\n return (\n <Text.numeral dp={findToken?.decimals ?? 6} padding={false}>\n {val}\n </Text.numeral>\n );\n },\n },\n {\n title: t(\"portfolio.overview.column.indexPrice\"),\n dataIndex: \"indexPrice\",\n align: \"left\",\n width: 140,\n render(val: number) {\n return (\n <Text.numeral rule=\"price\" dp={6} currency=\"$\" padding={false}>\n {val}\n </Text.numeral>\n );\n },\n },\n {\n title: t(\"portfolio.overview.column.assetValue\"),\n dataIndex: \"assetValue\",\n align: \"left\",\n width: 140,\n render(val: number) {\n return (\n <Text.numeral rule=\"price\" dp={6} currency=\"$\" padding={false}>\n {val}\n </Text.numeral>\n );\n },\n },\n {\n title: t(\"portfolio.overview.column.collateralRatio\"),\n dataIndex: \"collateralRatio\",\n align: \"left\",\n width: 140,\n render(val: number) {\n return (\n <Text.numeral dp={2} suffix=\"%\">\n {val * 100}\n </Text.numeral>\n );\n },\n },\n {\n title: t(\"transfer.deposit.collateralContribution\"),\n dataIndex: \"collateralContribution\",\n align: \"left\",\n width: 140,\n render(val: number) {\n return (\n <Text.numeral rule=\"price\" dp={6} currency=\"$\" padding={false}>\n {val}\n </Text.numeral>\n );\n },\n },\n {\n title: null,\n dataIndex: \"account_id\",\n align: \"center\",\n width: 180,\n render(id: string, record: EnhancedHolding) {\n const { token } = record;\n return (\n <Flex itemAlign=\"center\" justify=\"end\" gap={3}>\n {token !== \"USDC\" &&\n namespace !== ChainNamespace.solana &&\n typeof onConvert === \"function\" && (\n <Button\n size={\"sm\"}\n variant={\"outlined\"}\n color={\"secondary\"}\n onClick={() => onConvert?.(id, token)}\n >\n {t(\"transfer.convert\")}\n </Button>\n )}\n {typeof onTransfer === \"function\" && (\n <Button\n size={\"sm\"}\n variant={\"outlined\"}\n color={\"secondary\"}\n onClick={() => onTransfer?.(id, token)}\n >\n {t(\"common.transfer\")}\n </Button>\n )}\n </Flex>\n );\n },\n },\n ];\n }, [t, tokensInfo, onTransfer, onConvert, namespace]);\n return columns;\n};\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport React, { useMemo } from \"react\";\nimport { useWalletConnector } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { ChainNamespace } from \"@orderly.network/types\";\nimport {\n Button,\n cn,\n TokenIcon,\n Text,\n formatAddress,\n DataFilter,\n modal,\n Flex,\n} from \"@orderly.network/ui\";\nimport { SelectOption } from \"@orderly.network/ui/src/select/withOptions\";\nimport type { useAssetsScriptReturn } from \"./assets.script\";\nimport { AccountType } from \"./assets.ui.desktop\";\n\nconst AccountTag: React.FC<{ name: string }> = ({ name }) => {\n return (\n <div className=\"oui-mt-2 oui-flex oui-h-[18px] oui-w-fit oui-items-center oui-rounded oui-bg-white/[0.06] oui-px-2 oui-text-2xs oui-font-semibold oui-text-base-contrast-36\">\n {name}\n </div>\n );\n};\n\ntype AssetMobileItemProps = {\n item: any;\n};\n\nconst AssetMobileItem: React.FC<AssetMobileItemProps> = (props) => {\n const { item } = props;\n const { t } = useTranslation();\n const { namespace } = useWalletConnector();\n return (\n <div className=\"oui-flex oui-flex-col oui-gap-2 oui-rounded-xl oui-bg-base-9 oui-p-2\">\n <Flex\n width={\"100%\"}\n justify={\"between\"}\n itemAlign={\"center\"}\n className=\"oui-gap-x-0.5\"\n >\n <Flex\n className=\"oui-w-1/3 oui-truncate\"\n itemAlign={\"start\"}\n direction={\"column\"}\n >\n <div className=\"oui-text-2xs oui-font-semibold oui-text-base-contrast-36\">\n {t(\"common.token\")}\n </div>\n <Flex\n gap={1}\n justify={\"start\"}\n itemAlign={\"center\"}\n className=\"oui-text-xs oui-font-semibold oui-text-base-contrast-80\"\n >\n <TokenIcon name={item.token} size=\"2xs\" />\n {item.token}\n </Flex>\n </Flex>\n <Flex\n className=\"oui-w-1/3 oui-truncate\"\n itemAlign={\"start\"}\n direction={\"column\"}\n >\n <div className=\"oui-text-2xs oui-font-semibold oui-text-base-contrast-36\">\n {t(\"common.qty\")}\n </div>\n <Text.numeral\n className=\"oui-truncate\"\n size=\"xs\"\n dp={6}\n padding={false}\n >\n {item.holding}\n </Text.numeral>\n </Flex>\n <Flex\n className=\"oui-w-1/3 oui-truncate\"\n itemAlign={\"start\"}\n direction={\"column\"}\n >\n <div className=\"oui-w-full oui-text-end oui-text-2xs oui-font-semibold oui-text-base-contrast-36\">\n {t(\"common.indexPrice\")}\n </div>\n <Flex\n gap={1}\n width={\"100%\"}\n justify={\"end\"}\n itemAlign={\"center\"}\n className=\"oui-text-end oui-font-semibold oui-text-base-contrast-80\"\n >\n <Text.numeral\n size=\"xs\"\n rule=\"price\"\n dp={6}\n currency=\"$\"\n padding={false}\n >\n {item.indexPrice}\n </Text.numeral>\n <div className=\"oui-text-end oui-text-2xs oui-text-base-contrast-36\">\n USDC\n </div>\n </Flex>\n </Flex>\n </Flex>\n <Flex\n width={\"100%\"}\n justify={\"between\"}\n itemAlign={\"center\"}\n className=\"oui-gap-x-0.5\"\n >\n <Flex\n className=\"oui-w-1/3 oui-truncate\"\n itemAlign={\"start\"}\n direction={\"column\"}\n >\n <div className=\"oui-text-2xs oui-font-semibold oui-text-base-contrast-36\">\n {t(\"portfolio.overview.column.assetValue\")}\n </div>\n <Text.numeral\n size=\"xs\"\n intensity={80}\n className=\"oui-truncate oui-font-semibold\"\n rule=\"price\"\n dp={6}\n currency=\"$\"\n padding={false}\n >\n {item.assetValue}\n </Text.numeral>\n </Flex>\n <Flex\n className=\"oui-w-1/3 oui-truncate\"\n itemAlign={\"start\"}\n direction={\"column\"}\n >\n <div className=\"oui-text-2xs oui-font-semibold oui-text-base-contrast-36\">\n {t(\"portfolio.overview.column.collateralRatio\")}\n </div>\n <Text.numeral size=\"xs\" dp={2} suffix=\"%\">\n {item.collateralRatio * 100}\n </Text.numeral>\n </Flex>\n <Flex\n className=\"oui-w-1/3 oui-truncate\"\n itemAlign={\"start\"}\n direction={\"column\"}\n >\n <div className=\"oui-w-full oui-text-end oui-text-2xs oui-font-semibold oui-text-base-contrast-36\">\n {t(\"transfer.deposit.collateralContribution\")}\n </div>\n <Flex\n gap={1}\n width={\"100%\"}\n justify={\"end\"}\n itemAlign={\"center\"}\n className=\"oui-text-end oui-font-semibold oui-text-base-contrast-80\"\n >\n <Text.numeral\n size=\"xs\"\n rule=\"price\"\n dp={6}\n currency=\"$\"\n padding={false}\n >\n {item.collateralContribution}\n </Text.numeral>\n <div className=\"oui-text-end oui-text-2xs oui-text-base-contrast-36\">\n USDC\n </div>\n </Flex>\n </Flex>\n </Flex>\n <Flex justify={\"between\"} itemAlign={\"center\"} gap={2}>\n {item.token !== \"USDC\" && namespace !== ChainNamespace.solana && (\n <Button\n fullWidth\n variant=\"outlined\"\n size=\"sm\"\n color=\"gray\"\n onClick={() => {\n modal.show(\"ConvertSheetId\", {\n accountId: item.account_id,\n token: item.token,\n });\n }}\n className={cn(\n \"oui-flex-1 oui-border-white/[0.36] oui-text-base-contrast-54\",\n )}\n >\n {t(\"transfer.convert\")}\n </Button>\n )}\n <Button\n fullWidth\n variant=\"outlined\"\n size=\"sm\"\n color=\"gray\"\n onClick={() => {\n modal.show(\"TransferSheetId\", {\n accountId: item.account_id,\n token: item.token,\n });\n }}\n className={cn(\n \"oui-flex-1 oui-border-white/[0.36] oui-text-base-contrast-54\",\n )}\n >\n {t(\"common.transfer\")}\n </Button>\n </Flex>\n </div>\n );\n};\n\nexport const AssetsTableMobile: React.FC<useAssetsScriptReturn> = (props) => {\n const { t } = useTranslation();\n\n const {\n assetsOptions,\n state,\n isMainAccount,\n dataSource,\n selectedAccount,\n selectedAsset,\n onFilter,\n } = props;\n\n const subAccounts = state.subAccounts ?? [];\n\n const ALL_ACCOUNTS: SelectOption = {\n label: t(\"common.allAccount\"),\n value: AccountType.ALL,\n };\n\n const MAIN_ACCOUNT: SelectOption = {\n label: t(\"common.mainAccount\"),\n value: AccountType.MAIN,\n };\n\n const ALL_ASSETS: SelectOption = {\n label: \"All assets\",\n value: \"all\",\n };\n\n const memoizedOptions = useMemo(() => {\n if (Array.isArray(subAccounts) && subAccounts.length) {\n return [\n ALL_ACCOUNTS,\n MAIN_ACCOUNT,\n ...subAccounts.map<SelectOption>((value) => ({\n value: value.id,\n label: value?.description || formatAddress(value?.id),\n })),\n ];\n }\n return [ALL_ACCOUNTS, MAIN_ACCOUNT];\n }, [subAccounts]);\n\n // Create asset options from holding data - optimized and consistent with desktop\n const memoizedAssets = useMemo(() => {\n return [ALL_ASSETS, ...assetsOptions];\n }, [assetsOptions]);\n\n return (\n <div className={cn(\"oui-flex oui-flex-col oui-gap-1 oui-px-1 oui-pb-4\")}>\n {isMainAccount && (\n <DataFilter\n onFilter={onFilter}\n className=\"oui-border-none oui-py-2\"\n items={[\n {\n size: \"sm\",\n type: \"picker\",\n name: \"account\",\n value: selectedAccount,\n options: memoizedOptions,\n },\n {\n size: \"sm\",\n type: \"picker\",\n name: \"asset\",\n value: selectedAsset,\n options: memoizedAssets,\n },\n ]}\n />\n )}\n <div className=\"oui-flex oui-flex-col oui-gap-1\">\n {dataSource.map((assets, index) => {\n return (\n <React.Fragment key={`item-${index}`}>\n <AccountTag name={assets.description ?? \"sub account\"} />\n {Array.isArray(assets.children) &&\n assets.children.map((child) => (\n <AssetMobileItem\n item={child}\n key={`${child.token}-${child.account_id}`}\n />\n ))}\n </React.Fragment>\n );\n })}\n </div>\n </div>\n );\n};\n","import React from \"react\";\nimport { AssetsWidget } from \"./assetsPage/assets.widget\";\nimport type { AssetsWidgetProps } from \"./assetsPage/assets.widget\";\n\nexport type AssetsPageProps = AssetsWidgetProps;\n\nexport const AssetsPage: React.FC = () => {\n return <AssetsWidget />;\n};\n","export { HistoryPage } from \"./history.page\";\nexport { HistoryWidget } from \"./history.page\";\n","import React from \"react\";\nimport { HistoryDataGroupWidget } from \"../overview/historyDataGroup\";\n\nexport const HistoryWidget: React.FC = () => {\n return <HistoryDataGroupWidget />;\n};\n\nexport const HistoryPage: React.FC = () => {\n return <HistoryDataGroupWidget />;\n};\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/layout/context.tsx","../src/pages/overview/assets/assets.script.ts","../src/pages/overview/assets/assetsHeader.tsx","../src/pages/overview/assets/assets.ui.tsx","../src/pages/overview/assets/assets.widget.tsx","../src/pages/overview/assets/index.ts","../src/pages/overview/historyDataGroup/historyDataGroup.script.ts","../src/pages/overview/assetHistory/column.tsx","../src/pages/overview/helper/date.ts","../src/pages/overview/assetHistory/assetHistory.script.ts","../src/pages/overview/assetHistory/assetHistory.ui.tsx","../src/pages/overview/assetHistory/assetHistory.ui.mobile.tsx","../src/pages/overview/assetHistory/assetHistory.widget.tsx","../src/pages/overview/assetHistory/index.tsx","../src/pages/overview/funding/column.tsx","../src/pages/overview/funding/fundingHistory.ui.tsx","../src/pages/overview/funding/fundingHistory.ui.mobile.tsx","../src/pages/overview/funding/useDataSource.script.ts","../src/pages/overview/funding/fundingHistory.widget.tsx","../src/pages/overview/funding/index.tsx","../src/pages/overview/distribution/column.tsx","../src/pages/overview/distribution/distribution.ui.tsx","../src/pages/overview/distribution/distribution.ui.mobile.tsx","../src/pages/overview/distribution/useDataSource.script.ts","../src/pages/overview/distribution/distribution.widget.tsx","../src/pages/overview/distribution/index.tsx","../src/pages/overview/TransferHistory/column.tsx","../src/pages/overview/TransferHistory/transfer.ui.tsx","../src/pages/overview/TransferHistory/useDataSource.script.ts","../src/pages/overview/TransferHistory/transfer.widget.tsx","../src/pages/overview/TransferHistory/index.tsx","../src/pages/overview/VaultsHistory/column.tsx","../src/pages/overview/VaultsHistory/transfer.ui.tsx","../src/pages/overview/VaultsHistory/useDataSource.script.ts","../src/pages/overview/VaultsHistory/vaults.ui.mobile.tsx","../src/pages/overview/VaultsHistory/transfer.widget.tsx","../src/pages/overview/VaultsHistory/index.tsx","../src/pages/overview/historyDataGroup/historyDataGroup.ui.desktop.tsx","../src/hooks/useAccountsData.ts","../src/hooks/useAssetTotalValue.ts","../src/pages/assets/assetsPage/assets.ui.desktop.tsx","../src/hooks/useAccountFilter.ts","../src/hooks/useAssetsAccountFilter.ts","../src/hooks/index.ts","../src/pages/assets/convertPage/convert.script.ts","../src/pages/assets/convertPage/convert.column.tsx","../src/pages/assets/convertPage/convert.ui.desktop.tsx","../src/pages/assets/convertPage/convert.ui.mobile.tsx","../src/pages/assets/convertPage/convert.widget.tsx","../src/pages/overview/historyDataGroup/historyDataGroup.ui.mobile.tsx","../src/pages/overview/historyDataGroup/historyDataGroup.widget.tsx","../src/pages/overview/historyDataGroup/index.ts","../src/pages/overview/provider/overviewContext.tsx","../src/pages/overview/assetChart/assetsChart.script.ts","../src/pages/overview/shared/useAssetHistory.ts","../src/pages/overview/shared/periodHeader.tsx","../src/pages/overview/assetChart/assetsChart.ui.tsx","../src/pages/overview/assetChart/assetsChart.widget.tsx","../src/pages/overview/assetChart/index.ts","../src/pages/overview/performance/performance.ui.tsx","../src/pages/assets/type.ts","../src/pages/overview/performance/performance.script.ts","../src/pages/overview/performance/performance.widget.tsx","../src/pages/overview/performance/index.ts","../src/pages/feeTier/icons/effectiveFee.tsx","../src/pages/feeTier/icons/index.ts","../src/pages/feeTier/feeTierHeader.tsx","../src/pages/api/apiManager.script.tsx","../src/pages/api/dialog/createApiKey.tsx","../src/pages/api/dialog/createdApiKey.tsx","../src/pages/api/dialog/deleteApiKey.tsx","../src/pages/api/dialog/editApiKey.tsx","../src/pages/api/apiManager.ui.tsx","../src/layout/layout.widget.tsx","../src/layout/layout.script.tsx","../src/layout/layout.ui.tsx","../src/layout/layout.ui.mobile.tsx","../src/pages/overview/index.tsx","../src/pages/overview/performanceMobileDialog/performance.ui.tsx","../src/pages/overview/performanceMobileDialog/performance.widget.tsx","../src/pages/overview/provider/overviewProvider.tsx","../src/pages/overview/mobile/useRewardsData.script.ts","../src/pages/overview/main.tsx","../src/pages/overview/mobile/mobile.widget.tsx","../src/pages/overview/portfolioChartsMobile/portfolioChartsMobile.widget.tsx","../src/pages/overview/portfolioChartsMobile/portfolioChartsMobile.script.ts","../src/pages/overview/portfolioChartsMobile/portfolioChartsMobile.ui.tsx","../src/pages/overview/mobile/accountStatus.ui.mobile.tsx","../src/pages/overview/mobile/affiliateCard.ui.mobile.tsx","../src/pages/overview/mobile/portfolioHandle.ui.mobile.tsx","../src/pages/overview/mobile/portfolioVaule.ui.mobile.tsx","../src/pages/overview/mobile/settingRouter.ui.mobile.tsx","../src/pages/overview/mobile/traderCard.ui.mobile.tsx","../src/pages/feeTier/index.tsx","../src/pages/feeTier/feeTier.ui.tsx","../src/pages/feeTier/feeTier.widget.tsx","../src/pages/feeTier/page.tsx","../src/pages/feeTier/feeTier.script.ts","../src/pages/feeTier/column.tsx","../src/pages/feeTier/dataSource.ts","../src/pages/positions/page.tsx","../src/pages/orders/page.tsx","../src/pages/api/index.ts","../src/pages/api/apiManager.widget.tsx","../src/pages/api/apiManager.page.tsx","../src/pages/setting/index.ts","../src/pages/setting/setting.script.tsx","../src/pages/setting/setting.ui.tsx","../src/pages/setting/setting.ui.desktop.tsx","../src/pages/setting/setting.ui.mobile.tsx","../src/pages/setting/setting.widget.tsx","../src/pages/setting/setting.page.tsx","../src/pages/assets/index.tsx","../src/pages/assets/assetsPage/assets.widget.tsx","../src/pages/assets/assetsPage/assets.script.ts","../src/pages/assets/assetsPage/assets.column.tsx","../src/pages/assets/assetsPage/assets.ui.mobile.tsx","../src/pages/assets/page.tsx","../src/pages/history/index.tsx","../src/pages/history/history.page.tsx"],"names":["createContext","useContext","useState","useMemo","jsx","LayoutContext","useLayoutContext","LayoutProvider","init_context","__esmMin","props","routerAdapter","children","sideOpen","setSideOpen","memoizedValue","useCallback","useAccount","useCollateral","useLeverage","useLocalStorage","usePositionStream","useWalletConnector","useAppContext","AccountStatusEnum","modal","useScreen","LeverageWidgetWithDialogId","DepositAndWithdrawWithDialogId","DepositAndWithdrawWithSheetId","TransferDialogId","TransferSheetId","useAssetScript","init_assets_script","connect","namespace","state","isMainAccount","totalValue","freeCollateral","wrongNetwork","disabledConnect","data","curLeverage","visible","setVisible","isMobile","handleDomId","subAccounts","canTrade","onLeverageEdit","onDeposit","onWithdraw","onTransfer","useTranslation","ArrowDownSquareFillIcon","ArrowLeftRightIcon","ArrowUpSquareFillIcon","Button","CardTitle","Flex","jsxs","AssetsHeader","init_assetsHeader","Card","Divider","Grid","Either","Statistic","Text","EyeIcon","gradientTextVariants","EyeCloseIcon","AuthGuard","Fragment","AssetsUI","NoValue","AssetStatistic","init_assets_ui","AssetWidget","init_assets_widget","connectWallet","rest","assets_exports","__export","init_assets","useHistoryDataGroupScript","init_historyDataGroup_script","active","setActive","AssetHistoryStatusEnum","capitalizeFirstLetter","TokenIcon","toast","Decimal","useAssetHistoryColumns","init_column","options","chainsInfo","isDeposit","isWeb3Wallet","t","onCopy","e","txIdColumn","value","record","href","item","accountIdColumn","accountId","recoed","netAmount","differenceInDays","setHours","parseDateRangeForFilter","init_date","dateRange","from","to","getDate","getMonth","getYear","set","useAssetsHistory","useChainInfo","useTokensInfo","useTransferHistory","AssetHistorySideEnum","usePagination","subtractDaysFromCurrentDate","useAssetHistoryScript","init_assetHistory_script","side","today","d","tokensInfo","target","setTarget","setDateRange","page","pageSize","setPage","parsePagination","startTime","endTime","assetData","assetMeta","assetLoading","transferData","transferLoading","transferMeta","onFilter","filter","isLoading","meta","pagination","dataSource","findToken","token","DataFilter","AuthGuardDataTable","AssetHistory","init_assetHistory_ui","queryParameter","columns","Badge","ListView","ArrowRightShortIcon","EmptyDataState","AssetHistoryMobile","init_assetHistory_ui_mobile","loadMore","getStatusText","status","renderHistoryItem","formattedAmount","getTxLink","chainInfo","chain","itemColor","amountView","statusView","timeView","txIdView","accountIdView","AssetHistoryWidget","init_assetHistory_widget","assetHistory_exports","init_assetHistory","useFundingHistoryColumns","index","useSymbolsInfo","FundingHistoryDesktop","init_fundingHistory_ui","symbols","symbol","FundingHistoryMobile","init_fundingHistory_ui_mobile","switchPaymentType","paymentType","useFundingFeeHistory","useFundingHistoryHook","init_useDataSource_script","setSymbol","isValidating","FundingHistoryWidget","init_fundingHistory_widget","funding_exports","init_funding","useColumns","DistributionHistoryDesktop","init_distribution_ui","type","TYPES","DistributionHistoryMobile","init_distribution_ui_mobile","getTypeText","renderItem","useDistributionHistory","useDistributionHistoryHook","setType","DistributionHistoryWidget","init_distribution_widget","distribution_exports","init_distribution","React","capitalizeString","sub","val","subAccount","produce","formatAddress","TransferHistoryUI","init_transfer_ui","selectedAccount","ALL_ACCOUNTS","MAIN_ACCOUNT","memoizedOptions","draft","row","useTransferHistoryHook","date","setAccount","setSide","filteredData","onAccountFilter","TransferHistoryWidget","init_transfer_widget","accountState","TransferHistory_exports","init_TransferHistory","cn","VaultsHistoryUI","useVaultsHistory","useVaultsHistoryHook","onDateRangeFilter","VaultsHistoryMobile","init_vaults_ui_mobile","typeColor","typeText","amountText","VaultsHistoryWidget","VaultsHistory_exports","init_VaultsHistory","useEffect","ArrowLeftRightSquareFill","FeeTierIcon","ServerFillIcon","TabPanel","Tabs","VaultsIcon","LazyAssetHistoryWidget","LazyFundingHistoryWidget","LazyDistributionHistoryWidget","LazyTransferHistoryWidget","LazyVaultsHistoryWidget","HistoryDataGroupDesktop","init_historyDataGroup_ui_desktop","mod","onTabChange","EMPTY_HOLDING","useAccountsData","init_useAccountsData","holding","useIndexPricesStream","isNumber","calculateTotalHolding","useAssetTotalValue","init_useAssetTotalValue","getIndexPrice","total","hol","indexPrice","allAccounts","mainTotalValue","subTotalValue","find","pick","ArrowDownShortIcon","LazyConvertHistoryWidget","TotalValueInfo","DepositAndWithdrawButton","DataFilterSection","AssetsDataTable","AssetsTable","init_assets_ui_desktop","onToggleVisibility","Icon","mergedDisabled","selectedAsset","assetsOptions","ALL_ASSETS","memoizedAssetOptions","dataTableClassNames","classNames","root","scrollRoot","desc","init_useAccountFilter","useAssetsAccountFilter","useAssetsMultiFilter","init_useAssetsAccountFilter","setSelectedAccount","name","setSelectedAsset","accountFiltered","account","filteredChildren","child","init_hooks","useSubAccountQuery","EMPTY_LIST","useConvertScript","init_convert_script","indexPrices","statusFilter","setStatusFilter","convertedAssetFilter","setConvertedAssetFilter","convertedAssetOptions","assetOptions","queryUrl","params","summary","dataRows","totalConversions","totalUSDCReceived","sum","totalFees","detailSum","detail","Tooltip","ConvertedAssetColumn","useConvertColumns","useConvertDetailColumns","init_convert_column","convertedAssets","assets","tooltipContent","asset","onDetailsClick","qty","details","totalHaircut","convertId","haircut","txId","venue","result","DataTable","SimpleDialog","useModal","CONVERT_STATUS_OPTIONS","ConvertDetailsModal","ConvertDesktopUI","init_convert_ui_desktop","onOpenChange","detailColumns","convertState","dataFilter","SimpleSheet","ScrollIndicator","ConvertMobileUI","ConvertMobileField","ConvertMobileItem","ConverHistoryItemDetailsDialog","init_convert_ui_mobile","label","rule","copyable","className","onClick","hide","resolve","reject","convert_widget_exports","ConvertHistoryWidget","init_convert_widget","HistoryDataGroupMobile","init_historyDataGroup_ui_mobile","HistoryDataGroupWidget","init_historyDataGroup_widget","historyDataGroup_exports","init_historyDataGroup","OverviewContext","useOverviewContext","init_overviewContext","useDataTap","useAssetsChartScript","init_assetsChart_script","assetHistory","_data","invisible","useRef","subDays","format","usePrivateQuery","useStatisticsDaily","zero","getUTCStr","year","month","day","PeriodType","useAssetsHistoryData","init_useAssetHistory","localKey","isRealtime","periodTypes","period","setPeriod","convertToUSDCAndOperate","inputs","amount","op","delta","periodLabel","getStartDate","periodValue","startDate","setStartDate","endDate","totalDeposit","transferOutHistory","transferInHistory","allDepositHistory","totalDepositForROI","acc","totalTransferInForROI","onPeriodChange","lastItem","totalTransferIn","totalTransferOut","calculateLastPnl","list","i","calculate","mergeData","calculateData","realtime","calculatedData","aggregateValue","vol","pnl","roi","tail","dataTailIndex","lastAccountValue","createFakeData","start","end","_","periodHeader_exports","PeriodTitle","Select","init_periodHeader","AssetAreaChart","LazyPeriodTitle","AssetsChart","init_assetsChart_ui","AssetsChartWidget","init_assetsChart_widget","assetChart_exports","init_assetChart","PnlAreaChart","PnLBarChart","Box","PerformanceUI","LabelWithHint","PerformancePnL","CumulativePnlChart","init_performance_ui","volumeUpdateDate","curPeriod","hint","ORDERLY_ASSETS_VISIBLE_KEY","init_type","usePerformanceScript","init_performance_script","ctx","PerformanceWidget","init_performance_widget","performance_exports","init_performance","useId","EffectiveFee","init_effectiveFee","ref","linearId","init_icons","feeTierHeader_exports","DesktopHeaderItem","FeeTierHeader","MobileHeaderItem","useFeeState","useScaffoldContext","createElement","isEffective","EffectiveFeeDialog","init_feeTierHeader","interactive","tier","headerDataAdapter","refereeRebate","others","isEffectiveFee","items","mergedData","useApiKeyManager","capitalizeFirstChar","str","useApiManagerScript","init_apiManager_script","filterTags","keyStatus","showCreateDialog","setShowCreateDialog","showCreatedDialog","setShowCreatedDialog","generateKey","setGenerateKey","canCreateApiKey","keys","generateOrderlyKey","setIPRestriction","removeOrderlyKey","resetOrderlyKeyIPRestriction","refresh","error","curPubKey","setCurPubKey","pubKey","onCreateApiKey","onReadApiGuide","hideCreateDialog","doCreate","ipRestriction","scope","createdSuccess","res","ip","key","secretKey","generateKeyRes","err","hideCreatedDialog","onCopyApiKeyInfo","doConfirm","doDelete","curKey","doEdit","future","onCopyAccountId","onCopyApiKey","onCopyApiSecretKey","onCopyIP","keyList","filterTag","filterCurKey","verifyIP","accountStatus","userId","createApiKey_exports","Checkbox","CreateAPIKeyDialog","init_createApiKey","ipText","setIpText","read","setRead","trade","setTrade","setHint","open","scopes","createdApiKey_exports","CreatedAPIKeyDialog","CopyIcon","init_createdApiKey","deleteApiKey_exports","DeleteAPIKeyDialog","Trans","init_deleteApiKey","init_apiManager_ui","setOpen","onDelete","formatKey","editApiKey_exports","EditAPIKeyDialog","init_editApiKey","onUpdate","PlusIcon","AuthGuardEmpty","AuthGuardTooltip","LazyCreateAPIKeyDialog","LazyCreatedAPIKeyDialog","LazyDeleteAPIKeyDialog","LazyEditAPIKeyDialog","APIManager","AccountInfo","Subtitle","KeyList","EditButton","DeleteButton","useMediaQuery","PortfolioLeftSidebarPath","usePortfolioLayoutScript","current","setCurrent","hideSideBar","Scaffold","SideBar","PortfolioLayout","leftSideProps","LeftSidebar","expanded","setExpand","MainNavMobile","BottomNav","PortfolioLayoutMobile","PortfolioLayoutWidget","overview_exports","OverviewPage","OverviewProvider","PerformanceMobileDialogId","PerformanceMobileSheetId","PerformanceMobileUI","PerformanceMobileWidget","AssetLineChart","responsiveProps","i18n","registerSimpleDialog","registerSimpleSheet","useAllBrokers","useConfig","useCurEpochEstimate","useEpochInfo","useGetClaimed","noCacheConfig","DistributionId","TWType","useRewardsData","totalOrderClaimedReward","curEpochEstimate","brokers","mutate","epochList","brokerId","brokerName","lastStete","timerRef","useRewardsDataScript","referralInfo","isSignIn","rewardsData","ENVType","useGetEnv","DepositStatusWidget","usePortfolioChartsState","onPerformanceClick","Area","AreaChart","ChevronRightIcon","PortfolioChartsMobileUI","unrealPnL","unrealROI","colorId","PortfolioChartsMobileWidget","parseJSON","useChains","ChainNamespace","ChainIcon","useCurrentStatus","statusText","EVMChainPopover","chains","MoreIcon","EVMChains","ShowAccount","onCopyAddress","currentNamespace","getLinkDeviceStorage","leftNode","rightNode","bgClass","bg","AccountStatusMobile","description","rootClass","linkDeviceStorage","AffiliateIcon","commifyOptional","AffiliateCardMobile","rebate","CalendarMinusIcon","PortfolioHandleMobile","onGotoHistory","PortfolioValueMobile","SettingFillIcon","SettingRouterMobile","TraderMobileIcon","TraderCardMobile","MobileOverview","portfolioValue","toggleVisible","hasSubAccount","layoutContext","onRouteChange","env","goToClaim","url","navigateToPortfolioHistory","LazyAssetWidget","LazyAssetsChartWidget","LazyPerformanceWidget","LazyHistoryDataGroupWidget","feeTier_exports","FeeTierPage","useFeeTierScript","LazyFeeTierHeader","FeeTierTable","onRow","onCell","internalOnRow","config","internalOnCell","column","isFirstColumn","isLastColumn","FeeTier","FeeTierWidget","useAccountInfo","numberToHumanStyle","textStyle","useFeeTierColumns","volume_min","volume_max","volume_node","findCurrentTier","feeList","futures_taker_fee_rate","futures_maker_fee_rate","takerRate","makerRate","itemTakerRate","itemMakerRate","dataAdapter","setTier","cols","volumeStatistics","page_exports","PositionsPage","InfoCircleIcon","LiquidationWidget","PositionHistoryWidget","CombinePositionsWidget","PositionsWidget","tab","setTab","LiquidationTab","OrdersPage","OrdersWidget","sharePnLConfig","ordersRef","onDownload","TooltipIcon","api_exports","APIManagerPage","APIManagerWidget","setting_exports","SettingPage","SettingWidget","useDebouncedCallback","useMutation","useOrderlyContext","ORDERLY_ORDER_SOUND_ALERT_KEY","useSettingScript","update","isMutating","checked","setChecked","notification","soundAlert","setSoundAlert","updateCheckState","setMaintainConfig","maintenance_cancel_order_flag","canTouch","Switch","SettingDesktop","LanguageSwitcherWidget","SettingMobile","Setting","AssetsDataTableWidget","AssetsPage","AssetsTableMobile","AssetsWidget","useCanTrade","useAssetsColumns","onConvert","id","useAssetsScript","filtered","enhancedFiltered","accountData","enhancedChildren","tokenInfo","assetValue","collateralRatio","collateralContribution","handleTransfer","handleConvert","showTransfer","assetsColumns","openDepositAndWithdraw","viewName","AccountTag","AssetMobileItem","memoizedAssets","assetsState","history_exports","HistoryPage","HistoryWidget"],"mappings":"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","sourcesContent":["import React, { createContext, useContext, useState, useMemo } from \"react\";\nimport type { RouterAdapter } from \"@orderly.network/ui-scaffold\";\n\ntype LayoutContextValue = {\n sideOpen: boolean;\n onSideOpenChange: (open: boolean) => void;\n routerAdapter?: RouterAdapter;\n};\n\nconst LayoutContext = createContext<LayoutContextValue>({\n sideOpen: true,\n} as LayoutContextValue);\n\nexport const useLayoutContext = () => {\n return useContext(LayoutContext);\n};\n\nexport const LayoutProvider: React.FC<\n React.PropsWithChildren<{ routerAdapter?: RouterAdapter }>\n> = (props) => {\n const { routerAdapter, children } = props;\n const [sideOpen, setSideOpen] = useState(true);\n const memoizedValue = useMemo<LayoutContextValue>(\n () => ({\n sideOpen: sideOpen,\n onSideOpenChange: setSideOpen,\n routerAdapter: routerAdapter,\n }),\n [sideOpen, setSideOpen, routerAdapter],\n );\n return (\n <LayoutContext.Provider value={memoizedValue}>\n {children}\n </LayoutContext.Provider>\n );\n};\n","import { useCallback, useMemo } from \"react\";\nimport {\n useAccount,\n useCollateral,\n useLeverage,\n useLocalStorage,\n usePositionStream,\n useWalletConnector,\n} from \"@orderly.network/hooks\";\nimport { useAppContext } from \"@orderly.network/react-app\";\nimport { AccountStatusEnum } from \"@orderly.network/types\";\nimport { modal, useScreen } from \"@orderly.network/ui\";\nimport { LeverageWidgetWithDialogId } from \"@orderly.network/ui-leverage\";\nimport {\n DepositAndWithdrawWithDialogId,\n DepositAndWithdrawWithSheetId,\n TransferDialogId,\n TransferSheetId,\n} from \"@orderly.network/ui-transfer\";\n\nexport const useAssetScript = () => {\n const { connect, namespace } = useWalletConnector();\n const { state, isMainAccount } = useAccount();\n const { totalValue, freeCollateral } = useCollateral();\n const { wrongNetwork, disabledConnect } = useAppContext();\n const [data] = usePositionStream();\n const { curLeverage } = useLeverage();\n const [visible, setVisible] = useLocalStorage(\"orderly_assets_visible\", true);\n const { isMobile } = useScreen();\n const handleDomId = isMobile\n ? DepositAndWithdrawWithSheetId\n : DepositAndWithdrawWithDialogId;\n const subAccounts = state.subAccounts ?? [];\n\n const canTrade = useMemo(() => {\n return (\n !wrongNetwork &&\n !disabledConnect &&\n (state.status === AccountStatusEnum.EnableTrading ||\n state.status === AccountStatusEnum.EnableTradingWithoutConnected)\n );\n }, [state.status, wrongNetwork, disabledConnect]);\n\n const onLeverageEdit = () => {\n modal.show(LeverageWidgetWithDialogId);\n };\n\n const onDeposit = useCallback(() => {\n modal.show(handleDomId, { activeTab: \"deposit\" });\n }, [handleDomId]);\n\n const onWithdraw = useCallback(() => {\n modal.show(handleDomId, { activeTab: \"withdraw\" });\n }, []);\n\n const onTransfer = useCallback(() => {\n if (isMobile) {\n modal.show(TransferSheetId);\n } else {\n modal.show(TransferDialogId);\n }\n }, [isMobile]);\n\n return {\n canTrade,\n connect,\n portfolioValue: totalValue,\n freeCollateral,\n unrealPnL: data.aggregated.total_unreal_pnl,\n unrealROI: data.totalUnrealizedROI,\n currentLeverage: curLeverage,\n onLeverageEdit,\n visible,\n wrongNetwork,\n toggleVisible: () => setVisible(!visible),\n onDeposit,\n onWithdraw,\n onTransfer,\n namespace,\n isMainAccount,\n hasSubAccount: subAccounts?.length > 0,\n } as const;\n};\n\nexport type AssetScriptReturn = ReturnType<typeof useAssetScript>;\n","import { FC } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n ArrowDownSquareFillIcon,\n ArrowLeftRightIcon,\n ArrowUpSquareFillIcon,\n Button,\n CardTitle,\n Flex,\n} from \"@orderly.network/ui\";\n\ntype Props = {\n disabled: boolean;\n onWithdraw?: () => void;\n onDeposit?: () => void;\n onTransfer?: () => void;\n isMainAccount?: boolean;\n hasSubAccount?: boolean;\n};\n\nexport const AssetsHeader: FC<Props> = (props) => {\n const { t } = useTranslation();\n\n return (\n <Flex justify={\"between\"}>\n <CardTitle>{t(\"common.overview\")}</CardTitle>\n <Flex gap={3}>\n {props.isMainAccount && (\n <Button\n disabled={props.disabled}\n size=\"md\"\n onClick={() => props.onDeposit?.()}\n icon={\n <ArrowDownSquareFillIcon className=\"oui-text-primary-contrast\" />\n }\n data-testid=\"oui-testid-portfolio-assets-deposit-btn\"\n >\n {t(\"common.deposit\")}\n </Button>\n )}\n {props.hasSubAccount && (\n <Button\n disabled={props.disabled}\n size=\"md\"\n color=\"secondary\"\n onClick={() => props.onTransfer?.()}\n icon={<ArrowLeftRightIcon className=\"oui-text-base-contrast\" />}\n >\n {t(\"common.transfer\")}\n </Button>\n )}\n {props.isMainAccount && (\n <Button\n disabled={props.disabled}\n size=\"md\"\n color=\"secondary\"\n onClick={() => props.onWithdraw?.()}\n icon={<ArrowUpSquareFillIcon className=\"oui-text-base-contrast\" />}\n data-testid=\"oui-testid-portfolio-assets-withdraw-btn\"\n >\n {t(\"common.withdraw\")}\n </Button>\n )}\n </Flex>\n </Flex>\n );\n};\n","import React, { FC } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n Card,\n Divider,\n Flex,\n Grid,\n Either,\n Statistic,\n Text,\n EyeIcon,\n gradientTextVariants,\n EditIcon,\n EyeCloseIcon,\n} from \"@orderly.network/ui\";\nimport { AuthGuard } from \"@orderly.network/ui-connector\";\nimport { AssetScriptReturn } from \"./assets.script\";\nimport { AssetsHeader } from \"./assetsHeader\";\n\nexport const AssetsUI: React.FC<\n AssetScriptReturn & { onConnectWallet?: () => void }\n> = (props) => {\n const { t } = useTranslation();\n return (\n <Card\n classNames={{ footer: \"oui-h-[48px]\", root: \"oui-h-[240px]\" }}\n title={\n <AssetsHeader\n disabled={!props.canTrade}\n isMainAccount={props.isMainAccount}\n onDeposit={props.onDeposit}\n onWithdraw={props.onWithdraw}\n onTransfer={props.onTransfer}\n hasSubAccount={props.hasSubAccount}\n />\n }\n >\n <>\n <Statistic\n label={\n <Flex gap={1}>\n <Text intensity={54}>{t(\"common.totalValue\")}</Text>\n <button\n onClick={() => {\n props.toggleVisible();\n }}\n data-testid=\"oui-testid-portfolio-assets-eye-btn\"\n >\n {props.visible ? (\n <EyeIcon size={16} color={\"white\"} />\n ) : (\n <EyeCloseIcon size={16} color={\"white\"} />\n )}\n </button>\n </Flex>\n }\n >\n <Either value={props.canTrade!} left={<NoValue />}>\n <Text.numeral\n visible={props.visible}\n unit=\"USDC\"\n // @ts-ignore\n style={{ \"--oui-gradient-angle\": \"45deg\" }}\n unitClassName=\"oui-text-base oui-text-base-contrast-80 oui-h-9 oui-ml-1\"\n className={gradientTextVariants({\n className: \"oui-font-bold oui-text-3xl\",\n color: \"brand\",\n })}\n >\n {props.portfolioValue ?? \"--\"}\n </Text.numeral>\n </Either>\n </Statistic>\n <Divider className=\"oui-my-4\" intensity={8} />\n <AuthGuard buttonProps={{ size: \"lg\", fullWidth: true }}>\n <AssetStatistic\n unrealROI={props.unrealROI}\n unrealPnL={props.unrealPnL}\n freeCollateral={props.freeCollateral}\n currentLeverage={props.currentLeverage}\n onLeverageEdit={props.onLeverageEdit}\n visible={props.visible}\n />\n </AuthGuard>\n </>\n </Card>\n );\n};\n\nconst NoValue: FC = () => {\n return (\n <Flex gap={1} className={\"oui-h-9\"}>\n <Text.gradient color=\"brand\" weight=\"bold\">\n --\n </Text.gradient>\n <Text>USDC</Text>\n </Flex>\n );\n};\n\ntype AssetStatisticProps = Pick<\n AssetScriptReturn,\n | \"currentLeverage\"\n | \"unrealPnL\"\n | \"unrealROI\"\n | \"freeCollateral\"\n | \"onLeverageEdit\"\n | \"visible\"\n>;\n\nexport const AssetStatistic = (props: AssetStatisticProps) => {\n const { t } = useTranslation();\n\n return (\n <Grid cols={2} className=\"oui-h-12\">\n <Statistic label={t(\"common.unrealizedPnl\")}>\n <Flex>\n <Text.numeral\n coloring\n size=\"lg\"\n weight=\"semibold\"\n visible={props.visible}\n >\n {props.unrealPnL}\n </Text.numeral>\n <Text.numeral\n coloring\n rule=\"percentages\"\n size=\"sm\"\n weight=\"semibold\"\n prefix={\"(\"}\n suffix={\")\"}\n visible={props.visible}\n >\n {props.unrealROI}\n </Text.numeral>\n </Flex>\n </Statistic>\n <Statistic\n label={t(\"portfolio.overview.availableWithdraw\")}\n // @ts-ignore\n align=\"right\"\n // @ts-ignore\n valueProps={{ size: \"lg\", visible: props.visible }}\n >\n {props.freeCollateral}\n </Statistic>\n </Grid>\n );\n};\n","import React from \"react\";\nimport { useAssetScript } from \"./assets.script\";\nimport { AssetsUI } from \"./assets.ui\";\n\nexport const AssetWidget: React.FC = () => {\n const { connect: connectWallet, ...rest } = useAssetScript();\n return (\n <AssetsUI\n // TODO: remove duplicate props\n onConnectWallet={connectWallet}\n connect={connectWallet}\n {...rest}\n />\n );\n};\n","export { useAssetScript } from \"./assets.script\";\nexport { AssetsUI } from \"./assets.ui\";\nexport { AssetWidget } from \"./assets.widget\";\n","import { useState } from \"react\";\n\nexport type TabName =\n | \"deposit\"\n | \"withdraw\"\n | \"funding\"\n | \"distribution\"\n | \"transfer\"\n | \"vaults\";\n\nexport const useHistoryDataGroupScript = () => {\n const [active, setActive] = useState<TabName>(\"deposit\");\n return {\n active,\n onTabChange: setActive as React.Dispatch<React.SetStateAction<string>>,\n } as const;\n};\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { useMemo } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { AssetHistoryStatusEnum } from \"@orderly.network/types\";\nimport {\n capitalizeFirstLetter,\n Text,\n Flex,\n TokenIcon,\n toast,\n type Column,\n} from \"@orderly.network/ui\";\nimport { Decimal } from \"@orderly.network/utils\";\n\ntype Options = {\n chainsInfo: any[];\n isDeposit: boolean;\n isWeb3Wallet: boolean;\n};\n\nexport const useAssetHistoryColumns = (options: Options) => {\n const { chainsInfo, isDeposit, isWeb3Wallet } = options;\n const { t } = useTranslation();\n\n const onCopy = (e: any) => {\n e.preventDefault();\n e.stopPropagation();\n toast.success(t(\"common.copy.copied\"));\n };\n\n const columns = useMemo<Column[]>(() => {\n const txIdColumn: Column = {\n title: t(\"common.txId\"),\n dataIndex: \"tx_id\",\n width: 120,\n render: (value, record) => {\n if (!value) {\n return <div className=\"oui-text-base-contrast-54\">-</div>;\n }\n const chainInfo = chainsInfo?.find(\n (item) => parseInt(record.chain_id) === parseInt(item.chain_id),\n );\n const explorer_base_url = chainInfo?.explorer_base_url;\n const href = `${explorer_base_url}/tx/${value}`;\n return (\n <a href={href} target=\"_blank\" rel=\"noreferrer\">\n {/* <Tooltip content={value} delayDuration={0}> */}\n <Text.formatted\n copyable={!!value}\n rule=\"txId\"\n className=\"oui-underline oui-decoration-line-16 oui-decoration-dashed oui-underline-offset-4\"\n onCopy={onCopy}\n >\n {value}\n </Text.formatted>\n {/* </Tooltip> */}\n </a>\n );\n },\n };\n\n const accountIdColumn: Column = {\n title: t(\"common.accountId\"),\n dataIndex: \"account_id\",\n width: 120,\n render: (value, record) => {\n const accountId = isDeposit\n ? record.from_account_id\n : record.to_account_id;\n\n return (\n <Text.formatted rule=\"address\" copyable={!!accountId} onCopy={onCopy}>\n {accountId}\n </Text.formatted>\n );\n },\n };\n\n return [\n {\n title: t(\"common.token\"),\n dataIndex: \"token\",\n width: 80,\n render: (value) => {\n return (\n <Flex gapX={1}>\n <TokenIcon name={value} size=\"xs\" />\n <span>{value}</span>\n </Flex>\n );\n },\n },\n {\n title: t(\"common.time\"),\n dataIndex: \"created_time\",\n width: 80,\n rule: \"date\",\n },\n isWeb3Wallet ? txIdColumn : accountIdColumn,\n {\n title: t(\"common.status\"),\n dataIndex: \"trans_status\",\n width: 100,\n render: (value, recoed) => {\n value = isWeb3Wallet ? value : recoed.status;\n const statusMap = {\n [AssetHistoryStatusEnum.NEW]: t(\"assetHistory.status.pending\"),\n [AssetHistoryStatusEnum.PENDING]: t(\"assetHistory.status.pending\"),\n [AssetHistoryStatusEnum.CONFIRM]: t(\"assetHistory.status.confirm\"),\n [AssetHistoryStatusEnum.PROCESSING]: t(\n \"assetHistory.status.processing\",\n ),\n [AssetHistoryStatusEnum.COMPLETED]: t(\n \"assetHistory.status.completed\",\n ),\n [AssetHistoryStatusEnum.FAILED]: t(\"assetHistory.status.failed\"),\n };\n return (\n statusMap[value as keyof typeof statusMap] ||\n capitalizeFirstLetter(value?.toLowerCase())\n );\n },\n },\n {\n title: t(\"common.amount\"),\n dataIndex: \"amount\",\n width: 100,\n rule: \"price\",\n render: (value, record) => {\n const netAmount = new Decimal(value).minus(record.fee ?? 0);\n return (\n <Text.numeral\n dp={record.decimals}\n rule=\"price\"\n coloring\n showIdentifier\n padding={false}\n >\n {isDeposit ? netAmount.toNumber() : netAmount.neg().toNumber()}\n </Text.numeral>\n );\n },\n },\n ];\n }, [t, chainsInfo, isDeposit, isWeb3Wallet]);\n\n return columns;\n};\n","import { differenceInDays, setHours } from \"date-fns\";\n\nexport const parseDateRangeForFilter = (dateRange: {\n from: Date;\n to?: Date;\n}) => {\n const { from, to = new Date() } = dateRange;\n\n const diff = differenceInDays(from, to);\n\n if (diff === 0) {\n return [from, setHours(to, 23)];\n }\n\n return [from, to];\n};\n","import { useCallback, useMemo, useState } from \"react\";\nimport { getDate, getMonth, getYear, set } from \"date-fns\";\nimport {\n useAssetsHistory,\n useChainInfo,\n useTokensInfo,\n useTransferHistory,\n} from \"@orderly.network/hooks\";\nimport { AssetHistorySideEnum } from \"@orderly.network/types\";\nimport { modal, usePagination } from \"@orderly.network/ui\";\nimport { DepositAndWithdrawWithSheetId } from \"@orderly.network/ui-transfer\";\nimport { subtractDaysFromCurrentDate } from \"@orderly.network/utils\";\nimport { parseDateRangeForFilter } from \"../helper/date\";\n\nexport enum AssetTarget {\n Web3Wallet = \"Web3Wallet\",\n AccountId = \"AccountId\",\n}\n\nexport type AssetHistoryScriptOptions = {\n side: AssetHistorySideEnum;\n};\n\nexport type AssetHistoryScriptReturn = ReturnType<typeof useAssetHistoryScript>;\n\nexport const useAssetHistoryScript = (options: AssetHistoryScriptOptions) => {\n const { side } = options;\n const isDeposit = side === AssetHistorySideEnum.DEPOSIT;\n\n const [today] = useState(() => {\n const d = new Date();\n return new Date(getYear(d), getMonth(d), getDate(d), 0, 0, 0);\n });\n\n const tokensInfo = useTokensInfo();\n\n const [target, setTarget] = useState<AssetTarget>(AssetTarget.Web3Wallet);\n\n const [dateRange, setDateRange] = useState<Date[]>([\n subtractDaysFromCurrentDate(90, today),\n today,\n ]);\n const { page, pageSize, setPage, parsePagination } = usePagination();\n\n const { startTime, endTime } = useMemo(() => {\n const startTime = dateRange[0].getTime();\n const endTime = set(dateRange[1], {\n hours: 23,\n minutes: 59,\n seconds: 59,\n milliseconds: 0,\n }).getTime();\n\n return { startTime, endTime };\n }, [dateRange]);\n\n const [assetData, { meta: assetMeta, isLoading: assetLoading }] =\n useAssetsHistory(\n {\n startTime,\n endTime,\n page,\n pageSize,\n side,\n },\n {\n shouldUpdateOnWalletChanged: (data) => data.side === side,\n },\n );\n\n const [transferData, { isLoading: transferLoading, meta: transferMeta }] =\n useTransferHistory({\n dataRange: [startTime, endTime],\n side: isDeposit ? \"IN\" : \"OUT\",\n size: pageSize,\n page: page,\n main_sub_only: false,\n });\n\n const { data: chainsInfo } = useChainInfo();\n\n const onFilter = (filter: { name: string; value: any }) => {\n if (filter.name === \"dateRange\") {\n setDateRange(parseDateRangeForFilter(filter.value));\n setPage(1);\n } else if (filter.name === \"target\") {\n setTarget(filter.value);\n setPage(1);\n }\n };\n\n const isLoading = useMemo(() => {\n if (target === AssetTarget.Web3Wallet) {\n return assetLoading;\n }\n return transferLoading;\n }, [target, assetLoading, transferLoading]);\n\n const meta = useMemo(() => {\n if (target === AssetTarget.Web3Wallet) {\n return assetMeta;\n }\n return transferMeta;\n }, [target, assetMeta, transferMeta]);\n\n const pagination = useMemo(\n () => parsePagination(meta),\n [parsePagination, meta],\n );\n\n const dataSource = useMemo(() => {\n return (target === AssetTarget.Web3Wallet ? assetData : transferData).map(\n (item) => {\n const findToken = tokensInfo?.find(({ token }) => token === item.token);\n return {\n ...item,\n decimals: findToken?.decimals ?? 2,\n };\n },\n );\n }, [target, assetData, transferData, tokensInfo]);\n\n const onDeposit = useCallback(() => {\n modal.show(DepositAndWithdrawWithSheetId, { activeTab: \"deposit\" });\n }, []);\n\n const isWeb3Wallet = target === AssetTarget.Web3Wallet;\n\n return {\n dataSource,\n total: meta?.total,\n isLoading,\n queryParameter: {\n target,\n dateRange,\n },\n onFilter,\n pagination,\n onDeposit,\n chainsInfo: chainsInfo as any[],\n isDeposit,\n isWeb3Wallet,\n };\n};\n","import { FC, useMemo } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { DataFilter } from \"@orderly.network/ui\";\nimport { AuthGuardDataTable } from \"@orderly.network/ui-connector\";\nimport {\n AssetTarget,\n type AssetHistoryScriptReturn,\n} from \"./assetHistory.script\";\nimport { useAssetHistoryColumns } from \"./column\";\n\ntype AssetHistoryProps = AssetHistoryScriptReturn;\n\nexport const AssetHistory: FC<AssetHistoryProps> = (props) => {\n const { dataSource, queryParameter, onFilter, isLoading } = props;\n const { dateRange, target } = queryParameter;\n const columns = useAssetHistoryColumns({\n chainsInfo: props.chainsInfo,\n isDeposit: props.isDeposit,\n isWeb3Wallet: props.isWeb3Wallet,\n });\n const { t } = useTranslation();\n\n const options = useMemo(() => {\n return [\n { label: t(\"common.web3Wallet\"), value: AssetTarget.Web3Wallet },\n { label: t(\"common.accountId\"), value: AssetTarget.AccountId },\n ];\n }, [t]);\n\n return (\n <>\n <DataFilter\n items={[\n {\n type: \"select\",\n name: \"target\",\n options: options,\n value: target,\n },\n {\n type: \"range\",\n name: \"dateRange\",\n value: {\n from: dateRange[0],\n to: dateRange[1],\n },\n },\n ]}\n onFilter={(value) => {\n onFilter(value);\n }}\n />\n\n <AuthGuardDataTable\n bordered\n loading={isLoading}\n classNames={{\n root: \"oui-h-[calc(100%_-_49px)]\",\n scroll: \"oui-min-h-[400px]\",\n }}\n columns={columns}\n dataSource={dataSource}\n pagination={props.pagination}\n />\n </>\n );\n};\n","import { FC, useMemo } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { AssetHistoryStatusEnum } from \"@orderly.network/types\";\nimport {\n Badge,\n DataFilter,\n Flex,\n ListView,\n Text,\n capitalizeFirstLetter,\n toast,\n ArrowRightShortIcon,\n EmptyDataState,\n} from \"@orderly.network/ui\";\nimport {\n AssetTarget,\n type AssetHistoryScriptReturn,\n} from \"./assetHistory.script\";\n\ntype AssetHistoryMobileProps = AssetHistoryScriptReturn;\n\nexport const AssetHistoryMobile: FC<AssetHistoryMobileProps> = (props) => {\n const {\n dataSource,\n queryParameter,\n onFilter,\n isLoading,\n pagination,\n onDeposit,\n chainsInfo,\n isDeposit,\n isWeb3Wallet,\n } = props;\n const { dateRange, target } = queryParameter;\n const { t } = useTranslation();\n\n const options = useMemo(() => {\n return [\n { label: t(\"common.web3Wallet\"), value: AssetTarget.Web3Wallet },\n { label: t(\"common.accountId\"), value: AssetTarget.AccountId },\n ];\n }, [t]);\n\n const loadMore = () => {\n if (dataSource.length < (pagination?.count || 0)) {\n pagination?.onPageSizeChange?.(pagination?.pageSize + 50);\n }\n };\n\n const getStatusText = (item: any) => {\n const status = props.isWeb3Wallet ? item.trans_status : item.status;\n const statusMap = {\n [AssetHistoryStatusEnum.NEW]: t(\"assetHistory.status.pending\"),\n [AssetHistoryStatusEnum.PENDING]: t(\"assetHistory.status.pending\"),\n [AssetHistoryStatusEnum.CONFIRM]: t(\"assetHistory.status.confirm\"),\n [AssetHistoryStatusEnum.PROCESSING]: t(\"assetHistory.status.processing\"),\n [AssetHistoryStatusEnum.COMPLETED]: t(\"assetHistory.status.completed\"),\n [AssetHistoryStatusEnum.FAILED]: t(\"assetHistory.status.failed\"),\n };\n return (\n statusMap[status as keyof typeof statusMap] ||\n capitalizeFirstLetter(status?.toLowerCase())\n );\n };\n\n const renderHistoryItem = (item: any) => {\n // Amount formatting\n const formattedAmount = isDeposit\n ? `+${item.amount - (item.fee ?? 0)}`\n : -(item.amount - (item.fee ?? 0));\n\n // Get tx link\n const getTxLink = () => {\n if (!item.tx_id) {\n return undefined;\n }\n\n const chainInfo =\n chainsInfo && Array.isArray(chainsInfo)\n ? chainsInfo.find(\n (chain: any) =>\n parseInt(item.chain_id) === parseInt(chain.chain_id),\n )\n : undefined;\n\n if (chainInfo?.explorer_base_url) {\n return `${chainInfo.explorer_base_url}/tx/${item.tx_id}`;\n }\n\n return undefined;\n };\n\n const onCopy = (e: any) => {\n e.preventDefault();\n e.stopPropagation();\n toast.success(t(\"common.copy.copied\"));\n };\n\n const itemColor = isDeposit ? \"buy\" : \"sell\";\n\n const amountView = (\n <Flex className=\"oui-text-xs\">\n <Text color={itemColor}>{formattedAmount}</Text>\n <Text className=\"oui-ml-1\" intensity={80}>\n {item.token}\n </Text>\n {isWeb3Wallet && (\n <Badge color={itemColor} className=\"oui-ml-2\">\n {isDeposit ? t(\"common.deposit\") : t(\"common.withdraw\")}\n </Badge>\n )}\n </Flex>\n );\n\n const statusView = (\n <Text intensity={isWeb3Wallet ? 80 : 36} size=\"xs\">\n {getStatusText(item)}\n </Text>\n );\n\n const timeView = (\n <Text.formatted rule=\"date\" intensity={36} size=\"2xs\">\n {item.created_time}\n </Text.formatted>\n );\n\n const txIdView = item.tx_id ? (\n <a href={getTxLink()} target=\"_blank\" rel=\"noreferrer\">\n <Text.formatted\n copyable={!!item.tx_id}\n className=\"oui-underline oui-decoration-line-16 oui-decoration-dashed oui-underline-offset-4\"\n rule=\"txId\"\n onCopy={onCopy}\n intensity={36}\n size=\"xs\"\n >\n {item.tx_id}\n </Text.formatted>\n </a>\n ) : (\n <Text intensity={54}>-</Text>\n );\n\n const accountId = isDeposit ? item.from_account_id : item.to_account_id;\n\n const accountIdView = (\n <Flex gapX={1}>\n <Text intensity={36} size=\"xs\">\n {isDeposit\n ? t(\"transfer.internalTransfer.from\")\n : t(\"transfer.internalTransfer.to\")}\n </Text>\n <Text.formatted\n rule=\"address\"\n copyable={!!accountId}\n onCopy={onCopy}\n intensity={80}\n size=\"xs\"\n >\n {accountId}\n </Text.formatted>\n </Flex>\n );\n\n return (\n <Flex\n p={2}\n direction=\"column\"\n gapY={1}\n intensity={900}\n r=\"xl\"\n className=\"oui-font-semibold\"\n >\n <Flex justify=\"between\" width=\"100%\" height=\"18px\">\n {isWeb3Wallet ? (\n <>\n {amountView}\n {statusView}\n </>\n ) : (\n <>\n {accountIdView}\n {amountView}\n </>\n )}\n </Flex>\n\n <Flex justify=\"between\" width=\"100%\" height=\"18px\">\n {timeView}\n {isWeb3Wallet ? txIdView : statusView}\n </Flex>\n </Flex>\n );\n };\n\n return (\n <>\n <DataFilter\n items={[\n {\n type: \"picker\",\n name: \"target\",\n options: options,\n value: target,\n size: \"md\",\n },\n {\n type: \"range\",\n name: \"dateRange\",\n value: {\n from: dateRange[0],\n to: dateRange[1],\n },\n },\n ]}\n onFilter={(value) => {\n onFilter(value);\n }}\n className=\"oui-sticky oui-top-[44px] oui-z-10 oui-border-none oui-bg-base-10 oui-px-3 oui-py-2\"\n />\n\n <ListView\n dataSource={dataSource}\n renderItem={renderHistoryItem}\n contentClassName=\"!oui-space-y-1\"\n loadMore={loadMore}\n isLoading={isLoading}\n className=\"oui-px-1\"\n emptyView={\n <Flex\n direction={\"column\"}\n height={\"100%\"}\n itemAlign={\"center\"}\n justify={\"center\"}\n mt={3}\n >\n <EmptyDataState />\n {dataSource?.length == 0 && (\n <Flex\n direction=\"row\"\n itemAlign=\"center\"\n justify=\"center\"\n onClick={onDeposit}\n className=\"oui-mt-2 oui-h-4 oui-w-full oui-text-secondary\"\n >\n <Text color=\"primary\" size=\"2xs\">\n {t(\"common.deposit\")}\n </Text>\n <ArrowRightShortIcon\n className=\"oui-ml-0.5 oui-size-4 oui-text-primary oui-opacity-100\"\n color=\"primary\"\n size={16}\n opacity={100}\n />\n </Flex>\n )}\n </Flex>\n }\n />\n </>\n );\n};\n","import React from \"react\";\nimport { AssetHistorySideEnum } from \"@orderly.network/types\";\nimport { useScreen } from \"@orderly.network/ui\";\nimport { useAssetHistoryScript } from \"./assetHistory.script\";\nimport { AssetHistory } from \"./assetHistory.ui\";\nimport { AssetHistoryMobile } from \"./assetHistory.ui.mobile\";\n\ntype AssetHistoryWidgetProps = {\n side: AssetHistorySideEnum;\n};\n\nexport const AssetHistoryWidget: React.FC<AssetHistoryWidgetProps> = (\n props,\n) => {\n const state = useAssetHistoryScript({ side: props.side });\n const { isMobile } = useScreen();\n if (isMobile) {\n return <AssetHistoryMobile {...state} />;\n }\n return <AssetHistory {...state} />;\n};\n","export { useAssetHistoryColumns } from \"./column\";\nexport { useAssetHistoryScript } from \"./assetHistory.script\";\nexport { AssetHistory } from \"./assetHistory.ui\";\nexport { AssetHistoryWidget } from \"./assetHistory.widget\";\n","import { useMemo } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { API } from \"@orderly.network/types\";\nimport { Flex, Text, type Column } from \"@orderly.network/ui\";\n\nexport const useFundingHistoryColumns = () => {\n const { t } = useTranslation();\n\n const columns = useMemo(() => {\n return [\n {\n title: t(\"common.symbol\"),\n dataIndex: \"symbol\",\n width: 80,\n rule: \"symbol\",\n textProps: {\n showIcon: true,\n },\n },\n {\n title: t(\"common.time\"),\n dataIndex: \"created_time\",\n width: 120,\n rule: \"date\",\n },\n {\n title: `${t(\"funding.fundingRate\")} / ${t(\"funding.annualRate\")}`,\n dataIndex: \"funding_rate\",\n width: 80,\n render: (value: any, record) => {\n return (\n <Flex gap={1}>\n {/* <span>{`${record.funding_rate * 100}%`}</span> */}\n <Text.numeral rule={\"percentages\"} dp={6}>\n {record.funding_rate}\n </Text.numeral>\n <span>/</span>\n {/* <span>{`${record.annual_rate * 10}%`}</span> */}\n <Text.numeral rule={\"percentages\"} dp={6}>\n {record.annual_rate}\n </Text.numeral>\n </Flex>\n );\n },\n },\n {\n title: t(\"funding.paymentType\"),\n dataIndex: \"payment_type\",\n width: 80,\n render: (value: any) => {\n switch (value) {\n case \"Pay\":\n case \"Paid\":\n return t(\"funding.paymentType.paid\");\n case \"Receive\":\n case \"Received\":\n return t(\"funding.paymentType.received\");\n default:\n return value;\n }\n },\n },\n {\n title: `${t(\"funding.fundingFee\")} (USDC)`,\n dataIndex: \"funding_fee\",\n width: 80,\n rule: \"price\",\n formatter(value, record, index) {\n return Number(value) * -1;\n },\n numeralProps: {\n coloring: true,\n showIdentifier: true,\n ignoreDP: true,\n },\n },\n ] as Column<API.FundingFeeRow & { annual_rate: number }>[];\n }, [t]);\n\n return columns;\n};\n","import { FC, useMemo } from \"react\";\nimport { useSymbolsInfo } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { DataFilter } from \"@orderly.network/ui\";\nimport { AuthGuardDataTable } from \"@orderly.network/ui-connector\";\nimport { useFundingHistoryColumns } from \"./column\";\nimport { type UseFundingHistoryReturn } from \"./useDataSource.script\";\n\ntype FundingHistoryProps = {} & UseFundingHistoryReturn;\n\nexport const FundingHistoryDesktop: FC<FundingHistoryProps> = (props) => {\n const { dataSource, queryParameter, onFilter, isLoading } = props;\n const columns = useFundingHistoryColumns();\n const symbols = useSymbolsInfo();\n const { symbol, dateRange } = queryParameter;\n const { t } = useTranslation();\n\n const options = useMemo(() => {\n return [\n {\n label: t(\"common.all\"),\n value: \"All\",\n },\n ...Object.keys(symbols).map((symbol) => {\n const s = symbol.split(\"_\")[1];\n return {\n label: s,\n value: symbol,\n };\n }),\n ];\n }, [t, symbols]);\n\n return (\n <>\n <DataFilter\n items={[\n {\n type: \"select\",\n name: \"symbol\",\n isCombine: true,\n options,\n value: symbol,\n valueFormatter: (value) => {\n const option = options.find((item) => item.value === value);\n return option?.label || value;\n },\n },\n {\n type: \"range\",\n name: \"dateRange\",\n value: {\n from: dateRange[0],\n to: dateRange[1],\n },\n },\n ]}\n onFilter={(value) => {\n onFilter(value);\n }}\n />\n <AuthGuardDataTable\n bordered\n columns={columns}\n dataSource={dataSource}\n loading={isLoading}\n generatedRowKey={(record) => `${record.updated_time}`}\n classNames={{ root: \"oui-h-[calc(100%_-_49px)]\" }}\n pagination={props.pagination}\n />\n </>\n );\n};\n","import { FC } from \"react\";\nimport { useSymbolsInfo } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { DataFilter, Flex, ListView, Text, Badge } from \"@orderly.network/ui\";\nimport { type UseFundingHistoryReturn } from \"./useDataSource.script\";\n\ntype FundingHistoryProps = {} & UseFundingHistoryReturn;\n\nexport const FundingHistoryMobile: FC<FundingHistoryProps> = (props) => {\n const { dataSource, queryParameter, onFilter, isLoading, pagination } = props;\n const symbols = useSymbolsInfo();\n const { symbol, dateRange } = queryParameter;\n const { t } = useTranslation();\n\n const switchPaymentType = (paymentType: string) => {\n switch (paymentType) {\n case \"Pay\":\n case \"Paid\":\n return t(\"funding.paymentType.paid\");\n case \"Receive\":\n case \"Received\":\n return t(\"funding.paymentType.received\");\n default:\n return paymentType;\n }\n };\n\n const loadMore = () => {\n if (dataSource && dataSource.length < (pagination?.count || 0)) {\n pagination?.onPageSizeChange?.(pagination?.pageSize + 50);\n }\n };\n\n const renderHistoryItem = (item: any) => {\n return (\n <Flex\n p={2}\n direction=\"column\"\n gapY={2}\n className=\"oui-rounded-xl oui-bg-base-9 oui-font-semibold\"\n >\n <Flex direction=\"row\" justify=\"between\" width=\"100%\" height=\"20px\">\n <Text.formatted\n rule=\"symbol\"\n className=\"oui-text-base-contrast oui-mr-1 oui-text-sm\"\n >\n {item.symbol}\n </Text.formatted>\n <Badge color=\"neutral\" size=\"xs\">\n {switchPaymentType(item.payment_type)}\n </Badge>\n <Text.formatted\n rule=\"date\"\n className=\"oui-text-base-contrast-36 oui-text-2xs oui-ml-auto\"\n >\n {item.created_time}\n </Text.formatted>\n </Flex>\n <div className=\"oui-w-full oui-h-[1px] oui-bg-base-6\" />\n <Flex direction=\"row\" justify=\"between\" width=\"100%\">\n <Flex direction=\"column\">\n <Text className=\"oui-text-base-contrast-36 oui-text-2xs\">\n {t(\"funding.fundingRate\")}\n </Text>\n <Text.numeral\n rule={\"percentages\"}\n dp={6}\n className=\"oui-text-base-contrast-80 oui-text-xs\"\n >\n {item.funding_rate}\n </Text.numeral>\n </Flex>\n <Flex direction=\"column\">\n <Text className=\"oui-text-base-contrast-36 oui-text-2xs\">\n {t(\"funding.annualRate\")}\n </Text>\n <Text.numeral\n rule={\"percentages\"}\n dp={6}\n className=\"oui-text-base-contrast-80 oui-text-xs\"\n >\n {item.annual_rate}\n </Text.numeral>\n </Flex>\n <Flex direction=\"column\">\n <Text className=\"oui-text-base-contrast-36 oui-text-2xs\">\n {t(\"funding.fundingFee\")}{\" \"}\n <Text className=\"oui-text-base-contrast-20\">(USDC)</Text>\n </Text>\n <Text.numeral\n dp={6}\n ignoreDP={true}\n coloring={true}\n showIdentifier={true}\n className=\"oui-text-xs oui-self-end\"\n >\n {Number(item.funding_fee) * -1}\n </Text.numeral>\n </Flex>\n </Flex>\n </Flex>\n );\n };\n\n return (\n <>\n <DataFilter\n items={[\n {\n type: \"select\",\n name: \"symbol\",\n isCombine: true,\n options: [\n {\n label: \"All\",\n value: \"All\",\n },\n ...Object.keys(symbols).map((symbol) => {\n const s = symbol.split(\"_\")[1];\n return {\n label: s,\n value: symbol,\n };\n }),\n ],\n value: symbol,\n valueFormatter: (value) => {\n if (value === \"All\") {\n return \"All\";\n }\n return value.split(\"_\")[1];\n },\n },\n {\n type: \"range\",\n name: \"dateRange\",\n value: {\n from: dateRange[0],\n to: dateRange[1],\n },\n },\n ]}\n onFilter={(value) => {\n onFilter(value);\n }}\n className=\"oui-px-3 oui-py-2 oui-sticky oui-top-[44px] oui-z-10 oui-bg-base-10\"\n />\n <ListView\n dataSource={dataSource}\n renderItem={renderHistoryItem}\n contentClassName=\"!oui-space-y-1\"\n loadMore={loadMore}\n isLoading={isLoading}\n className=\"oui-px-1\"\n />\n </>\n );\n};\n","import { useFundingFeeHistory } from \"@orderly.network/hooks\";\nimport { usePagination } from \"@orderly.network/ui\";\nimport { subtractDaysFromCurrentDate } from \"@orderly.network/utils\";\nimport { useMemo, useState } from \"react\";\nimport { parseDateRangeForFilter } from \"../helper/date\";\nimport { getDate, getMonth, getYear, set } from \"date-fns\";\n\nexport const useFundingHistoryHook = () => {\n // const today = useRef(setMinutes(setHours(new Date(), 23), 59));\n\n const [today] = useState(() => {\n const d = new Date();\n\n return new Date(getYear(d), getMonth(d), getDate(d), 0, 0, 0);\n });\n\n const [dateRange, setDateRange] = useState<Date[]>([\n subtractDaysFromCurrentDate(90, today),\n today,\n ]);\n\n const [symbol, setSymbol] = useState<string>(\"All\");\n const { page, pageSize, setPage, parsePagination } = usePagination();\n\n const [data, { isLoading, meta, isValidating }] = useFundingFeeHistory(\n {\n // dataRange: dateRange.map((date) => date.getTime()),\n dataRange: [\n dateRange[0].getTime(),\n set(dateRange[1], {\n hours: 23,\n minutes: 59,\n seconds: 59,\n milliseconds: 0,\n })\n // addDays(dateRange[1], 1)\n .getTime(),\n ],\n symbol,\n page,\n pageSize,\n },\n {\n keepPreviousData: true,\n }\n );\n\n const onFilter = (filter: { name: string; value: any }) => {\n if (filter.name === \"symbol\") {\n setSymbol(filter.value);\n setPage(1);\n }\n\n if (filter.name === \"dateRange\") {\n // setDateRange([filter.value.from, filter.value.to]);\n setDateRange(parseDateRangeForFilter(filter.value));\n setPage(1);\n }\n };\n\n const pagination = useMemo(\n () => parsePagination(meta),\n [parsePagination, meta]\n );\n\n return {\n dataSource: data,\n isLoading,\n isValidating,\n // onDateRangeChange,\n queryParameter: {\n symbol,\n dateRange,\n },\n onFilter,\n pagination,\n } as const;\n};\n\nexport type UseFundingHistoryReturn = ReturnType<typeof useFundingHistoryHook>;\n","import React from \"react\";\nimport { useScreen } from \"@orderly.network/ui\";\nimport { FundingHistoryDesktop } from \"./fundingHistory.ui\";\nimport { FundingHistoryMobile } from \"./fundingHistory.ui.mobile\";\nimport { useFundingHistoryHook } from \"./useDataSource.script\";\n\nexport const FundingHistoryWidget: React.FC = () => {\n const state = useFundingHistoryHook();\n const { isMobile } = useScreen();\n if (isMobile) {\n return <FundingHistoryMobile {...state} />;\n }\n return <FundingHistoryDesktop {...state} />;\n};\n","export { FundingHistoryWidget } from \"./fundingHistory.widget\";\nexport { FundingHistoryDesktop } from \"./fundingHistory.ui\";\nexport { FundingHistoryMobile } from \"./fundingHistory.ui.mobile\";\nexport { useFundingHistoryColumns } from \"./column\";\nexport { useFundingHistoryHook } from \"./useDataSource.script\";\n","import { useMemo } from \"react\";\nimport { useTranslation, i18n } from \"@orderly.network/i18n\";\nimport { API } from \"@orderly.network/types\";\nimport { Flex, type Column, TokenIcon } from \"@orderly.network/ui\";\n\nexport const useColumns = () => {\n const { t } = useTranslation();\n\n const columns = useMemo(() => {\n return [\n {\n title: t(\"common.token\"),\n dataIndex: \"token\",\n width: 80,\n // rule: \"symbol\",\n render: (value, record) => {\n return (\n <Flex gapX={2}>\n <TokenIcon name={value} size=\"xs\" />\n <span>{value}</span>\n </Flex>\n );\n },\n },\n {\n title: t(\"common.time\"),\n dataIndex: \"updated_time\",\n width: 120,\n rule: \"date\",\n },\n {\n title: t(\"common.status\"),\n dataIndex: \"status\",\n width: 120,\n formatter(value, record, index) {\n switch (value) {\n case \"CREATED\":\n case \"SPLIT\":\n return t(\"assetHistory.status.processing\");\n case \"COMPLETED\":\n default:\n return t(\"assetHistory.status.completed\");\n }\n },\n },\n\n {\n title: t(\"common.type\"),\n dataIndex: \"type\",\n width: 80,\n formatter: (value: any) => {\n switch (value) {\n case \"REFERRER_REBATE\":\n return t(\n \"portfolio.overview.distribution.type.referralCommission\",\n );\n case \"REFEREE_REBATE\":\n return t(\"portfolio.overview.distribution.type.refereeRebate\");\n case \"BROKER_FEE\":\n return t(\"portfolio.overview.distribution.type.brokerFee\");\n default:\n return \"-\";\n }\n },\n },\n {\n title: t(\"common.amount\"),\n dataIndex: \"amount\",\n width: 80,\n // rule: \"price\",\n },\n ] as Column<API.FundingFeeRow & { annual_rate: number }>[];\n }, [t]);\n\n return columns;\n};\n","import { FC, useMemo } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { DataFilter } from \"@orderly.network/ui\";\nimport { AuthGuardDataTable } from \"@orderly.network/ui-connector\";\nimport { useColumns } from \"./column\";\nimport { type useDistributionHistoryHookReturn } from \"./useDataSource.script\";\n\ntype FundingHistoryProps = {} & useDistributionHistoryHookReturn;\n\nexport const DistributionHistoryDesktop: FC<FundingHistoryProps> = (props) => {\n const { dataSource, queryParameter, onFilter, isLoading, isValidating } =\n props;\n const columns = useColumns();\n const { type, dateRange } = queryParameter;\n const { t } = useTranslation();\n\n const TYPES = useMemo(() => {\n return [\n { label: t(\"common.all\"), value: \"All\" },\n {\n label: t(\"portfolio.overview.distribution.type.referralCommission\"),\n value: \"REFERRER_REBATE\",\n },\n {\n label: t(\"portfolio.overview.distribution.type.refereeRebate\"),\n value: \"REFEREE_REBATE\",\n },\n {\n label: t(\"portfolio.overview.distribution.type.brokerFee\"),\n value: \"BROKER_FEE\",\n },\n ];\n }, [t]);\n\n return (\n <>\n <DataFilter\n items={[\n {\n type: \"select\",\n name: \"type\",\n options: TYPES,\n value: type,\n },\n {\n type: \"range\",\n name: \"dateRange\",\n value: {\n from: dateRange[0],\n to: dateRange[1],\n },\n },\n ]}\n onFilter={(value) => {\n onFilter(value);\n }}\n />\n <AuthGuardDataTable\n bordered\n columns={columns}\n dataSource={dataSource}\n loading={isLoading}\n // isValidating={isValidating}\n className=\"oui-font-semibold\"\n classNames={{\n root: \"oui-h-[calc(100%_-_49px)]\",\n }}\n pagination={props.pagination}\n />\n </>\n );\n};\n","import { FC, useMemo } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { DataFilter, Flex, Text, TokenIcon } from \"@orderly.network/ui\";\nimport { ListView } from \"@orderly.network/ui\";\nimport { type useDistributionHistoryHookReturn } from \"./useDataSource.script\";\n\ntype FundingHistoryProps = {} & useDistributionHistoryHookReturn;\n\nexport const DistributionHistoryMobile: FC<FundingHistoryProps> = (props) => {\n const { dataSource, queryParameter, onFilter, isLoading, pagination } = props;\n const { type, dateRange } = queryParameter;\n const { t } = useTranslation();\n\n const TYPES = useMemo(() => {\n return [\n { label: t(\"common.all\"), value: \"All\" },\n {\n label: t(\"portfolio.overview.distribution.type.referralCommission\"),\n value: \"REFERRER_REBATE\",\n },\n {\n label: t(\"portfolio.overview.distribution.type.refereeRebate\"),\n value: \"REFEREE_REBATE\",\n },\n {\n label: t(\"portfolio.overview.distribution.type.brokerFee\"),\n value: \"BROKER_FEE\",\n },\n ];\n }, [t]);\n\n const getStatusText = (status: string) => {\n switch (status) {\n case \"CREATED\":\n case \"SPLIT\":\n return t(\"assetHistory.status.processing\") as string;\n case \"COMPLETED\":\n default:\n return t(\"assetHistory.status.completed\") as string;\n }\n };\n\n const getTypeText = (type: string) => {\n switch (type) {\n case \"REFERRER_REBATE\":\n return t(\"portfolio.overview.distribution.type.referralCommission\");\n case \"REFEREE_REBATE\":\n return t(\"portfolio.overview.distribution.type.refereeRebate\");\n case \"BROKER_FEE\":\n return t(\"portfolio.overview.distribution.type.brokerFee\");\n default:\n return \"-\";\n }\n };\n\n const renderItem = (item: any) => {\n return (\n <Flex\n p={2}\n direction=\"column\"\n gapY={2}\n className=\"oui-rounded-xl oui-bg-base-9 oui-font-semibold\"\n >\n <Flex direction=\"row\" justify=\"between\" width=\"100%\" height=\"20px\">\n <Text.formatted\n rule=\"date\"\n className=\"oui-text-2xs oui-text-base-contrast-36\"\n >\n {item.created_time}\n </Text.formatted>\n <Text className=\"oui-text-sm oui-text-base-contrast-80\">\n {getStatusText(item.status)}\n </Text>\n </Flex>\n <div className=\"oui-h-px oui-w-full oui-bg-base-6\" />\n <Flex direction=\"row\" justify=\"between\" width=\"100%\">\n <Flex direction=\"column\">\n <Text className=\"oui-text-2xs oui-text-base-contrast-36\">\n {t(\"common.token\")}\n </Text>\n <Flex gapX={2}>\n <TokenIcon name={item.token} size=\"xs\" />\n <span className=\"oui-text-xs oui-text-base-contrast-80\">\n {item.token}\n </span>\n </Flex>\n </Flex>\n <Flex direction=\"column\">\n <Text className=\"oui-text-2xs oui-text-base-contrast-36\">\n {t(\"common.type\")}\n </Text>\n <Text className=\"oui-text-xs oui-text-base-contrast-80\">\n {getTypeText(item.type)}\n </Text>\n </Flex>\n <Flex direction=\"column\">\n <Text className=\"oui-text-2xs oui-text-base-contrast-36\">\n {t(\"common.amount\")}\n </Text>\n <Text className=\"oui-text-xs oui-text-base-contrast-80\">\n {item.amount}\n </Text>\n </Flex>\n </Flex>\n </Flex>\n );\n };\n\n const loadMore = () => {\n if (dataSource.length < (pagination?.count || 0)) {\n pagination?.onPageSizeChange &&\n pagination.onPageSizeChange(pagination?.pageSize + 50);\n }\n };\n\n return (\n <>\n <DataFilter\n items={[\n {\n type: \"picker\",\n name: \"type\",\n options: TYPES,\n value: type,\n size: \"md\",\n },\n {\n type: \"range\",\n name: \"dateRange\",\n value: {\n from: dateRange[0],\n to: dateRange[1],\n },\n },\n ]}\n onFilter={(value) => {\n onFilter(value);\n }}\n className=\"oui-px-3 oui-py-2 oui-sticky oui-top-[44px] oui-z-10 oui-bg-base-10\"\n />\n <ListView\n dataSource={dataSource}\n renderItem={renderItem}\n contentClassName=\"oui-space-y-1\"\n loadMore={loadMore}\n isLoading={isLoading}\n className=\"oui-px-1\"\n />\n </>\n );\n};\n","import { useDistributionHistory } from \"@orderly.network/hooks\";\nimport { subtractDaysFromCurrentDate } from \"@orderly.network/utils\";\nimport { useMemo, useState } from \"react\";\nimport { usePagination } from \"@orderly.network/ui\";\nimport { parseDateRangeForFilter } from \"../helper/date\";\nimport { getDate, getMonth, getYear, set } from \"date-fns\";\n\nexport const useDistributionHistoryHook = () => {\n // const today = useRef(setMinutes(setHours(new Date(), 23), 59));\n\n const [today] = useState(() => {\n const d = new Date();\n\n return new Date(getYear(d), getMonth(d), getDate(d), 0, 0, 0);\n });\n\n const [dateRange, setDateRange] = useState<Date[]>([\n subtractDaysFromCurrentDate(90, today),\n today,\n ]);\n const [type, setType] = useState<string>(\"All\");\n const { page, pageSize, setPage, parsePagination } = usePagination();\n\n const [data, { isLoading, meta, isValidating }] = useDistributionHistory({\n // dataRange: dateRange.map((date) => date.getTime()),\n dataRange: [\n dateRange[0].getTime(),\n set(dateRange[1], {\n hours: 23,\n minutes: 59,\n seconds: 59,\n milliseconds: 0,\n }).getTime(),\n ],\n type,\n pageSize,\n page,\n });\n\n // console.log(\"----\", isLoading, isValidating);\n\n // const res = useQuery(\"v1/public/info/funding_period\");\n\n const onFilter = (filter: { name: string; value: any }) => {\n if (filter.name === \"type\") {\n setType(filter.value);\n setPage(1);\n }\n\n if (filter.name === \"dateRange\") {\n // setDateRange([filter.value.from, filter.value.to]);\n setDateRange(parseDateRangeForFilter(filter.value));\n setPage(1);\n }\n };\n\n const pagination = useMemo(\n () => parsePagination(meta),\n [parsePagination, meta]\n );\n\n return {\n dataSource: data,\n isLoading,\n isValidating,\n // onDateRangeChange,\n queryParameter: {\n type,\n dateRange,\n },\n onFilter,\n pagination,\n } as const;\n};\n\nexport type useDistributionHistoryHookReturn = ReturnType<\n typeof useDistributionHistoryHook\n>;\n","import React from \"react\";\nimport { useScreen } from \"@orderly.network/ui\";\nimport { DistributionHistoryDesktop } from \"./distribution.ui\";\nimport { DistributionHistoryMobile } from \"./distribution.ui.mobile\";\nimport { useDistributionHistoryHook } from \"./useDataSource.script\";\n\nexport const DistributionHistoryWidget: React.FC = () => {\n const state = useDistributionHistoryHook();\n const { isMobile } = useScreen();\n if (isMobile) {\n return <DistributionHistoryMobile {...state} />;\n }\n return <DistributionHistoryDesktop {...state} />;\n};\n","export { DistributionHistoryWidget } from \"./distribution.widget\";\nexport { DistributionHistoryMobile } from \"./distribution.ui.mobile\";\nexport { DistributionHistoryDesktop } from \"./distribution.ui\";\n","import React from \"react\";\nimport { useAccount } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { API, EMPTY_LIST } from \"@orderly.network/types\";\nimport { Flex, TokenIcon, Text, toast, Badge } from \"@orderly.network/ui\";\nimport type { Column } from \"@orderly.network/ui\";\nimport { capitalizeString } from \"@orderly.network/utils\";\n\nexport const useColumns = () => {\n const { t } = useTranslation();\n const onCopy = () => {\n toast.success(t(\"common.copy.copied\"));\n };\n const { state } = useAccount();\n const sub = state.subAccounts ?? [];\n const columns = React.useMemo<Column<API.TransferHistoryRow>[]>(() => {\n return [\n {\n title: t(\"common.token\"),\n dataIndex: \"token\",\n width: 80,\n render(val: string) {\n return (\n <Flex gapX={2}>\n <TokenIcon name={val} size=\"xs\" />\n <span>{val}</span>\n </Flex>\n );\n },\n },\n {\n title: t(\"common.time\"),\n dataIndex: \"updated_time\",\n width: 120,\n rule: \"date\",\n },\n {\n title: `${t(\"transfer.internalTransfer.from\")} (Account ID)`,\n dataIndex: \"from_account_id\",\n render(val: string) {\n const isMainAccount = val === state.mainAccountId;\n const subAccount = sub.find((item) => item.id === val);\n return (\n <Flex itemAlign=\"start\" py={2} gap={1} direction=\"column\">\n <Text.formatted onCopy={onCopy} copyable rule=\"address\">\n {val}\n </Text.formatted>\n <Badge className=\"oui-select-none\" color=\"neutral\" size=\"xs\">\n {isMainAccount\n ? t(\"common.mainAccount\")\n : subAccount?.description || t(\"common.subAccount\")}\n </Badge>\n </Flex>\n );\n },\n },\n {\n title: `${t(\"transfer.internalTransfer.to\")} (Account ID)`,\n dataIndex: \"to_account_id\",\n render(val: string) {\n const isMainAccount = val === state.mainAccountId;\n const subAccount = sub.find((item) => item.id === val);\n return (\n <Flex itemAlign=\"start\" py={2} gap={1} direction=\"column\">\n <Text.formatted onCopy={onCopy} copyable rule=\"address\">\n {val}\n </Text.formatted>\n <Badge className=\"oui-select-none\" color=\"neutral\" size=\"xs\">\n {isMainAccount\n ? t(\"common.mainAccount\")\n : subAccount?.description || t(\"common.subAccount\")}\n </Badge>\n </Flex>\n );\n },\n },\n {\n title: t(\"common.status\"),\n dataIndex: \"status\",\n width: 120,\n render(val: string) {\n return capitalizeString(val);\n },\n },\n {\n title: t(\"common.amount\"),\n dataIndex: \"amount\",\n width: 80,\n },\n ];\n }, [t, state.mainAccountId, sub]);\n return columns;\n};\n","import React, { useMemo } from \"react\";\nimport { produce } from \"immer\";\nimport { useAccount } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport type { API } from \"@orderly.network/types\";\nimport { DataFilter, formatAddress } from \"@orderly.network/ui\";\nimport { AuthGuardDataTable } from \"@orderly.network/ui-connector\";\nimport type { SelectOption } from \"@orderly.network/ui/src/select/withOptions\";\nimport { useColumns } from \"./column\";\nimport type { useTransferHistoryHookReturn } from \"./useDataSource.script\";\n\ntype HistoryProps = useTransferHistoryHookReturn;\n\nexport enum AccountType {\n ALL = \"All accounts\",\n MAIN = \"Main accounts\",\n}\n\nexport const TransferHistoryUI: React.FC<\n Readonly<HistoryProps & ReturnType<typeof useAccount>>\n> = (props) => {\n const {\n dataSource,\n queryParameter,\n state,\n isMainAccount,\n isLoading,\n selectedAccount,\n onFilter,\n } = props;\n const { side, dateRange } = queryParameter;\n\n const { t } = useTranslation();\n\n const ALL_ACCOUNTS: SelectOption = {\n label: t(\"common.allAccount\"),\n value: AccountType.ALL,\n };\n\n const MAIN_ACCOUNT: SelectOption = {\n label: t(\"common.mainAccount\"),\n value: AccountType.MAIN,\n };\n\n const subAccounts = state.subAccounts ?? [];\n\n const memoizedOptions = useMemo(() => {\n if (Array.isArray(subAccounts) && subAccounts.length) {\n return [\n ALL_ACCOUNTS,\n MAIN_ACCOUNT,\n ...subAccounts.map<SelectOption>((value) => ({\n value: value.id,\n label: value?.description || formatAddress(value?.id),\n })),\n ];\n }\n return [ALL_ACCOUNTS, MAIN_ACCOUNT];\n }, [subAccounts]);\n\n const columns = useColumns();\n\n return (\n <>\n <DataFilter\n onFilter={onFilter}\n items={produce(\n [\n {\n type: \"select\",\n name: \"side\",\n value: side,\n options: [\n { value: \"OUT\", label: \"Outflow\" },\n { value: \"IN\", label: \"Inflow\" },\n ],\n },\n {\n type: \"range\",\n name: \"dateRange\",\n value: {\n from: dateRange[0],\n to: dateRange[1],\n },\n },\n ],\n (draft) => {\n if (isMainAccount) {\n draft.unshift({\n type: \"select\",\n name: \"account\",\n value: selectedAccount as any,\n options: memoizedOptions,\n });\n }\n },\n )}\n />\n <AuthGuardDataTable<API.TransferHistoryRow>\n bordered\n columns={columns}\n dataSource={dataSource}\n loading={isLoading}\n // isValidating={isValidating}\n className=\"oui-font-semibold\"\n classNames={{ root: \"oui-h-[calc(100%_-_49px)]\" }}\n pagination={props.pagination}\n generatedRowKey={(row) => row.id}\n />\n </>\n );\n};\n","import React from \"react\";\nimport { getDate, getMonth, getYear, set } from \"date-fns\";\nimport { useAccount, useTransferHistory } from \"@orderly.network/hooks\";\nimport { usePagination } from \"@orderly.network/ui\";\nimport type { PaginationMeta } from \"@orderly.network/ui\";\nimport { subtractDaysFromCurrentDate } from \"@orderly.network/utils\";\nimport { parseDateRangeForFilter } from \"../helper/date\";\nimport { AccountType } from \"./transfer.ui\";\n\nexport const useTransferHistoryHook = () => {\n // const today = useRef(setMinutes(setHours(new Date(), 23), 59));\n\n const today = React.useMemo<Date>(() => {\n const date = new Date();\n return new Date(getYear(date), getMonth(date), getDate(date), 0, 0, 0);\n }, []);\n\n const [dateRange, setDateRange] = React.useState<Date[]>([\n subtractDaysFromCurrentDate(90, today),\n today,\n ]);\n\n const { page, pageSize, setPage, parsePagination } = usePagination();\n\n const { state } = useAccount();\n\n const [selectedAccount, setAccount] = React.useState<string>(AccountType.ALL);\n\n const [side, setSide] = React.useState<\"IN\" | \"OUT\">(\"OUT\");\n\n const [data, { isLoading, meta }] = useTransferHistory({\n dataRange: [\n dateRange[0]?.getTime(),\n set(dateRange[1], {\n hours: 23,\n minutes: 59,\n seconds: 59,\n milliseconds: 0,\n })?.getTime(),\n ],\n side: side,\n size: pageSize,\n page: page,\n main_sub_only: true,\n });\n\n const filteredData = React.useMemo(() => {\n return data.filter((item) => {\n if (!selectedAccount || selectedAccount === AccountType.ALL) {\n return true;\n }\n if (selectedAccount === AccountType.MAIN) {\n return (\n item.from_account_id === state.mainAccountId ||\n item.to_account_id === state.mainAccountId\n );\n } else {\n return (\n item.from_account_id === selectedAccount ||\n item.to_account_id === selectedAccount\n );\n }\n });\n }, [data, selectedAccount]);\n\n const onAccountFilter = React.useCallback(\n (filter: { value: string; name: string }) => {\n if (filter.name === \"account\") {\n setAccount(filter.value);\n }\n if (filter.name === \"side\") {\n setSide(filter.value as \"IN\" | \"OUT\");\n }\n if (filter.name === \"dateRange\") {\n setDateRange(parseDateRangeForFilter(filter.value as any));\n }\n setPage(1);\n },\n [setPage],\n );\n\n const pagination = React.useMemo<PaginationMeta>(\n () => parsePagination(meta),\n [parsePagination, meta],\n );\n\n return {\n dataSource: filteredData,\n isLoading,\n // onDateRangeChange,\n queryParameter: {\n side,\n dateRange,\n },\n selectedAccount,\n onFilter: onAccountFilter,\n pagination,\n } as const;\n};\n\nexport type useTransferHistoryHookReturn = ReturnType<\n typeof useTransferHistoryHook\n>;\n","import React from \"react\";\nimport { useAccount } from \"@orderly.network/hooks\";\nimport { TransferHistoryUI } from \"./transfer.ui\";\nimport { useTransferHistoryHook } from \"./useDataSource.script\";\n\nexport const TransferHistoryWidget: React.FC = () => {\n const state = useTransferHistoryHook();\n const accountState = useAccount();\n return <TransferHistoryUI {...state} {...accountState} />;\n};\n","export { TransferHistoryWidget } from \"./transfer.widget\";\nexport { TransferHistoryUI } from \"./transfer.ui\";\n","import React from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport type { API } from \"@orderly.network/types\";\nimport { Flex, TokenIcon, Text, cn } from \"@orderly.network/ui\";\nimport type { Column } from \"@orderly.network/ui\";\nimport { capitalizeString } from \"@orderly.network/utils\";\n\nexport const useColumns = () => {\n const { t } = useTranslation();\n const columns = React.useMemo<Column<API.StrategyVaultHistoryRow>[]>(() => {\n return [\n {\n title: t(\"common.type\"),\n dataIndex: \"type\",\n className: (record) => {\n if (record?.type === \"deposit\") {\n return \"oui-text-success\";\n }\n if (record?.type === \"withdrawal\") {\n return \"oui-text-danger\";\n }\n return \"\";\n },\n render(val: string) {\n if (val === \"deposit\") {\n return t(\"common.deposit\");\n }\n if (val === \"withdrawal\") {\n return t(\"common.withdraw\");\n }\n return null;\n },\n },\n {\n title: t(\"portfolio.overview.vaultName\"),\n dataIndex: \"vaultName\",\n },\n {\n title: t(\"common.token\"),\n dataIndex: \"token\",\n render(val: string) {\n return (\n <Flex justify=\"start\" itemAlign=\"center\" gap={2}>\n <TokenIcon name={val} />\n {val}\n </Flex>\n );\n },\n },\n {\n title: t(\"common.time\"),\n dataIndex: \"created_time\",\n rule: \"date\",\n },\n {\n title: t(\"common.status\"),\n dataIndex: \"status\",\n render(val: string) {\n return capitalizeString(val);\n },\n },\n {\n title: t(\"common.amount\"),\n dataIndex: \"amount_change\",\n render(val: number) {\n return (\n <Text.numeral\n showIdentifier\n className={cn(\n \"oui-select-none\",\n val >= 0 ? \"oui-text-success\" : \"oui-text-danger\",\n )}\n >\n {val}\n </Text.numeral>\n );\n },\n },\n ];\n }, [t]);\n return columns;\n};\n","import React from \"react\";\nimport type { API } from \"@orderly.network/types\";\nimport { DataFilter } from \"@orderly.network/ui\";\nimport { AuthGuardDataTable } from \"@orderly.network/ui-connector\";\nimport { useColumns } from \"./column\";\nimport type { useVaultsHistoryHookReturn } from \"./useDataSource.script\";\n\ntype HistoryProps = useVaultsHistoryHookReturn;\n\nexport const VaultsHistoryUI: React.FC<Readonly<HistoryProps>> = (props) => {\n const { dataSource, dateRange, isLoading, onFilter } = props;\n\n const columns = useColumns();\n\n return (\n <>\n <DataFilter\n onFilter={onFilter}\n items={[\n {\n type: \"range\",\n name: \"dateRange\",\n value: {\n from: dateRange[0],\n to: dateRange[1],\n },\n },\n ]}\n />\n <AuthGuardDataTable<API.StrategyVaultHistoryRow>\n bordered\n columns={columns}\n dataSource={dataSource}\n loading={isLoading}\n className=\"oui-font-semibold\"\n classNames={{ root: \"oui-h-[calc(100%_-_49px)]\" }}\n pagination={props.pagination}\n generatedRowKey={(row) => row.id}\n />\n </>\n );\n};\n","import React from \"react\";\nimport { getDate, getMonth, getYear, set } from \"date-fns\";\nimport { useVaultsHistory } from \"@orderly.network/hooks\";\nimport type { API } from \"@orderly.network/types\";\nimport { usePagination } from \"@orderly.network/ui\";\nimport type { PaginationMeta } from \"@orderly.network/ui\";\nimport { subtractDaysFromCurrentDate } from \"@orderly.network/utils\";\nimport { parseDateRangeForFilter } from \"../helper/date\";\n\nexport const useVaultsHistoryHook = () => {\n const today = React.useMemo<Date>(() => {\n const date = new Date();\n return new Date(getYear(date), getMonth(date), getDate(date), 0, 0, 0);\n }, []);\n\n const [dateRange, setDateRange] = React.useState<Date[]>([\n subtractDaysFromCurrentDate(90, today),\n today,\n ]);\n\n const { page, pageSize, setPage, parsePagination } = usePagination();\n\n const [data, { isLoading, meta }] = useVaultsHistory({\n dataRange: [\n dateRange[0]?.getTime(),\n set(dateRange[1], {\n hours: 23,\n minutes: 59,\n seconds: 59,\n milliseconds: 0,\n })?.getTime(),\n ],\n size: pageSize,\n page: page,\n });\n\n const dataSource = React.useMemo(() => {\n if (!Array.isArray(data) || !data.length) {\n return [];\n }\n return data.map<API.StrategyVaultHistoryRow>((item) => ({\n ...item,\n token: \"USDC\", // need to hard code for now\n vaultName: \"Orderly OmniVault\",\n amount_change:\n item.type === \"withdrawal\" ? -item.amount_change : item.amount_change,\n }));\n }, [data]);\n\n const onDateRangeFilter = React.useCallback(\n (filter: { value: string; name: string }) => {\n if (filter.name === \"dateRange\") {\n setDateRange(parseDateRangeForFilter(filter.value as any));\n }\n setPage(1);\n },\n [setPage],\n );\n\n const pagination = React.useMemo<PaginationMeta>(\n () => parsePagination(meta),\n [parsePagination, meta],\n );\n\n return {\n dataSource: dataSource,\n isLoading,\n dateRange,\n onFilter: onDateRangeFilter,\n pagination,\n } as const;\n};\n\nexport type useVaultsHistoryHookReturn = ReturnType<\n typeof useVaultsHistoryHook\n>;\n","import { useTranslation } from \"@orderly.network/i18n\";\nimport { Divider } from \"@orderly.network/ui\";\nimport { DataFilter, TokenIcon, ListView, Text } from \"@orderly.network/ui\";\nimport { useVaultsHistoryHookReturn } from \"./useDataSource.script\";\n\nexport const VaultsHistoryMobile = (props: useVaultsHistoryHookReturn) => {\n const { dateRange, onFilter, dataSource, isLoading, pagination } = props;\n const { t } = useTranslation();\n\n const loadMore = () => {\n if (dataSource.length < (pagination?.count || 0)) {\n pagination?.onPageSizeChange?.(pagination?.pageSize + 50);\n }\n };\n\n const renderHistoryItem = (item: any) => {\n const typeColor = item.type === \"deposit\" ? \"buy\" : \"sell\";\n const typeText =\n item.type === \"deposit\" ? t(\"common.deposit\") : t(\"common.withdraw\");\n const amountText = item.amount_change ? Math.abs(item.amount_change) : \"-\";\n return (\n <div className=\"oui-flex oui-flex-col oui-rounded-xl oui-bg-base-9 oui-p-2 oui-font-semibold\">\n <div className=\"oui-flex oui-items-center oui-justify-between oui-text-sm oui-text-base-contrast-80\">\n <div>{item.vaultName}</div>\n <div>\n {item.status?.slice(0, 1).toUpperCase() + item.status?.slice(1)}\n </div>\n </div>\n <Text.formatted rule=\"date\" intensity={36} size=\"2xs\">\n {item.created_time}\n </Text.formatted>\n <Divider className=\"oui-my-2\" />\n <div className=\"oui-flex oui-items-center [&>div]:oui-flex-1 [&>div]:oui-text-2xs [&>div]:oui-text-base-contrast-36\">\n <div>\n <div>{t(\"common.token\")}</div>\n <div className=\"oui-flex oui-items-center oui-gap-1 oui-text-xs oui-text-base-contrast-80\">\n <TokenIcon name={\"USDC\"} size=\"2xs\" />\n <Text>USDC</Text>\n </div>\n </div>\n <div>\n <div>{t(\"common.type\")}</div>\n <Text color={typeColor} className=\"oui-text-xs\">\n {typeText}\n </Text>\n </div>\n <div className=\"oui-text-right\">\n <div>{t(\"common.amount\")}</div>\n <div className=\"oui-text-xs oui-text-base-contrast-80\">\n {amountText}\n </div>\n </div>\n </div>\n </div>\n );\n };\n\n return (\n <>\n <DataFilter\n items={[\n {\n type: \"range\",\n name: \"dateRange\",\n value: {\n from: dateRange[0],\n to: dateRange[1],\n },\n },\n ]}\n onFilter={(value) => {\n onFilter(value);\n }}\n className=\"oui-sticky oui-top-[44px] oui-z-10 oui-border-none oui-bg-base-10 oui-px-3 oui-py-2\"\n />\n <ListView\n dataSource={dataSource}\n renderItem={renderHistoryItem}\n contentClassName=\"!oui-space-y-1\"\n loadMore={loadMore}\n isLoading={isLoading}\n className=\"oui-px-1\"\n />\n </>\n );\n};\n","import React from \"react\";\nimport { useScreen } from \"@orderly.network/ui\";\nimport { VaultsHistoryUI } from \"./transfer.ui\";\nimport { useVaultsHistoryHook } from \"./useDataSource.script\";\nimport { VaultsHistoryMobile } from \"./vaults.ui.mobile\";\n\nexport const VaultsHistoryWidget: React.FC = () => {\n const state = useVaultsHistoryHook();\n const { isMobile } = useScreen();\n if (isMobile) {\n return <VaultsHistoryMobile {...state} />;\n }\n return <VaultsHistoryUI {...state} />;\n};\n","export { VaultsHistoryWidget } from \"./transfer.widget\";\nexport { VaultsHistoryUI } from \"./transfer.ui\";\n","import React, { useEffect } from \"react\";\nimport { useAccount } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { AssetHistorySideEnum } from \"@orderly.network/types\";\nimport {\n ArrowDownSquareFillIcon,\n ArrowLeftRightSquareFill,\n ArrowUpSquareFillIcon,\n Card,\n FeeTierIcon,\n ServerFillIcon,\n TabPanel,\n Tabs,\n VaultsIcon,\n} from \"@orderly.network/ui\";\nimport type { TabName } from \"./historyDataGroup.script\";\n\nconst LazyAssetHistoryWidget = React.lazy(() =>\n import(\"../assetHistory\").then((mod) => {\n return { default: mod.AssetHistoryWidget };\n }),\n);\n\nconst LazyFundingHistoryWidget = React.lazy(() =>\n import(\"../funding\").then((mod) => {\n return { default: mod.FundingHistoryWidget };\n }),\n);\n\nconst LazyDistributionHistoryWidget = React.lazy(() =>\n import(\"../distribution\").then((mod) => {\n return { default: mod.DistributionHistoryWidget };\n }),\n);\n\nconst LazyTransferHistoryWidget = React.lazy(() =>\n import(\"../TransferHistory\").then((mod) => {\n return { default: mod.TransferHistoryWidget };\n }),\n);\n\nconst LazyVaultsHistoryWidget = React.lazy(() =>\n import(\"../VaultsHistory\").then((mod) => {\n return { default: mod.VaultsHistoryWidget };\n }),\n);\n\nexport const HistoryDataGroupDesktop: React.FC<{\n active?: TabName;\n onTabChange: (tab: string) => void;\n}> = (props) => {\n const { active = \"deposit\", onTabChange } = props;\n const { t } = useTranslation();\n const { isMainAccount } = useAccount();\n useEffect(() => {\n if (active === \"vaults\" && !isMainAccount) {\n onTabChange(\"deposit\");\n }\n }, [active, isMainAccount]);\n return (\n <Card>\n <Tabs\n value={active}\n onValueChange={onTabChange}\n variant=\"contained\"\n size=\"xl\"\n >\n <TabPanel\n title={t(\"common.deposits\")}\n icon={<ArrowDownSquareFillIcon />}\n value={\"deposit\"}\n >\n <React.Suspense fallback={null}>\n <LazyAssetHistoryWidget side={AssetHistorySideEnum.DEPOSIT} />\n </React.Suspense>\n </TabPanel>\n <TabPanel\n title={t(\"common.withdrawals\")}\n icon={<ArrowUpSquareFillIcon />}\n value={\"withdraw\"}\n >\n <React.Suspense fallback={null}>\n <LazyAssetHistoryWidget side={AssetHistorySideEnum.WITHDRAW} />\n </React.Suspense>\n </TabPanel>\n <TabPanel\n title={t(\"common.funding\")}\n icon={<FeeTierIcon />}\n value={\"funding\"}\n >\n <React.Suspense fallback={null}>\n <LazyFundingHistoryWidget />\n </React.Suspense>\n </TabPanel>\n <TabPanel\n title={t(\"portfolio.overview.distribution\")}\n icon={<ServerFillIcon />}\n value={\"distribution\"}\n >\n <React.Suspense fallback={null}>\n <LazyDistributionHistoryWidget />\n </React.Suspense>\n </TabPanel>\n <TabPanel\n title={t(\"portfolio.overview.transferHistory\")}\n icon={<ArrowLeftRightSquareFill />}\n value={\"transfer\"}\n >\n <React.Suspense fallback={null}>\n <LazyTransferHistoryWidget />\n </React.Suspense>\n </TabPanel>\n {isMainAccount && (\n <TabPanel\n value={\"vaults\"}\n icon={<VaultsIcon />}\n title={t(\"portfolio.overview.vaults\")}\n >\n <React.Suspense fallback={null}>\n <LazyVaultsHistoryWidget />\n </React.Suspense>\n </TabPanel>\n )}\n </Tabs>\n </Card>\n );\n};\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { useMemo } from \"react\";\nimport { produce } from \"immer\";\nimport { useAccount, useCollateral } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport type { API } from \"@orderly.network/types\";\n\nconst EMPTY_HOLDING: Partial<API.Holding> = {\n token: \"USDC\",\n holding: 0,\n frozen: 0,\n};\n\n// Account data structure used in assets display\nexport interface AccountWithChildren {\n account_id: string;\n id?: string;\n description?: string;\n children: Array<API.Holding & { account_id: string }>;\n}\n\n// Hook to transform raw account data into display format\nexport const useAccountsData = (): AccountWithChildren[] => {\n const { t } = useTranslation();\n const { state, isMainAccount } = useAccount();\n const { holding = [] } = useCollateral();\n const subAccounts = state.subAccounts ?? [];\n\n return useMemo(() => {\n return produce<any[]>(subAccounts, (draft) => {\n // Process sub accounts\n for (const sub of draft) {\n sub.account_id = sub.id;\n if (Array.isArray(sub.holding) && sub.holding.length) {\n sub.children = sub.holding.map((item: API.Holding) => ({\n ...item,\n account_id: sub.id,\n }));\n } else {\n sub.children = [{ ...EMPTY_HOLDING, account_id: sub.id }];\n }\n // Remove original holding to avoid confusion\n Reflect.deleteProperty(sub, \"holding\");\n }\n\n // Add main account at the beginning if user is main account\n if (isMainAccount) {\n draft.unshift({\n account_id: state.mainAccountId!,\n description: t(\"common.mainAccount\"),\n children:\n Array.isArray(holding) && holding.length\n ? holding.map((item: API.Holding) => ({\n ...item,\n account_id: state.mainAccountId!,\n }))\n : [\n {\n ...EMPTY_HOLDING,\n account_id: state.mainAccountId!,\n },\n ],\n });\n }\n });\n }, [holding, subAccounts, isMainAccount, state.mainAccountId, t]);\n};\n","import { useMemo } from \"react\";\nimport {\n useAccount,\n useCollateral,\n useIndexPricesStream,\n} from \"@orderly.network/hooks\";\nimport { SubAccount } from \"@orderly.network/hooks\";\nimport { Decimal } from \"@orderly.network/utils\";\nimport { useAccountsData } from \"./useAccountsData\";\n\nconst isNumber = (val: unknown): val is number => {\n return typeof val === \"number\" && !Number.isNaN(val);\n};\n\nexport const calculateTotalHolding = (\n data: SubAccount[] | SubAccount[\"holding\"],\n getIndexPrice: (token: string) => number,\n) => {\n let total = new Decimal(0);\n for (const item of data) {\n if (Array.isArray(item.holding)) {\n for (const hol of item.holding) {\n if (isNumber(hol.holding)) {\n const indexPrice = getIndexPrice(hol.token);\n total = total.plus(new Decimal(hol.holding).mul(indexPrice));\n }\n }\n } else if (isNumber(item.holding) && \"token\" in item) {\n const indexPrice = getIndexPrice(item.token);\n total = total.plus(new Decimal(item.holding).mul(indexPrice));\n }\n }\n return total;\n};\n\nexport const useAssetTotalValue = () => {\n const { state, isMainAccount } = useAccount();\n const { holding = [] } = useCollateral();\n const { getIndexPrice } = useIndexPricesStream();\n const allAccounts = useAccountsData();\n\n const subAccounts = state.subAccounts ?? [];\n\n // Calculate main account total value\n const mainTotalValue = useMemo<Decimal>(\n () => calculateTotalHolding(holding, getIndexPrice),\n [holding, getIndexPrice],\n );\n\n // Calculate sub accounts total value\n const subTotalValue = useMemo<Decimal>(\n () => calculateTotalHolding(subAccounts, getIndexPrice),\n [subAccounts, getIndexPrice],\n );\n\n // Calculate final total value\n const totalValue = useMemo<number>(() => {\n if (isMainAccount) {\n return mainTotalValue.plus(subTotalValue).toNumber();\n } else {\n const find = allAccounts.find((item) => item.id === state.accountId);\n if (Array.isArray(find?.children)) {\n return calculateTotalHolding(find.children, getIndexPrice).toNumber();\n }\n return 0;\n }\n }, [\n isMainAccount,\n mainTotalValue,\n subTotalValue,\n allAccounts,\n state.accountId,\n getIndexPrice,\n ]);\n\n return totalValue;\n};\n","import React, { useMemo } from \"react\";\nimport pick from \"ramda/es/pick\";\nimport { SubAccount } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { useAppContext } from \"@orderly.network/react-app\";\nimport {\n Text,\n Card,\n Flex,\n gradientTextVariants,\n EyeIcon,\n EyeCloseIcon,\n cn,\n DataFilter,\n formatAddress,\n Tabs,\n TabPanel,\n ArrowDownShortIcon,\n Button,\n} from \"@orderly.network/ui\";\nimport { AuthGuard, AuthGuardDataTable } from \"@orderly.network/ui-connector\";\nimport type { SelectOption } from \"@orderly.network/ui/src/select/withOptions\";\nimport type { useAssetsScriptReturn } from \"./assets.script\";\nimport type {\n AssetsDataTableWidgetProps,\n AssetsWidgetProps,\n} from \"./assets.widget\";\n\nconst LazyConvertHistoryWidget = React.lazy(() =>\n import(\"../convertPage/convert.widget\").then((mod) => {\n return { default: mod.ConvertHistoryWidget };\n }),\n);\n\nexport type AssetsProps = useAssetsScriptReturn;\n\nexport enum AccountType {\n ALL = \"All accounts\",\n MAIN = \"Main accounts\",\n}\n\nconst TotalValueInfo: React.FC<\n Readonly<\n Pick<AssetsWidgetProps, \"totalValue\" | \"visible\" | \"onToggleVisibility\">\n >\n> = (props) => {\n const { totalValue, visible, onToggleVisibility } = props;\n const { t } = useTranslation();\n const Icon = visible ? EyeIcon : EyeCloseIcon;\n return (\n <Flex direction=\"column\" gap={1} className=\"oui-text-2xs\" itemAlign=\"start\">\n <Flex gap={1} justify=\"start\" itemAlign=\"center\">\n <Text size=\"2xs\" color=\"neutral\" weight=\"semibold\">\n {t(\"common.totalValue\")}\n </Text>\n <button onClick={onToggleVisibility}>\n <Icon size={18} className={cn(\"oui-text-base-contrast-54\")} />\n </button>\n </Flex>\n <Flex justify={\"start\"} itemAlign=\"end\" gap={1}>\n <Text.numeral\n visible={visible}\n weight=\"bold\"\n size=\"2xl\"\n className={gradientTextVariants({ color: \"brand\" })}\n as=\"div\"\n padding={false}\n dp={2}\n >\n {totalValue ?? \"--\"}\n </Text.numeral>\n <Text as=\"div\" weight=\"bold\">\n USDC\n </Text>\n </Flex>\n </Flex>\n );\n};\n\nconst DepositAndWithdrawButton: React.FC<\n Readonly<\n Pick<AssetsWidgetProps, \"isMainAccount\" | \"onWithdraw\" | \"onDeposit\">\n >\n> = (props) => {\n const { t } = useTranslation();\n const { isMainAccount, onWithdraw, onDeposit } = props;\n const { wrongNetwork, disabledConnect } = useAppContext();\n if (!isMainAccount) {\n return null;\n }\n const mergedDisabled = wrongNetwork || disabledConnect;\n return (\n <Flex\n className=\"oui-text-2xs oui-text-base-contrast-54\"\n itemAlign=\"center\"\n gap={3}\n >\n <Button\n disabled={mergedDisabled}\n data-testid=\"oui-testid-assetView-deposit-button\"\n fullWidth\n size=\"md\"\n onClick={onDeposit}\n >\n <ArrowDownShortIcon\n color=\"white\"\n opacity={mergedDisabled ? 0.4 : 1}\n className=\"oui-rotate-0 oui-text-primary-contrast\"\n />\n <Text>{t(\"common.deposit\")}</Text>\n </Button>\n <Button\n fullWidth\n disabled={mergedDisabled}\n color=\"secondary\"\n size=\"md\"\n onClick={onWithdraw}\n data-testid=\"oui-testid-assetView-withdraw-button\"\n >\n <ArrowDownShortIcon\n color=\"white\"\n opacity={mergedDisabled ? 0.4 : 1}\n className=\"oui-rotate-180 oui-text-base-contrast\"\n />\n <Text>{t(\"common.withdraw\")}</Text>\n </Button>\n </Flex>\n );\n};\n\nconst DataFilterSection: React.FC<\n Pick<\n AssetsWidgetProps,\n | \"isMainAccount\"\n | \"onFilter\"\n | \"selectedAccount\"\n | \"selectedAsset\"\n | \"assetsOptions\"\n | \"state\"\n >\n> = (props) => {\n const { t } = useTranslation();\n const {\n isMainAccount,\n onFilter,\n selectedAccount,\n selectedAsset,\n assetsOptions,\n state,\n } = props;\n\n const ALL_ACCOUNTS: SelectOption = {\n label: t(\"common.allAccount\"),\n value: AccountType.ALL,\n };\n\n const MAIN_ACCOUNT: SelectOption = {\n label: t(\"common.mainAccount\"),\n value: AccountType.MAIN,\n };\n\n const ALL_ASSETS: SelectOption = {\n label: t(\"common.allAssets\", \"All assets\"),\n value: \"all\",\n };\n\n const subAccounts = useMemo<SubAccount[]>(() => {\n return state.subAccounts ?? [];\n }, [state.subAccounts]);\n\n const memoizedOptions = useMemo(() => {\n if (Array.isArray(subAccounts) && subAccounts.length) {\n return [\n ALL_ACCOUNTS,\n MAIN_ACCOUNT,\n ...subAccounts.map<SelectOption>((value) => ({\n value: value?.id,\n label: value?.description || formatAddress(value?.id),\n })),\n ];\n }\n return [ALL_ACCOUNTS, MAIN_ACCOUNT];\n }, [ALL_ACCOUNTS, MAIN_ACCOUNT, subAccounts]);\n\n const memoizedAssetOptions = useMemo(() => {\n return [ALL_ASSETS, ...assetsOptions];\n }, [ALL_ASSETS, assetsOptions]);\n\n if (!isMainAccount) {\n return null;\n }\n\n return (\n <DataFilter\n className=\"oui-border-none oui-py-0\"\n onFilter={onFilter}\n items={[\n {\n type: \"select\",\n name: \"account\",\n value: selectedAccount,\n options: memoizedOptions,\n },\n {\n type: \"select\",\n name: \"asset\",\n value: selectedAsset,\n options: memoizedAssetOptions,\n },\n ]}\n />\n );\n};\n\nexport const AssetsDataTable: React.FC<\n Pick<\n AssetsWidgetProps,\n | \"columns\"\n | \"dataSource\"\n | \"isMainAccount\"\n | \"onFilter\"\n | \"selectedAccount\"\n | \"selectedAsset\"\n | \"assetsOptions\"\n | \"state\"\n | \"canTrade\"\n > &\n AssetsDataTableWidgetProps\n> = (props) => {\n const { columns, dataSource, dataTableClassNames, classNames } = props;\n const { root, scrollRoot, desc } = classNames ?? {};\n\n if (!props.canTrade) {\n // show auth button when not can trade\n return (\n <AuthGuardDataTable\n classNames={{\n root: \"oui-rounded-xl oui-font-semibold\",\n scroll: \"oui-h-[252px]\",\n }}\n loading={props.canTrade}\n columns={[]}\n dataSource={[]}\n />\n );\n }\n\n return (\n <Flex width=\"100%\" height=\"100%\" direction={\"column\"} className={root}>\n <DataFilterSection\n {...pick(\n [\n \"isMainAccount\",\n \"onFilter\",\n \"selectedAccount\",\n \"selectedAsset\",\n \"assetsOptions\",\n \"state\",\n ],\n props,\n )}\n />\n {dataSource?.map((item, index) => {\n return (\n <Flex\n key={`item-${index}`}\n className={cn(\"oui-rounded-xl oui-bg-base-9 oui-p-6\", scrollRoot)}\n direction={\"column\"}\n itemAlign={\"start\"}\n justify={\"between\"}\n my={4}\n >\n <Text\n className={cn(\"oui-mb-4\", desc)}\n intensity={98}\n weight=\"semibold\"\n size=\"lg\"\n >\n {item?.description || formatAddress(item?.id ?? \"\")}\n </Text>\n <AuthGuardDataTable\n bordered\n className=\"oui-font-semibold\"\n classNames={{\n // root: \"oui-bg-transparent\",\n // scroll: \"oui-min-h-0\",\n ...dataTableClassNames,\n }}\n columns={columns}\n dataSource={item.children}\n />\n </Flex>\n );\n })}\n </Flex>\n );\n};\n\nexport const AssetsTable: React.FC<AssetsWidgetProps> = (props) => {\n const { t } = useTranslation();\n return (\n <Card\n className={\"oui-bg-transparent oui-p-0\"}\n classNames={{ content: \"!oui-pt-0\" }}\n >\n <Tabs\n defaultValue=\"assets\"\n variant=\"contained\"\n classNames={{ tabsList: \"\" }}\n size=\"lg\"\n >\n <TabPanel value=\"assets\" className=\"\" title={t(\"common.assets\")}>\n <Flex\n className=\"oui-rounded-xl oui-bg-base-9 oui-p-6\"\n direction={\"row\"}\n itemAlign={\"center\"}\n justify={\"between\"}\n my={4}\n >\n <TotalValueInfo\n {...pick([\"totalValue\", \"visible\", \"onToggleVisibility\"], props)}\n />\n <DepositAndWithdrawButton\n {...pick([\"isMainAccount\", \"onDeposit\", \"onWithdraw\"], props)}\n />\n </Flex>\n <AssetsDataTable\n {...pick(\n [\n \"columns\",\n \"dataSource\",\n \"isMainAccount\",\n \"onFilter\",\n \"selectedAccount\",\n \"selectedAsset\",\n \"assetsOptions\",\n \"state\",\n \"canTrade\",\n ],\n props,\n )}\n classNames={{\n scrollRoot:\n \"oui-max-h-[700px] oui-overflow-y-auto oui-custom-scrollbar oui-w-full\",\n }}\n />\n </TabPanel>\n <TabPanel\n value=\"convertHistory\"\n className=\"oui-rounded-xl oui-bg-base-9 oui-px-6\"\n title={t(\"portfolio.overview.tab.convert.history\")}\n >\n <React.Suspense fallback={null}>\n <LazyConvertHistoryWidget />\n </React.Suspense>\n </TabPanel>\n </Tabs>\n </Card>\n );\n};\n","import { useMemo } from \"react\";\nimport { useAccount } from \"@orderly.network/hooks\";\nimport { AccountType } from \"../pages/assets/assetsPage/assets.ui.desktop\";\n\n// Account filter function type\nexport type AccountFilterFunction<T = any> = (\n data: T[],\n selectedAccount: string,\n accountState: ReturnType<typeof useAccount>,\n) => T[];\n\n// Generic account filter utility\nexport const createAccountFilter = <T extends { account_id?: string }>(\n getAccountId?: (item: T) => string | undefined,\n): AccountFilterFunction<T> => {\n return (data, selectedAccount, accountState) => {\n const { state, isMainAccount } = accountState;\n\n return data.filter((item) => {\n const accountId = getAccountId ? getAccountId(item) : item.account_id;\n\n if (isMainAccount) {\n if (!selectedAccount || selectedAccount === AccountType.ALL) {\n return true;\n }\n if (selectedAccount === AccountType.MAIN) {\n return accountId === state.mainAccountId;\n } else {\n return accountId === selectedAccount;\n }\n } else {\n return accountId === state.accountId;\n }\n });\n };\n};\n\n// Hook for standard account-based data filtering\nexport const useAccountFilter = <T extends { account_id?: string }>(\n data: T[],\n selectedAccount: string,\n getAccountId?: (item: T) => string | undefined,\n): T[] => {\n const accountState = useAccount();\n\n return useMemo(() => {\n const { state, isMainAccount } = accountState;\n\n return data.filter((item) => {\n const accountId = getAccountId ? getAccountId(item) : item.account_id;\n\n if (isMainAccount) {\n if (!selectedAccount || selectedAccount === AccountType.ALL) {\n return true;\n }\n if (selectedAccount === AccountType.MAIN) {\n return accountId === state.mainAccountId;\n } else {\n return accountId === selectedAccount;\n }\n } else {\n return accountId === state.accountId;\n }\n });\n }, [data, selectedAccount, accountState, getAccountId]);\n};\n\n// Hook specifically for transfer history filtering\nexport const useTransferHistoryAccountFilter = <\n T extends { from_account_id?: string; to_account_id?: string },\n>(\n data: T[],\n selectedAccount: string,\n): T[] => {\n const accountState = useAccount();\n\n return useMemo(() => {\n const { state, isMainAccount } = accountState;\n\n return data.filter((item) => {\n if (isMainAccount) {\n if (!selectedAccount || selectedAccount === AccountType.ALL) {\n return true;\n }\n if (selectedAccount === AccountType.MAIN) {\n return (\n item.from_account_id === state.mainAccountId ||\n item.to_account_id === state.mainAccountId\n );\n } else {\n return (\n item.from_account_id === selectedAccount ||\n item.to_account_id === selectedAccount\n );\n }\n } else {\n return (\n item.from_account_id === state.accountId ||\n item.to_account_id === state.accountId\n );\n }\n });\n }, [data, selectedAccount, accountState]);\n};\n\n// Pre-defined account filters for common use cases\nexport const AccountFilters = {\n // Standard account filter factory\n standard: <T extends { account_id?: string }>() => createAccountFilter<T>(),\n\n // Transfer history filter factory\n transferHistory:\n <T extends { from_account_id?: string; to_account_id?: string }>() =>\n (\n data: T[],\n selectedAccount: string,\n accountState: ReturnType<typeof useAccount>,\n ): T[] => {\n const { state, isMainAccount } = accountState;\n\n return data.filter((item) => {\n if (isMainAccount) {\n if (!selectedAccount || selectedAccount === AccountType.ALL) {\n return true;\n }\n if (selectedAccount === AccountType.MAIN) {\n return (\n item.from_account_id === state.mainAccountId ||\n item.to_account_id === state.mainAccountId\n );\n } else {\n return (\n item.from_account_id === selectedAccount ||\n item.to_account_id === selectedAccount\n );\n }\n } else {\n return (\n item.from_account_id === state.accountId ||\n item.to_account_id === state.accountId\n );\n }\n });\n },\n\n // Custom account ID filter factory\n customAccountId: <T extends Record<string, any>>(accountIdKey: keyof T) =>\n createAccountFilter<T>((item) => item[accountIdKey] as string),\n};\n","import React, { useMemo } from \"react\";\nimport { useAccount } from \"@orderly.network/hooks\";\nimport { AccountType } from \"../pages/assets/assetsPage/assets.ui.desktop\";\n\n// Account filter hook for assets-like data structures\nexport const useAssetsAccountFilter = <T extends { account_id?: string }>(\n data: T[],\n) => {\n const { state, isMainAccount } = useAccount();\n const [selectedAccount, setSelectedAccount] = React.useState<string>(\n AccountType.ALL,\n );\n\n // Filter data based on selected account\n const filteredData = useMemo(() => {\n return data.filter((item) => {\n if (isMainAccount) {\n if (!selectedAccount || selectedAccount === AccountType.ALL) {\n return true;\n }\n if (selectedAccount === AccountType.MAIN) {\n return item.account_id === state.mainAccountId;\n } else {\n return item.account_id === selectedAccount;\n }\n } else {\n return item.account_id === state.accountId;\n }\n });\n }, [data, selectedAccount, isMainAccount, state]);\n\n // Handle filter changes\n const onAccountFilter = React.useCallback(\n (filter: { name: string; value: string }) => {\n const { name, value } = filter;\n if (name === \"account\") {\n setSelectedAccount(value);\n }\n },\n [],\n );\n\n return {\n selectedAccount,\n filteredData,\n onAccountFilter,\n setSelectedAccount,\n };\n};\n\n// Enhanced account and asset combined filter hook\nexport const useAssetsMultiFilter = <\n T extends {\n account_id?: string;\n children?: Array<{ token: string; [key: string]: any }>;\n },\n>(\n data: T[],\n) => {\n const { state, isMainAccount } = useAccount();\n const [selectedAccount, setSelectedAccount] = React.useState<string>(\n AccountType.ALL,\n );\n const [selectedAsset, setSelectedAsset] = React.useState<string>(\"all\");\n\n // Filter data based on both account and asset\n const filteredData = useMemo(() => {\n let accountFiltered = data;\n\n // First apply account filter\n if (isMainAccount) {\n if (selectedAccount && selectedAccount !== AccountType.ALL) {\n if (selectedAccount === AccountType.MAIN) {\n accountFiltered = data.filter(\n (item) => item.account_id === state.mainAccountId,\n );\n } else {\n accountFiltered = data.filter(\n (item) => item.account_id === selectedAccount,\n );\n }\n }\n } else {\n accountFiltered = data.filter(\n (item) => item.account_id === state.accountId,\n );\n }\n\n // Then apply asset filter\n if (selectedAsset && selectedAsset !== \"all\") {\n accountFiltered = accountFiltered\n .map((account) => {\n if (account.children) {\n const filteredChildren = account.children.filter(\n (child) => child.token === selectedAsset,\n );\n // Only include accounts that have the selected asset\n return filteredChildren.length > 0\n ? { ...account, children: filteredChildren }\n : null;\n }\n return account;\n })\n .filter(Boolean) as T[];\n }\n\n return accountFiltered;\n }, [data, selectedAccount, selectedAsset, isMainAccount, state]);\n\n // Handle combined filter changes\n const onFilter = React.useCallback(\n (filter: { name: string; value: string }) => {\n const { name, value } = filter;\n if (name === \"account\") {\n setSelectedAccount(value);\n } else if (name === \"asset\") {\n setSelectedAsset(value);\n }\n },\n [],\n );\n\n return {\n selectedAccount,\n selectedAsset,\n filteredData,\n onFilter,\n setSelectedAccount,\n setSelectedAsset,\n };\n};\n\n// Generic account filter function that can be used standalone\nexport const filterByAccount = <T extends { account_id?: string }>(\n data: T[],\n selectedAccount: string,\n accountState: {\n isMainAccount: boolean;\n state: {\n mainAccountId?: string;\n accountId?: string;\n };\n },\n): T[] => {\n const { isMainAccount, state } = accountState;\n\n return data.filter((item) => {\n if (isMainAccount) {\n if (!selectedAccount || selectedAccount === AccountType.ALL) {\n return true;\n }\n if (selectedAccount === AccountType.MAIN) {\n return item.account_id === state.mainAccountId;\n } else {\n return item.account_id === selectedAccount;\n }\n } else {\n return item.account_id === state.accountId;\n }\n });\n};\n","export * from \"./useAssetTotalValue\";\nexport * from \"./useAccountFilter\";\nexport * from \"./useAssetsAccountFilter\";\nexport * from \"./useAccountsData\";\n","import React, { useMemo, useState } from \"react\";\nimport { getDate, getMonth, getYear, set } from \"date-fns\";\nimport {\n useAccount,\n useCollateral,\n useIndexPricesStream,\n useSubAccountQuery,\n useTokensInfo,\n useChainInfo,\n} from \"@orderly.network/hooks\";\nimport { EMPTY_LIST } from \"@orderly.network/types\";\nimport { usePagination } from \"@orderly.network/ui\";\nimport { subtractDaysFromCurrentDate } from \"@orderly.network/utils\";\nimport { useAccountsData, useAssetsAccountFilter } from \"../../../hooks\";\nimport { parseDateRangeForFilter } from \"../../overview/helper/date\";\nimport type { ConvertRecord } from \"../type\";\n\nexport const useConvertScript = () => {\n const { isMainAccount, state } = useAccount();\n const { holding = [] } = useCollateral();\n const { data: indexPrices } = useIndexPricesStream();\n\n const { data: chainsInfo } = useChainInfo();\n\n // Pagination\n const { page, pageSize, setPage, parsePagination } = usePagination({\n page: 1,\n pageSize: 20,\n });\n\n // Use the same account data structure as assets\n const allAccounts = useAccountsData();\n\n const tokensInfo = useTokensInfo();\n\n // Use the same account filter logic as assets\n const { selectedAccount, onAccountFilter } =\n useAssetsAccountFilter(allAccounts);\n\n // Simple date range handling like other scripts\n const [today] = useState(() => {\n const d = new Date();\n return new Date(getYear(d), getMonth(d), getDate(d), 0, 0, 0);\n });\n\n const [dateRange, setDateRange] = useState<Date[]>([\n subtractDaysFromCurrentDate(90, today),\n today,\n ]);\n\n // Filter states (matching API fields)\n const [statusFilter, setStatusFilter] = useState<string>(\"all\");\n const [convertedAssetFilter, setConvertedAssetFilter] =\n useState<string>(\"all\");\n\n // Create asset options from holding data - similar to assets script\n const convertedAssetOptions = useMemo(() => {\n // Create options array\n const assetOptions =\n tokensInfo?.map((item) => ({\n value: item.token,\n label: item.token,\n })) || [];\n\n return [{ label: \"All assets\", value: \"all\" }, ...assetOptions];\n }, [tokensInfo]);\n\n // Handle all filters (including account filter and date range)\n const onFilter = React.useCallback(\n (filter: { name: string; value: string | { from: Date; to: Date } }) => {\n const { name, value } = filter;\n\n // Delegate account filter to the hook\n if (name === \"account\") {\n onAccountFilter(filter as { name: string; value: string });\n } else if (name === \"status\") {\n setStatusFilter(value as string);\n setPage(1); // Reset to first page when filter changes\n } else if (name === \"converted_asset\") {\n setConvertedAssetFilter(value as string);\n setPage(1);\n } else if (name === \"time\" || name === \"dateRange\") {\n setDateRange(\n parseDateRangeForFilter(value as { from: Date; to: Date }),\n );\n setPage(1);\n }\n },\n [onAccountFilter, setPage],\n );\n\n // Build query URL with parameters\n const queryUrl = React.useMemo(() => {\n const params = new URLSearchParams();\n\n // Add pagination parameters\n params.set(\"page\", page.toString());\n params.set(\"size\", pageSize.toString());\n\n // Add date range parameters\n if (dateRange[0]) {\n params.set(\"start_t\", dateRange[0].getTime().toString());\n }\n if (dateRange[1]) {\n params.set(\n \"end_t\",\n set(dateRange[1], {\n hours: 23,\n minutes: 59,\n seconds: 59,\n milliseconds: 0,\n })\n .getTime()\n .toString(),\n );\n }\n\n // Add filter parameters (only if not \"all\")\n if (statusFilter !== \"all\") {\n params.set(\"status\", statusFilter);\n }\n\n if (convertedAssetFilter !== \"all\") {\n params.set(\"converted_asset\", convertedAssetFilter);\n }\n\n return `/v1/asset/convert_history?${params.toString()}`;\n }, [page, pageSize, dateRange, statusFilter, convertedAssetFilter]);\n\n // Query convert history with all parameters\n const { data, isLoading } = useSubAccountQuery<{\n rows: ConvertRecord[];\n meta: {\n total: number;\n current_page: number;\n records_per_page: number;\n };\n }>(queryUrl, {\n accountId: isMainAccount ? state.mainAccountId : state.accountId,\n formatter: (data) => {\n return data;\n },\n });\n\n // Parse pagination from API response meta\n const pagination = useMemo(() => {\n if (data?.meta) {\n return parsePagination(data.meta);\n }\n return {\n page,\n pageSize,\n onPageChange: setPage,\n onPageSizeChange: () => {\n // Handle page size change if needed\n },\n };\n }, [data?.meta, parsePagination, page, pageSize, setPage]);\n\n // Calculate summary\n const summary = useMemo(() => {\n const dataRows = data?.rows || [];\n\n const totalConversions = dataRows.length;\n const totalUSDCReceived = dataRows.reduce(\n (sum, record) => sum + record.received_qty,\n 0,\n );\n const totalFees = dataRows.reduce(\n (sum, record) =>\n sum +\n record.details.reduce(\n (detailSum, detail) => detailSum + detail.haircut,\n 0,\n ),\n 0,\n );\n\n return {\n totalConversions,\n totalUSDCReceived,\n totalFees,\n };\n }, [data]);\n\n return {\n // Data\n dataSource: data?.rows || EMPTY_LIST,\n summary,\n pagination,\n\n // Filter state and handlers (compatible with assets)\n selectedAccount,\n onFilter,\n\n // Query parameters (consistent with other scripts)\n dateRange,\n\n // Filter states\n statusFilter,\n convertedAssetFilter,\n convertedAssetOptions,\n\n // State\n isMainAccount,\n isLoading,\n holding,\n\n // Index prices\n indexPrices,\n chainsInfo,\n };\n};\n\nexport type UseConvertScriptReturn = ReturnType<typeof useConvertScript>;\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport React, { useMemo } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n Button,\n Flex,\n Text,\n TokenIcon,\n Tooltip,\n toast,\n} from \"@orderly.network/ui\";\nimport type { Column } from \"@orderly.network/ui\";\nimport type { ConvertRecord, ConvertTransaction } from \"../type\";\n\nexport interface ConvertColumnsOptions {\n onDetailsClick?: (convertId: number) => void;\n}\n\nexport interface ConvertDetailColumnsOptions {\n onTxClick?: (txId: string) => void;\n indexPrices: Record<string, number>;\n chainsInfo: any[];\n}\n\nexport const ConvertedAssetColumn = ({\n convertedAssets,\n}: {\n convertedAssets: Record<string, number>;\n}) => {\n const { t } = useTranslation();\n const assets = useMemo(() => {\n return Object.keys(convertedAssets);\n }, [convertedAssets]);\n\n const tooltipContent = useMemo(() => {\n return (\n <Flex\n direction=\"column\"\n gap={2}\n className=\"oui-w-[275px] oui-font-semibold oui-text-base-contrast-80\"\n >\n <Flex\n itemAlign=\"center\"\n justify=\"between\"\n className=\"oui-w-full oui-text-2xs oui-text-base-contrast-36\"\n >\n <div>{t(\"common.assets\")}</div>\n <div>{t(\"common.qty\")}</div>\n </Flex>\n {assets.map((asset) => (\n <Flex\n key={asset}\n itemAlign=\"center\"\n justify=\"between\"\n className=\"oui-w-full\"\n >\n <Flex itemAlign=\"center\" gap={1}>\n <TokenIcon size=\"xs\" name={asset} />\n <Text.formatted>{asset}</Text.formatted>\n </Flex>\n <div>\n <Text.formatted>{convertedAssets[asset]}</Text.formatted>\n </div>\n </Flex>\n ))}\n </Flex>\n );\n }, [assets]);\n\n return (\n <Flex itemAlign=\"center\" gap={2}>\n <div className=\"oui-relative oui-flex\">\n {assets.slice(0, 3).map((asset, index) => (\n <div\n key={asset}\n className=\"oui-relative\"\n style={{\n marginLeft: index > 0 ? \"-8px\" : \"0\",\n zIndex: assets.length + index,\n }}\n >\n <TokenIcon size=\"xs\" name={asset} />\n </div>\n ))}\n </div>\n <Tooltip content={tooltipContent}>\n <Text.formatted className=\"oui-cursor-pointer oui-underline oui-decoration-line-16 oui-decoration-dashed oui-underline-offset-4\">\n {assets.slice(0, 3).join(\", \")}{\" \"}\n {assets.length > 3 && `+${assets.length - 3}`}\n </Text.formatted>\n </Tooltip>\n </Flex>\n );\n};\n\nexport const useConvertColumns = (options: ConvertColumnsOptions) => {\n const { onDetailsClick } = options;\n const { t } = useTranslation();\n const onCopy = (e: any) => {\n e.preventDefault();\n e.stopPropagation();\n toast.success(t(\"common.copy.copied\"));\n };\n\n const columns = React.useMemo<Column[]>(() => {\n return [\n {\n title: t(\"portfolio.overview.column.convert.convertedAsset\"),\n dataIndex: \"converted_asset\",\n align: \"left\",\n width: 200,\n maxWidth: 200,\n render(convertedAssets: Record<string, number>) {\n return <ConvertedAssetColumn convertedAssets={convertedAssets} />;\n },\n },\n {\n title: t(\"portfolio.overview.column.convert.usdcAmount\"),\n dataIndex: \"received_qty\",\n align: \"left\",\n width: 150,\n render(qty: number) {\n return (\n <Text.numeral dp={6} padding={false}>\n {qty}\n </Text.numeral>\n );\n },\n },\n {\n title: t(\"common.fee\"),\n dataIndex: \"details\",\n align: \"left\",\n width: 120,\n render(details: ConvertRecord[\"details\"]) {\n const totalHaircut = details.reduce(\n (sum, detail) => sum + detail.haircut,\n 0,\n );\n return (\n <Text.numeral dp={6} padding={false}>\n {totalHaircut}\n </Text.numeral>\n );\n },\n },\n {\n title: t(\"common.type\"),\n dataIndex: \"type\",\n align: \"left\",\n width: 150,\n render(type: string) {\n return <Text>{type.charAt(0).toUpperCase() + type.slice(1)}</Text>;\n },\n },\n {\n title: t(\"portfolio.overview.column.convert.convertId\"),\n dataIndex: \"convert_id\",\n align: \"left\",\n width: 150,\n render(convertId: number) {\n return (\n <Text.formatted onCopy={onCopy} copyable>\n {convertId}\n </Text.formatted>\n );\n },\n },\n {\n title: t(\"common.time\"),\n dataIndex: \"created_time\",\n align: \"left\",\n width: 160,\n rule: \"date\",\n },\n {\n title: t(\"common.status\"),\n dataIndex: \"status\",\n align: \"left\",\n width: 150,\n render(status: string) {\n return (\n <Text>{status.charAt(0).toUpperCase() + status.slice(1)}</Text>\n );\n },\n },\n {\n title: \"\",\n dataIndex: \"updated_time\",\n align: \"center\",\n width: 80,\n render(convertId: number, record: ConvertRecord) {\n return (\n <Button\n size=\"sm\"\n variant=\"text\"\n className=\"oui-text-primary\"\n onClick={() => onDetailsClick?.(record.convert_id)}\n >\n {t(\"portfolio.overview.column.convert.details\")}\n </Button>\n );\n },\n },\n ];\n }, [onDetailsClick]);\n\n return columns;\n};\n\n// Converted asset, Qty., USDC amount, Fee, TxID, Network, Status\nexport const useConvertDetailColumns = (\n options: ConvertDetailColumnsOptions,\n) => {\n const { t } = useTranslation();\n const onCopy = (e: any) => {\n e.preventDefault();\n e.stopPropagation();\n toast.success(t(\"common.copy.copied\"));\n };\n const columns = React.useMemo<Column[]>(() => {\n return [\n {\n title: t(\"portfolio.overview.column.convert.convertedAsset\"),\n dataIndex: \"converted_asset\",\n align: \"left\",\n width: 150,\n render(asset: string) {\n return (\n <Flex itemAlign=\"center\" gap={2}>\n <TokenIcon name={asset} />\n {asset}\n </Flex>\n );\n },\n },\n {\n title: t(\"common.qty\"),\n dataIndex: \"converted_qty\",\n align: \"left\",\n width: 100,\n render(qty: number) {\n return (\n <Text.numeral dp={6} padding={false}>\n {qty}\n </Text.numeral>\n );\n },\n },\n {\n title: t(\"portfolio.overview.column.convert.usdcAmount\"),\n dataIndex: \"received_qty\",\n align: \"left\",\n width: 100,\n render(qty: number) {\n return (\n <Text.numeral dp={6} padding={false}>\n {qty}\n </Text.numeral>\n );\n },\n },\n {\n title: t(\"common.fee\"),\n dataIndex: \"haircut\",\n align: \"left\",\n width: 100,\n render(haircut: number) {\n return (\n <Text.numeral dp={6} padding={false}>\n {haircut}\n </Text.numeral>\n );\n },\n },\n {\n title: t(\"common.txId\"),\n dataIndex: \"tx_id\",\n align: \"left\",\n width: 150,\n render(txId: string, record: ConvertTransaction) {\n if (!txId) return <Text intensity={54}>-</Text>;\n const chainInfo = (options.chainsInfo as any[])?.find(\n (item) => record.chain_id === parseInt(item.chain_id),\n );\n const explorer_base_url = chainInfo?.explorer_base_url;\n const href = `${explorer_base_url}/tx/${txId}`;\n return (\n <a href={href} target=\"_blank\" rel=\"noreferrer\">\n <Text.formatted\n onCopy={onCopy}\n rule=\"txId\"\n copyable={!!txId}\n className=\"oui-cursor-pointer oui-underline oui-decoration-line-16 oui-decoration-dashed oui-underline-offset-4\"\n >\n {txId}\n </Text.formatted>\n </a>\n );\n },\n },\n {\n title: t(\"transfer.network\"),\n dataIndex: \"chain_id\",\n align: \"left\",\n width: 150,\n render(venue: string, record: ConvertTransaction) {\n return (\n <Text>\n {options.chainsInfo.find(\n (item) => item.chain_id == record.chain_id,\n )?.name || \"-\"}\n </Text>\n );\n },\n },\n {\n title: t(\"common.result\"),\n dataIndex: \"result\",\n align: \"left\",\n width: 100,\n render(result: string) {\n return (\n <Text>{result?.charAt(0).toUpperCase() + result?.slice(1)}</Text>\n );\n },\n },\n ];\n }, []);\n\n return columns;\n};\n","import { useMemo } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n DataFilter,\n Flex,\n DataTable,\n modal,\n SimpleDialog,\n Divider,\n} from \"@orderly.network/ui\";\nimport { useModal } from \"@orderly.network/ui\";\nimport { AuthGuardDataTable } from \"@orderly.network/ui-connector\";\nimport type { ConvertRecord } from \"../type\";\nimport { useConvertColumns, useConvertDetailColumns } from \"./convert.column\";\nimport { useConvertScript } from \"./convert.script\";\n\ntype ConvertDesktopUIProps = {\n convertState: ReturnType<typeof useConvertScript>;\n};\n\nexport const CONVERT_STATUS_OPTIONS = [\n {\n label: \"All status\",\n value: \"all\",\n },\n {\n label: \"Completed\",\n value: \"completed\",\n },\n {\n label: \"Pending\",\n value: \"pending\",\n },\n];\n\n// Convert Details Modal Component\nconst ConvertDetailsModal = modal.create<{\n record: ConvertRecord;\n indexPrices: Record<string, number>;\n chainsInfo: any[];\n}>((props) => {\n const { t } = useTranslation();\n const { visible, onOpenChange } = useModal();\n // console.log(props);\n\n const detailColumns = useConvertDetailColumns({\n indexPrices: props.indexPrices,\n chainsInfo: props.chainsInfo,\n });\n\n return (\n <SimpleDialog\n open={visible}\n onOpenChange={onOpenChange}\n title={t(\"portfolio.overview.convert.dialog.title.details\")}\n size=\"lg\"\n closable\n classNames={{\n content: \"oui-max-w-4xl\",\n }}\n >\n <DataTable\n columns={detailColumns}\n dataSource={props.record.details}\n bordered\n className=\"oui-w-full\"\n classNames={{\n header: \"oui-h-10\",\n root: \"oui-bg-base-8 oui-max-h-[60vh] oui-overflow-y-scroll\",\n }}\n onRow={() => ({\n className: \"oui-h-[40px]\",\n })}\n generatedRowKey={(record) =>\n record.transaction_id || Math.random().toString()\n }\n />\n </SimpleDialog>\n );\n});\n\nexport const ConvertDesktopUI: React.FC<ConvertDesktopUIProps> = ({\n convertState,\n}) => {\n const handleDetailsClick = (convertId: number) => {\n // Find the convert record by ID\n const record = convertState.dataSource.find(\n (item) => item.convert_id === convertId,\n );\n if (record) {\n modal.show(ConvertDetailsModal, {\n record,\n indexPrices: convertState.indexPrices,\n chainsInfo: convertState.chainsInfo as any,\n });\n }\n };\n\n const columns = useConvertColumns({\n onDetailsClick: handleDetailsClick,\n });\n\n const {\n convertedAssetFilter,\n statusFilter,\n dateRange,\n onFilter,\n convertedAssetOptions,\n } = convertState;\n\n const dataFilter = useMemo(() => {\n return (\n <DataFilter\n className=\"\"\n onFilter={onFilter}\n items={[\n // {\n // type: \"select\",\n // name: \"account\",\n // value: selectedAccount,\n // options: memoizedOptions,\n // },\n {\n type: \"select\",\n name: \"converted_asset\",\n value: convertedAssetFilter,\n options: convertedAssetOptions,\n },\n {\n type: \"select\",\n name: \"status\",\n value: statusFilter,\n options: CONVERT_STATUS_OPTIONS,\n },\n {\n type: \"range\",\n name: \"time\",\n value: {\n from: dateRange?.[0],\n to: dateRange?.[1],\n },\n },\n ]}\n />\n );\n }, [\n convertedAssetFilter,\n statusFilter,\n dateRange,\n onFilter,\n convertedAssetOptions,\n ]);\n\n return (\n <Flex direction=\"column\" mt={4} itemAlign=\"center\" className=\"oui-w-full\">\n <Divider className=\"oui-w-full oui-border-b oui-border-line-4 oui-pt-6\" />\n <Flex direction=\"row\" className=\"oui-w-full\">\n {dataFilter}\n </Flex>\n <AuthGuardDataTable\n columns={columns}\n dataSource={convertState.dataSource}\n loading={convertState.isLoading}\n bordered\n pagination={convertState.pagination}\n manualPagination\n className=\"oui-mt-4 oui-w-full\"\n classNames={{\n root: \"oui-h-[calc(100vh_-_200px)]\",\n header: \"oui-h-12\",\n }}\n onRow={() => ({\n className: \"oui-h-[48px] oui-cursor-pointer\",\n })}\n generatedRowKey={(record) => {\n return record.convert_id.toString();\n }}\n />\n </Flex>\n );\n};\n","import { useMemo } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n useModal,\n modal,\n Text,\n Divider,\n TokenIcon,\n Flex,\n DataFilter,\n SimpleSheet,\n toast,\n ScrollIndicator,\n} from \"@orderly.network/ui\";\nimport { ConvertRecord, ConvertTransaction } from \"../type\";\nimport { ConvertedAssetColumn } from \"./convert.column\";\nimport { useConvertScript } from \"./convert.script\";\nimport { CONVERT_STATUS_OPTIONS } from \"./convert.ui.desktop\";\n\ntype ConvertMobileUIProps = {\n convertState: ReturnType<typeof useConvertScript>;\n};\n\ntype ConvertMobileItemProps = {\n item?: any;\n chainsInfo: any[];\n};\n\ntype ConvertMobileFieldProps = {\n label: string;\n value?: string | number;\n className?: string;\n copyable?: boolean;\n rule?: \"address\" | \"txId\";\n onClick?: () => void;\n};\n\nexport const ConvertMobileUI: React.FC<ConvertMobileUIProps> = ({\n convertState,\n}) => {\n const { t } = useTranslation();\n\n const {\n convertedAssetFilter,\n statusFilter,\n dateRange,\n onFilter,\n convertedAssetOptions,\n } = convertState;\n\n const dataFilter = useMemo(() => {\n return (\n <DataFilter\n onFilter={onFilter}\n items={[\n // {\n // size: \"sm\",\n // type: \"picker\",\n // name: \"account\",\n // value: selectedAccount,\n // options: memoizedOptions,\n // },\n {\n size: \"md\",\n type: \"picker\",\n name: \"converted_asset\",\n value: convertedAssetFilter,\n options: convertedAssetOptions,\n className: \"oui-whitespace-nowrap\",\n },\n {\n size: \"md\",\n type: \"picker\",\n name: \"status\",\n value: statusFilter,\n options: CONVERT_STATUS_OPTIONS,\n className: \"oui-whitespace-nowrap\",\n },\n {\n type: \"range\",\n name: \"time\",\n value: {\n from: dateRange?.[0],\n to: dateRange?.[1],\n },\n },\n ]}\n />\n );\n }, [\n convertedAssetFilter,\n statusFilter,\n dateRange,\n onFilter,\n convertedAssetOptions,\n ]);\n\n return (\n <div className=\"oui-flex oui-flex-col oui-gap-1 oui-px-3\">\n <ScrollIndicator className=\"oui-pr-5\">\n <Flex direction=\"row\">{dataFilter}</Flex>\n </ScrollIndicator>\n {convertState.dataSource.map((item) => (\n <ConvertMobileItem\n key={item.convert_id}\n item={item}\n chainsInfo={convertState.chainsInfo as any}\n />\n ))}\n </div>\n );\n};\n\nconst ConvertMobileField: React.FC<ConvertMobileFieldProps> = ({\n label,\n value,\n rule,\n copyable = false,\n className = \"\",\n onClick,\n}) => {\n const { t } = useTranslation();\n const onCopy = (e: any) => {\n e.preventDefault();\n e.stopPropagation();\n toast.success(t(\"common.copy.copied\"));\n };\n return (\n <div\n className={`oui-text-2xs oui-font-semibold oui-text-base-contrast-80 [&_p]:oui-text-base-contrast-36 ${className}`}\n onClick={onClick}\n >\n <p>{label}</p>\n <Text.formatted rule={rule} copyable={copyable} onCopy={onCopy}>\n {value || \"-\"}\n </Text.formatted>\n </div>\n );\n};\n\nconst ConvertMobileItem: React.FC<ConvertMobileItemProps> = (props) => {\n const { item } = props;\n const { t } = useTranslation();\n\n if (!item) {\n return null;\n }\n\n const totalHaircut = item.details.reduce(\n (sum: number, detail: ConvertTransaction) => sum + detail.haircut,\n 0,\n );\n\n return (\n <div className=\"oui-flex oui-flex-col oui-gap-2 oui-rounded-xl oui-bg-base-9 oui-p-2\">\n <div className=\"oui-flex oui-justify-between\">\n <div className=\"oui-flex oui-items-center oui-text-xs oui-font-semibold oui-text-base-contrast-80\">\n <ConvertedAssetColumn convertedAssets={item.converted_asset} />\n <div\n className=\"oui-ml-2 oui-text-primary\"\n onClick={() => {\n modal.show(ConverHistoryItemDetailsDialog, {\n item,\n chainsInfo: props.chainsInfo,\n });\n }}\n >\n {t(\"portfolio.overview.column.convert.details\")}\n </div>\n </div>\n <Text.formatted\n className=\"oui-text-2xs oui-text-base-contrast-36\"\n rule=\"date\"\n >\n {item.created_time}\n </Text.formatted>\n </div>\n\n {/* 5 fields in grid container: 3 per row, wrap to next line */}\n <div className=\"oui-grid oui-grid-cols-3 oui-gap-2\">\n <ConvertMobileField\n label={t(\"portfolio.overview.column.convert.usdcAmount\")}\n value={item.received_qty}\n />\n <ConvertMobileField label={t(\"common.fee\")} value={totalHaircut} />\n <ConvertMobileField\n label={t(\"portfolio.overview.column.convert.convertId\")}\n value={item.convert_id}\n copyable={true}\n />\n <ConvertMobileField\n label={t(\"common.type\")}\n value={item.type?.charAt(0).toUpperCase() + item.type?.slice(1)}\n />\n <ConvertMobileField\n label={t(\"common.status\")}\n value={item.status?.charAt(0).toUpperCase() + item.status?.slice(1)}\n />\n </div>\n </div>\n );\n};\n\ntype ConvertHistoryItemDetailsDialogProps = {\n item: ConvertRecord;\n chainsInfo: any[];\n};\n\nconst ConverHistoryItemDetailsDialog =\n modal.create<ConvertHistoryItemDetailsDialogProps>((props) => {\n const { item, chainsInfo } = props;\n const { t } = useTranslation();\n const { visible, hide, resolve, reject, onOpenChange } = useModal();\n\n return (\n <SimpleSheet\n title={t(\"portfolio.overview.convert.dialog.title.details\")}\n open={visible}\n onOpenChange={onOpenChange}\n >\n <div className=\"oui-flex oui-h-[300px] oui-flex-col oui-gap-3 oui-overflow-y-auto oui-rounded-lg oui-bg-base-7 oui-p-2\">\n {item.details.map((detail, index) => (\n <>\n <div className=\"oui-flex oui-flex-col oui-gap-2\">\n <div className=\"oui-flex oui-items-center oui-gap-1\">\n <TokenIcon name={detail.converted_asset} size=\"xs\" />\n <div className=\"oui-text-xs oui-text-base-contrast-80\">\n {detail.converted_asset}\n </div>\n </div>\n <div className=\"oui-grid oui-grid-cols-3 oui-gap-2\">\n <ConvertMobileField\n label={t(\"common.qty\")}\n value={detail.converted_qty}\n />\n <ConvertMobileField\n label={t(\"portfolio.overview.column.convert.usdcAmount\")}\n value={detail.received_qty}\n />\n <ConvertMobileField label=\"Fee\" value={detail.haircut} />\n <ConvertMobileField\n label={t(\"common.txId\")}\n copyable={!!detail.tx_id}\n rule=\"txId\"\n value={detail.tx_id}\n onClick={() => {\n if (detail.tx_id) {\n const chainInfo = chainsInfo.find(\n (item) => item.chain_id == detail.chain_id,\n );\n if (chainInfo?.explorer_base_url) {\n window.open(\n `${chainInfo.explorer_base_url}/tx/${detail.tx_id}`,\n \"_blank\",\n );\n }\n }\n }}\n />\n <ConvertMobileField\n label={t(\"transfer.network\")}\n value={\n chainsInfo.find(\n (item) => item.chain_id == detail.chain_id,\n )?.name || \"-\"\n }\n />\n <ConvertMobileField\n label={t(\"common.result\")}\n value={\n detail.result\n ? detail.result.charAt(0).toUpperCase() +\n detail.result.slice(1)\n : \"-\"\n }\n />\n </div>\n </div>\n {index < item.details.length - 1 && <Divider />}\n </>\n ))}\n </div>\n </SimpleSheet>\n );\n });\n","import React from \"react\";\nimport { useScreen } from \"@orderly.network/ui\";\nimport { useConvertScript } from \"./convert.script\";\nimport { ConvertDesktopUI } from \"./convert.ui.desktop\";\nimport { ConvertMobileUI } from \"./convert.ui.mobile\";\n\nexport const ConvertHistoryWidget: React.FC = () => {\n const convertState = useConvertScript();\n const { isMobile } = useScreen();\n if (isMobile) {\n return <ConvertMobileUI convertState={convertState} />;\n }\n return <ConvertDesktopUI convertState={convertState} />;\n};\n","import React from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { AssetHistorySideEnum } from \"@orderly.network/types\";\nimport { TabPanel, Tabs } from \"@orderly.network/ui\";\nimport { ConvertHistoryWidget } from \"../../assets/convertPage/convert.widget\";\nimport { VaultsHistoryWidget } from \"../VaultsHistory/transfer.widget\";\nimport { AssetHistoryWidget } from \"../assetHistory\";\nimport { DistributionHistoryWidget } from \"../distribution\";\nimport { FundingHistoryWidget } from \"../funding\";\nimport { TabName } from \"./historyDataGroup.script\";\n\nexport const HistoryDataGroupMobile: React.FC<{\n active?: TabName;\n onTabChange: (tab: string) => void;\n}> = (props) => {\n const { active = \"deposit\", onTabChange } = props;\n const { t } = useTranslation();\n\n return (\n <Tabs\n value={active}\n onValueChange={onTabChange}\n variant=\"contained\"\n size=\"lg\"\n classNames={{\n tabsList: \"oui-px-3 oui-py-2\",\n scrollIndicator: \"oui-pr-3\",\n }}\n showScrollIndicator\n >\n <TabPanel title={t(\"common.deposits\")} value={\"deposit\"}>\n <AssetHistoryWidget side={AssetHistorySideEnum.DEPOSIT} />\n </TabPanel>\n <TabPanel title={t(\"common.withdrawals\")} value={\"withdraw\"}>\n <AssetHistoryWidget side={AssetHistorySideEnum.WITHDRAW} />\n </TabPanel>\n <TabPanel title={t(\"common.funding\")} value={\"funding\"}>\n <FundingHistoryWidget />\n </TabPanel>\n <TabPanel\n title={t(\"portfolio.overview.distribution\")}\n value={\"distribution\"}\n >\n <DistributionHistoryWidget />\n </TabPanel>\n <TabPanel\n title={t(\"portfolio.overview.tab.convert.history\")}\n value={\"convert\"}\n >\n <ConvertHistoryWidget />\n </TabPanel>\n <TabPanel title={t(\"common.vaults\")} value={\"vaults\"}>\n <VaultsHistoryWidget />\n </TabPanel>\n </Tabs>\n );\n};\n","import { useScreen } from \"@orderly.network/ui\";\nimport { useHistoryDataGroupScript } from \"./historyDataGroup.script\";\nimport { HistoryDataGroupDesktop } from \"./historyDataGroup.ui.desktop\";\nimport { HistoryDataGroupMobile } from \"./historyDataGroup.ui.mobile\";\n\nexport const HistoryDataGroupWidget: React.FC = () => {\n const state = useHistoryDataGroupScript();\n const { isMobile } = useScreen();\n if (isMobile) {\n return <HistoryDataGroupMobile {...state} />;\n }\n return <HistoryDataGroupDesktop {...state} />;\n};\n","export { HistoryDataGroupWidget } from \"./historyDataGroup.widget\";\n","import { createContext, useContext } from \"react\";\nimport { TWType } from \"@orderly.network/hooks\";\nimport { UseRewardsDataReturn } from \"../mobile/useRewardsData.script\";\nimport { useAssetsHistoryDataReturn } from \"../shared/useAssetHistory\";\n\nexport type OverviewContextState = {\n // period: PeriodType;\n type?: TWType;\n} & useAssetsHistoryDataReturn &\n UseRewardsDataReturn;\n\nexport const OverviewContext = createContext<OverviewContextState>(\n {} as OverviewContextState,\n);\n\nexport const useOverviewContext = () => {\n return useContext(OverviewContext);\n};\n","import { useMemo } from \"react\";\nimport { useAccount } from \"@orderly.network/hooks\";\nimport { useAppContext, useDataTap } from \"@orderly.network/react-app\";\nimport { AccountStatusEnum } from \"@orderly.network/types\";\nimport { useOverviewContext } from \"../provider/overviewContext\";\n\nexport const useAssetsChartScript = () => {\n const assetHistory = useOverviewContext();\n\n const { wrongNetwork, disabledConnect } = useAppContext();\n const { state } = useAccount();\n\n const filteredData = useDataTap(assetHistory.data, {\n accountStatus:\n state.status === AccountStatusEnum.EnableTradingWithoutConnected\n ? AccountStatusEnum.EnableTradingWithoutConnected\n : AccountStatusEnum.EnableTrading,\n fallbackData: assetHistory.createFakeData(\n { account_value: 0 },\n { account_value: 500 },\n ),\n });\n\n const _data = useMemo(() => {\n if (filteredData?.length) {\n return filteredData;\n }\n return assetHistory.createFakeData(\n { account_value: 0 },\n { account_value: 500 },\n );\n }, [filteredData, assetHistory]);\n\n const invisible =\n wrongNetwork || disabledConnect || !assetHistory.data.length;\n\n return {\n ...assetHistory,\n data: _data,\n invisible,\n } as const;\n};\n\nexport type useAssetsChartScriptReturn = ReturnType<\n typeof useAssetsChartScript\n>;\n","import { useCallback, useMemo, useRef, useState } from \"react\";\nimport { subDays, format } from \"date-fns\";\nimport {\n useAccount,\n useAssetsHistory,\n useCollateral,\n useIndexPricesStream,\n useLocalStorage,\n usePrivateQuery,\n useStatisticsDaily,\n} from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { API } from \"@orderly.network/types\";\nimport { Decimal, zero } from \"@orderly.network/utils\";\n\nexport enum PeriodType {\n WEEK = \"7D\",\n MONTH = \"30D\",\n QUARTER = \"90D\",\n}\n\nexport const useAssetsHistoryData = (\n localKey: string,\n options?: { isRealtime?: boolean },\n) => {\n const [today] = useState(() => new Date());\n\n const { getIndexPrice } = useIndexPricesStream();\n // const { account } = useAccount();\n\n const { t } = useTranslation();\n\n const { isRealtime = false } = options || {};\n const periodTypes = Object.values(PeriodType);\n\n const [period, setPeriod] = useLocalStorage<PeriodType>(\n localKey,\n PeriodType.WEEK,\n );\n\n const convertToUSDCAndOperate = useCallback(\n (inputs: {\n token: string;\n amount: string | number;\n value: Decimal;\n op?: \"add\" | \"sub\";\n }): Decimal => {\n const { token, amount, value, op = \"sub\" } = inputs;\n if (token.toUpperCase() === \"USDC\") {\n return op === \"add\" ? value.add(amount) : value.sub(amount);\n } else {\n const indexPrice = getIndexPrice(token);\n if (indexPrice) {\n const delta = new Decimal(amount).mul(indexPrice);\n return op === \"add\" ? value.add(delta) : value.sub(delta);\n }\n return value;\n }\n },\n [getIndexPrice],\n );\n\n const periodLabel = useMemo<Record<PeriodType, string>>(() => {\n return {\n [PeriodType.WEEK]: t(\"common.select.7d\"),\n [PeriodType.MONTH]: t(\"common.select.30d\"),\n [PeriodType.QUARTER]: t(\"common.select.90d\"),\n };\n }, [t]);\n\n const { totalValue } = useCollateral();\n\n const getStartDate = (value: PeriodType) => {\n switch (value) {\n case PeriodType.MONTH:\n return subDays(today, 35);\n case PeriodType.QUARTER:\n return subDays(today, 95);\n default:\n return subDays(today, 10);\n }\n };\n\n const periodValue = useMemo(() => {\n switch (period) {\n case PeriodType.WEEK:\n return 7;\n case PeriodType.MONTH:\n return 30;\n case PeriodType.QUARTER:\n return 90;\n default:\n return 7;\n }\n }, [period]);\n\n const [startDate, setStartDate] = useState(getStartDate(period));\n // const nowStamp = useRef(new Date().getTime().toString());\n // const now = useRef(new Date());\n\n // const endDate = useMemo(() => addDays(today, 1), [today]);\n const endDate = today;\n\n const totalDeposit = useRef<Decimal>(zero);\n\n // get transfer history\n const { data: transferOutHistory } = usePrivateQuery<API.TransferHistory>(\n `/v1/internal_transfer_history?page=1&size=200&side=OUT&main_sub_only=true&start_t=${startDate.getTime()}&end_t=${endDate.getTime()}`,\n {\n revalidateOnFocus: false,\n },\n );\n const { data: transferInHistory } = usePrivateQuery<API.TransferHistory>(\n `/v1/internal_transfer_history?page=1&size=200&side=IN&main_sub_only=true&start_t=${startDate.getTime()}&end_t=${endDate.getTime()}`,\n {\n revalidateOnFocus: false,\n },\n );\n\n const [data] = useStatisticsDaily(\n {\n startDate: startDate.toISOString().split(\"T\")[0],\n endDate: endDate.toISOString().split(\"T\")[0],\n },\n {\n ignoreAggregation: true,\n },\n );\n\n // get deposit & withdraw records to calculate the current PNL\n const [assetHistory] = useAssetsHistory({\n startTime: subDays(today, 2).getTime(),\n endTime: endDate.getTime(),\n pageSize: 50,\n });\n\n // get all deposit records to calculate the ROI\n const [allDepositHistory] = useAssetsHistory({\n side: \"DEPOSIT\",\n startTime: subDays(today, periodValue).getTime(),\n endTime: endDate.getTime(),\n pageSize: 200,\n });\n\n const totalDepositForROI = useMemo(() => {\n return allDepositHistory\n ?.filter((item) => item.trans_status === \"COMPLETED\")\n .reduce((acc, item) => {\n return acc.add(\n // item.amount\n convertToUSDCAndOperate({\n token: item.token,\n amount: item.amount,\n value: zero,\n op: \"add\",\n }),\n );\n }, zero);\n }, [allDepositHistory, convertToUSDCAndOperate]);\n\n const totalTransferInForROI = useMemo(() => {\n if (!Array.isArray(transferInHistory)) {\n return zero;\n }\n return transferInHistory\n ?.filter((item) => item.status === \"COMPLETED\")\n .reduce((acc, item) => {\n return acc.add(\n convertToUSDCAndOperate({\n token: item.token,\n amount: item.amount,\n value: zero,\n op: \"add\",\n }),\n );\n }, zero);\n }, [transferInHistory, convertToUSDCAndOperate]);\n\n const onPeriodChange = (value: PeriodType) => {\n setStartDate(getStartDate(value));\n setPeriod(value);\n };\n\n // const lastItem = data[data.length - 1];\n\n const lastItem = useMemo(() => {\n return data.length > 0 ? data[data.length - 1] : null;\n }, [data]);\n\n const totalTransferIn = useMemo(() => {\n if (!Array.isArray(transferInHistory)) {\n return null;\n }\n if (\n lastItem == null ||\n transferInHistory?.length === 0 ||\n typeof lastItem.snapshot_time === \"undefined\"\n ) {\n return zero;\n }\n const list = transferInHistory?.filter((item) => {\n return (\n item.status === \"COMPLETED\" &&\n item.created_time > lastItem?.snapshot_time\n );\n });\n return list?.reduce((acc, item) => {\n return acc.add(\n convertToUSDCAndOperate({\n token: item.token,\n amount: item.amount,\n value: zero,\n op: \"add\",\n }),\n );\n }, zero);\n }, [transferInHistory, lastItem, convertToUSDCAndOperate]);\n\n const totalTransferOut = useMemo(() => {\n if (!Array.isArray(transferOutHistory)) {\n return null;\n }\n if (\n lastItem == null ||\n transferOutHistory?.length === 0 ||\n typeof lastItem.snapshot_time === \"undefined\"\n ) {\n return zero;\n }\n const list = transferOutHistory?.filter((item) => {\n return (\n item.status === \"COMPLETED\" &&\n item.created_time > lastItem?.snapshot_time\n );\n });\n return list?.reduce((acc, item) => {\n return acc.add(\n convertToUSDCAndOperate({\n token: item.token,\n amount: item.amount,\n value: zero,\n op: \"add\",\n }),\n );\n }, zero);\n }, [transferOutHistory, lastItem, convertToUSDCAndOperate]);\n\n const calculateLastPnl = (inputs: {\n lastItem: API.DailyRow;\n assetHistory: ReadonlyArray<API.AssetHistoryRow> | API.AssetHistoryRow[];\n transferHistory: {\n OUT: Decimal;\n IN: Decimal;\n };\n totalValue: number | null;\n }) => {\n if (totalValue == null) {\n return null;\n }\n // today daily pnl = totalValue - lastItem.account_value - deposit + withdraw\n let value = new Decimal(totalValue).sub(inputs.lastItem.account_value);\n\n // subtraction of deposit and withdraw\n if (\n Array.isArray(inputs.assetHistory) &&\n inputs.assetHistory.length > 0 &&\n typeof inputs.lastItem.snapshot_time !== \"undefined\"\n ) {\n // find a list with the timestamp greater than the last item timestamp and trans_status = success;\n const list = [];\n\n for (let i = 0; i < inputs.assetHistory.length; i++) {\n const item = inputs.assetHistory[i];\n if (item.created_time > inputs.lastItem.snapshot_time) {\n list.push(item);\n }\n }\n\n // calculate the sum of deposit and withdraw\n for (let i = 0; i < list.length; i++) {\n const item = list[i];\n if (item.side === \"DEPOSIT\") {\n if (item.trans_status === \"COMPLETED\") {\n value = convertToUSDCAndOperate({\n token: item.token,\n amount: item.amount,\n value,\n op: \"sub\",\n });\n\n totalDeposit.current = convertToUSDCAndOperate({\n token: item.token,\n amount: item.amount,\n value: totalDeposit.current,\n op: \"add\",\n });\n }\n } else if (item.side === \"WITHDRAW\") {\n if (item.trans_status !== \"FAILED\") {\n value = convertToUSDCAndOperate({\n token: item.token,\n amount: item.amount,\n value,\n op: \"add\",\n });\n }\n }\n }\n }\n\n value = value\n .sub(inputs.transferHistory.IN)\n .add(inputs.transferHistory.OUT);\n\n return value.toNumber();\n };\n\n const calculate = (\n data: API.DailyRow[],\n totalValue: number | null,\n totalTransferIn: Decimal,\n totalTransferOut: Decimal,\n ) => {\n const lastItem = data[data.length - 1];\n\n return {\n ...lastItem,\n date: getUTCStr(today),\n perp_volume: 0,\n account_value:\n totalValue !== null ? totalValue : (lastItem?.account_value ?? 0),\n pnl:\n calculateLastPnl({\n lastItem,\n assetHistory,\n totalValue,\n transferHistory: {\n OUT: totalTransferOut,\n IN: totalTransferIn,\n },\n }) ?? 0,\n __isCalculated: true,\n };\n };\n\n const mergeData = (\n data: ReadonlyArray<API.DailyRow> | API.DailyRow[],\n totalValue: number | null,\n totalTransferIn: Decimal,\n totalTransferOut: Decimal,\n ) => {\n if (!Array.isArray(data) || data.length === 0) {\n return data;\n }\n\n if (data[data.length - 1].date === getUTCStr(today)) {\n return data;\n }\n\n return data.concat([\n calculate(data, totalValue, totalTransferIn, totalTransferOut),\n ]);\n };\n\n const calculateData = (\n data: ReadonlyArray<API.DailyRow> | API.DailyRow[],\n realtime: boolean,\n totalValue: number | null,\n totalTransferIn: Decimal,\n totalTransferOut: Decimal,\n ) => {\n const _data = !realtime\n ? data\n : mergeData(data, totalValue, totalTransferIn, totalTransferOut);\n\n return _data.slice(Math.max(0, _data.length - periodValue));\n };\n\n const calculatedData = useMemo(() => {\n /**\n * need the totalValue and data are all ready, else return null;\n */\n if (totalValue === null) {\n return [];\n }\n // if the transferOutHistory or transferInHistory is not ready, return null;\n\n if (totalTransferOut === null || totalTransferIn === null) {\n return [];\n }\n return calculateData(\n data,\n isRealtime,\n totalValue,\n totalTransferIn,\n totalTransferOut,\n );\n }, [\n data,\n totalValue,\n assetHistory,\n isRealtime,\n getIndexPrice,\n // transferOutHistory,\n // transferInHistory,\n totalTransferIn,\n totalTransferOut,\n ]);\n\n const aggregateValue = useMemo(() => {\n let vol = zero;\n let pnl = zero;\n let roi = zero;\n\n if (Array.isArray(calculatedData) && calculatedData.length) {\n calculatedData.forEach((d) => {\n // vol = vol.add(d.perp_volume);\n pnl = pnl.add(d.pnl);\n });\n\n const tail = calculatedData[0];\n\n const dataTailIndex = data.findIndex((d) => d.date === tail.date);\n\n const lastAccountValue = data[dataTailIndex - 1]?.account_value;\n\n // console.log(data, calculatedData, tail, dataTailIndex);\n\n if (typeof lastAccountValue === \"undefined\" || lastAccountValue === 0) {\n roi = zero;\n } else {\n roi = pnl.div(\n totalTransferInForROI.add(lastAccountValue).add(totalDepositForROI),\n );\n }\n }\n\n if (data.length > 0) {\n for (let i = 0; i < periodValue; i++) {\n const item = data[data.length - 1 - i];\n\n if (item) {\n vol = vol.add(item.perp_volume ?? 0);\n }\n }\n }\n\n // console.log(\"---------------------------\");\n\n return { vol: vol.toNumber(), pnl: pnl.toNumber(), roi: roi.toNumber() };\n }, [\n calculatedData,\n data,\n periodValue,\n totalTransferInForROI,\n totalDepositForROI,\n ]);\n\n const createFakeData = (\n start: Partial<API.DailyRow>,\n end: Partial<API.DailyRow>,\n ) => {\n return Array.from({ length: 2 }, (_, i) => {\n const date = format(i === 0 ? startDate : new Date(), \"yyyy-MM-dd\");\n return { date, ...(i === 0 ? start : end) };\n });\n };\n\n return {\n periodTypes,\n period: period as PeriodType,\n onPeriodChange: onPeriodChange,\n periodLabel: periodLabel,\n curPeriod: periodLabel[period as PeriodType],\n // data: calculatedDataUpdateByIndexPrice, // calculatedData,\n data: calculatedData, // calculatedData,\n aggregateValue,\n createFakeData,\n volumeUpdateDate: data?.[data.length - 1]?.date ?? \"\",\n } as const;\n};\n\nexport type useAssetsHistoryDataReturn = ReturnType<\n typeof useAssetsHistoryData\n>;\n\nfunction getUTCStr(date: Date) {\n const year = date.getUTCFullYear();\n const month = `0${date.getUTCMonth() + 1}`.slice(-2);\n const day = `0${date.getUTCDate()}`.slice(-2);\n\n return `${year}-${month}-${day}`;\n}\n","import React, { useMemo } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { CardTitle, Flex, Select } from \"@orderly.network/ui\";\nimport { PeriodType } from \"./useAssetHistory\";\n\nexport const PeriodTitle: React.FC<{\n onPeriodChange: (period: PeriodType) => void;\n periodTypes: string[];\n period: PeriodType;\n title: string;\n}> = (props) => {\n const { t } = useTranslation();\n\n const periodLabel = useMemo(() => {\n return {\n [PeriodType.WEEK]: t(\"common.select.7d\"),\n [PeriodType.MONTH]: t(\"common.select.30d\"),\n [PeriodType.QUARTER]: t(\"common.select.90d\"),\n };\n }, [t]);\n\n return (\n <Flex itemAlign={\"center\"} justify={\"between\"}>\n <CardTitle>{props.title}</CardTitle>\n <div className={\"oui-min-w-14\"}>\n <Select.options\n size={\"xs\"}\n value={props.period}\n onValueChange={props.onPeriodChange}\n options={props.periodTypes.map((item) => ({\n value: item,\n label: periodLabel[item as PeriodType],\n }))}\n />\n </div>\n </Flex>\n );\n};\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport React from \"react\";\nimport { AssetAreaChart } from \"@orderly.network/chart\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { Card } from \"@orderly.network/ui\";\nimport { useAssetsChartScriptReturn } from \"./assetsChart.script\";\n\nconst LazyPeriodTitle = React.lazy(() =>\n import(\"../shared/periodHeader\").then((mod) => {\n return { default: mod.PeriodTitle };\n }),\n);\n\nexport type AssetsLineChartProps = {} & useAssetsChartScriptReturn;\n\nexport const AssetsChart: React.FC<AssetsLineChartProps> = (props) => {\n const { onPeriodChange, data, periodTypes, period } = props;\n const { t } = useTranslation();\n return (\n <Card\n title={\n <React.Suspense fallback={null}>\n <LazyPeriodTitle\n onPeriodChange={onPeriodChange}\n periodTypes={periodTypes}\n period={period}\n title={t(\"common.assets\")}\n />\n </React.Suspense>\n }\n id=\"portfolio-overview-assets-chart\"\n classNames={{ content: \"oui-h-[168px] oui-pb-0\" }}\n >\n <React.Suspense fallback={null}>\n <AssetAreaChart data={data as any} invisible={props.invisible} />\n </React.Suspense>\n </Card>\n );\n};\n","import React from \"react\";\nimport { useAssetsChartScript } from \"./assetsChart.script\";\nimport { AssetsChart } from \"./assetsChart.ui\";\n\nexport const AssetsChartWidget: React.FC = () => {\n const state = useAssetsChartScript();\n return <AssetsChart {...state} />;\n};\n","export { AssetsChartWidget } from \"./assetsChart.widget\";\nexport { useAssetsChartScript } from \"./assetsChart.script\";\nexport { AssetsChart } from \"./assetsChart.ui\";\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport React from \"react\";\nimport { PnlAreaChart, PnLBarChart } from \"@orderly.network/chart\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { EMPTY_LIST } from \"@orderly.network/types\";\nimport {\n Card,\n Grid,\n Box,\n Statistic,\n Text,\n Flex,\n Tooltip,\n cn,\n} from \"@orderly.network/ui\";\nimport type { UsePerformanceScriptReturn } from \"./performance.script\";\n\nconst LazyPeriodTitle = React.lazy(() =>\n import(\"../shared/periodHeader\").then((mod) => {\n return { default: mod.PeriodTitle };\n }),\n);\n\nexport type PerformanceUIProps = {\n // periodTypes: string[];\n // period: string;\n // onPeriodChange: (period: string) => void;\n} & UsePerformanceScriptReturn;\n\nexport const PerformanceUI: React.FC<PerformanceUIProps> = (props) => {\n const {\n periodTypes,\n period,\n onPeriodChange,\n aggregateValue,\n invisible,\n visible,\n volumeUpdateDate,\n curPeriod,\n } = props;\n const { t } = useTranslation();\n\n return (\n <Card\n title={\n <React.Suspense fallback={null}>\n <LazyPeriodTitle\n onPeriodChange={onPeriodChange}\n periodTypes={periodTypes}\n period={period}\n title={t(\"portfolio.overview.performance\")}\n />\n </React.Suspense>\n }\n id=\"portfolio-overview-performance\"\n >\n <Grid cols={3} gap={4}>\n <Box\n gradient=\"neutral\"\n r=\"md\"\n px={4}\n py={2}\n angle={184}\n border\n borderColor={6}\n >\n <Statistic\n label={\n <LabelWithHint\n label={t(\"portfolio.overview.performance.roi\", {\n period: curPeriod,\n })}\n hint={t(\"portfolio.overview.performance.roi.tooltip\")}\n />\n }\n valueProps={{ rule: \"percentages\", coloring: true, visible }}\n >\n {invisible ? \"--\" : aggregateValue.roi}\n </Statistic>\n </Box>\n <Box\n gradient=\"neutral\"\n r=\"md\"\n px={4}\n py={2}\n angle={184}\n border\n borderColor={6}\n >\n <Statistic\n label={\n <LabelWithHint\n label={t(\"portfolio.overview.performance.pnl\", {\n period: curPeriod,\n })}\n hint={t(\"portfolio.overview.performance.pnl.tooltip\")}\n />\n }\n valueProps={{ coloring: true, showIdentifier: true, visible }}\n >\n {invisible ? \"--\" : aggregateValue.pnl}\n </Statistic>\n </Box>\n <Box\n gradient=\"neutral\"\n r=\"md\"\n px={4}\n py={2}\n angle={184}\n border\n borderColor={6}\n >\n <Statistic\n classNames={{\n label: \"oui-w-full\",\n }}\n label={\n <Flex justify={\"between\"}>\n <span>\n <LabelWithHint\n label={t(\"portfolio.overview.performance.volume\", {\n period: curPeriod,\n })}\n hint={t(\"portfolio.overview.performance.volume.tooltip\")}\n />\n </span>\n <span>{volumeUpdateDate}</span>\n </Flex>\n }\n valueProps={{ visible }}\n >\n {invisible ? \"--\" : aggregateValue.vol}\n </Statistic>\n </Box>\n </Grid>\n <Grid cols={2} gap={4}>\n <PerformancePnL\n data={props.data ?? EMPTY_LIST}\n invisible={props.invisible}\n />\n <CumulativePnlChart\n data={props.data ?? EMPTY_LIST}\n invisible={props.invisible || (props.data?.length ?? 0) <= 2}\n />\n </Grid>\n </Card>\n );\n};\n\ntype LabelWithHintProps = {\n label: string;\n hint?: React.ReactNode;\n};\n\nconst LabelWithHint: React.FC<LabelWithHintProps> = (props) => {\n const { label, hint } = props;\n return (\n <Tooltip\n open={hint ? undefined : false}\n content={hint}\n className=\"oui-max-w-[240px] oui-bg-base-6 \"\n arrow={{ className: \"oui-fill-base-6\" }}\n delayDuration={300}\n >\n <Text\n size=\"xs\"\n intensity={36}\n className={cn(\n hint &&\n \"oui-cursor-pointer oui-border-b oui-border-dashed oui-border-line-12\",\n )}\n >\n {label}\n </Text>\n </Tooltip>\n );\n};\n\nexport const PerformancePnL: React.FC<{\n data: ReadonlyArray<any> | any[];\n invisible: boolean;\n}> = (props) => {\n const { t } = useTranslation();\n return (\n <Box mt={4} height={\"188px\"}>\n <Text as=\"div\" size=\"sm\" className=\"oui-mb-3\">\n {t(\"portfolio.overview.performance.dailyPnl\")}\n </Text>\n <Box r=\"md\" className=\"oui-h-[188px] oui-border oui-border-line-4\">\n <PnLBarChart\n data={props.data}\n invisible={props.invisible || (props.data?.length ?? 0) <= 2}\n />\n </Box>\n </Box>\n );\n};\n\nexport const CumulativePnlChart: React.FC<{\n data: ReadonlyArray<any> | any[];\n invisible: boolean;\n}> = (props) => {\n const { t } = useTranslation();\n return (\n <Box mt={4}>\n <Text as=\"div\" size=\"sm\" className=\"oui-mb-3\">\n {t(\"portfolio.overview.performance.cumulativePnl\")}\n </Text>\n <Box r=\"md\" className=\"oui-h-[188px] oui-border oui-border-line-4\">\n <PnlAreaChart\n data={props.data}\n invisible={props.invisible || (props.data?.length ?? 0) <= 2}\n />\n </Box>\n </Box>\n );\n};\n","// Asset conversion types\nexport interface ConvertedAssets {\n [asset: string]: number;\n}\n\nexport interface ConvertTransaction {\n transaction_id: number;\n venue: \"on_chain\" | \"internal_fund\";\n converted_asset: string;\n received_asset: string;\n converted_qty: number;\n received_qty: number;\n haircut: number;\n chain_id?: number; // Optional, only for on_chain venue\n tx_id?: string; // Optional, only for on_chain venue\n result?: string;\n}\n\nexport interface ConvertRecord {\n convert_id: number;\n converted_asset: ConvertedAssets;\n received_asset: string;\n received_qty: number;\n type: \"auto\" | \"manual\";\n status: \"completed\" | \"pending\" | \"failed\" | \"cancelled\";\n created_time: number;\n updated_time: number;\n details: ConvertTransaction[];\n}\n\n// Additional utility types\nexport type ConvertType = \"auto\" | \"manual\";\n\nexport type ConvertStatus = \"completed\" | \"pending\" | \"failed\" | \"cancelled\";\n\nexport type VenueType = \"on_chain\" | \"internal_fund\";\n\nexport const ORDERLY_ASSETS_VISIBLE_KEY = \"orderly_assets_visible\";\n","import { useMemo } from \"react\";\nimport { useAccount, useLocalStorage } from \"@orderly.network/hooks\";\nimport { useAppContext, useDataTap } from \"@orderly.network/react-app\";\nimport { AccountStatusEnum } from \"@orderly.network/types\";\nimport { ORDERLY_ASSETS_VISIBLE_KEY } from \"../../assets/type\";\nimport { useOverviewContext } from \"../provider/overviewContext\";\n\nexport const usePerformanceScript = () => {\n const ctx = useOverviewContext();\n const [visible, setVisible] = useLocalStorage<boolean>(\n ORDERLY_ASSETS_VISIBLE_KEY,\n true,\n );\n\n const { wrongNetwork, disabledConnect } = useAppContext();\n const { state } = useAccount();\n const filteredData = useDataTap(ctx?.data, {\n accountStatus:\n state.status === AccountStatusEnum.EnableTradingWithoutConnected\n ? AccountStatusEnum.EnableTradingWithoutConnected\n : AccountStatusEnum.EnableTrading,\n fallbackData: ctx?.createFakeData?.(\n { account_value: 0, pnl: 0 },\n { account_value: 500, pnl: 500 },\n ),\n });\n\n const _data = useMemo(() => {\n if (filteredData?.length) {\n return filteredData;\n }\n return ctx?.createFakeData?.(\n { account_value: 0, pnl: 0 },\n { account_value: 500, pnl: 500 },\n );\n }, [ctx, filteredData]);\n\n const invisible =\n wrongNetwork ||\n disabledConnect ||\n (state.status < AccountStatusEnum.EnableTrading &&\n state.status !== AccountStatusEnum.EnableTradingWithoutConnected);\n\n return {\n ...ctx,\n data: _data as ReadonlyArray<any>,\n invisible,\n visible: visible as boolean,\n setVisible: setVisible,\n };\n};\n\nexport type UsePerformanceScriptReturn = ReturnType<\n typeof usePerformanceScript\n>;\n","import React from \"react\";\nimport { usePerformanceScript } from \"./performance.script\";\nimport { PerformanceUI } from \"./performance.ui\";\n\nexport const PerformanceWidget: React.FC = () => {\n const state = usePerformanceScript();\n return <PerformanceUI {...state} />;\n};\n","export { PerformanceUI } from \"./performance.ui\";\nexport { PerformanceWidget } from \"./performance.widget\";\nexport { usePerformanceScript } from \"./performance.script\";\n","import React, { useId } from \"react\";\n\nexport const EffectiveFee = React.forwardRef<\n SVGSVGElement,\n React.SVGAttributes<SVGSVGElement>\n>((props, ref) => {\n const linearId = useId();\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width={14}\n height={14}\n viewBox=\"0 0 14 14\"\n fill=\"currentColor\"\n ref={ref}\n focusable={false}\n {...props}\n >\n <path\n d=\"M6.16411 1.53106C6.61974 1.07566 7.35888 1.07551 7.81442 1.53106L8.48833 2.20496C8.6797 2.39624 8.93064 2.51452 9.19755 2.54106L9.3132 2.54676H10.2662C10.9104 2.54691 11.4328 3.06926 11.4329 3.71343V4.66647C11.4329 4.97589 11.5559 5.27312 11.7747 5.49191L12.4492 6.16582C12.9047 6.62142 12.9047 7.36054 12.4492 7.81613L11.7753 8.49004L11.6972 8.57549C11.5272 8.78302 11.433 9.04426 11.4329 9.31491V10.2685L11.4272 10.3876C11.3715 10.9366 10.9348 11.373 10.3859 11.4289L10.2662 11.4352H9.3132L9.19755 11.4409C8.93066 11.4674 8.67969 11.5857 8.48833 11.777L7.81442 12.4509L7.72555 12.5306C7.29789 12.8795 6.68066 12.8794 6.25297 12.5306L6.16411 12.4509L5.4902 11.777C5.29887 11.5857 5.04786 11.4675 4.78097 11.4409L4.66533 11.4352H3.71171L3.59265 11.4289C3.04358 11.3731 2.60705 10.9367 2.55131 10.3876L2.54505 10.2685V9.31491C2.54499 9.04416 2.45089 8.78306 2.28072 8.57549L2.20325 8.49004L1.52934 7.81613C1.10213 7.38905 1.07534 6.71297 1.44902 6.25469L1.52934 6.16582L2.20382 5.49191C2.42248 5.27314 2.54505 4.97579 2.54505 4.66647V3.71343C2.54513 3.10945 3.00442 2.61221 3.59265 2.55246L3.71171 2.54676H4.66533L4.78097 2.54106C5.00968 2.51826 5.22694 2.4281 5.40475 2.28244L5.4902 2.20496L6.16411 1.53106ZM6.31507 3.02983C5.87756 3.46727 5.28401 3.71336 4.66533 3.71343H3.71171V4.66647C3.71171 5.28521 3.46614 5.87922 3.02869 6.31678L2.35421 6.99069L3.02812 7.6646C3.46577 8.10214 3.71164 8.69607 3.71171 9.31491V10.2685H4.66533C5.28396 10.2686 5.87757 10.5142 6.31507 10.9515L6.98898 11.6255L7.66289 10.9515C8.10045 10.5141 8.69446 10.2685 9.3132 10.2685H10.2662V9.31491C10.2663 8.69604 10.5127 8.10214 10.9504 7.6646L11.6243 6.99069L10.9498 6.31678C10.5122 5.8792 10.2662 5.28531 10.2662 4.66647V3.71343H9.3132C8.69438 3.71343 8.10047 3.46739 7.66289 3.02983L6.98898 2.35592L6.31507 3.02983ZM8.52934 4.64255C8.7571 4.41479 9.12639 4.41489 9.35421 4.64255C9.58202 4.87035 9.58202 5.23961 9.35421 5.46742L5.4657 9.35593C5.2379 9.58372 4.86863 9.58373 4.64083 9.35593C4.41318 9.12811 4.41308 8.75881 4.64083 8.53106L8.52934 4.64255ZM8.66435 7.83265C9.1245 7.83272 9.49777 8.2059 9.49777 8.66607C9.49769 9.12616 9.12445 9.49941 8.66435 9.49948C8.20419 9.49948 7.83101 9.12621 7.83094 8.66607C7.83094 8.20586 8.20415 7.83265 8.66435 7.83265ZM5.33126 4.49956C5.79141 4.49963 6.16468 4.87282 6.16468 5.33298C6.1646 5.79307 5.79136 6.16575 5.33126 6.16582C4.87111 6.16582 4.49793 5.79311 4.49785 5.33298C4.49785 4.87277 4.87106 4.49956 5.33126 4.49956Z\"\n fill={`url(#${linearId})`}\n />\n <defs>\n <linearGradient\n id={linearId}\n x1=\"12.7908\"\n y1=\"6.99084\"\n x2=\"1.1875\"\n y2=\"6.99084\"\n gradientUnits=\"userSpaceOnUse\"\n >\n <stop stopColor=\"rgb(var(--oui-gradient-brand-end))\" />\n <stop stopColor=\"rgb(var(--oui-gradient-brand-start))\" offset={1} />\n </linearGradient>\n </defs>\n </svg>\n );\n});\n\nif (process.env.NODE_ENV !== \"production\") {\n EffectiveFee.displayName = \"EffectiveFee\";\n}\n","export * from \"./effectiveFee\";\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { useMemo } from \"react\";\nimport { useFeeState } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n Box,\n Flex,\n modal,\n Text,\n Tooltip,\n useModal,\n useScreen,\n} from \"@orderly.network/ui\";\nimport {\n RouterAdapter,\n useScaffoldContext,\n} from \"@orderly.network/ui-scaffold\";\nimport { Decimal } from \"@orderly.network/utils\";\nimport { useLayoutContext } from \"../../layout/context\";\nimport { EffectiveFee } from \"./icons\";\n\nexport type FeeTierHeaderItemProps = {\n label: string;\n value: React.ReactNode;\n interactive?: boolean;\n};\n\nexport type FeeTierHeaderProps = {\n tier?: number | null;\n vol?: number | null;\n headerDataAdapter?: (original: any[]) => any[];\n};\n\nconst isEffective = (val?: unknown) =>\n typeof val !== \"undefined\" && val !== null;\n\nconst EffectiveFeeDialog: React.FC<{\n routerAdapter: RouterAdapter | undefined;\n}> = (props) => {\n const { routerAdapter } = props;\n const { t } = useTranslation();\n const { hide } = useModal();\n return (\n <Text size=\"2xs\" className=\"oui-whitespace-normal oui-break-words\">\n {t(\"portfolio.feeTier.effectiveFee.tooltip\")}{\" \"}\n <a\n href=\"/rewards/affiliate\"\n onClick={(e) => {\n e.preventDefault();\n routerAdapter?.onRouteChange({\n href: \"/rewards/affiliate\",\n name: t(\"portfolio.feeTier.effectiveFee.tooltipLink\"),\n });\n hide();\n }}\n className=\"oui-cursor-pointer oui-border-none oui-bg-transparent oui-p-0 oui-text-2xs oui-underline hover:oui-text-base-contrast-80\"\n >\n {t(\"portfolio.feeTier.effectiveFee.tooltipLink\")}\n </a>\n </Text>\n );\n};\n\nexport const MobileHeaderItem: React.FC<FeeTierHeaderItemProps> = (props) => {\n const { label, value, interactive } = props;\n const { t } = useTranslation();\n const { routerAdapter } = useLayoutContext();\n return (\n <Flex justify=\"between\" itemAlign=\"center\" width=\"100%\">\n <Text\n as=\"div\"\n intensity={36}\n size=\"xs\"\n weight=\"semibold\"\n className=\"oui-leading-[18px]\"\n >\n {label}\n </Text>\n <Flex className=\"oui-gap-1.5\" itemAlign=\"center\" justify=\"between\">\n <Text size=\"xs\" intensity={80} className=\"oui-leading-[24px]\">\n {value}\n </Text>\n {interactive && (\n <Flex\n gap={1}\n justify=\"center\"\n itemAlign=\"center\"\n className=\"oui-cursor-pointer oui-rounded oui-bg-gradient-to-r oui-from-[rgb(var(--oui-gradient-brand-start)_/_0.12)] oui-to-[rgb(var(--oui-gradient-brand-end)_/_0.12)] oui-px-1\"\n onClick={() => {\n modal.dialog({\n size: \"sm\",\n title: t(\"common.tips\"),\n content: <EffectiveFeeDialog routerAdapter={routerAdapter} />,\n });\n }}\n >\n <EffectiveFee />\n <Text.gradient\n className=\"oui-select-none\"\n color={\"brand\"}\n size=\"3xs\"\n weight=\"regular\"\n >\n {t(\"common.effectiveFee\")}\n </Text.gradient>\n </Flex>\n )}\n </Flex>\n </Flex>\n );\n};\n\nexport const DesktopHeaderItem: React.FC<FeeTierHeaderItemProps> = (props) => {\n const { label, value, interactive } = props;\n const { t } = useTranslation();\n const { routerAdapter } = useScaffoldContext();\n return (\n <Box\n gradient=\"neutral\"\n r=\"lg\"\n px={4}\n py={2}\n angle={184}\n width=\"100%\"\n border\n borderColor={6}\n >\n <Flex itemAlign=\"center\" justify=\"between\">\n <Text\n as=\"div\"\n intensity={36}\n size=\"2xs\"\n weight=\"semibold\"\n className=\"oui-leading-[18px]\"\n >\n {label}\n </Text>\n {interactive && (\n <Tooltip\n content={\n <Text\n size=\"2xs\"\n className=\"oui-whitespace-normal oui-break-words\"\n >\n {t(\"portfolio.feeTier.effectiveFee.tooltip\")}{\" \"}\n <a\n href=\"/rewards/affiliate\"\n onClick={(e) => {\n e.preventDefault();\n routerAdapter?.onRouteChange({\n href: \"/rewards/affiliate\",\n name: t(\"portfolio.feeTier.effectiveFee.tooltipLink\"),\n });\n }}\n className=\"oui-cursor-pointer oui-border-none oui-bg-transparent oui-p-0 oui-text-2xs oui-underline hover:oui-text-base-contrast-80\"\n >\n {t(\"portfolio.feeTier.effectiveFee.tooltipLink\")}\n </a>\n </Text>\n }\n className=\"oui-p-1.5 oui-text-base-contrast-54\"\n >\n <Flex\n gap={1}\n justify=\"center\"\n itemAlign=\"center\"\n className=\"oui-cursor-pointer oui-rounded oui-bg-gradient-to-r oui-from-[rgb(var(--oui-gradient-brand-start)_/_0.12)] oui-to-[rgb(var(--oui-gradient-brand-end)_/_0.12)] oui-px-1\"\n >\n <EffectiveFee />\n <Text.gradient\n className=\"oui-select-none\"\n color={\"brand\"}\n size=\"xs\"\n weight=\"regular\"\n >\n {t(\"common.effectiveFee\")}\n </Text.gradient>\n </Flex>\n </Tooltip>\n )}\n </Flex>\n <Flex className=\"oui-mt-1 oui-w-full\">\n <Text size=\"base\" intensity={80} className=\"oui-leading-[24px]\">\n {value}\n </Text>\n </Flex>\n </Box>\n );\n};\n\nexport const FeeTierHeader: React.FC<FeeTierHeaderProps> = (props) => {\n const { t } = useTranslation();\n const { tier, vol, headerDataAdapter } = props;\n const { isMobile } = useScreen();\n const { refereeRebate, ...others } = useFeeState();\n const isEffectiveFee = isEffective(refereeRebate);\n const items: FeeTierHeaderItemProps[] = [\n {\n label: t(\"portfolio.feeTier.header.yourTier\"),\n interactive: false,\n value: (\n <Text.gradient\n color={\"brand\"}\n angle={270}\n size={isMobile ? \"xs\" : \"base\"}\n >\n {tier || \"--\"}\n </Text.gradient>\n ),\n },\n {\n label: `${t(\"portfolio.feeTier.header.30dVolume\")} (USDC)`,\n interactive: false,\n value: (\n <Text.numeral\n rule=\"price\"\n dp={2}\n rm={Decimal.ROUND_DOWN}\n size={isMobile ? \"xs\" : \"base\"}\n >\n {vol !== undefined && vol !== null ? `${vol}` : \"-\"}\n </Text.numeral>\n ),\n },\n {\n label: t(\"portfolio.feeTier.header.takerFeeRate\"),\n interactive: isEffectiveFee,\n value: (\n <Text.gradient\n color={\"brand\"}\n angle={270}\n size={isMobile ? \"xs\" : \"base\"}\n >\n {isEffectiveFee\n ? others.effectiveTakerFee || \"--\"\n : others.takerFee || \"--\"}{\" \"}\n (RWA:{\" \"}\n {(isEffectiveFee\n ? others.rwaEffectiveTakerFee\n : others.rwaTakerFee) || \"--\"}\n )\n </Text.gradient>\n ),\n },\n {\n label: t(\"portfolio.feeTier.header.makerFeeRate\"),\n interactive: isEffectiveFee,\n value: (\n <Text.gradient\n color={\"brand\"}\n angle={270}\n size={isMobile ? \"xs\" : \"base\"}\n >\n {isEffectiveFee\n ? others.effectiveMakerFee || \"--\"\n : others.makerFee || \"--\"}{\" \"}\n (RWA:{\" \"}\n {(isEffectiveFee\n ? others.rwaEffectiveMakerFee\n : others.rwaMakerFee) || \"--\"}\n )\n </Text.gradient>\n ),\n },\n ];\n\n const mergedData = useMemo<FeeTierHeaderItemProps[]>(() => {\n if (typeof headerDataAdapter === \"function\") {\n return headerDataAdapter(items);\n }\n return items;\n }, [headerDataAdapter, items]);\n\n if (!Array.isArray(mergedData)) {\n return null;\n }\n\n if (isMobile) {\n return (\n <Flex\n className=\"oui-rounded-xl oui-bg-base-9 oui-p-3\"\n direction=\"column\"\n gap={2}\n itemAlign={\"stretch\"}\n >\n {mergedData.map((item, index) => (\n <MobileHeaderItem {...item} key={`mobile-item-${index}`} />\n ))}\n </Flex>\n );\n }\n\n return (\n <Flex className=\"\" direction=\"row\" gapX={4} my={4} itemAlign={\"stretch\"}>\n {mergedData.map((item, index) => (\n <DesktopHeaderItem {...item} key={`desktop-item-${index}`} />\n ))}\n </Flex>\n );\n};\n","import { useEffect, useMemo, useState } from \"react\";\nimport {\n APIKeyItem,\n ScopeType,\n useAccount,\n useApiKeyManager,\n} from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { useAppContext, useDataTap } from \"@orderly.network/react-app\";\nimport { AccountStatusEnum } from \"@orderly.network/types\";\nimport { toast, usePagination } from \"@orderly.network/ui\";\n\nexport type GenerateKeyInfo = {\n key: string;\n screctKey: string;\n ip?: string;\n permissions?: string;\n};\n\nexport const useApiManagerScript = (props?: {\n filterTags?: [string];\n keyStatus?: string;\n}) => {\n const { filterTags, keyStatus } = props ?? {};\n const [showCreateDialog, setShowCreateDialog] = useState(false);\n const [showCreatedDialog, setShowCreatedDialog] = useState(false);\n const [generateKey, setGenerateKey] = useState<GenerateKeyInfo | undefined>();\n const { wrongNetwork, disabledConnect } = useAppContext();\n const { state, account } = useAccount();\n const { t } = useTranslation();\n\n const canCreateApiKey =\n !wrongNetwork &&\n !disabledConnect &&\n (state.status === AccountStatusEnum.EnableTrading ||\n state.status === AccountStatusEnum.EnableTradingWithoutConnected);\n\n const [\n keys,\n {\n generateOrderlyKey,\n setIPRestriction,\n removeOrderlyKey,\n resetOrderlyKeyIPRestriction,\n refresh,\n isLoading,\n error,\n },\n ] = useApiKeyManager({\n keyInfo: { key_status: keyStatus },\n });\n\n const [curPubKey, setCurPubKey] = useState<string | undefined>(undefined);\n\n useEffect(() => {\n account.keyStore\n .getOrderlyKey()\n ?.getPublicKey()\n .then((pubKey) => {\n setCurPubKey(pubKey);\n });\n }, [account, state]);\n\n const onCreateApiKey = () => {\n setShowCreateDialog(true);\n };\n const onReadApiGuide = () => {\n window.open(\n \"https://orderly.network/docs/build-on-omnichain/evm-api/api-authentication#api-authentication\",\n \"_blank\",\n );\n };\n\n const hideCreateDialog = () => {\n setShowCreateDialog(false);\n };\n\n const doCreate = async (\n ipRestriction?: string,\n scope?: ScopeType,\n ): Promise<number> => {\n try {\n const createdSuccess = (\n res: {\n key: string;\n secretKey: string;\n },\n ip?: string,\n ) => {\n const { key, secretKey } = res;\n hideCreateDialog();\n setGenerateKey({\n key: key,\n screctKey: secretKey,\n ip: ip,\n permissions: scope\n ?.split(\",\")\n ?.map((e) => capitalizeFirstChar(e))\n .join(\", \"),\n });\n setShowCreatedDialog(true);\n };\n\n const res = await generateOrderlyKey(scope);\n /// add ed25519: prefix to the key\n const generateKeyRes = {\n ...res,\n key: `ed25519:${res.key}`,\n };\n toast.success(t(\"portfolio.apiKey.created\"));\n\n if ((ipRestriction?.length || 0) > 0) {\n const key = generateKeyRes.key;\n const res = await setIPRestriction(key, ipRestriction!);\n if (res.success) {\n createdSuccess(\n generateKeyRes,\n res.data.ip_restriction_list?.join(\",\"),\n );\n }\n } else {\n createdSuccess(generateKeyRes, undefined);\n }\n } catch (err: any) {\n if (err?.message) toast.error(err?.message);\n }\n\n return Promise.resolve(0);\n };\n\n const hideCreatedDialog = () => {\n setShowCreatedDialog(false);\n refresh();\n };\n\n const onCopyApiKeyInfo = () => {\n navigator.clipboard.writeText(JSON.stringify(generateKey));\n toast.success(t(\"portfolio.apiKey.apiInfo.copied\"));\n };\n const doConfirm = () => {\n hideCreatedDialog();\n };\n\n const doDelete = (item: APIKeyItem): Promise<any> => {\n return new Promise(async (resolve) => {\n await removeOrderlyKey(item.orderly_key)\n .then(\n async (data) => {\n if (data?.success) {\n toast.success(t(\"portfolio.apiKey.deleted\"));\n refresh();\n // delete current api key, wiil disconnect\n const curKey = await account.keyStore\n .getOrderlyKey()\n ?.getPublicKey();\n if (item.orderly_key === curKey) {\n account.destroyOrderlyKey();\n }\n }\n resolve(1);\n },\n (reject) => {},\n )\n .catch((err) => {});\n });\n };\n\n const doEdit = async (item: APIKeyItem, ip?: string): Promise<void> => {\n let future;\n if ((ip?.length || 0) === 0) {\n future = resetOrderlyKeyIPRestriction(item.orderly_key, \"ALLOW_ALL_IPS\");\n } else {\n future = setIPRestriction(item.orderly_key, ip!);\n }\n\n const data = await future;\n\n if (data.success) {\n toast.success(t(\"portfolio.apiKey.updated\"));\n refresh();\n return Promise.resolve();\n } else {\n toast.error(data.message);\n }\n return Promise.reject();\n };\n\n const onCopyAccountId = () =>\n toast.success(t(\"portfolio.apiKey.accountId.copied\"));\n const onCopyApiKey = (key?: string) => {\n toast.success(t(\"portfolio.apiKey.column.apiKey.copy\"));\n };\n const onCopyApiSecretKey = () =>\n toast.success(t(\"portfolio.apiKey.secretKey.copied\"));\n const onCopyIP = () =>\n toast.success(t(\"portfolio.apiKey.column.restrictedIP.copy\"));\n\n const keyList = useMemo(() => {\n return keys?.filter((e) => {\n const filterTag = filterTags ? filterTags?.includes(e.tag) : true;\n const filterCurKey = curPubKey\n ? !e.orderly_key.includes(curPubKey)\n : true;\n return filterTag && filterCurKey;\n });\n }, [keys, filterTags, curPubKey]);\n\n const verifyIP = (ip: string) => {\n const ipRegex =\n /^((25[0-5]|2[0-4][0-9]|1[0-9]{2}|[1-9]?[0-9])\\.){3}(25[0-5]|2[0-4][0-9]|1[0-9]{2}|[1-9]?[0-9])(,((25[0-5]|2[0-4][0-9]|1[0-9]{2}|[1-9]?[0-9])\\.){3}(25[0-5]|2[0-4][0-9]|1[0-9]{2}|[1-9]?[0-9]))*$/;\n return ipRegex.test(ip)\n ? \"\"\n : \"The IP restriction format is incorrect. Please use the correct format: [xx.xx.xxx.x],[xx.xxx.xxx.xxx]\";\n };\n\n const accountStatus =\n state.status === AccountStatusEnum.EnableTradingWithoutConnected\n ? AccountStatusEnum.EnableTradingWithoutConnected\n : AccountStatusEnum.EnableTrading;\n\n const accountId = useDataTap(state.accountId, {\n accountStatus,\n });\n\n const userId = useDataTap(state.userId, {\n accountStatus,\n });\n\n const { pagination } = usePagination();\n\n return {\n accountId: accountId ?? \"--\",\n userId: userId ?? \"--\",\n onCreateApiKey,\n onReadApiGuide,\n showCreateDialog,\n hideCreateDialog,\n doCreate,\n showCreatedDialog,\n hideCreatedDialog,\n onCopyApiKeyInfo,\n doConfirm,\n doDelete,\n doEdit,\n canCreateApiKey,\n status: state.status,\n keys: keyList,\n generateKey,\n onCopyAccountId,\n wrongNetwork,\n onCopyApiKey,\n onCopyApiSecretKey,\n onCopyIP,\n verifyIP,\n isLoading,\n pagination,\n };\n};\n\nexport function capitalizeFirstChar(str: string): string {\n return str.charAt(0).toUpperCase() + str.slice(1);\n}\n\nexport type ApiManagerScriptReturns = ReturnType<typeof useApiManagerScript>;\n","import { FC, useEffect, useState } from \"react\";\nimport { ScopeType } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { cn, Flex, SimpleDialog, Statistic, Text } from \"@orderly.network/ui\";\nimport { ApiManagerScriptReturns } from \"../apiManager.script\";\n\nexport const CreateAPIKeyDialog: FC<ApiManagerScriptReturns> = (props) => {\n const [ipText, setIpText] = useState(\"\");\n const [read, setRead] = useState(true);\n const [trade, setTrade] = useState(true);\n const [hint, setHint] = useState(\"\");\n const { t } = useTranslation();\n\n useEffect(() => {\n if (!props.showCreateDialog) {\n setIpText(\"\");\n setRead(true);\n setTrade(true);\n setHint(\"\");\n }\n }, [props.showCreateDialog]);\n\n useEffect(() => {\n if (ipText.length === 0) setHint(\"\");\n }, [ipText]);\n\n return (\n <SimpleDialog\n size=\"sm\"\n open={props.showCreateDialog}\n onOpenChange={(open) => {\n props.hideCreateDialog?.();\n }}\n title={t(\"portfolio.apiKey.create.dialog.title\")}\n actions={{\n primary: {\n label: t(\"common.confirm\"),\n className: \"oui-w-[120px] lg:oui-w-[154px]\",\n \"data-testid\": \"oui-testid-apiKey-createApiKey-dialog-comfirm-btn\",\n onClick: async () => {\n if (ipText.length > 0) {\n const hint = props.verifyIP(ipText);\n setHint(hint);\n if (hint.length > 0) {\n return;\n }\n }\n\n const scopes: string[] = [];\n if (read) {\n scopes.push(\"read\");\n }\n if (trade) {\n scopes.push(\"trading\");\n }\n await props.doCreate(ipText, scopes.join(\",\") as ScopeType);\n },\n disabled: !trade && !read,\n size: \"md\",\n },\n }}\n classNames={{\n footer: \"oui-justify-center\",\n content:\n \"oui-bg-base-8 oui-w-[300px] lg:oui-w-[360px] oui-font-semibold\",\n }}\n >\n <Flex direction={\"column\"} gap={6}>\n <Flex direction={\"column\"} gap={1} width={\"100%\"} itemAlign={\"start\"}>\n <Text intensity={54} size=\"2xs\">\n {t(\"portfolio.apiKey.create.ipRestriction\")}\n </Text>\n <textarea\n data-testid=\"oui-testid-apiKey-createApiKey-dialog-textarea\"\n placeholder={t(\"portfolio.apiKey.create.ipRestriction.placeholder\")}\n className={cn(\n \"oui-h-[100px] oui-w-full oui-rounded-xl oui-bg-base-6 oui-p-3 oui-text-sm oui-text-base-contrast-80\",\n \"oui-border-0 oui-outline-none focus:oui-border-2 focus:oui-border-primary-darken\",\n \"oui-placeholder-base-contrast-20\",\n hint.length > 0 &&\n \"oui-outline-1 oui-outline-danger focus:oui-outline-none\",\n )}\n value={ipText}\n onChange={(e) => {\n setIpText(e.target.value);\n }}\n style={{\n resize: \"none\",\n }}\n />\n {hint.length > 0 && (\n <Flex gap={1} className=\"oui-relative\">\n <div\n className={cn(\n \"oui-absolute oui-top-[10px]\",\n \"oui-size-1 oui-rounded-full oui-bg-danger\",\n )}\n />\n <Text color=\"danger\" size=\"xs\" className=\"oui-ml-2\">\n {hint}\n </Text>\n </Flex>\n )}\n </Flex>\n <Statistic\n label={\n <Text size=\"xs\" intensity={54}>\n {t(\"portfolio.apiKey.permissions\")}\n </Text>\n }\n className=\"oui-w-full\"\n >\n <Flex\n direction={\"row\"}\n gap={6}\n itemAlign={\"start\"}\n className=\"oui-mt-2\"\n >\n <Checkbox\n size={18}\n checked={read}\n onCheckedChange={(e) => setRead(e as boolean)}\n label={t(\"portfolio.apiKey.permissions.read\")}\n testid=\"oui-testid-apiKey-createApiKey-dialog-read-checkbox\"\n />\n <Checkbox\n size={18}\n checked={trade}\n onCheckedChange={(e) => setTrade(e as boolean)}\n label={t(\"portfolio.apiKey.permissions.trading\")}\n testid=\"oui-testid-apiKey-createApiKey-dialog-trading-checkbox\"\n />\n </Flex>\n </Statistic>\n </Flex>\n </SimpleDialog>\n );\n};\n\nexport const Checkbox: FC<{\n size?: number;\n checked: boolean;\n onCheckedChange: (checked?: boolean) => void;\n disabled?: boolean;\n label: string;\n testid?: string;\n}> = (props) => {\n return (\n <button\n disabled={props.disabled}\n onClick={(e) => {\n props.onCheckedChange(!props.checked);\n }}\n className={\n \"oui-flex oui-items-center oui-gap-2 disabled:oui-cursor-not-allowed disabled:oui-opacity-50\"\n }\n data-testid={props.testid}\n >\n {props.checked ? (\n <svg\n width={\"props.size\"}\n height={props.size}\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M6.99072 2.92981C4.78172 2.92981 2.99072 4.72071 2.99072 6.92981V16.9298C2.99072 19.1389 4.78172 20.9298 6.99072 20.9298H16.9907C19.1997 20.9298 20.9907 19.1389 20.9907 16.9298V6.92981C20.9907 4.72071 19.1997 2.92981 16.9907 2.92981H6.99072ZM16.9853 7.31211C17.2125 7.09537 17.5236 7 17.8218 7C18.1201 7 18.4312 7.09537 18.6584 7.31211C19.1139 7.74546 19.1139 8.47384 18.6584 8.9072L10.5077 16.675C10.0534 17.1083 9.28909 17.1083 8.83472 16.675L5.34077 13.3459C4.88641 12.9126 4.88641 12.1841 5.34077 11.7508C5.79631 11.3175 6.56057 11.3175 7.01493 11.7508L9.67122 14.2822L16.9853 7.31211Z\"\n fill=\"white\"\n fillOpacity=\"0.54\"\n />\n </svg>\n ) : (\n <svg\n width={props.size}\n height={props.size}\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M6.99072 2.92981C4.78172 2.92981 2.99072 4.72071 2.99072 6.92981V16.9298C2.99072 19.1389 4.78172 20.9298 6.99072 20.9298H16.9907C19.1997 20.9298 20.9907 19.1389 20.9907 16.9298V6.92981C20.9907 4.72071 19.1997 2.92981 16.9907 2.92981H6.99072ZM6.99072 4.92981H16.9907C18.0957 4.92981 18.9907 5.82521 18.9907 6.92981V16.9298C18.9907 18.0344 18.0957 18.9298 16.9907 18.9298H6.99072C5.88572 18.9298 4.99072 18.0344 4.99072 16.9298V6.92981C4.99072 5.82521 5.88572 4.92981 6.99072 4.92981Z\"\n fill=\"white\"\n fillOpacity=\"0.54\"\n />\n </svg>\n )}\n\n <Text\n intensity={54}\n size=\"sm\"\n className=\"oui-whitespace-nowrap oui-break-normal\"\n >\n {props.label}\n </Text>\n </button>\n );\n};\n","import { FC } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n Box,\n CopyIcon,\n Flex,\n SimpleDialog,\n Statistic,\n Text,\n} from \"@orderly.network/ui\";\nimport { ApiManagerScriptReturns } from \"../apiManager.script\";\n\nexport const CreatedAPIKeyDialog: FC<ApiManagerScriptReturns> = (props) => {\n const ip = props.generateKey?.ip ?? \"--\";\n const { t } = useTranslation();\n return (\n <SimpleDialog\n size=\"sm\"\n open={props.showCreatedDialog}\n onOpenChange={(open) => {\n props.hideCreatedDialog?.();\n }}\n title={t(\"portfolio.apiKey.created\")}\n actions={{\n primary: {\n label: t(\"common.ok\"),\n \"data-testid\": \"oui-testid-apiKey-createdApiKey-dialog-ok-btn\",\n className:\n \"oui-w-[120px] lg:oui-w-[154px] oui-bg-base-2 hover:oui-bg-base-3\",\n size: \"md\",\n onClick: async () => {\n return props.doConfirm();\n },\n },\n secondary: {\n label: t(\"portfolio.apiKey.created.button.copyApiInfo\"),\n \"data-testid\": \"oui-testid-apiKey-createdApiKey-dialog-copy-btn\",\n className:\n \"oui-w-[120px] lg:oui-w-[154px] oui-bg-primary-darken hover:oui-opacity-80\",\n size: \"md\",\n onClick: async () => {\n return props.onCopyApiKeyInfo();\n },\n },\n }}\n classNames={{\n footer: \"oui-justify-center\",\n content:\n \"oui-bg-base-8 oui-w-[300px] lg:oui-w-[360px] oui-font-semibold\",\n body: \"oui-py-0 oui-pt-5\",\n }}\n >\n <Flex direction={\"column\"} gap={4} itemAlign={\"start\"}>\n <Statistic label={t(\"common.accountId\")}>\n <Text.formatted\n size=\"sm\"\n intensity={80}\n copyable\n copyIconSize={16}\n className=\"oui-break-all\"\n onCopy={props.onCopyAccountId}\n data-testid=\"oui-testid-apiKey-createdApiKey-dialog-key-span\"\n >\n {props.accountId}\n </Text.formatted>\n </Statistic>\n <Statistic label={t(\"portfolio.apiKey.column.apiKey\")}>\n <Text.formatted\n size=\"sm\"\n intensity={80}\n copyable\n copyIconSize={16}\n className=\"oui-break-all\"\n onCopy={() => props.onCopyApiKey(props.generateKey?.key)}\n data-testid=\"oui-testid-apiKey-createdApiKey-dialog-key-span\"\n >\n {props.generateKey?.key}\n </Text.formatted>\n </Statistic>\n <Statistic label={t(\"portfolio.apiKey.secretKey\")}>\n <Text.formatted\n size=\"sm\"\n intensity={80}\n copyable\n copyIconSize={16}\n className=\"oui-break-all\"\n onCopy={props.onCopyApiSecretKey}\n >\n {props.generateKey?.screctKey}\n </Text.formatted>{\" \"}\n </Statistic>\n <Statistic label={t(\"portfolio.apiKey.ip\")}>\n <Flex\n width={320}\n gap={1}\n itemAlign={\"center\"}\n className=\"oui-text-base-contrast-80 oui-text-sm\"\n >\n <Box className=\"oui-max-h-[100px] oui-flex-1 oui-overflow-hidden oui-text-ellipsis oui-line-clamp-5 oui-break-all\">\n {ip}\n </Box>\n {ip !== \"--\" && (\n <Box\n width={16}\n height={16}\n className=\"oui-cursor-pointer oui-flex-shrink-0\"\n >\n <CopyIcon\n color=\"white\"\n opacity={0.54}\n size={16}\n onClick={(e) => {\n if (props.generateKey?.ip)\n navigator.clipboard.writeText(props.generateKey?.ip);\n props?.onCopyIP();\n }}\n />\n </Box>\n )}\n </Flex>\n </Statistic>\n <Statistic label={t(\"portfolio.apiKey.permissions\")}>\n <Text\n size=\"sm\"\n intensity={80}\n data-testid=\"oui-testid-apiKey-createdApiKey-dialog-permissions-span\"\n >\n {props.generateKey?.permissions}\n </Text>\n </Statistic>\n <div></div>\n <Text color=\"warning\" size=\"xs\" className=\"oui-text-center\">\n {t(\"portfolio.apiKey.created.warning\")}\n </Text>\n </Flex>\n </SimpleDialog>\n );\n};\n","import { FC } from \"react\";\nimport { Flex, SimpleDialog, Text } from \"@orderly.network/ui\";\nimport { APIKeyItem } from \"@orderly.network/hooks\";\nimport { formatKey } from \"../apiManager.ui\";\nimport { useTranslation, Trans } from \"@orderly.network/i18n\";\n\nexport const DeleteAPIKeyDialog: FC<{\n item: APIKeyItem;\n open: boolean;\n setOpen?: any;\n onDelete?: (item: APIKeyItem) => Promise<void>;\n}> = (props) => {\n const { item, open, setOpen, onDelete } = props;\n const { t } = useTranslation();\n return (\n <SimpleDialog\n size=\"sm\"\n open={open}\n onOpenChange={setOpen}\n title={t(\"portfolio.apiKey.delete.dialog.title\")}\n actions={{\n primary: {\n label: t(\"common.confirm\"),\n \"data-testid\": \"oui-testid-apiKey-deleteApiKey-dialog-confirm-btn\",\n className: \"oui-w-[120px] lg:oui-w-[154px]\",\n size: \"md\",\n onClick: async () => {\n await props.onDelete?.(item);\n setOpen(false);\n },\n },\n secondary: {\n label: t(\"common.cancel\"),\n className: \"oui-w-[120px] lg:oui-w-[154px]\",\n size: \"md\",\n onClick: async () => {\n setOpen(false);\n },\n },\n }}\n classNames={{\n footer: \"oui-justify-center\",\n content:\n \"oui-bg-base-8 oui-w-[300px] lg:oui-w-[360px] oui-font-semibold\",\n }}\n >\n <Flex className=\"oui-text-xs\">\n {/* @ts-ignore */}\n <Trans\n i18nKey=\"portfolio.apiKey.delete.dialog.description\"\n values={{ apiKey: formatKey(item?.orderly_key) }}\n components={[<Text color=\"primary\" className=\"oui-px-1\" />]}\n />\n </Flex>\n </SimpleDialog>\n );\n};\n","import { FC, useEffect, useState } from \"react\";\nimport { APIKeyItem } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { cn, Flex, SimpleDialog, Statistic, Text } from \"@orderly.network/ui\";\nimport { Checkbox } from \"./createApiKey\";\n\nexport const EditAPIKeyDialog: FC<{\n item: APIKeyItem;\n open: boolean;\n setOpen?: any;\n onUpdate?: (item: APIKeyItem, ip?: string) => Promise<void>;\n verifyIP: (ip: string) => string;\n}> = (props) => {\n const { item, open, setOpen, onUpdate } = props;\n const [ipText, setIpText] = useState(item.ip_restriction_list?.join(\",\"));\n const [read, setRead] = useState(true);\n const [trade, setTrade] = useState(true);\n const [hint, setHint] = useState(\"\");\n const { t } = useTranslation();\n\n useEffect(() => {\n setIpText(item.ip_restriction_list.join(\",\"));\n const scope = item.scope?.toLocaleLowerCase() || \"\";\n\n setRead(scope.includes(\"read\"));\n setTrade(scope.includes(\"trading\"));\n }, [item]);\n\n useEffect(() => {\n if (ipText.length === 0) setHint(\"\");\n }, [ipText]);\n\n return (\n <SimpleDialog\n size=\"sm\"\n open={open}\n onOpenChange={setOpen}\n title={t(\"portfolio.apiKey.edit.dialog.title\")}\n actions={{\n primary: {\n label: t(\"common.confirm\"),\n \"data-testid\": \"oui-testid-apiKey-editApiKey-dialog-confirm-btn\",\n className: \"oui-w-[120px] lg:oui-w-[154px]\",\n onClick: async () => {\n if (ipText.length > 0) {\n const hint = props.verifyIP(ipText);\n setHint(hint);\n if (hint.length > 0) {\n return;\n }\n }\n await props.onUpdate?.(item, ipText);\n setOpen(false);\n },\n disabled: item.ip_restriction_list.join(\",\") === ipText,\n size: \"md\",\n fullWidth: true,\n },\n }}\n classNames={{\n footer: \"oui-justify-center\",\n content:\n \"oui-bg-base-8 oui-w-[300px] lg:oui-w-[360px] oui-font-semibold\",\n }}\n >\n <Flex direction={\"column\"} gap={6}>\n {/* <TextField label={\"IP restriction (optional)\"} rows={5} className=\"oui-w-full oui-h-auto\" classNames={{\n input: \"oui-h-[100px]\",\n root: \"oui-h-[100px]\"\n }}/> */}\n <Flex direction={\"column\"} gap={1} width={\"100%\"} itemAlign={\"start\"}>\n <Text intensity={54} size=\"2xs\">\n {t(\"portfolio.apiKey.create.ipRestriction\")}\n </Text>\n <textarea\n data-testid=\"oui-testid-apiKey-editApiKey-dialog-textarea\"\n placeholder={t(\"portfolio.apiKey.create.ipRestriction.placeholder\")}\n className={cn(\n \"oui-h-[100px] oui-w-full oui-rounded-xl oui-bg-base-6 oui-p-3 oui-text-sm oui-text-base-contrast-80\",\n \"oui-border-0 oui-outline-none focus:oui-border-2 focus:oui-border-primary-darken\",\n \"oui-placeholder-base-contrast-20\",\n hint.length > 0 &&\n \"oui-outline-1 oui-outline-danger focus:oui-outline-none\",\n )}\n value={ipText}\n onChange={(e) => {\n setIpText(e.target.value);\n }}\n style={{\n resize: \"none\",\n }}\n />\n {hint.length > 0 && (\n <Flex gap={1} className=\"oui-relative\">\n <div\n className={cn(\n \"oui-absolute oui-top-[10px]\",\n \"oui-size-1 oui-rounded-full oui-bg-danger\",\n )}\n />\n <Text color=\"danger\" size=\"xs\" className=\"oui-ml-2\">\n {hint}\n </Text>\n </Flex>\n )}\n </Flex>\n <Statistic\n label={\n <Text size=\"xs\" intensity={54}>\n {t(\"portfolio.apiKey.permissions\")}\n </Text>\n }\n className=\"oui-w-full\"\n >\n <Flex\n direction={\"row\"}\n gap={6}\n itemAlign={\"start\"}\n className=\"oui-mt-2\"\n >\n <Checkbox\n disabled\n size={18}\n checked={read}\n onCheckedChange={(e) => setRead(e as boolean)}\n label={t(\"portfolio.apiKey.permissions.read\")}\n />\n <Checkbox\n disabled\n size={18}\n checked={trade}\n onCheckedChange={(e) => setTrade(e as boolean)}\n label={t(\"portfolio.apiKey.permissions.trading\")}\n />\n </Flex>\n </Statistic>\n </Flex>\n </SimpleDialog>\n );\n};\n","import React, { useState } from \"react\";\nimport { APIKeyItem } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n Box,\n Button,\n Card,\n CopyIcon,\n Flex,\n PlusIcon,\n Column,\n Text,\n Tooltip,\n} from \"@orderly.network/ui\";\nimport {\n AuthGuardEmpty,\n AuthGuardDataTable,\n AuthGuardTooltip,\n} from \"@orderly.network/ui-connector\";\nimport {\n type ApiManagerScriptReturns,\n capitalizeFirstChar,\n} from \"./apiManager.script\";\n\nconst LazyCreateAPIKeyDialog = React.lazy(() =>\n import(\"./dialog/createApiKey\").then((mod) => {\n return { default: mod.CreateAPIKeyDialog };\n }),\n);\n\nconst LazyCreatedAPIKeyDialog = React.lazy(() =>\n import(\"./dialog/createdApiKey\").then((mod) => {\n return { default: mod.CreatedAPIKeyDialog };\n }),\n);\n\nconst LazyDeleteAPIKeyDialog = React.lazy(() =>\n import(\"./dialog/deleteApiKey\").then((mod) => {\n return { default: mod.DeleteAPIKeyDialog };\n }),\n);\n\nconst LazyEditAPIKeyDialog = React.lazy(() =>\n import(\"./dialog/editApiKey\").then((mod) => {\n return { default: mod.EditAPIKeyDialog };\n }),\n);\n\nexport const APIManager: React.FC<ApiManagerScriptReturns> = (props) => {\n const { t } = useTranslation();\n return (\n <Card\n title={t(\"portfolio.apiKeys\")}\n id=\"portfolio-apikey-manager\"\n className=\"oui-bg-base-9 oui-font-semibold\"\n >\n <Flex\n direction={\"column\"}\n gap={4}\n width={\"100%\"}\n className=\"oui-font-semibold\"\n >\n <AccountInfo {...props} />\n <Subtitle {...props} />\n </Flex>\n <div>\n <KeyList {...props} />\n <React.Suspense fallback={null}>\n <LazyCreateAPIKeyDialog {...props} />\n </React.Suspense>\n <React.Suspense fallback={null}>\n <LazyCreatedAPIKeyDialog {...props} />\n </React.Suspense>\n </div>\n </Card>\n );\n};\n\nconst AccountInfo: React.FC<ApiManagerScriptReturns> = (props) => {\n const { t } = useTranslation();\n return (\n <Flex\n width={\"100%\"}\n gap={4}\n className=\"oui-border-t-2 oui-border-line-6 oui-pt-4\"\n >\n <Flex\n py={2}\n px={4}\n direction={\"column\"}\n itemAlign={\"start\"}\n r=\"xl\"\n gradient=\"neutral\"\n angle={27}\n border\n className=\"oui-w-1/2\"\n >\n <Text size=\"xs\" intensity={36}>\n {t(\"common.accountId\")}\n </Text>\n <Text.formatted\n size=\"base\"\n inlist={80}\n rule={\"address\"}\n copyable={props.accountId !== \"--\"}\n copyIconSize={16}\n onCopy={props.onCopyAccountId}\n copyIconTestid=\"oui-testid-apiKey-accountInfo-accountId-copy-btn\"\n >\n {props.accountId}\n </Text.formatted>\n </Flex>\n <Flex\n py={2}\n px={4}\n direction={\"column\"}\n itemAlign={\"start\"}\n r=\"xl\"\n gradient=\"neutral\"\n angle={27}\n border\n className=\"oui-w-1/2\"\n >\n <Text size=\"xs\" intensity={36}>\n {t(\"portfolio.apiKey.uid\")}\n </Text>\n <Text size=\"base\" inlist={80}>\n {props.userId}\n </Text>\n </Flex>\n </Flex>\n );\n};\n\nconst Subtitle: React.FC<ApiManagerScriptReturns> = (props) => {\n const { t } = useTranslation();\n return (\n <Flex\n width={\"100%\"}\n direction={\"row\"}\n className=\"oui-text-sm oui-border-b-2 oui-border-line-6 oui-pb-4\"\n >\n <Flex direction={\"column\"} itemAlign={\"start\"} width={\"100%\"} gap={1}>\n <Text intensity={54}>{t(\"portfolio.apiKey.description\")}</Text>\n <Flex\n itemAlign={\"center\"}\n className=\"oui-text-primary-light oui-fill-primary-light hover:oui-text-primary-darken oui-cursor-pointer oui-text-2xs md:oui-text-xs xl:oui-text-sm\"\n onClick={props.onReadApiGuide}\n >\n <Text>{t(\"portfolio.apiKey.readApiGuide\")}</Text>\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"currentColor\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path d=\"M4.008 7.995c0-.368.298-.666.666-.666H9.71L7.733 5.331l.937-.936 3.143 3.122c.13.13.195.304.195.479a.67.67 0 0 1-.195.478L8.67 11.596l-.937-.937 1.978-1.998H4.674a.666.666 0 0 1-.666-.666\" />\n </svg>\n </Flex>\n </Flex>\n <AuthGuardTooltip\n side=\"top\"\n tooltip={{\n connectWallet: t(\"portfolio.apiKey.create.connectWallet.tooltip\"),\n signIn: t(\"portfolio.apiKey.create.createAccount.tooltip\"),\n enableTrading: t(\"portfolio.apiKey.create.enableTrading.tooltip\"),\n wrongNetwork: t(\"portfolio.apiKey.create.wrongNetwork.tooltip\"),\n }}\n >\n <Button\n size=\"md\"\n icon={<PlusIcon />}\n variant=\"contained\"\n color=\"primary\"\n onClick={props.onCreateApiKey}\n disabled={!props.canCreateApiKey}\n // className=\"disabled:oui-cursor-default\"\n data-testid=\"oui-testid-apiKey-createApiKey-btn\"\n >\n {t(\"portfolio.apiKey.create.dialog.title\")}\n </Button>\n </AuthGuardTooltip>\n </Flex>\n );\n};\n\nconst KeyList: React.FC<ApiManagerScriptReturns> = (props) => {\n const { t } = useTranslation();\n const columns: Column<APIKeyItem>[] = [\n {\n title: t(\"portfolio.apiKey.column.apiKey\"),\n dataIndex: \"orderly_key\",\n width: 150,\n render: (value) => {\n return (\n <Text.formatted\n rule={\"\"}\n copyable\n copyIconSize={16}\n onCopy={() => {\n props.onCopyApiKey?.(value);\n }}\n >\n {formatKey(value)}\n </Text.formatted>\n );\n },\n },\n {\n title: t(\"portfolio.apiKey.column.permissionType\"),\n dataIndex: \"scope\",\n render: (value) =>\n value\n ?.split(\",\")\n .map((e: any) => capitalizeFirstChar(`${e}`))\n .join(\", \"),\n },\n {\n title: t(\"portfolio.apiKey.column.restrictedIP\"),\n dataIndex: \"ip_restriction_list\",\n render: (value) => {\n let ip = value.join(\",\");\n if (ip.length === 0) {\n ip = \"--\";\n }\n return (\n <Tooltip content={ip} className=\"oui-max-w-[200px] oui-break-all\">\n <Flex gap={1}>\n <div className=\" oui-overflow-ellipsis oui-overflow-hidden\">\n {ip}\n </div>\n {ip !== \"--\" && (\n <Box width={16} height={16} className=\"oui-cursor-pointer\">\n <CopyIcon\n color=\"white\"\n opacity={0.54}\n size={16}\n onClick={(e) => {\n navigator.clipboard.writeText(ip);\n props?.onCopyIP();\n }}\n />\n </Box>\n )}\n </Flex>\n </Tooltip>\n );\n },\n },\n {\n title: t(\"portfolio.apiKey.column.expirationDate\"),\n dataIndex: \"expiration\",\n render: (value) => (\n <Text.formatted rule={\"date\"} formatString=\"yyyy-MM-dd\">\n {value}\n </Text.formatted>\n ),\n },\n {\n title: \"\",\n type: \"action\",\n dataIndex: \"action\",\n width: 120,\n render: (_, item) => {\n return (\n <Flex direction={\"row\"} gap={2}>\n <EditButton\n item={item}\n onUpdate={props.doEdit}\n verifyIP={props.verifyIP}\n />\n <DeleteButton item={item} onDelete={props.doDelete} />\n </Flex>\n );\n },\n },\n ];\n\n return (\n <AuthGuardDataTable\n bordered\n columns={columns}\n loading={props.isLoading}\n dataSource={props.keys}\n emptyView={<AuthGuardEmpty />}\n pagination={props.pagination}\n manualPagination={false}\n />\n );\n};\n\nconst EditButton: React.FC<{\n item: APIKeyItem;\n onUpdate: (item: APIKeyItem, ip?: string) => Promise<void>;\n verifyIP: (ip: string) => string;\n}> = (props) => {\n const { item, onUpdate, verifyIP } = props;\n const [open, setOpen] = useState(false);\n const { t } = useTranslation();\n\n return (\n <>\n <Button\n size=\"xs\"\n color=\"primary\"\n variant=\"contained\"\n onClick={(e) => {\n e.stopPropagation();\n setOpen(true);\n }}\n data-testid=\"oui-testid-apiKey-keyList-edit-btn\"\n >\n {t(\"common.edit\")}\n </Button>\n {open && (\n <React.Suspense fallback={null}>\n <LazyEditAPIKeyDialog\n item={item}\n open={open}\n setOpen={setOpen}\n onUpdate={onUpdate}\n verifyIP={verifyIP}\n />\n </React.Suspense>\n )}\n </>\n );\n};\n\nconst DeleteButton: React.FC<{\n item: APIKeyItem;\n onDelete: (item: APIKeyItem) => Promise<void>;\n}> = (props) => {\n const { item, onDelete } = props;\n const [open, setOpen] = useState(false);\n const { t } = useTranslation();\n return (\n <>\n <Button\n size=\"xs\"\n color=\"gray\"\n variant=\"contained\"\n onClick={(e) => {\n e.stopPropagation();\n setOpen(true);\n }}\n data-testid=\"oui-testid-apiKey-keyList-delete-btn\"\n >\n {t(\"common.delete\")}\n </Button>\n {open && (\n <React.Suspense fallback={null}>\n <LazyDeleteAPIKeyDialog\n item={item}\n open={open}\n setOpen={setOpen}\n onDelete={onDelete}\n />\n </React.Suspense>\n )}\n </>\n );\n};\n\nexport function formatKey(value: string): string {\n if (typeof value === \"undefined\") {\n return \"-\";\n }\n const key = `${value}`.slice(0, Math.min(value.length, 12));\n return `${key}***`;\n}\n","import { FC, PropsWithChildren } from \"react\";\nimport { useScreen } from \"@orderly.network/ui\";\nimport { usePortfolioLayoutScript } from \"./layout.script\";\nimport { PortfolioLayout, PortfolioLayoutProps } from \"./layout.ui\";\nimport { PortfolioLayoutMobile } from \"./layout.ui.mobile\";\n\nexport type PortfolioLayoutWidgetProps = PortfolioLayoutProps;\n\nexport const PortfolioLayoutWidget: FC<\n PropsWithChildren<PortfolioLayoutWidgetProps>\n> = (props) => {\n const state = usePortfolioLayoutScript({\n current: props.leftSideProps?.current,\n });\n const { isMobile } = useScreen();\n\n return (\n <>\n {isMobile ? (\n // @ts-ignore\n <PortfolioLayoutMobile {...state} {...props} />\n ) : (\n <PortfolioLayout {...state} {...props} />\n )}\n </>\n );\n};\n","import { useEffect, useMemo, useState } from \"react\";\nimport { useMediaQuery } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { SideMenuItem, useScaffoldContext } from \"@orderly.network/ui-scaffold\";\n\nexport enum PortfolioLeftSidebarPath {\n Overview = \"/portfolio\",\n Positions = \"/portfolio/positions\",\n Orders = \"/portfolio/orders\",\n Assets = \"/portfolio/assets\",\n FeeTier = \"/portfolio/feeTier\",\n ApiKey = \"/portfolio/apiKey\",\n Setting = \"/portfolio/setting\",\n History = \"/portfolio/history\",\n}\n\nexport type UseLayoutBuilderOptions = {\n current?: string;\n};\n\nexport const usePortfolioLayoutScript = (props: UseLayoutBuilderOptions) => {\n const { routerAdapter } = useScaffoldContext();\n const [current, setCurrent] = useState(\n props.current ?? routerAdapter?.currentPath ?? \"/portfolio\",\n );\n const { t } = useTranslation();\n\n useEffect(() => {\n if (props.current || routerAdapter?.currentPath) {\n setCurrent(props.current || routerAdapter?.currentPath || \"/portfolio\");\n }\n }, [props.current, routerAdapter?.currentPath]);\n\n const items = useMemo(() => {\n return [\n {\n name: t(\"common.overview\"),\n href: PortfolioLeftSidebarPath.Overview,\n icon: (\n <svg\n width=\"18\"\n height=\"18\"\n viewBox=\"0 0 18 18\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M5.24316 2.19727C3.58641 2.19727 2.24316 3.54044 2.24316 5.19727V12.6973C2.24316 14.3541 3.58641 15.6973 5.24316 15.6973H12.7432C14.3999 15.6973 15.7432 14.3541 15.7432 12.6973V5.19727C15.7432 3.54044 14.3999 2.19727 12.7432 2.19727H5.24316ZM5.24316 3.69727H12.7432C13.5719 3.69727 14.2432 4.36882 14.2432 5.19727V12.6973C14.2432 13.2484 13.9319 13.734 13.4894 13.9947C13.3454 12.2235 11.4427 11.1973 8.99316 11.1973C6.54366 11.1973 4.60341 12.251 4.48566 13.9997C4.04241 13.739 3.74316 13.2484 3.74316 12.6973V5.19727C3.74316 4.36882 4.41441 3.69727 5.24316 3.69727ZM8.99316 5.19727C7.54341 5.19727 6.36816 6.37252 6.36816 7.82227C6.36816 9.27202 7.54341 10.4473 8.99316 10.4473C10.4429 10.4473 11.6182 9.27202 11.6182 7.82227C11.6182 6.37252 10.4429 5.19727 8.99316 5.19727Z\"\n className=\"oui-fill-current group-data-[actived=true]:oui-fill-[url(#side-menu-gradient)]\"\n />\n </svg>\n ),\n },\n {\n name: t(\"common.positions\"),\n href: PortfolioLeftSidebarPath.Positions,\n icon: (\n <svg\n width=\"18\"\n height=\"18\"\n viewBox=\"0 0 18 18\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M4.51 3.021a3 3 0 0 0-3 3v6a3 3 0 0 0 3 3h9a3 3 0 0 0 3-3v-6a3 3 0 0 0-3-3zm2.25 3a.76.76 0 0 1 .54.211.77.77 0 0 1 0 1.078l-.75.75a.77.77 0 0 1-.54.211h-.75a.75.75 0 0 1 0-1.5h.422l.54-.539a.76.76 0 0 1 .539-.21m3 .75h3a.75.75 0 0 1 0 1.5h-3a.75.75 0 0 1 0-1.5m-3 2.25a.76.76 0 0 1 .54.211.77.77 0 0 1 0 1.079l-.75.75a.77.77 0 0 1-.54.21h-.75a.75.75 0 0 1 0-1.5h.422l.54-.539a.76.76 0 0 1 .539-.21m3 .75h3a.75.75 0 0 1 0 1.5h-3a.75.75 0 0 1 0-1.5\"\n className=\"oui-fill-current group-data-[actived=true]:oui-fill-[url(#side-menu-gradient)]\"\n />\n </svg>\n ),\n },\n {\n name: t(\"common.orders\"),\n href: PortfolioLeftSidebarPath.Orders,\n icon: (\n <svg\n width=\"18\"\n height=\"18\"\n viewBox=\"0 0 18 18\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M5.693 1.5C4.229 1.5 3.02 2.61 3.02 4.006v9.984c0 1.398 1.208 2.508 2.672 2.508h6.657c1.463 0 2.671-1.11 2.671-2.508V6.726c0-2.672-2.579-5.227-5.25-5.227zm4.828 1.593c1.33.352 2.562 1.58 2.906 2.906h-1.734c-.667 0-1.172-.472-1.172-1.008zm-3.75 2.906h.75a.75.75 0 0 1 0 1.5h-.75a.75.75 0 0 1 0-1.5m0 3h4.5a.75.75 0 0 1 0 1.5h-4.5a.75.75 0 0 1 0-1.5m0 3h4.5a.75.75 0 0 1 0 1.5h-4.5a.75.75 0 0 1 0-1.5\"\n className=\"oui-fill-current group-data-[actived=true]:oui-fill-[url(#side-menu-gradient)]\"\n />\n </svg>\n ),\n },\n {\n name: t(\"common.assets\"),\n href: PortfolioLeftSidebarPath.Assets,\n icon: (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"18\"\n height=\"18\"\n viewBox=\"0 0 18 18\"\n fill=\"none\"\n >\n <path\n d=\"M9 1.5C4.85 1.5 1.5 4.85 1.5 9C1.5 13.15 4.85 16.5 9 16.5C13.15 16.5 16.5 13.15 16.5 9C16.5 4.85 13.15 1.5 9 1.5ZM8.17529 3.75H9.67529V4.94971L10.125 5.17529C10.35 5.32529 10.5756 5.47471 10.7256 5.69971C10.8756 5.92471 11.0256 6.14971 11.1006 6.44971C11.1756 6.74971 11.25 7.05029 11.25 7.42529H9.82471C9.82471 6.97529 9.75059 6.67471 9.60059 6.44971C9.45059 6.22471 9.3 6.14941 9 6.14941C8.85 6.14941 8.7 6.15059 8.625 6.22559L8.39941 6.44971C8.32441 6.52471 8.325 6.675 8.25 6.75C8.175 6.825 8.17529 6.975 8.17529 7.125C8.17529 7.275 8.25 7.35 8.25 7.5C8.25 7.65 8.32441 7.72529 8.39941 7.80029C8.47441 7.95029 8.54971 8.02559 8.69971 8.10059C8.77471 8.17559 8.92441 8.24971 9.14941 8.32471C9.44941 8.47471 9.75059 8.62441 9.97559 8.77441C10.2756 8.92441 10.4994 9.07529 10.6494 9.30029C10.8744 9.52529 11.0256 9.75059 11.1006 9.97559C11.1756 10.2006 11.25 10.5 11.25 10.875C11.25 11.25 11.1756 11.5494 11.1006 11.7744C11.0256 12.0744 10.8756 12.2247 10.7256 12.4497C10.5756 12.5997 10.35 12.7494 10.125 12.8994C9.975 12.9744 9.9 13.0503 9.75 13.0503V14.25H8.25V12.9756C8.1 12.9006 7.95029 12.8997 7.80029 12.8247C7.50029 12.7497 7.35 12.6 7.125 12.375C6.975 12.225 6.82529 11.925 6.67529 11.625C6.60029 11.25 6.52441 10.8753 6.52441 10.4253H8.02441C8.02441 10.6503 8.02559 10.8756 8.10059 11.1006C8.17559 11.3256 8.24971 11.4753 8.32471 11.5503C8.39971 11.6253 8.475 11.6994 8.625 11.7744C8.775 11.8494 8.85 11.8506 9 11.8506C9.15 11.8506 9.225 11.8494 9.375 11.7744C9.525 11.6994 9.60029 11.6253 9.67529 11.5503C9.75029 11.4753 9.74971 11.4 9.82471 11.25C9.89971 11.175 9.89941 11.025 9.89941 10.875C9.89941 10.725 9.82471 10.575 9.82471 10.5C9.82471 10.425 9.75029 10.2747 9.67529 10.1997C9.60029 10.0497 9.525 9.97441 9.375 9.89941L8.92529 9.67529C8.62529 9.52529 8.32559 9.37559 8.10059 9.22559C7.80059 9.07559 7.57529 8.92471 7.42529 8.69971C7.20029 8.54971 7.05059 8.32441 6.97559 8.02441C6.90059 7.79941 6.82471 7.5 6.82471 7.125C6.82471 6.825 6.82441 6.52529 6.89941 6.30029C7.04941 6.07529 7.12559 5.85 7.35059 5.625C7.50059 5.4 7.65029 5.25029 7.80029 5.17529C7.95029 5.10029 8.02529 5.02441 8.17529 5.02441V3.75Z\"\n className=\"oui-fill-current group-data-[actived=true]:oui-fill-[url(#side-menu-gradient)]\"\n />\n </svg>\n ),\n },\n {\n name: t(\"portfolio.feeTier\"),\n href: PortfolioLeftSidebarPath.FeeTier,\n icon: (\n <svg\n width=\"18\"\n height=\"18\"\n viewBox=\"0 0 18 18\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M5.99829 1.51062C4.34154 1.51062 2.99829 2.85387 2.99829 4.51062V13.5106C2.99829 15.1674 4.34154 16.5106 5.99829 16.5106H11.9983C13.655 16.5106 14.9983 15.1674 14.9983 13.5106V4.51062C14.9983 2.85387 13.655 1.51062 11.9983 1.51062H5.99829ZM5.99829 3.76062H11.9983C12.4123 3.76062 12.7483 4.09662 12.7483 4.51062V6.01062C12.7483 6.42462 12.4123 6.76062 11.9983 6.76062H5.99829C5.58429 6.76062 5.24829 6.42462 5.24829 6.01062V4.51062C5.24829 4.09662 5.58429 3.76062 5.99829 3.76062ZM5.99829 8.26062C6.41229 8.26062 6.74829 8.59662 6.74829 9.01062C6.74829 9.42462 6.41229 9.76062 5.99829 9.76062C5.58429 9.76062 5.24829 9.42462 5.24829 9.01062C5.24829 8.59662 5.58429 8.26062 5.99829 8.26062ZM8.99829 8.26062C9.41229 8.26062 9.74829 8.59662 9.74829 9.01062C9.74829 9.42462 9.41229 9.76062 8.99829 9.76062C8.58429 9.76062 8.24829 9.42462 8.24829 9.01062C8.24829 8.59662 8.58429 8.26062 8.99829 8.26062ZM11.9983 8.26062C12.4123 8.26062 12.7483 8.59662 12.7483 9.01062C12.7483 9.42462 12.4123 9.76062 11.9983 9.76062C11.5843 9.76062 11.2483 9.42462 11.2483 9.01062C11.2483 8.59662 11.5843 8.26062 11.9983 8.26062ZM5.99829 10.5106C6.41229 10.5106 6.74829 10.8466 6.74829 11.2606C6.74829 11.6746 6.41229 12.0106 5.99829 12.0106C5.58429 12.0106 5.24829 11.6746 5.24829 11.2606C5.24829 10.8466 5.58429 10.5106 5.99829 10.5106ZM8.99829 10.5106C9.41229 10.5106 9.74829 10.8466 9.74829 11.2606C9.74829 11.6746 9.41229 12.0106 8.99829 12.0106C8.58429 12.0106 8.24829 11.6746 8.24829 11.2606C8.24829 10.8466 8.58429 10.5106 8.99829 10.5106ZM11.9983 10.5106C12.4123 10.5106 12.7483 10.8466 12.7483 11.2606V13.5106C12.7483 13.9246 12.4123 14.2606 11.9983 14.2606C11.5843 14.2606 11.2483 13.9246 11.2483 13.5106V11.2606C11.2483 10.8466 11.5843 10.5106 11.9983 10.5106ZM5.99829 12.7606C6.41229 12.7606 6.74829 13.0966 6.74829 13.5106C6.74829 13.9246 6.41229 14.2606 5.99829 14.2606C5.58429 14.2606 5.24829 13.9246 5.24829 13.5106C5.24829 13.0966 5.58429 12.7606 5.99829 12.7606ZM8.99829 12.7606C9.41229 12.7606 9.74829 13.0966 9.74829 13.5106C9.74829 13.9246 9.41229 14.2606 8.99829 14.2606C8.58429 14.2606 8.24829 13.9246 8.24829 13.5106C8.24829 13.0966 8.58429 12.7606 8.99829 12.7606Z\"\n className=\"oui-fill-current group-data-[actived=true]:oui-fill-[url(#side-menu-gradient)]\"\n />\n </svg>\n ),\n },\n {\n name: t(\"portfolio.apiKeys\"),\n href: PortfolioLeftSidebarPath.ApiKey,\n icon: (\n <svg\n width=\"18\"\n height=\"18\"\n viewBox=\"0 0 18 18\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M9.02124 1.49915C7.77849 1.49915 6.77124 2.5064 6.77124 3.74915C6.77124 4.70015 7.40049 5.55517 8.26974 5.86942L8.27124 8.24915H5.27124C4.85724 8.24915 4.52124 8.58515 4.52124 8.99915L4.52048 12.1304C3.65723 12.4274 3.02124 13.2981 3.02124 14.2491C3.02124 15.4919 4.02849 16.4991 5.27124 16.4991C6.51399 16.4991 7.52124 15.4919 7.52124 14.2491C7.52124 13.2981 6.92499 12.4596 6.02949 12.1206L6.02124 9.74915H9.02124H12.0212L12.0265 12.1319C11.1257 12.4446 10.5212 13.2981 10.5212 14.2491C10.5212 15.4919 11.5285 16.4991 12.7712 16.4991C14.014 16.4991 15.0212 15.4919 15.0212 14.2491C15.0212 13.2981 14.407 12.4611 13.5272 12.1281L13.5212 8.99915C13.5212 8.58515 13.1852 8.24915 12.7712 8.24915H9.77124L9.76899 5.86639C10.642 5.55814 11.2712 4.70015 11.2712 3.74915C11.2712 2.5064 10.264 1.49915 9.02124 1.49915Z\"\n className=\"oui-fill-current group-data-[actived=true]:oui-fill-[url(#side-menu-gradient)]\"\n />\n </svg>\n ),\n },\n {\n name: t(\"portfolio.setting\"),\n href: PortfolioLeftSidebarPath.Setting,\n icon: (\n <svg\n width=\"18\"\n height=\"18\"\n viewBox=\"0 0 18 18\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M6.72601 1.84159C5.66251 2.17834 4.74527 2.7296 3.93677 3.48185C3.68702 3.7151 3.61052 4.09534 3.77252 4.39609C4.37327 5.50684 3.74476 6.69484 2.39026 6.76309C2.05801 6.78034 1.76477 7.02559 1.68677 7.34884C1.55252 7.90759 1.49927 8.37559 1.49927 8.98984C1.49927 9.50509 1.55476 10.0878 1.66351 10.6068C1.73101 10.9308 2.01302 11.1641 2.34302 11.1933C3.70652 11.3111 4.38152 12.3506 3.77252 13.6773C3.63752 13.9721 3.69902 14.3246 3.93677 14.5443C4.73327 15.2816 5.64826 15.8006 6.72601 16.1381C7.03351 16.2348 7.38076 16.1186 7.56976 15.8568C8.40376 14.7033 9.61352 14.6988 10.4055 15.8568C10.5923 16.1298 10.9343 16.2611 11.2493 16.1613C12.2895 15.8343 13.2585 15.2771 14.0618 14.5443C14.3093 14.3193 14.3745 13.9541 14.226 13.6541C13.602 12.3948 14.3198 11.2383 15.6083 11.2166C15.9503 11.2106 16.2548 10.9856 16.335 10.6541C16.4648 10.1163 16.4993 9.64759 16.4993 8.98984C16.4993 8.42434 16.4325 7.86709 16.3118 7.32559C16.2353 6.98359 15.936 6.74059 15.585 6.73984C14.3168 6.73759 13.6058 5.49109 14.226 4.39609C14.3985 4.09084 14.3445 3.71735 14.085 3.48185C13.2675 2.73935 12.2708 2.15959 11.226 1.84159C10.905 1.74409 10.5638 1.86409 10.3823 2.14609C9.65776 3.27109 8.30477 3.29135 7.59302 2.16935C7.41077 1.8821 7.05001 1.73809 6.72601 1.84159ZM8.99927 5.98984C10.656 5.98984 11.9993 7.33309 11.9993 8.98984C11.9993 10.6466 10.656 11.9898 8.99927 11.9898C7.34252 11.9898 5.99927 10.6466 5.99927 8.98984C5.99927 7.33309 7.34252 5.98984 8.99927 5.98984Z\"\n className=\"oui-fill-current group-data-[actived=true]:oui-fill-[url(#side-menu-gradient)]\"\n />\n </svg>\n ),\n },\n {\n name: t(\"trading.history\"),\n href: PortfolioLeftSidebarPath.History,\n hide: true,\n },\n ];\n }, [t]);\n\n const hideSideBar = useMediaQuery(\"(max-width: 768px)\");\n\n return {\n items,\n current,\n hideSideBar,\n onItemSelect: (item: SideMenuItem) => {\n if (typeof item.href === \"undefined\") {\n console.warn(\"Item href is not defined\");\n return;\n }\n setCurrent(item.href!);\n routerAdapter?.onRouteChange({\n href: item.href,\n name: item.name,\n });\n },\n };\n};\n\nexport const useCustomSidebarHook = () => {\n const { expanded, setExpand } = useScaffoldContext();\n\n return {\n open: expanded,\n onOpenChange: (open: boolean) => {\n setExpand(open);\n },\n };\n};\n\nexport type usePortfolioLayoutScriptType = ReturnType<\n typeof usePortfolioLayoutScript\n>;\n","import { FC, PropsWithChildren } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { cn } from \"@orderly.network/ui\";\nimport {\n ScaffoldProps,\n RouterAdapter,\n Scaffold,\n SideBar,\n SideBarProps,\n useScaffoldContext,\n} from \"@orderly.network/ui-scaffold\";\n\nexport type PortfolioLayoutProps = ScaffoldProps & {\n hideSideBar?: boolean;\n items?: SideBarProps[\"items\"];\n};\n\nexport const PortfolioLayout: FC<PropsWithChildren<PortfolioLayoutProps>> = (\n props,\n) => {\n const { children, leftSideProps, classNames, ...rest } = props;\n\n return (\n <Scaffold\n leftSidebar={\n props.hideSideBar ? null : (\n <LeftSidebar\n current={props.routerAdapter?.currentPath}\n routerAdapter={props.routerAdapter}\n items={props.items}\n {...leftSideProps}\n />\n )\n }\n routerAdapter={props.routerAdapter}\n classNames={{\n ...classNames,\n content: cn(\"oui-my-6 oui-px-3\", classNames?.content),\n topNavbar: cn(\"oui-bg-base-9\", classNames?.topNavbar),\n leftSidebar: cn(\n \"oui-rounded-xl oui-bg-base-9\",\n \"oui-m-3 oui-p-4\",\n \"oui-border oui-border-line\",\n classNames?.leftSidebar,\n ),\n }}\n {...rest}\n >\n {children}\n </Scaffold>\n );\n};\n\ntype LeftSidebarProps = SideBarProps & {\n routerAdapter?: RouterAdapter;\n};\n\nconst LeftSidebar: FC<LeftSidebarProps> = (props) => {\n const { expanded, setExpand } = useScaffoldContext();\n const { t } = useTranslation();\n return (\n <SideBar\n title={t(\"common.portfolio\")}\n {...props}\n open={expanded}\n onOpenChange={(open) => setExpand(open)}\n onItemSelect={(e) => {\n props.onItemSelect?.(e);\n props.routerAdapter?.onRouteChange?.({\n href: e.href || \"\",\n name: e.name,\n });\n }}\n />\n );\n};\n","import { FC, PropsWithChildren } from \"react\";\nimport { Flex, Box } from \"@orderly.network/ui\";\nimport {\n MainNavMobile,\n BottomNav,\n type ScaffoldProps,\n} from \"@orderly.network/ui-scaffold\";\nimport { LayoutProvider } from \"./context\";\nimport { usePortfolioLayoutScriptType } from \"./layout.script\";\n\nexport const PortfolioLayoutMobile: FC<\n PropsWithChildren<\n ScaffoldProps & usePortfolioLayoutScriptType & { current?: string }\n >\n> = (props) => {\n return (\n <LayoutProvider {...props}>\n <Flex\n direction={\"column\"}\n width={\"100%\"}\n height={\"100%\"}\n className=\"oui-h-full-screen oui-bg-base-10\"\n >\n <header className=\"oui-scaffold-topNavbar oui-sticky oui-top-0 oui-z-10 oui-w-full oui-bg-base-10\">\n <MainNavMobile\n {...props.mainNavProps}\n current={props?.current}\n subItems={props?.items}\n routerAdapter={props.routerAdapter}\n />\n </header>\n <Box className=\"oui-scaffold-container oui-min-h-[calc(100vh-44px-64px-env(safe-area-inset-bottom))] oui-w-full\">\n {props.children}\n </Box>\n <footer className=\"oui-scaffold-bottomNav oui-fixed oui-bottom-0 oui-z-10 oui-w-full oui-bg-base-9 oui-pb-[calc(env(safe-area-inset-bottom))]\">\n <BottomNav\n mainMenus={props.bottomNavProps?.mainMenus}\n current={props?.current}\n onRouteChange={props.routerAdapter?.onRouteChange}\n />\n </footer>\n </Flex>\n </LayoutProvider>\n );\n};\n","export { AssetWidget, AssetsUI } from \"./assets\";\nexport { HistoryDataGroupWidget } from \"./historyDataGroup\";\n\nexport * from \"./assetChart\";\nexport * from \"./assetHistory\";\n\nexport {\n PerformanceUI,\n PerformanceWidget,\n usePerformanceScript,\n} from \"./performance\";\n\nexport * from \"./performanceMobileDialog\";\n\nexport {\n FundingHistoryWidget,\n useFundingHistoryColumns,\n useFundingHistoryHook,\n} from \"./funding\";\n\nexport {\n DistributionHistoryWidget,\n DistributionHistoryMobile,\n DistributionHistoryDesktop,\n} from \"./distribution\";\n\nexport { OverviewPage } from \"./main\";\n\nexport { OverviewProvider } from \"./provider/overviewProvider\";\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport React from \"react\";\nimport {\n AssetLineChart,\n PnlAreaChart,\n PnLBarChart,\n PnlLineChartProps,\n} from \"@orderly.network/chart\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { Tabs, TabPanel, Flex, Text } from \"@orderly.network/ui\";\nimport type { UsePerformanceScriptReturn } from \"../performance/performance.script\";\nimport {\n PeriodType,\n useAssetsHistoryDataReturn,\n} from \"../shared/useAssetHistory\";\n\nconst responsiveProps: PnlLineChartProps[\"responsiveContainerProps\"] = {\n width: \"100%\",\n minHeight: 144,\n aspect: 2.5,\n};\n\nexport const PerformanceMobileUI: React.FC<\n Pick<\n useAssetsHistoryDataReturn & UsePerformanceScriptReturn,\n | \"data\"\n | \"curPeriod\"\n | \"aggregateValue\"\n | \"onPeriodChange\"\n | \"invisible\"\n | \"visible\"\n | \"createFakeData\"\n | \"period\"\n >\n> = (props) => {\n const { t } = useTranslation();\n const {\n data,\n aggregateValue,\n visible,\n invisible,\n curPeriod,\n period,\n onPeriodChange,\n createFakeData,\n } = props;\n\n const mergedData = data.length\n ? data\n : (createFakeData?.(\n { account_value: 0, pnl: 0 },\n { account_value: 500, pnl: 500 },\n ) as any[]);\n\n return (\n <div>\n <Tabs\n value={period}\n defaultValue={PeriodType.WEEK}\n classNames={{ tabsList: \"oui-justify-between\", trigger: \"oui-w-1/3\" }}\n onValueChange={(value) => onPeriodChange(value as PeriodType)}\n >\n <TabPanel\n title={t(\"common.select.7d\")}\n value={PeriodType.WEEK}\n className=\"oui-min-h-40\"\n >\n <AssetLineChart\n data={mergedData}\n invisible={invisible || (mergedData?.length ?? 0) <= 2}\n responsiveContainerProps={responsiveProps}\n />\n </TabPanel>\n <TabPanel\n title={t(\"common.select.30d\")}\n value={PeriodType.MONTH}\n className=\"oui-min-h-40\"\n >\n <AssetLineChart\n data={mergedData}\n invisible={invisible || (mergedData?.length ?? 0) <= 2}\n responsiveContainerProps={responsiveProps}\n />\n </TabPanel>\n <TabPanel\n title={t(\"common.select.90d\")}\n value={PeriodType.QUARTER}\n className=\"oui-min-h-40\"\n >\n <AssetLineChart\n data={mergedData}\n invisible={invisible || (mergedData?.length ?? 0) <= 2}\n responsiveContainerProps={responsiveProps}\n />\n </TabPanel>\n </Tabs>\n <Flex justify=\"between\" itemAlign=\"center\" gap={2} my={4}>\n <Flex\n gap={1}\n direction=\"column\"\n itemAlign=\"start\"\n className=\"oui-w-1/3 oui-rounded-lg oui-bg-base-7 oui-px-2 oui-py-1.5\"\n >\n <Text className=\"oui-truncate\" intensity={36} size=\"2xs\">\n {t(\"portfolio.overview.performance.roi\", { period: curPeriod })}\n </Text>\n <Text.numeral size=\"sm\" visible={visible} rule=\"percentages\" coloring>\n {invisible ? \"--\" : aggregateValue.roi}\n </Text.numeral>\n </Flex>\n <Flex\n gap={1}\n direction=\"column\"\n itemAlign=\"start\"\n className=\"oui-w-1/3 oui-rounded-lg oui-bg-base-7 oui-px-2 oui-py-1.5\"\n >\n <Text className=\"oui-truncate\" intensity={36} size=\"2xs\">\n {t(\"portfolio.overview.performance.pnl\", { period: curPeriod })}\n </Text>\n <Text.numeral size=\"sm\" visible={visible} coloring showIdentifier>\n {invisible ? \"--\" : aggregateValue.pnl}\n </Text.numeral>\n </Flex>\n <Flex\n gap={1}\n direction=\"column\"\n itemAlign=\"start\"\n className=\"oui-w-1/3 oui-rounded-lg oui-bg-base-7 oui-px-2 oui-py-1.5\"\n >\n <Text className=\"oui-truncate\" intensity={36} size=\"2xs\">\n {t(\"portfolio.overview.performance.volume\", { period: curPeriod })}\n </Text>\n <Text.numeral size=\"sm\" visible={visible} coloring={false}>\n {invisible ? \"--\" : aggregateValue.vol}\n </Text.numeral>\n </Flex>\n </Flex>\n <Tabs defaultValue={\"dailyPnl\"}>\n <TabPanel\n value={\"dailyPnl\"}\n title={t(\"portfolio.overview.performance.dailyPnl\")}\n className=\"oui-min-h-40\"\n >\n <PnLBarChart\n data={mergedData}\n invisible={invisible || (mergedData?.length ?? 0) <= 2}\n responsiveContainerProps={responsiveProps}\n />\n </TabPanel>\n <TabPanel\n value={\"cumulativePnl\"}\n title={t(\"portfolio.overview.performance.cumulativePnl\")}\n className=\"oui-min-h-40\"\n >\n <PnlAreaChart\n data={mergedData}\n invisible={invisible || (mergedData?.length ?? 0) <= 2}\n responsiveContainerProps={responsiveProps}\n />\n </TabPanel>\n </Tabs>\n </div>\n );\n};\n","import React from \"react\";\nimport { pick } from \"ramda\";\nimport { i18n } from \"@orderly.network/i18n\";\nimport { registerSimpleDialog, registerSimpleSheet } from \"@orderly.network/ui\";\nimport { usePerformanceScript } from \"..\";\nimport { localKey } from \"../provider/overviewProvider\";\nimport { useAssetsHistoryData } from \"../shared/useAssetHistory\";\nimport { PerformanceMobileUI } from \"./performance.ui\";\n\nexport const PerformanceMobileWidget: React.FC = () => {\n const state = useAssetsHistoryData(localKey, { isRealtime: true });\n const { visible, invisible } = usePerformanceScript();\n return (\n <PerformanceMobileUI\n {...pick(\n [\n \"data\",\n \"curPeriod\",\n \"aggregateValue\",\n \"onPeriodChange\",\n \"createFakeData\",\n \"period\",\n ],\n state,\n )}\n visible={visible}\n invisible={invisible}\n />\n );\n};\n\nexport const PerformanceMobileSheetId = \"PerformanceMobileSheetId\";\n\nexport const PerformanceMobileDialogId = \"PerformanceMobileDialogId\";\n\nregisterSimpleSheet(PerformanceMobileSheetId, PerformanceMobileWidget, {\n title: () => i18n.t(\"portfolio.overview.performance\"),\n});\n\nregisterSimpleDialog(PerformanceMobileDialogId, PerformanceMobileWidget, {\n title: () => i18n.t(\"portfolio.overview.performance\"),\n classNames: {\n content: \"oui-w-[420px]\",\n },\n});\n","import { FC, PropsWithChildren, useMemo } from \"react\";\nimport { TWType } from \"@orderly.network/hooks\";\nimport { useRewardsData } from \"../mobile/useRewardsData.script\";\nimport { useAssetsHistoryData } from \"../shared/useAssetHistory\";\nimport { OverviewContext, OverviewContextState } from \"./overviewContext\";\n\nexport const localKey = \"portfolio_performance_period\";\n\nexport const OverviewProvider: FC<PropsWithChildren<{ type?: TWType }>> = (\n props,\n) => {\n const { type, children } = props;\n const state = useAssetsHistoryData(localKey, { isRealtime: true });\n const rewardsData = useRewardsData({ type: type });\n\n const memoizedValue = useMemo<OverviewContextState>(() => {\n return {\n ...state,\n type: type,\n ...rewardsData,\n };\n }, [state, type, rewardsData]);\n\n return (\n <OverviewContext.Provider value={memoizedValue}>\n {children}\n </OverviewContext.Provider>\n );\n};\n","import { useMemo, useRef, useEffect } from \"react\";\nimport {\n useAllBrokers,\n useConfig,\n useCurEpochEstimate,\n useEpochInfo,\n useGetClaimed,\n useAccount,\n RefferalAPI,\n usePrivateQuery,\n noCacheConfig,\n} from \"@orderly.network/hooks\";\nimport { DistributionId, TWType } from \"@orderly.network/hooks\";\nimport { useAppContext } from \"@orderly.network/react-app\";\nimport { AccountStatusEnum } from \"@orderly.network/types\";\nimport { useOverviewContext } from \"../provider/overviewContext\";\n\nexport const useRewardsData = ({ type = TWType.normal }: { type?: TWType }) => {\n const totalOrderClaimedReward = useGetClaimed(\n type === TWType.mm ? DistributionId.mmOrder : DistributionId.order,\n );\n const [curEpochEstimate] = useCurEpochEstimate(type);\n const [brokers] = useAllBrokers();\n const { state } = useAccount();\n const { data, mutate } = usePrivateQuery<RefferalAPI.ReferralInfo>(\n \"/v1/referral/info\",\n { revalidateOnFocus: true, errorRetryCount: 3, ...noCacheConfig },\n );\n\n const epochList = useEpochInfo(type as TWType);\n const brokerId = useConfig(\"brokerId\");\n\n const brokerName = useMemo(() => {\n return brokers?.[brokerId];\n }, [brokerId, brokers]);\n\n const lastStete = useRef<AccountStatusEnum>(AccountStatusEnum.NotConnected);\n\n const timerRef = useRef<ReturnType<typeof setTimeout> | null>(null);\n\n useEffect(() => {\n if (lastStete.current !== state.status) {\n lastStete.current = state.status;\n timerRef.current = setTimeout(() => {\n mutate();\n }, 1000);\n }\n return () => {\n if (timerRef.current) {\n clearTimeout(timerRef.current);\n }\n };\n }, [state.status]);\n\n return {\n totalOrderClaimedReward,\n curEpochEstimate,\n epochList,\n brokerName,\n referralInfo: data,\n };\n};\n\nexport const useRewardsDataScript = () => {\n const {\n totalOrderClaimedReward,\n curEpochEstimate,\n epochList,\n brokerName,\n referralInfo,\n } = useOverviewContext();\n const { state } = useAccount();\n const { wrongNetwork } = useAppContext();\n const isSignIn =\n state.status === AccountStatusEnum.EnableTrading ||\n state.status === AccountStatusEnum.EnableTradingWithoutConnected;\n\n return {\n totalOrderClaimedReward,\n curEpochEstimate,\n epochList,\n brokerName,\n isSignIn,\n referralInfo,\n wrongNetwork,\n };\n};\n\nexport type UseRewardsDataReturn = ReturnType<typeof useRewardsData>;\n","import React from \"react\";\nimport { Grid, useScreen } from \"@orderly.network/ui\";\nimport { MobileOverview } from \"./mobile\";\nimport { OverviewProvider } from \"./provider/overviewProvider\";\n\nconst LazyAssetWidget = React.lazy(() =>\n import(\"./assets\").then((mod) => {\n return { default: mod.AssetWidget };\n }),\n);\n\nconst LazyAssetsChartWidget = React.lazy(() =>\n import(\"./assetChart\").then((mod) => {\n return { default: mod.AssetsChartWidget };\n }),\n);\n\nconst LazyPerformanceWidget = React.lazy(() =>\n import(\"./performance\").then((mod) => {\n return { default: mod.PerformanceWidget };\n }),\n);\n\nconst LazyHistoryDataGroupWidget = React.lazy(() =>\n import(\"./historyDataGroup\").then((mod) => {\n return { default: mod.HistoryDataGroupWidget };\n }),\n);\n\nexport const OverviewPage: React.FC = () => {\n const { isMobile } = useScreen();\n return (\n <OverviewProvider>\n {isMobile ? (\n <MobileOverview />\n ) : (\n <Grid cols={2} gap={4}>\n <React.Suspense fallback={null}>\n <LazyAssetWidget />\n </React.Suspense>\n <React.Suspense fallback={null}>\n <LazyAssetsChartWidget />\n </React.Suspense>\n <Grid.span colSpan={2}>\n <React.Suspense fallback={null}>\n <LazyPerformanceWidget />\n </React.Suspense>\n </Grid.span>\n <Grid.span colSpan={2}>\n <React.Suspense fallback={null}>\n <LazyHistoryDataGroupWidget />\n </React.Suspense>\n </Grid.span>\n </Grid>\n )}\n </OverviewProvider>\n );\n};\n","import React from \"react\";\nimport { ENVType, useGetEnv } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { useAppContext } from \"@orderly.network/react-app\";\nimport { Flex } from \"@orderly.network/ui\";\nimport { DepositStatusWidget } from \"@orderly.network/ui-transfer\";\nimport { useLayoutContext } from \"../../../layout/context\";\nimport { useAssetScript } from \"../assets\";\nimport { PortfolioChartsMobileWidget } from \"../portfolioChartsMobile\";\nimport { AccountStatusMobile } from \"./accountStatus.ui.mobile\";\nimport { AffiliateCardMobile } from \"./affiliateCard.ui.mobile\";\nimport { PortfolioHandleMobile } from \"./portfolioHandle.ui.mobile\";\nimport { PortfolioValueMobile } from \"./portfolioVaule.ui.mobile\";\nimport { SettingRouterMobile } from \"./settingRouter.ui.mobile\";\nimport { TraderCardMobile } from \"./traderCard.ui.mobile\";\n// import { TradingRewardsCardMobile } from \"./tradingRewardsCard.ui.mobile\";\nimport { useRewardsDataScript } from \"./useRewardsData.script\";\n\nexport const MobileOverview: React.FC = () => {\n const {\n canTrade,\n onWithdraw,\n onDeposit,\n portfolioValue,\n unrealPnL,\n unrealROI,\n visible,\n namespace,\n toggleVisible,\n onTransfer,\n isMainAccount,\n hasSubAccount,\n } = useAssetScript();\n const { t } = useTranslation();\n const rewardsData = useRewardsDataScript();\n const layoutContext = useLayoutContext();\n const { onRouteChange } = useAppContext();\n const env = useGetEnv();\n\n const goToClaim = () => {\n const url = `https://${\n env !== ENVType.prod ? `${env}-` : \"\"\n }app.orderly.network/tradingRewards`;\n window.open(url, \"_blank\");\n };\n\n const navigateToPortfolioHistory =\n typeof onRouteChange === \"function\"\n ? () => {\n onRouteChange({\n href: \"/portfolio/history\",\n name: t(\"trading.history\"),\n });\n }\n : undefined;\n\n // console.log('rewards data', rewardsData, layoutContext, props);\n\n return (\n <>\n <div className=\"oui-my-1 oui-px-3\">\n <AccountStatusMobile />\n </div>\n <Flex\n direction={\"column\"}\n width={\"100%\"}\n height={\"100%\"}\n className=\"oui-gap-5 oui-px-3\"\n >\n <Flex direction=\"column\" width=\"100%\" gapY={2}>\n <PortfolioValueMobile\n toggleVisible={toggleVisible}\n portfolioValue={portfolioValue}\n unrealPnL={unrealPnL}\n unrealROI={unrealROI}\n visible={visible}\n canTrade={canTrade}\n namespace={namespace}\n routerAdapter={layoutContext?.routerAdapter}\n />\n <DepositStatusWidget onClick={navigateToPortfolioHistory} />\n <PortfolioChartsMobileWidget />\n </Flex>\n <PortfolioHandleMobile\n disabled={!canTrade}\n onWithdraw={onWithdraw}\n onDeposit={onDeposit}\n onTransfer={onTransfer}\n isMainAccount={isMainAccount}\n routerAdapter={layoutContext?.routerAdapter}\n hasSubAccount={hasSubAccount}\n />\n <Flex\n direction={\"row\"}\n width={\"100%\"}\n height={\"100%\"}\n className=\"oui-gap-3\"\n >\n {/* Disable trading rewards card for now. Set to row */}\n <Flex direction=\"row\" className=\"oui-flex-1 oui-gap-3\">\n <AffiliateCardMobile\n referralInfo={rewardsData.referralInfo}\n routerAdapter={layoutContext?.routerAdapter}\n />\n <TraderCardMobile\n referralInfo={rewardsData.referralInfo}\n routerAdapter={layoutContext?.routerAdapter}\n />\n </Flex>\n {/* <Flex direction=\"column\" className=\"oui-flex-1\">\n <TradingRewardsCardMobile {...rewardsData} goToClaim={goToClaim} />\n </Flex> */}\n </Flex>\n <SettingRouterMobile routerAdapter={layoutContext?.routerAdapter} />\n </Flex>\n </>\n );\n};\n","import React from \"react\";\nimport { EMPTY_LIST } from \"@orderly.network/types\";\nimport { useAssetsChartScript } from \"../assetChart\";\nimport { usePortfolioChartsState } from \"./portfolioChartsMobile.script\";\nimport { PortfolioChartsMobileUI } from \"./portfolioChartsMobile.ui\";\n\nexport const PortfolioChartsMobileWidget: React.FC = () => {\n const { data, invisible } = useAssetsChartScript();\n const state = usePortfolioChartsState();\n return (\n <PortfolioChartsMobileUI\n data={data || EMPTY_LIST}\n invisible={invisible}\n {...state}\n />\n );\n};\n","import { useCallback } from \"react\";\nimport { useLocalStorage, usePositionStream } from \"@orderly.network/hooks\";\nimport { modal } from \"@orderly.network/ui\";\nimport { ORDERLY_ASSETS_VISIBLE_KEY } from \"../../assets/type\";\nimport { PerformanceMobileSheetId } from \"../performanceMobileDialog\";\n\nexport const usePortfolioChartsState = () => {\n const [data] = usePositionStream();\n const [visible, setVisible] = useLocalStorage<boolean>(\n ORDERLY_ASSETS_VISIBLE_KEY,\n true,\n );\n const onPerformanceClick = useCallback(() => {\n return modal.show(PerformanceMobileSheetId);\n }, []);\n return {\n unrealPnL: data?.aggregated.total_unreal_pnl,\n unrealROI: data?.totalUnrealizedROI,\n visible: visible as boolean,\n setVisible: setVisible,\n onPerformanceClick: onPerformanceClick,\n } as const;\n};\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport React, { useId } from \"react\";\nimport { Area, AreaChart } from \"@orderly.network/chart\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { EMPTY_LIST } from \"@orderly.network/types\";\nimport { ChevronRightIcon, cn, Flex, Text } from \"@orderly.network/ui\";\nimport { usePortfolioChartsState } from \".\";\n\nexport const PortfolioChartsMobileUI: React.FC<\n ReturnType<typeof usePortfolioChartsState> & {\n data: any[];\n invisible?: boolean;\n }\n> = (props) => {\n const { data, invisible, unrealPnL, unrealROI, visible, onPerformanceClick } =\n props;\n const { t } = useTranslation();\n const colorId = useId();\n return (\n <Flex\n p={4}\n width={\"100%\"}\n itemAlign=\"center\"\n justify=\"between\"\n className={cn(\n \"oui-relative oui-overflow-hidden oui-rounded-2xl oui-border oui-border-solid oui-border-line-12 oui-bg-base-9\",\n )}\n >\n <Flex\n width={\"100%\"}\n justify={\"center\"}\n itemAlign={\"start\"}\n direction={\"column\"}\n gap={2}\n >\n <Text size=\"xs\" intensity={54}>\n {t(\"common.unrealizedPnl\")}\n </Text>\n <Flex justify={\"start\"} itemAlign={\"center\"}>\n <Text.numeral\n coloring\n size=\"base\"\n weight=\"semibold\"\n visible={visible}\n >\n {unrealPnL}\n </Text.numeral>\n <Text.numeral\n coloring\n rule=\"percentages\"\n size=\"sm\"\n weight=\"semibold\"\n prefix={\"(\"}\n suffix={\")\"}\n visible={visible}\n >\n {unrealROI}\n </Text.numeral>\n </Flex>\n <Text\n size=\"xs\"\n intensity={54}\n className=\"oui-flex oui-items-center oui-justify-start oui-gap-1\"\n onClick={onPerformanceClick}\n >\n {t(\"portfolio.overview.performance\")}\n <ChevronRightIcon className=\"oui-text-base-contrast-54\" />\n </Text>\n </Flex>\n <Flex\n width={\"100%\"}\n justify={\"center\"}\n itemAlign={\"center\"}\n direction={\"column\"}\n >\n <AreaChart data={data || EMPTY_LIST} width={160} height={52}>\n {!invisible && (\n <>\n <defs>\n <linearGradient id={colorId} x1=\"0\" y1=\"0\" x2=\"0\" y2=\"1\">\n <stop stopColor=\"#00B49E\" offset=\"0%\" stopOpacity={0.5} />\n <stop stopColor=\"#00B49E\" offset=\"100%\" stopOpacity={0} />\n </linearGradient>\n </defs>\n <Area\n type=\"natural\"\n dataKey=\"account_value\"\n stroke={\"rgb(41, 233, 169)\"}\n strokeWidth={1.5}\n dot={false}\n isAnimationActive={false}\n fill={`url(#${colorId})`}\n />\n </>\n )}\n </AreaChart>\n </Flex>\n </Flex>\n );\n};\n","import { FC, SVGProps, useCallback, useMemo } from \"react\";\nimport {\n parseJSON,\n useAccount,\n useChains,\n useLocalStorage,\n useWalletConnector,\n} from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { useAppContext } from \"@orderly.network/react-app\";\nimport { AccountStatusEnum, ChainNamespace } from \"@orderly.network/types\";\nimport {\n cn,\n modal,\n toast,\n formatAddress,\n Flex,\n CopyIcon,\n ChainIcon,\n} from \"@orderly.network/ui\";\n\ninterface StatusInfo {\n title: string;\n description: string;\n titleColor?: any;\n titleClsName?: string;\n}\n\nconst useCurrentStatus = () => {\n const { state, account } = useAccount();\n const { wrongNetwork, disabledConnect, connectWallet } = useAppContext();\n const { t } = useTranslation();\n\n const statusText = {\n wrongNetwork: {\n description: t(\"connector.wrongNetwork.tooltip\"),\n rootClass: \"oui-bg-[linear-gradient(15deg,#D25F00_0%,transparent_30%)]\",\n },\n connectWallet: {\n description: t(\"connector.trade.connectWallet.tooltip\"),\n rootClass: \"oui-bg-[linear-gradient(15deg,#27FDFE_0%,transparent_30%)]\",\n },\n notSignedIn: {\n description: t(\"connector.trade.createAccount.tooltip\"),\n rootClass: \"oui-bg-[linear-gradient(15deg,#335FFC_0%,transparent_30%)]\",\n },\n disabledTrading: {\n description: t(\"connector.trade.enableTrading.tooltip\"),\n rootClass: \"oui-bg-[linear-gradient(15deg,#335FFC_0%,transparent_30%)]\",\n },\n default: {\n description: \"\",\n rootClass: \"\",\n arrowIconClass: \"\",\n textClass: \"\",\n },\n };\n\n return useMemo(() => {\n if (disabledConnect) {\n return statusText.connectWallet;\n }\n\n if (wrongNetwork) {\n return statusText.wrongNetwork;\n }\n\n switch (state.status) {\n case AccountStatusEnum.NotConnected:\n return statusText.connectWallet;\n case AccountStatusEnum.NotSignedIn:\n return statusText.notSignedIn;\n case AccountStatusEnum.DisabledTrading:\n return statusText.disabledTrading;\n default:\n return statusText.default;\n }\n }, [state.status, wrongNetwork]);\n};\n\nexport function EVMChainPopover({ children }: { children: React.ReactNode }) {\n // const [chains] = useState(getChainsByNetwork(\"mainnet\"));\n const [chains] = useChains(\"mainnet\", {\n pick: \"network_infos\",\n });\n const { t } = useTranslation();\n\n const showDialog = () => {\n modal.dialog({\n title: t(\"connector.privy.supportedEvmChain\"),\n size: \"xs\",\n content: (\n <div>\n <div className=\"oui-p-1 oui-grid oui-grid-cols-2 oui-gap-x-2 oui-gap-y-3 oui-text-2xs oui-text-base-contrast-54\">\n {chains.map((item, key) => (\n <div\n key={key}\n className=\"oui-flex oui-items-center oui-justify-start oui-gap-1\"\n >\n <ChainIcon chainId={item.chain_id} size=\"2xs\" />\n <div>{item.name}</div>\n </div>\n ))}\n </div>\n </div>\n ),\n });\n };\n\n return <button onClick={showDialog}>{children}</button>;\n}\n\nexport const MoreIcon: FC<SVGProps<SVGSVGElement>> = (props) => (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"currentColor\"\n {...props}\n >\n <path d=\"M8.00521 6.66797C8.74161 6.66797 9.33854 7.26464 9.33854 8.0013C9.33854 8.73797 8.74161 9.33464 8.00521 9.33464C7.26881 9.33464 6.67188 8.73797 6.67188 8.0013C6.67188 7.26464 7.26881 6.66797 8.00521 6.66797Z\" />\n <path d=\"M3.33333 6.66797C4.06973 6.66797 4.66667 7.26464 4.66667 8.0013C4.66667 8.73797 4.06973 9.33464 3.33333 9.33464C2.59693 9.33464 2 8.73797 2 8.0013C2 7.26464 2.59693 6.66797 3.33333 6.66797Z\" />\n <path d=\"M12.6666 6.66797C13.403 6.66797 14 7.26464 14 8.0013C14 8.73797 13.403 9.33464 12.6666 9.33464C11.9302 9.33464 11.3333 8.73797 11.3333 8.0013C11.3333 7.26464 11.9302 6.66797 12.6666 6.66797Z\" />\n </svg>\n);\n\nconst EVMChains = () => {\n return (\n <div className=\"oui-relative oui-flex oui-items-center oui-justify-center\">\n <div className=\"oui-flex oui-h-[18px] oui-items-center oui-justify-center \">\n <img\n src=\"https://oss.orderly.network/static/sdk/portfolio/chains.png\"\n className=\"oui-relative oui-z-0 oui-h-[18px] oui-w-[49px]\"\n />\n </div>\n <div className=\"oui-relative oui-left-[-9px] oui-flex oui-items-center oui-justify-center oui-gap-1\">\n <div className=\"oui-flex oui-size-[18px] oui-items-center oui-justify-center oui-rounded-full oui-bg-[#282e3a]\">\n <EVMChainPopover>\n <MoreIcon\n className=\"oui-relative oui-z-10 oui-size-3 oui-text-base-contrast-54 hover:oui-text-base-contrast\"\n style={{ zIndex: 1 }}\n />\n </EVMChainPopover>\n </div>\n <div className=\"oui-text-2xs oui-font-semibold oui-text-base-contrast\">\n Evm\n </div>\n </div>\n </div>\n );\n};\n\nconst ShowAccount: FC = () => {\n const { state, account } = useAccount();\n const { namespace } = useWalletConnector();\n const { t } = useTranslation();\n const onCopyAddress = () => {\n navigator.clipboard.writeText(state.address ?? \"\");\n toast.success(t(\"common.copy.copied\"));\n };\n\n const currentNamespace = useMemo(() => {\n if (namespace) {\n return namespace;\n }\n if (state.status === AccountStatusEnum.EnableTradingWithoutConnected) {\n return getLinkDeviceStorage()?.chainNamespace;\n }\n return null;\n }, [namespace, state.status]);\n\n const leftNode = useMemo(() => {\n if (!state.address) {\n return;\n }\n return (\n <Flex className=\"oui-text-base oui-text-base-contrast\" gapX={2}>\n {formatAddress(state.address ?? \"\")}\n <button\n className=\"oui-cursor-pointer\"\n onClick={() => {\n onCopyAddress();\n }}\n >\n <CopyIcon\n size={18}\n className=\"oui-text-base-contrast-80\"\n opacity={1}\n />\n </button>\n </Flex>\n );\n }, [state.address]);\n const rightNode = useMemo(() => {\n if (currentNamespace === ChainNamespace.evm) {\n return <EVMChains />;\n }\n\n return (\n <Flex gapX={1} itemAlign={\"center\"} className=\"oui-text-2xs\">\n <img\n src=\"https://oss.orderly.network/static/sdk/solana-logo.png\"\n className=\"oui-w-[15px]\"\n />\n Solana\n </Flex>\n );\n }, [currentNamespace]);\n\n const bgClass = useMemo(() => {\n let bg = \"\";\n if (currentNamespace == ChainNamespace.evm) {\n bg =\n \"oui-bg-[linear-gradient(15deg,#283BEE_-11%,transparent_30%,transparent_77%,#A53411_100%)]\";\n } else if (currentNamespace == ChainNamespace.solana) {\n bg =\n \"oui-bg-[linear-gradient(15deg,#7400D0_-11%,transparent_30%,transparent_77%,#009A7E_100%)]\";\n }\n return bg;\n }, [currentNamespace]);\n return (\n <div\n className={cn([\n \"oui-flex oui-h-[44px] oui-w-full oui-items-center oui-justify-between oui-rounded-[10px] oui-px-3 oui-py-[10px]\",\n bgClass,\n ])}\n >\n {leftNode}\n {rightNode}\n </div>\n );\n};\n\nexport const AccountStatusMobile: FC = () => {\n const { state } = useAccount();\n const { wrongNetwork } = useAppContext();\n const { description, rootClass } = useCurrentStatus();\n\n const alreadyShowAccount = useMemo(() => {\n if (state.status === AccountStatusEnum.EnableTradingWithoutConnected) {\n return true;\n }\n if (wrongNetwork) {\n return false;\n }\n return state.status >= AccountStatusEnum.EnableTrading;\n }, [state.status, wrongNetwork]);\n\n if (alreadyShowAccount) {\n return <ShowAccount />;\n }\n\n return (\n <div\n className={cn([\n \"oui-flex oui-h-[44px] oui-w-full oui-items-center oui-justify-center oui-rounded-[10px] oui-px-3 oui-py-[10px]\",\n rootClass,\n // \"oui-bg-linear-65\",\n // \"oui-from-[-20%]\",\n // \"oui-to-[40%]\",\n // \" oui-from-[#FF7B00]\",\n // \" oui-to-[#FFEA00]\",\n ])}\n >\n <div\n className={cn(\n \"oui-flex oui-items-center oui-justify-end oui-rounded-[10px] oui-text-xs oui-font-semibold\",\n \"oui-text-base-contrast-54\",\n )}\n >\n {description}\n </div>\n </div>\n );\n};\ntype LinkDeviceStorage = { chainId: number; chainNamespace: ChainNamespace };\n\nfunction getLinkDeviceStorage() {\n try {\n const linkDeviceStorage = localStorage.getItem(\"orderly_link_device\");\n const json = linkDeviceStorage ? parseJSON(linkDeviceStorage) : null;\n return json as LinkDeviceStorage;\n } catch (err) {\n console.error(\"getLinkDeviceStorage\", err);\n }\n}\n","import { FC } from \"react\";\nimport { RefferalAPI as API } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n Flex,\n Text,\n AffiliateIcon,\n ChevronRightIcon,\n cn,\n} from \"@orderly.network/ui\";\nimport { RouterAdapter } from \"@orderly.network/ui-scaffold\";\nimport { commifyOptional } from \"@orderly.network/utils\";\n\nconst isNumber = (val: unknown): val is number => {\n return typeof val === \"number\" && !Number.isNaN(val);\n};\n\ntype AffiliateCardMobileProps = {\n referralInfo?: API.ReferralInfo;\n routerAdapter?: RouterAdapter;\n};\n\nexport const AffiliateCardMobile: FC<AffiliateCardMobileProps> = (props) => {\n const { t } = useTranslation();\n const { referralInfo, routerAdapter } = props;\n const rebate = referralInfo?.referrer_info?.[\"30d_referrer_rebate\"];\n return (\n <Flex\n className=\"\n oui-via-21.6% \n oui-via-83.23% \n oui-relative \n oui-h-[112px] \n oui-w-full \n oui-flex-col \n oui-items-start \n oui-rounded-xl \n oui-border \n oui-border-solid \n oui-border-[rgba(var(--oui-gradient-primary-start)/0.36)] \n oui-bg-gradient-to-r\n oui-from-[rgba(var(--oui-gradient-primary-end)/0.12)]\n oui-to-[rgba(var(--oui-gradient-primary-start)/0.12)]\n oui-p-3\n \"\n >\n <Flex className=\"oui-w-full oui-flex-row oui-justify-between oui-items-center\">\n <Flex className=\"oui-flex-col oui-items-start\">\n <Text className=\"oui-text-base-contrast oui-text-base oui-font-semibold\">\n {t(\"affiliate.asAffiliate.affilates\")}\n </Text>\n <Text className=\"oui-text-2xs oui-font-normal oui-text-base-contrast-54\">\n {t(\"affiliate.commission\")}\n </Text>\n </Flex>\n <AffiliateIcon />\n </Flex>\n <Flex className=\"oui-mt-auto oui-w-full oui-flex-row oui-items-center oui-gap-1\">\n <img\n src=\"https://oss.orderly.network/static/symbol_logo/USDC.png\"\n alt=\"USDC\"\n className=\"oui-size-5\"\n />\n <Text\n className={cn(\n \"oui-text-xs oui-font-semibold\",\n isNumber(rebate) && rebate !== 0\n ? \"oui-text-base-contrast\"\n : \"oui-text-base-contrast-36\",\n )}\n >\n {commifyOptional(rebate, { fix: 2, fallback: \"--\" })}\n </Text>\n <Text className=\"oui-text-xs oui-font-semibold oui-text-base-contrast-36\">\n (30D)\n </Text>\n <ChevronRightIcon\n size={18}\n color=\"white\"\n className=\"oui-ml-auto\"\n onClick={() => {\n routerAdapter?.onRouteChange({\n href: \"/rewards/affiliate?tab=affiliate\",\n name: t(\"tradingRewards.rewards\"),\n });\n }}\n />\n </Flex>\n </Flex>\n );\n};\n","import { FC } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n Flex,\n Text,\n ArrowDownSquareFillIcon,\n ArrowUpSquareFillIcon,\n CalendarMinusIcon,\n ArrowLeftRightIcon,\n} from \"@orderly.network/ui\";\nimport { RouterAdapter } from \"@orderly.network/ui-scaffold\";\nimport { PortfolioLeftSidebarPath } from \"../../../layout\";\n\ntype Props = {\n disabled: boolean;\n onWithdraw?: () => void;\n onDeposit?: () => void;\n onTransfer?: () => void;\n isMainAccount?: boolean;\n routerAdapter?: RouterAdapter;\n hasSubAccount?: boolean;\n};\n\nexport const PortfolioHandleMobile: FC<Props> = (props) => {\n const { t } = useTranslation();\n\n const onGotoHistory = () => {\n props.routerAdapter?.onRouteChange({\n href: PortfolioLeftSidebarPath.History,\n name: t(\"trading.history\"),\n });\n };\n\n return (\n <Flex\n direction={\"row\"}\n width={\"100%\"}\n height={\"71px\"}\n className=\"oui-gap-3 oui-bg-transparent\"\n >\n {props.isMainAccount && (\n <Flex\n direction=\"column\"\n gapY={2}\n itemAlign={\"center\"}\n className=\"oui-flex-1 oui-cursor-pointer\"\n onClick={props?.onDeposit}\n >\n <div className=\"oui-flex oui-size-[48px] oui-items-center oui-justify-center oui-rounded-xl oui-bg-base-9\">\n <ArrowDownSquareFillIcon size={28} color=\"white\" opacity={1} />\n </div>\n <Text className=\"oui-text-base-80 oui-text-2xs\">\n {t(\"common.deposit\")}\n </Text>\n </Flex>\n )}\n {props.hasSubAccount && (\n <Flex\n direction=\"column\"\n gapY={2}\n itemAlign={\"center\"}\n className=\"oui-flex-1 oui-cursor-pointer\"\n onClick={props?.onTransfer}\n >\n <div className=\"oui-flex oui-size-[48px] oui-items-center oui-justify-center oui-rounded-xl oui-bg-base-9\">\n <ArrowLeftRightIcon size={28} color=\"white\" opacity={1} />\n </div>\n <Text className=\"oui-text-base-80 oui-text-2xs\">\n {t(\"common.transfer\")}\n </Text>\n </Flex>\n )}\n {props.isMainAccount && (\n <Flex\n direction=\"column\"\n gapY={2}\n itemAlign={\"center\"}\n className=\"oui-flex-1 oui-cursor-pointer\"\n onClick={props?.onWithdraw}\n >\n <div className=\"oui-flex oui-size-[48px] oui-items-center oui-justify-center oui-rounded-xl oui-bg-base-9\">\n <ArrowUpSquareFillIcon size={28} color=\"white\" opacity={1} />\n </div>\n <Text className=\"oui-text-base-80 oui-text-2xs\">\n {t(\"common.withdraw\")}\n </Text>\n </Flex>\n )}\n <Flex\n direction=\"column\"\n gapY={2}\n itemAlign={\"center\"}\n className=\"oui-flex-1 oui-cursor-pointer\"\n >\n <div\n className=\"oui-flex oui-size-[48px] oui-items-center oui-justify-center oui-rounded-xl oui-bg-base-9\"\n onClick={onGotoHistory}\n >\n <CalendarMinusIcon\n size={28}\n color=\"white\"\n opacity={1}\n viewBox=\"0 0 28 28\"\n className=\"oui-w-[28px] oui-h-[28px]\"\n />\n </div>\n <Text className=\"oui-text-base-80 oui-text-2xs\">\n {t(\"trading.history\")}\n </Text>\n </Flex>\n </Flex>\n );\n};\n","import { FC, useMemo } from \"react\";\nimport { parseJSON, useAccount } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { AccountStatusEnum, ChainNamespace } from \"@orderly.network/types\";\nimport {\n Flex,\n Text,\n cn,\n ArrowRightShortIcon,\n EyeIcon,\n} from \"@orderly.network/ui\";\nimport { RouterAdapter } from \"@orderly.network/ui-scaffold\";\nimport { PortfolioLeftSidebarPath } from \"../../../layout\";\n\ntype Props = {\n portfolioValue: number | null;\n unrealPnL: number;\n unrealROI: number;\n visible: boolean;\n namespace: string | null;\n toggleVisible: () => void;\n canTrade: boolean;\n routerAdapter?: RouterAdapter;\n};\n\nexport const PortfolioValueMobile: FC<Props> = (props) => {\n const { t } = useTranslation();\n const { state } = useAccount();\n\n const currentNamespace = useMemo(() => {\n if (props.namespace) {\n return props.namespace;\n }\n if (state.status === AccountStatusEnum.EnableTradingWithoutConnected) {\n return getLinkDeviceStorage()?.chainNamespace;\n }\n return null;\n }, [props.namespace, state.status]);\n return (\n <Flex\n direction={\"column\"}\n width={\"100%\"}\n height={\"100%\"}\n className={cn([\n \"oui-relative oui-items-start oui-overflow-hidden oui-rounded-2xl oui-bg-base-9\",\n currentNamespace === ChainNamespace.evm && \"oui-bg-[#283BEE]\",\n currentNamespace === ChainNamespace.solana && \"oui-bg-[#630EAD]\",\n ])}\n p={4}\n >\n <Flex direction=\"row\" gapX={1} itemAlign={\"center\"}>\n <Text className=\"oui-text-sm oui-text-base-contrast-54\">\n {t(\"portfolio.overview.handle.title\")}\n </Text>\n <EyeIcon\n size={16}\n className={cn(\n props.canTrade ? \"oui-text-base-contrast-54\" : \"oui-hidden\",\n )}\n onClick={props.toggleVisible}\n />\n </Flex>\n <Flex\n direction=\"row\"\n gapX={1}\n itemAlign={\"baseline\"}\n className=\"oui-mt-1\"\n >\n <Text.numeral\n visible={props.visible}\n className=\"oui-text-3xl oui-font-bold oui-text-base-contrast\"\n >\n {props.portfolioValue ?? \"--\"}\n </Text.numeral>\n <Text className=\"oui-text-base oui-font-bold oui-text-base-contrast-80\">\n USDC\n </Text>\n </Flex>\n <Flex\n direction=\"row\"\n gapX={1}\n itemAlign={\"center\"}\n className=\"oui-text-sm oui-text-base-contrast\"\n >\n <Text.numeral visible={props.visible}>\n {props.unrealPnL ?? \"--\"}\n </Text.numeral>\n <Text.numeral\n visible={props.visible}\n rule=\"percentages\"\n prefix={\"(\"}\n suffix={\")\"}\n >\n {props.unrealROI ?? \"--\"}\n </Text.numeral>\n </Flex>\n <div\n className=\"oui-absolute oui-right-0 oui-top-0 oui-flex oui-h-full oui-items-center oui-justify-center oui-px-4\"\n onClick={() =>\n props.routerAdapter?.onRouteChange({\n href: PortfolioLeftSidebarPath.Assets,\n name: \"Assets\",\n })\n }\n >\n <ArrowRightShortIcon size={18} color=\"white\" opacity={0.54} />\n </div>\n </Flex>\n );\n};\n\ntype LinkDeviceStorage = { chainId: number; chainNamespace: ChainNamespace };\n\nfunction getLinkDeviceStorage() {\n try {\n const linkDeviceStorage = localStorage.getItem(\"orderly_link_device\");\n const json = linkDeviceStorage ? parseJSON(linkDeviceStorage) : null;\n return json as LinkDeviceStorage;\n } catch (err) {\n console.error(\"getLinkDeviceStorage\", err);\n }\n}\n","import { FC } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n Flex,\n Text,\n SettingFillIcon,\n ChevronRightIcon,\n} from \"@orderly.network/ui\";\nimport { RouterAdapter } from \"@orderly.network/ui-scaffold\";\nimport { PortfolioLeftSidebarPath } from \"../../../layout\";\n\ntype Props = {\n routerAdapter?: RouterAdapter;\n};\n\nexport const SettingRouterMobile: FC<Props> = (props) => {\n const { t } = useTranslation();\n return (\n <Flex\n direction={\"row\"}\n width={\"100%\"}\n className=\"oui-cursor-pointer oui-items-center oui-gap-2 oui-rounded-xl oui-bg-base-9 oui-p-4 oui-mb-3\"\n onClick={() =>\n props?.routerAdapter?.onRouteChange({\n href: PortfolioLeftSidebarPath.Setting,\n name: t(\"portfolio.setting\"),\n })\n }\n >\n <SettingFillIcon size={18} opacity={0.98} color=\"white\" />\n <Text className=\"oui-text-base oui-font-semibold oui-text-base-contrast-80\">\n {t(\"portfolio.setting\")}\n </Text>\n <ChevronRightIcon\n className=\"oui-ml-auto\"\n size={18}\n opacity={0.36}\n color=\"white\"\n />\n </Flex>\n );\n};\n","import { FC } from \"react\";\nimport { RefferalAPI as API } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n Flex,\n Text,\n TraderMobileIcon,\n ChevronRightIcon,\n cn,\n} from \"@orderly.network/ui\";\nimport { RouterAdapter } from \"@orderly.network/ui-scaffold\";\nimport { commifyOptional } from \"@orderly.network/utils\";\n\nconst isNumber = (val: unknown): val is number => {\n return typeof val === \"number\" && !Number.isNaN(val);\n};\n\ntype TraderCardMobileProps = {\n referralInfo?: API.ReferralInfo;\n routerAdapter?: RouterAdapter;\n};\n\nexport const TraderCardMobile: FC<TraderCardMobileProps> = (props) => {\n const { t } = useTranslation();\n const { referralInfo, routerAdapter } = props;\n const rebate = referralInfo?.referee_info?.[\"30d_referee_rebate\"];\n return (\n <Flex\n className=\"\n oui-via-21.6% \n oui-via-83.23% \n oui-relative \n oui-h-[112px] \n oui-w-full \n oui-flex-col \n oui-items-start \n oui-rounded-xl \n oui-border\n oui-border-solid \n oui-border-[rgba(var(--oui-gradient-success-start)/0.36)]\n oui-bg-gradient-to-r\n oui-from-[rgba(var(--oui-gradient-success-end)/0.12)]\n oui-to-[rgba(var(--oui-gradient-success-start)/0.12)]\n oui-p-3\n \"\n >\n <Flex className=\"oui-w-full oui-flex-row oui-justify-between oui-items-center\">\n <Flex className=\"oui-flex-col oui-items-start\">\n <Text className=\"oui-text-base-contrast oui-text-base oui-font-semibold\">\n {t(\"affiliate.trader.rebates\")}\n </Text>\n <Text className=\"oui-text-2xs oui-font-normal oui-text-base-contrast-54\">\n {t(\"affiliate.trader.tradingRebates\")}\n </Text>\n </Flex>\n <TraderMobileIcon />\n </Flex>\n\n <Flex\n className={cn(\n \"oui-mt-auto oui-w-full oui-flex-row oui-items-center oui-gap-1\",\n )}\n >\n <img\n src=\"https://oss.orderly.network/static/symbol_logo/USDC.png\"\n alt=\"USDC\"\n className=\"oui-size-5\"\n />\n <Text\n className={cn(\n \"oui-text-xs oui-font-semibold\",\n isNumber(rebate) && rebate !== 0\n ? \"oui-text-base-contrast\"\n : \"oui-text-base-contrast-36\",\n )}\n >\n {commifyOptional(rebate, { fix: 2, fallback: \"--\" })}\n </Text>\n <Text className=\"oui-text-xs oui-font-semibold oui-text-base-contrast-36\">\n (30D)\n </Text>\n <ChevronRightIcon\n size={18}\n color=\"white\"\n className=\"oui-ml-auto\"\n onClick={() => {\n routerAdapter?.onRouteChange({\n href: \"/rewards/affiliate?tab=trader\",\n name: t(\"tradingRewards.rewards\"),\n });\n }}\n />\n </Flex>\n </Flex>\n );\n};\n","export { FeeTierPage } from \"./page\";\nexport { useFeeTierScript } from \"./feeTier.script\";\nexport type { FeeDataType, UseFeeTierScriptOptions } from \"./feeTier.script\";\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport React, { useCallback } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n Box,\n Flex,\n Text,\n Card,\n Divider,\n DataTable,\n Column,\n useScreen,\n cn,\n TanstackColumn,\n} from \"@orderly.network/ui\";\nimport type { FeeDataType, useFeeTierScriptReturn } from \"./feeTier.script\";\n\nconst LazyFeeTierHeader = React.lazy(() =>\n import(\"./feeTierHeader\").then((mod) => {\n return { default: mod.FeeTierHeader };\n }),\n);\n\nexport type FeeTierProps = useFeeTierScriptReturn;\n\nexport type FeeTierHeaderProps = {\n tier?: number;\n vol?: number;\n};\n\ntype FeeTierTableProps = {\n columns: Column<any>[];\n dataSource?: any[];\n page?: number;\n pageSize?: number;\n dataCount?: number;\n tier?: number | null;\n vol?: number | null;\n onRow?: (\n record: any,\n index: number,\n ) => {\n normal?: any;\n active?: any;\n };\n onCell?: (\n column: TanstackColumn<any>,\n record: any,\n index: number,\n ) => {\n normal?: any;\n active?: any;\n };\n};\n\nexport const FeeTierTable: React.FC<FeeTierTableProps> = (props) => {\n const { isMobile } = useScreen();\n\n const { tier, columns, dataSource, onRow, onCell } = props;\n\n const internalOnRow = useCallback(\n (record: FeeDataType, index: number) => {\n const config =\n typeof onRow === \"function\"\n ? onRow(record, index)\n : { normal: undefined, active: undefined };\n const active = tier !== undefined && tier !== null && tier === index + 1;\n if (active) {\n return {\n \"data-state\": \"active\",\n className: cn(\n \"oui-pointer-events-none oui-h-[54px] oui-text-[rgba(0,0,0,0.88)] oui-gradient-brand\",\n ),\n ...config.active,\n };\n } else {\n return {\n \"data-state\": \"none\",\n className: cn(\"oui-h-[54px]\"),\n ...config.normal,\n };\n }\n },\n [tier, onRow],\n );\n\n const internalOnCell = useCallback(\n (\n column: TanstackColumn<FeeDataType>,\n record: FeeDataType,\n index: number,\n ) => {\n const config =\n typeof onCell === \"function\"\n ? onCell(column, record, index)\n : { normal: undefined, active: undefined };\n const active = tier !== undefined && tier !== null && tier === index + 1;\n const isFirstColumn = column.getIsFirstColumn();\n const isLastColumn = column.getIsLastColumn();\n if (active) {\n return {\n className: cn(\n isFirstColumn && \"oui-rounded-l-lg\",\n isLastColumn && \"oui-rounded-r-lg\",\n ),\n ...config.active,\n };\n } else {\n return {\n className: \"\",\n ...config.normal,\n };\n }\n },\n [tier, onCell],\n );\n\n return (\n <Box\n className={cn(\n \"oui-relative oui-border-b oui-border-line-4\",\n isMobile ? \"oui-mt-2 oui-rounded-xl oui-bg-base-9\" : undefined,\n )}\n >\n <DataTable\n bordered\n className=\"oui-font-semibold\"\n classNames={{ root: \"oui-bg-transparent\" }}\n onRow={internalOnRow}\n onCell={internalOnCell}\n columns={columns}\n dataSource={dataSource}\n />\n </Box>\n );\n};\n\nconst CardTitle: React.FC = () => {\n const { t } = useTranslation();\n const { isMobile } = useScreen();\n if (isMobile) {\n return (\n <Flex itemAlign={\"center\"} justify={\"center\"} gap={2}>\n <Text size=\"xs\" intensity={54}>\n {t(\"portfolio.feeTier.updatedDailyBy\")}\n </Text>\n <Text size=\"xs\" intensity={80}>\n ~2:15 UTC\n </Text>\n </Flex>\n );\n }\n return (\n <Flex itemAlign={\"center\"} justify={\"between\"}>\n <Text size={\"lg\"}>{t(\"portfolio.feeTier\")}</Text>\n <Flex itemAlign={\"center\"} justify={\"center\"} gap={1}>\n <Text size=\"xs\" intensity={54}>\n {t(\"portfolio.feeTier.updatedDailyBy\")}\n </Text>\n <Text size=\"xs\" intensity={80}>\n ~2:15 UTC\n </Text>\n </Flex>\n </Flex>\n );\n};\n\nexport const FeeTier: React.FC<FeeTierProps> = (props) => {\n const { columns, dataSource, tier, vol, headerDataAdapter, onRow, onCell } =\n props;\n const { isMobile } = useScreen();\n return (\n <Card\n title={<CardTitle />}\n id=\"oui-portfolio-fee-tier\"\n className=\"w-full\"\n classNames={{\n root: isMobile ? \"oui-bg-transparent oui-p-2\" : \"oui-bg-base-9\",\n }}\n >\n {!isMobile && <Divider />}\n <React.Suspense fallback={null}>\n <LazyFeeTierHeader\n vol={vol}\n tier={tier}\n headerDataAdapter={headerDataAdapter}\n />\n </React.Suspense>\n <FeeTierTable\n dataSource={dataSource}\n columns={columns}\n vol={vol}\n tier={tier}\n onRow={onRow}\n onCell={onCell}\n />\n </Card>\n );\n};\n","import React from \"react\";\nimport { useFeeTierScript, type UseFeeTierScriptOptions } from \".\";\nimport { FeeTier } from \"./feeTier.ui\";\n\nexport type FeeTierWidgetProps = UseFeeTierScriptOptions;\n\nexport const FeeTierWidget: React.FC<FeeTierWidgetProps> = (props) => {\n const state = useFeeTierScript(props);\n return <FeeTier {...state} />;\n};\n","import React from \"react\";\nimport { FeeTierWidget, FeeTierWidgetProps } from \"./feeTier.widget\";\n\nexport type FeeTierPageProps = FeeTierWidgetProps;\n\nexport const FeeTierPage: React.FC<FeeTierPageProps> = (props) => {\n return <FeeTierWidget {...props} />;\n};\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport React, { useEffect, useMemo, useState } from \"react\";\nimport { on } from \"events\";\nimport {\n useAccount,\n useAccountInfo,\n usePrivateQuery,\n} from \"@orderly.network/hooks\";\nimport { useDataTap } from \"@orderly.network/react-app\";\nimport { AccountStatusEnum, API } from \"@orderly.network/types\";\nimport type { Column, TanstackColumn } from \"@orderly.network/ui\";\nimport { Decimal } from \"@orderly.network/utils\";\nimport { useFeeTierColumns } from \"./column\";\nimport { dataSource as defaultDataSource } from \"./dataSource\";\n\nexport type useFeeTierScriptReturn = ReturnType<typeof useFeeTierScript>;\n\nexport type UseFeeTierScriptOptions = {\n dataAdapter?: (\n columns: Column<any>[],\n dataSource: any[],\n context?: {\n tier?: number;\n },\n ) => {\n columns: Column<any>[];\n dataSource: any[];\n };\n headerDataAdapter?: (original: any[]) => any[];\n onRow?: (\n record: any,\n index: number,\n ) => {\n normal?: any;\n active?: any;\n };\n onCell?: (\n column: TanstackColumn<any>,\n record: any,\n index: number,\n ) => {\n normal?: any;\n active?: any;\n };\n};\n\nexport interface FeeDataType {\n tier: number | null;\n volume_min?: number | null;\n volume_max?: number | null;\n volume_node?: React.ReactNode;\n or?: string | null;\n maker_fee: string;\n taker_fee: string;\n}\n\nconst findCurrentTier = (feeList: FeeDataType[], data: API.AccountInfo) => {\n const { futures_taker_fee_rate = 0, futures_maker_fee_rate = 0 } = data;\n const takerRate = new Decimal(futures_taker_fee_rate).mul(0.01);\n const makerRate = new Decimal(futures_maker_fee_rate).mul(0.01);\n const findItem = feeList.find((item) => {\n const itemTakerRate = item.taker_fee.split(\"/\")?.[0].trim();\n const itemMakerRate = item.maker_fee.split(\"/\")?.[0].trim();\n return (\n itemTakerRate === `${takerRate.toNumber()}%` &&\n itemMakerRate === `${makerRate.toNumber()}%`\n );\n });\n return findItem?.tier;\n};\n\nexport const useFeeTierScript = (options?: UseFeeTierScriptOptions) => {\n const { dataAdapter, headerDataAdapter, onRow, onCell } = options || {};\n const [tier, setTier] = useState<number | null>();\n const { data, isLoading } = useAccountInfo();\n const { state } = useAccount();\n\n const cols = useFeeTierColumns();\n\n const { data: volumeStatistics } = usePrivateQuery<{\n perp_volume_last_30_days: number;\n }>(\"/v1/volume/user/stats\");\n\n const { columns, dataSource } = useMemo(() => {\n return typeof dataAdapter === \"function\"\n ? dataAdapter(cols, defaultDataSource, { tier: tier! })\n : { columns: cols, dataSource: defaultDataSource };\n }, [dataAdapter, cols, tier]);\n\n useEffect(() => {\n if (!data || isLoading) {\n return;\n }\n setTier(findCurrentTier(dataSource, data));\n }, [data, isLoading, dataSource]);\n\n const authData = useDataTap(\n {\n tier: tier,\n vol: volumeStatistics?.perp_volume_last_30_days,\n },\n {\n accountStatus:\n state.status === AccountStatusEnum.EnableTradingWithoutConnected\n ? AccountStatusEnum.EnableTradingWithoutConnected\n : AccountStatusEnum.EnableTrading,\n },\n );\n\n return {\n ...authData,\n columns: columns,\n dataSource: dataSource,\n onRow: onRow,\n onCell: onCell,\n headerDataAdapter: headerDataAdapter,\n };\n};\n","import React, { useMemo } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport type { Column } from \"@orderly.network/ui\";\nimport { numberToHumanStyle } from \"@orderly.network/utils\";\nimport type { FeeDataType } from \"./feeTier.script\";\n\nconst textStyle: React.CSSProperties = {\n fontVariantLigatures: \"none\",\n};\n\nexport const useFeeTierColumns = () => {\n const { t } = useTranslation();\n return useMemo<Column<FeeDataType>[]>(() => {\n return [\n {\n title: t(\"portfolio.feeTier.column.tier\"),\n dataIndex: \"tier\",\n align: \"left\",\n width: 100,\n },\n {\n title: `${t(\"portfolio.feeTier.column.30dVolume\")} (USDC)`,\n dataIndex: \"volume\",\n align: \"center\",\n width: 180,\n render: (val, record) => {\n const { volume_min, volume_max, volume_node } = record;\n if (volume_node) {\n return volume_node;\n }\n if (!volume_min && !volume_max) {\n return <div style={textStyle}>--</div>;\n }\n if (volume_min && !volume_max) {\n return t(\"portfolio.feeTier.column.30dVolume.above\", {\n volume: numberToHumanStyle(\n volume_min,\n volume_min === 2500000 ? 1 : 0,\n ),\n });\n }\n return (\n <div>\n {volume_min &&\n numberToHumanStyle(volume_min, volume_min === 2500000 ? 1 : 0)}\n {` - `}\n {volume_max &&\n numberToHumanStyle(volume_max, volume_max === 2500000 ? 1 : 0)}\n </div>\n );\n },\n },\n {\n title: t(\"portfolio.feeTier.column.maker\"),\n dataIndex: \"maker_fee\",\n align: \"right\",\n width: 100,\n },\n {\n title: t(\"portfolio.feeTier.column.taker\"),\n dataIndex: \"taker_fee\",\n align: \"right\",\n width: 100,\n },\n ];\n }, [t]);\n};\n","import type { FeeDataType } from \"./feeTier.script\";\n\nexport const dataSource: FeeDataType[] = [\n {\n tier: 1,\n volume_min: 0,\n volume_max: 500000,\n maker_fee: \"0.025% / 0%\",\n taker_fee: \"0.04% / 0.05%\",\n },\n {\n tier: 2,\n volume_min: 500000,\n volume_max: 1000000,\n maker_fee: \"0.02% / 0%\",\n taker_fee: \"0.035% / 0.05%\",\n },\n {\n tier: 3,\n volume_min: 1000000,\n volume_max: 5000000,\n maker_fee: \"0.018% / 0%\",\n taker_fee: \"0.03% / 0.05%\",\n },\n {\n tier: 4,\n volume_min: 5000000,\n volume_max: 20000000,\n maker_fee: \"0.012% / 0%\",\n taker_fee: \"0.025% / 0.05%\",\n },\n {\n tier: 5,\n volume_min: 20000000,\n volume_max: 50000000,\n or: \"/\",\n maker_fee: \"0.009% / 0%\",\n taker_fee: \"0.022% / 0.05%\",\n },\n {\n tier: 6,\n volume_min: 50000000,\n volume_max: 100000000,\n or: \"/\",\n maker_fee: \"0.005% / 0%\",\n taker_fee: \"0.018% / 0.05%\",\n },\n {\n tier: 7,\n volume_min: 100000000,\n volume_max: undefined,\n or: \"/\",\n maker_fee: \"0% / 0%\",\n taker_fee: \"0.015% / 0.05%\",\n },\n];\n","import { useMemo, useState } from \"react\";\nimport React from \"react\";\nimport { useAccount } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n Flex,\n Text,\n Divider,\n Box,\n Tabs,\n TabPanel,\n DataFilter,\n formatAddress,\n Tooltip,\n InfoCircleIcon,\n} from \"@orderly.network/ui\";\nimport {\n LiquidationWidget,\n PositionHistoryWidget,\n PositionsProps,\n CombinePositionsWidget,\n PositionsWidget,\n} from \"@orderly.network/ui-positions\";\nimport type { SelectOption } from \"@orderly.network/ui/src/select/withOptions\";\nimport { AccountType } from \"../assets/assetsPage/assets.ui.desktop\";\n\nenum TabsType {\n positions = \"Positions\",\n positionHistory = \"Position history\",\n liquidation = \"Liquidation\",\n}\n\nexport const PositionsPage: React.FC<PositionsProps> = (props) => {\n const [tab, setTab] = useState(TabsType.positions);\n const { t } = useTranslation();\n const { state, isMainAccount } = useAccount();\n\n const subAccounts = state.subAccounts ?? [];\n\n const [selectedAccount, setAccount] = React.useState<string>(AccountType.ALL);\n\n const onAccountFilter = React.useCallback(\n (filter: { name: string; value: string }) => {\n const { name, value } = filter;\n if (name === \"account\") {\n setAccount(value);\n }\n },\n [],\n );\n\n const ALL_ACCOUNTS: SelectOption = {\n label: t(\"common.allAccount\"),\n value: AccountType.ALL,\n };\n\n const MAIN_ACCOUNT: SelectOption = {\n label: t(\"common.mainAccount\"),\n value: AccountType.MAIN,\n };\n\n const memoizedOptions = useMemo(() => {\n if (Array.isArray(subAccounts) && subAccounts.length) {\n return [\n ALL_ACCOUNTS,\n MAIN_ACCOUNT,\n ...subAccounts.map<SelectOption>((value) => ({\n value: value.id,\n label: value?.description || formatAddress(value?.id),\n })),\n ];\n }\n return [ALL_ACCOUNTS, MAIN_ACCOUNT];\n }, [subAccounts]);\n\n return (\n <Flex\n // p={6}\n direction={\"column\"}\n itemAlign={\"start\"}\n gap={4}\n width=\"100%\"\n height=\"100%\"\n >\n <Flex>\n <Text size=\"lg\">{t(\"common.positions\")}</Text>\n </Flex>\n <Divider className=\"oui-w-full\" />\n {/* 26(title height) + 1(divider) + 32 (padding) */}\n <Box width=\"100%\" className=\"oui-h-[calc(100%_-_59px)]\">\n <Tabs\n value={tab}\n onValueChange={(e) => setTab(e as any)}\n classNames={{\n tabsList: \"!oui-border-none oui-pb-1\",\n tabsContent: \"oui-h-[calc(100%_-_28px)]\",\n trigger: \"oui-group\",\n }}\n className=\"oui-h-full\"\n >\n <TabPanel value={TabsType.positions} title={t(\"common.positions\")}>\n {isMainAccount ? (\n <>\n <DataFilter\n onFilter={onAccountFilter}\n items={[\n {\n type: \"select\",\n name: \"account\",\n value: selectedAccount,\n options: memoizedOptions,\n },\n ]}\n />\n <CombinePositionsWidget\n selectedAccount={selectedAccount}\n {...props}\n />\n </>\n ) : (\n <PositionsWidget {...props} enableSortingStorage={false} />\n )}\n </TabPanel>\n <TabPanel\n value={TabsType.positionHistory}\n title={t(\"positions.positionHistory\")}\n >\n <PositionHistoryWidget {...props} enableSortingStorage={false} />\n </TabPanel>\n <TabPanel value={TabsType.liquidation} title={<LiquidationTab />}>\n <LiquidationWidget />\n </TabPanel>\n </Tabs>\n </Box>\n </Flex>\n );\n};\n\nconst LiquidationTab: React.FC = () => {\n const { t } = useTranslation();\n return (\n <div className=\"oui-flex oui-space-x-1\">\n <span>{t(\"positions.liquidation\")}</span>\n <Tooltip\n className=\"oui-max-w-[275px] oui-bg-base-6\"\n content={\n <div>\n <div className=\"oui-text-pretty\">\n {t(\"positions.Liquidation.tooltip.liquidation\")}\n </div>\n <div>\n <a\n href=\"https://orderly.network/docs/introduction/trade-on-orderly/perpetual-futures/liquidations\"\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n className=\"oui-text-primary\"\n >\n {t(\"positions.Liquidation.tooltip.viewMore\")}\n </a>\n </div>\n </div>\n }\n arrow={{\n className: \"oui-fill-base-6\",\n }}\n >\n <button className=\"oui-hidden group-data-[state=active]:oui-block\">\n <InfoCircleIcon />\n </button>\n </Tooltip>\n </div>\n );\n};\n","import { FC, SVGProps, useRef } from \"react\";\nimport React from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { Box, Button, Divider, Flex, Text, Tooltip } from \"@orderly.network/ui\";\nimport { OrderListInstance, OrdersWidget } from \"@orderly.network/ui-orders\";\nimport { SharePnLConfig } from \"@orderly.network/ui-share\";\n\nexport const OrdersPage: React.FC<{ sharePnLConfig?: SharePnLConfig }> = (\n props,\n) => {\n const { sharePnLConfig } = props;\n const { t } = useTranslation();\n\n const ordersRef = useRef<OrderListInstance>(null);\n\n const onDownload = () => {\n ordersRef.current?.download?.();\n };\n\n return (\n <Flex\n // p={6}\n direction={\"column\"}\n itemAlign={\"start\"}\n gap={4}\n width=\"100%\"\n height=\"100%\"\n >\n <Flex width=\"100%\" justify=\"between\">\n <Text size=\"lg\">{t(\"common.orders\")}</Text>\n <Tooltip content={t(\"orders.download.tooltip\")}>\n <Button\n color=\"gray\"\n size=\"sm\"\n className=\"oui-bg-base-4\"\n onClick={onDownload}\n >\n {t(\"common.download\")}\n <TooltipIcon className=\"oui-text-base-contrast-36 oui-ml-[5px]\" />\n </Button>\n </Tooltip>\n </Flex>\n <Divider className=\"oui-w-full\" />\n {/* 26(title height) + 1(divider) + 32 (padding) */}\n <Box width=\"100%\" className=\"oui-h-[calc(100%_-_59px)]\">\n <OrdersWidget ref={ordersRef} sharePnLConfig={sharePnLConfig} />\n </Box>\n </Flex>\n );\n};\n\nconst TooltipIcon = React.forwardRef<SVGSVGElement, SVGProps<SVGSVGElement>>(\n (props, ref) => {\n return (\n <svg\n width=\"12\"\n height=\"12\"\n viewBox=\"0 0 12 12\"\n fill=\"currentColor\"\n xmlns=\"http://www.w3.org/2000/svg\"\n ref={ref}\n {...props}\n >\n <path d=\"M5.999 1.007a5 5 0 1 0 0 10 5 5 0 0 0 0-10m0 2.5a.5.5 0 1 1 0 1 .5.5 0 0 1 0-1m0 1.5a.5.5 0 0 1 .5.5v2.5a.5.5 0 0 1-1 0v-2.5a.5.5 0 0 1 .5-.5\" />\n </svg>\n );\n },\n);\n","export { APIManagerWidget } from \"./apiManager.widget\";\nexport { APIManagerPage } from \"./apiManager.page\";\n","import { APIManager } from \"./apiManager.ui\";\nimport { useApiManagerScript } from \"./apiManager.script\";\n\n\nexport const APIManagerWidget = (props?: {\n filterTags?: [string];\n keyStatus?: string;\n}) => {\n const state = useApiManagerScript(props);\n return <APIManager {...state} />;\n};\n","import { APIManagerWidget } from \"./apiManager.widget\";\n\n/**\n * API key manager page\n * @param filterTags filterTags\n * @param keyStatus filterTags default is \"ACTIVE\"\n * @returns\n */\nexport const APIManagerPage = (props: {\n filterTags?: [string];\n keyStatus?: string;\n}) => {\n const { filterTags, keyStatus = \"ACTIVE\" } = props;\n return <APIManagerWidget filterTags={filterTags} keyStatus={keyStatus}/>;\n};\n","export { SettingWidget } from \"./setting.widget\";\nexport { SettingPage } from \"./setting.page\";\n","import { useEffect, useState } from \"react\";\nimport {\n useAccount,\n useAccountInfo,\n useDebouncedCallback,\n useMutation,\n useLocalStorage,\n useOrderlyContext,\n} from \"@orderly.network/hooks\";\nimport { useAppContext } from \"@orderly.network/react-app\";\nimport { AccountStatusEnum } from \"@orderly.network/types\";\nimport { toast } from \"@orderly.network/ui\";\n\nconst ORDERLY_ORDER_SOUND_ALERT_KEY = \"orderly_order_sound_alert\";\n\nexport type SettingScriptReturns = {\n maintenance_cancel_orders?: boolean;\n setMaintainConfig: (maintenance_cancel_order_flag: boolean) => void;\n isSetting: boolean;\n canTouch: boolean;\n soundAlert: boolean;\n setSoundAlert: (value: boolean) => void;\n hasOrderFilledMedia: boolean;\n};\n\nexport const useSettingScript = (): SettingScriptReturns => {\n const { data, mutate: refresh } = useAccountInfo();\n const { wrongNetwork, disabledConnect } = useAppContext();\n const [update, { isMutating }] = useMutation(\"/v1/client/maintenance_config\");\n const [checked, setChecked] = useState(false);\n const { notification } = useOrderlyContext();\n\n const [soundAlert, setSoundAlert] = useLocalStorage<boolean>(\n ORDERLY_ORDER_SOUND_ALERT_KEY,\n notification?.orderFilled?.defaultOpen ?? false,\n );\n\n useEffect(() => {\n setChecked(data?.maintenance_cancel_orders || false);\n }, [data]);\n\n const updateCheckState = useDebouncedCallback((value: boolean) => {\n // if (value === data?.maintenance_cancel_orders) return;\n update({\n maintenance_cancel_order_flag: value,\n }).then((data) => {\n if (data.success) {\n toast.success(value ? \"Opened\" : \"Closed\");\n } else {\n setChecked(!value);\n }\n });\n }, 300);\n\n const setMaintainConfig = (maintenance_cancel_order_flag: boolean) => {\n setChecked(maintenance_cancel_order_flag);\n updateCheckState(maintenance_cancel_order_flag);\n };\n const { state } = useAccount();\n\n const canTouch =\n !wrongNetwork &&\n !disabledConnect &&\n (state.status === AccountStatusEnum.EnableTrading ||\n state.status === AccountStatusEnum.EnableTradingWithoutConnected);\n\n return {\n maintenance_cancel_orders: checked, //data?.maintenance_cancel_orders,\n setMaintainConfig,\n isSetting: false,\n canTouch,\n soundAlert,\n setSoundAlert,\n hasOrderFilledMedia: Boolean(notification?.orderFilled?.media),\n };\n};\n","import { FC } from \"react\";\nimport { useScreen } from \"@orderly.network/ui\";\nimport { SettingScriptReturns } from \"./setting.script\";\nimport { SettingDesktop } from \"./setting.ui.desktop\";\nimport { SettingMobile } from \"./setting.ui.mobile\";\n\nexport const Setting: FC<SettingScriptReturns> = (props) => {\n const { isMobile } = useScreen();\n if (isMobile) {\n return (\n <div className=\"oui-px-3\">\n <SettingMobile {...props} />\n </div>\n );\n }\n return <SettingDesktop {...props} />;\n};\n","import { FC } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { Card, Flex, Switch, Text } from \"@orderly.network/ui\";\nimport { AuthGuardTooltip } from \"@orderly.network/ui-connector\";\nimport type { SettingScriptReturns } from \"./setting.script\";\n\nexport const SettingDesktop: FC<SettingScriptReturns> = (props) => {\n const { t } = useTranslation();\n\n return (\n <>\n <Card\n title={t(\"portfolio.setting.systemUpgrade\")}\n id=\"portfolio-apikey-manager\"\n className=\"oui-bg-base-9 oui-font-semibold\"\n >\n <Flex\n direction={\"row\"}\n gap={4}\n width={\"100%\"}\n itemAlign={\"center\"}\n pt={4}\n className=\"oui-border-t-2 oui-border-line-6 oui-font-semibold\"\n >\n <Flex direction={\"column\"} itemAlign={\"start\"} className=\"oui-flex-1\">\n <Text intensity={80} size=\"base\">\n {t(\"portfolio.setting.cancelOpenOrders\")}\n </Text>\n <Text intensity={54} size=\"sm\">\n {t(\"portfolio.setting.cancelOpenOrders.description\")}\n </Text>\n </Flex>\n\n <AuthGuardTooltip align=\"end\">\n <Switch\n checked={props.maintenance_cancel_orders}\n onCheckedChange={(e) => {\n props.setMaintainConfig(e);\n }}\n disabled={props.isSetting || !props.canTouch}\n data-testid=\"oui-testid-setting-switch-btn\"\n />\n </AuthGuardTooltip>\n </Flex>\n </Card>\n\n {props.hasOrderFilledMedia && (\n <Card\n title={t(\"portfolio.setting.soundAlerts\")}\n id=\"portfolio-sound-alert-setting\"\n className=\"oui-bg-base-9 oui-font-semibold oui-mt-3\"\n >\n <Flex\n direction={\"row\"}\n gap={4}\n width={\"100%\"}\n itemAlign={\"center\"}\n pt={4}\n className=\"oui-border-t-2 oui-border-line-6 oui-font-semibold\"\n >\n <Flex\n direction={\"column\"}\n itemAlign={\"start\"}\n className=\"oui-flex-1\"\n >\n <Text intensity={54} size=\"sm\">\n {t(\"portfolio.setting.soundAlerts.description\")}\n </Text>\n </Flex>\n\n <AuthGuardTooltip align=\"end\">\n <Switch\n checked={props.soundAlert}\n onCheckedChange={(checked) => props.setSoundAlert(checked)}\n disabled={!props.canTouch}\n data-testid=\"oui-testid-setting-sound-switch-btn\"\n />\n </AuthGuardTooltip>\n </Flex>\n </Card>\n )}\n </>\n );\n};\n","import { FC, useState } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n Card,\n Flex,\n Switch,\n Text,\n ChevronRightIcon,\n} from \"@orderly.network/ui\";\nimport { AuthGuardTooltip } from \"@orderly.network/ui-connector\";\nimport { LanguageSwitcherWidget } from \"@orderly.network/ui-scaffold\";\nimport type { SettingScriptReturns } from \"./setting.script\";\n\nexport const SettingMobile: FC<SettingScriptReturns> = (props) => {\n const { t } = useTranslation();\n const [open, setOpen] = useState<boolean>(false);\n const onLanguageChange = () => {\n setOpen(true);\n };\n\n return (\n <>\n <Flex mt={1} p={4} intensity={900} r=\"xl\" itemAlign=\"center\">\n <LanguageSwitcherWidget open={open} onOpenChange={setOpen} />\n <Flex\n className=\"oui-cursor-pointer\"\n itemAlign=\"center\"\n width=\"100%\"\n onClick={onLanguageChange}\n >\n <Text\n size=\"base\"\n weight=\"semibold\"\n intensity={80}\n className=\"oui-ml-2\"\n >\n {t(\"languageSwitcher.language\")}\n </Text>\n <ChevronRightIcon\n size={18}\n className=\"oui-ml-auto oui-text-base-contrast-36\"\n />\n </Flex>\n </Flex>\n\n <Card\n // @ts-ignore\n title={\n <div className=\"oui-text-sm\">\n {t(\"portfolio.setting.systemUpgrade\")}\n </div>\n }\n id=\"portfolio-apikey-manager\"\n className=\"oui-bg-base-9 oui-font-semibold oui-mt-2\"\n classNames={{ root: \"oui-p-4\", content: \"!oui-pt-3\" }}\n >\n <Flex\n direction={\"row\"}\n gap={4}\n width={\"100%\"}\n itemAlign={\"center\"}\n pt={3}\n className=\"oui-font-semibold oui-border-t-2 oui-border-line-6\"\n >\n <Flex\n direction={\"column\"}\n itemAlign={\"start\"}\n className=\"oui-flex-1 oui-gap-2\"\n >\n <Text intensity={80} size=\"xs\">\n {t(\"portfolio.setting.cancelOpenOrders\")}\n </Text>\n <Text intensity={36} size=\"2xs\" className=\"oui-font-normal\">\n {t(\"portfolio.setting.cancelOpenOrders.description\")}\n </Text>\n <AuthGuardTooltip>\n <Switch\n className=\"oui-mt-1\"\n checked={props.maintenance_cancel_orders}\n onCheckedChange={(e) => {\n props.setMaintainConfig(e);\n }}\n disabled={props.isSetting || !props.canTouch}\n data-testid=\"oui-testid-setting-switch-btn\"\n />\n </AuthGuardTooltip>\n </Flex>\n </Flex>\n </Card>\n\n {props.hasOrderFilledMedia && (\n <Card\n // @ts-ignore\n title={\n <div className=\"oui-text-sm\">\n {t(\"portfolio.setting.soundAlerts\")}\n </div>\n }\n id=\"portfolio-sound-alert-setting\"\n className=\"oui-bg-base-9 oui-font-semibold oui-mt-2\"\n classNames={{ root: \"oui-p-4\", content: \"!oui-pt-3\" }}\n >\n <Flex\n direction={\"row\"}\n gap={4}\n width={\"100%\"}\n itemAlign={\"center\"}\n pt={3}\n className=\"oui-font-semibold oui-border-t-2 oui-border-line-6\"\n >\n <Flex\n direction={\"column\"}\n itemAlign={\"start\"}\n className=\"oui-flex-1 oui-gap-2\"\n >\n <Text intensity={36} size=\"2xs\" className=\"oui-font-normal\">\n {t(\"portfolio.setting.soundAlerts.description\")}\n </Text>\n <AuthGuardTooltip>\n <Switch\n className=\"oui-mt-1\"\n checked={props.soundAlert}\n onCheckedChange={(e) => {\n props.setSoundAlert(e);\n }}\n disabled={!props.canTouch}\n data-testid=\"oui-testid-setting-sound-switch-btn\"\n />\n </AuthGuardTooltip>\n </Flex>\n </Flex>\n </Card>\n )}\n </>\n );\n};\n","import React from \"react\";\nimport { useSettingScript } from \"./setting.script\";\nimport { Setting } from \"./setting.ui\";\n\nexport const SettingWidget: React.FC = () => {\n const state = useSettingScript();\n return <Setting {...state} />;\n};\n","import React from \"react\";\nimport { SettingWidget } from \"./setting.widget\";\n\nexport const SettingPage: React.FC = () => {\n return <SettingWidget />;\n};\n","export { AssetsPage } from \"./page\";\nexport {\n AssetsWidget,\n AssetsDataTableWidget,\n} from \"./assetsPage/assets.widget\";\nexport type { AssetsWidgetProps } from \"./assetsPage/assets.widget\";\nexport { AssetsTable, AssetsDataTable } from \"./assetsPage/assets.ui.desktop\";\nexport { AssetsTableMobile } from \"./assetsPage/assets.ui.mobile\";\n","import React from \"react\";\nimport { useAccount } from \"@orderly.network/hooks\";\nimport { DataTableClassNames, useScreen } from \"@orderly.network/ui\";\nimport { useAssetsScript } from \"./assets.script\";\nimport type { useAssetsScriptReturn } from \"./assets.script\";\nimport { AssetsDataTable, AssetsTable } from \"./assets.ui.desktop\";\nimport { AssetsTableMobile } from \"./assets.ui.mobile\";\n\nexport type AssetsWidgetProps = useAssetsScriptReturn;\n\nexport type AssetsDataTableWidgetProps = {\n classNames?: {\n root?: string;\n desc?: string;\n scrollRoot?: string;\n };\n tbClassName?: string;\n dataTableClassNames?: DataTableClassNames;\n};\n\nexport const AssetsDataTableWidget: React.FC<AssetsDataTableWidgetProps> = (\n props,\n) => {\n const assetsState = useAssetsScript();\n const accountState = useAccount();\n return <AssetsDataTable {...assetsState} {...accountState} {...props} />;\n};\n\nexport const AssetsWidget: React.FC = () => {\n const assetsState = useAssetsScript();\n const accountState = useAccount();\n const { isMobile } = useScreen();\n if (isMobile) {\n return <AssetsTableMobile {...assetsState} {...accountState} />;\n }\n return <AssetsTable {...assetsState} {...accountState} />;\n};\n","import { useCallback, useEffect, useMemo } from \"react\";\nimport {\n useAccount,\n useCollateral,\n useLocalStorage,\n useIndexPricesStream,\n useTokensInfo,\n} from \"@orderly.network/hooks\";\nimport { account } from \"@orderly.network/perp\";\nimport { useCanTrade, useDataTap } from \"@orderly.network/react-app\";\nimport { AccountStatusEnum, EMPTY_LIST } from \"@orderly.network/types\";\nimport { modal } from \"@orderly.network/ui\";\nimport {\n DepositAndWithdrawWithDialogId,\n TransferDialogId,\n} from \"@orderly.network/ui-transfer\";\nimport { Decimal, zero } from \"@orderly.network/utils\";\nimport { useAccountsData, useAssetsMultiFilter } from \"../../../hooks\";\nimport { useAssetTotalValue } from \"../../../hooks/useAssetTotalValue\";\nimport { ORDERLY_ASSETS_VISIBLE_KEY } from \"../type\";\nimport { useAssetsColumns } from \"./assets.column\";\n\nexport const useAssetsScript = () => {\n const [visible, setVisible] = useLocalStorage<boolean>(\n ORDERLY_ASSETS_VISIBLE_KEY,\n true,\n );\n\n const { state, subAccount, isMainAccount } = useAccount();\n const { holding = [] } = useCollateral();\n const { getIndexPrice } = useIndexPricesStream();\n\n const tokensInfo = useTokensInfo();\n\n const subAccounts = state.subAccounts ?? [];\n\n useEffect(() => {\n if (holding.length > 0) {\n subAccount.refresh();\n }\n }, [holding]);\n\n // Use the extracted total value hook\n const totalValue = useAssetTotalValue();\n\n const toggleVisible = () => {\n // @ts-ignore\n setVisible((visible: boolean) => !visible);\n };\n\n const assetsOptions = useMemo(() => {\n return tokensInfo?.map((item) => ({\n label: item.token,\n value: item.token,\n }));\n }, [tokensInfo]);\n\n // Use the extracted accounts data hook\n const allAccounts = useAccountsData();\n\n // Use the extracted account and asset filter hook\n const {\n selectedAccount,\n selectedAsset,\n filteredData: filtered,\n onFilter,\n } = useAssetsMultiFilter(allAccounts);\n\n // Enhanced filtered data with additional calculations for children\n const enhancedFiltered = useMemo(() => {\n return filtered.map((accountData) => {\n // Enhance each child (holding) with calculated fields\n const enhancedChildren =\n accountData.children?.map((holding) => {\n const tokenInfo = tokensInfo?.find(\n (item) => item.token === holding.token,\n );\n\n // Use extracted function for index price calculation\n const indexPrice = getIndexPrice(holding.token);\n\n // Use extracted function for asset value calculation\n const assetValue = new Decimal(holding.holding)\n .mul(indexPrice)\n .toNumber();\n\n // Calculate collateral ratio for this token\n const collateralRatio = tokenInfo\n ? account.collateralRatio({\n baseWeight: tokenInfo.base_weight ?? 0,\n discountFactor: tokenInfo.discount_factor ?? 0,\n collateralQty: holding.holding,\n collateralCap: tokenInfo?.user_max_qty ?? holding.holding,\n indexPrice: indexPrice,\n })\n : zero;\n\n // Calculate collateral contribution for this token\n const collateralContribution = account.collateralContribution({\n collateralQty: holding.holding,\n collateralCap: tokenInfo?.user_max_qty ?? holding.holding,\n collateralRatio: collateralRatio.toNumber(),\n indexPrice: indexPrice,\n });\n\n return {\n ...holding,\n indexPrice,\n assetValue,\n collateralRatio,\n collateralContribution,\n };\n }) || [];\n\n return {\n ...accountData,\n children: enhancedChildren,\n };\n });\n }, [filtered, getIndexPrice, tokensInfo]);\n\n const handleTransfer = useCallback((accountId: string, token: string) => {\n if (!accountId) {\n return;\n }\n modal.show(TransferDialogId, {\n toAccountId: accountId,\n token,\n });\n }, []);\n\n const handleConvert = (accountId: string, token: string) => {\n modal.show(\"ConvertDialogId\", {\n accountId,\n token,\n });\n };\n\n const showTransfer = isMainAccount ? subAccounts.length > 0 : true;\n\n const assetsColumns = useAssetsColumns({\n onTransfer: showTransfer ? handleTransfer : undefined,\n onConvert: handleConvert,\n });\n\n const openDepositAndWithdraw = useCallback(\n (viewName: \"deposit\" | \"withdraw\") => {\n modal.show(DepositAndWithdrawWithDialogId, {\n activeTab: viewName,\n });\n },\n [],\n );\n\n const onDeposit = useCallback(() => {\n openDepositAndWithdraw(\"deposit\");\n }, []);\n\n const onWithdraw = useCallback(() => {\n openDepositAndWithdraw(\"withdraw\");\n }, []);\n\n // Use enhanced filtered data with calculated children\n const dataSource = useDataTap(enhancedFiltered, {\n accountStatus:\n state.status === AccountStatusEnum.EnableTradingWithoutConnected\n ? AccountStatusEnum.EnableTradingWithoutConnected\n : AccountStatusEnum.EnableTrading,\n });\n\n const canTrade = useCanTrade();\n\n return {\n columns: assetsColumns,\n dataSource,\n visible: visible as boolean,\n onToggleVisibility: toggleVisible,\n selectedAccount,\n selectedAsset,\n onFilter,\n totalValue,\n hasSubAccount: subAccounts.length > 0,\n onDeposit,\n onWithdraw,\n holding,\n assetsOptions: assetsOptions ?? EMPTY_LIST,\n canTrade,\n };\n};\n\nexport type useAssetsScriptReturn = ReturnType<typeof useAssetsScript> &\n ReturnType<typeof useAccount>;\n","import React from \"react\";\nimport { useTokensInfo } from \"@orderly.network/hooks\";\nimport { useWalletConnector } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { ChainNamespace } from \"@orderly.network/types\";\nimport { Button, Flex, Text, TokenIcon } from \"@orderly.network/ui\";\nimport type { Column } from \"@orderly.network/ui\";\n\nexport interface ColumnsOptions {\n onTransfer?: (accountId: string, token: string) => void;\n onConvert?: (accountId: string, token: string) => void;\n}\n\n// Define the enhanced holding interface with calculated fields\ninterface EnhancedHolding {\n token: string;\n holding: number;\n indexPrice: number;\n assetValue: number;\n collateralRatio: number;\n collateralContribution: number;\n account_id: string;\n}\n\nexport const useAssetsColumns = (options: ColumnsOptions) => {\n const { t } = useTranslation();\n const tokensInfo = useTokensInfo();\n const { namespace } = useWalletConnector();\n const { onTransfer, onConvert } = options;\n const columns = React.useMemo<Column[]>(() => {\n return [\n {\n title: t(\"portfolio.overview.column.token\"),\n dataIndex: \"token\",\n align: \"left\",\n width: 150,\n render(val: string) {\n return (\n <Flex itemAlign=\"center\" gap={2}>\n <TokenIcon name={val} />\n {val}\n </Flex>\n );\n },\n },\n {\n title: t(\"portfolio.overview.column.qty\"),\n dataIndex: \"holding\",\n align: \"left\",\n width: 140,\n render(val: number, record) {\n const findToken = tokensInfo?.find(\n ({ token }) => token === record.token,\n );\n return (\n <Text.numeral dp={findToken?.decimals ?? 6} padding={false}>\n {val}\n </Text.numeral>\n );\n },\n },\n {\n title: t(\"portfolio.overview.column.indexPrice\"),\n dataIndex: \"indexPrice\",\n align: \"left\",\n width: 140,\n render(val: number) {\n return (\n <Text.numeral rule=\"price\" dp={6} currency=\"$\" padding={false}>\n {val}\n </Text.numeral>\n );\n },\n },\n {\n title: t(\"portfolio.overview.column.assetValue\"),\n dataIndex: \"assetValue\",\n align: \"left\",\n width: 140,\n render(val: number) {\n return (\n <Text.numeral rule=\"price\" dp={6} currency=\"$\" padding={false}>\n {val}\n </Text.numeral>\n );\n },\n },\n {\n title: t(\"portfolio.overview.column.collateralRatio\"),\n dataIndex: \"collateralRatio\",\n align: \"left\",\n width: 140,\n render(val: number) {\n return (\n <Text.numeral dp={2} suffix=\"%\">\n {val * 100}\n </Text.numeral>\n );\n },\n },\n {\n title: t(\"transfer.deposit.collateralContribution\"),\n dataIndex: \"collateralContribution\",\n align: \"left\",\n width: 140,\n render(val: number) {\n return (\n <Text.numeral rule=\"price\" dp={6} currency=\"$\" padding={false}>\n {val}\n </Text.numeral>\n );\n },\n },\n {\n title: null,\n dataIndex: \"account_id\",\n align: \"center\",\n width: 180,\n render(id: string, record: EnhancedHolding) {\n const { token } = record;\n return (\n <Flex itemAlign=\"center\" justify=\"end\" gap={3}>\n {token !== \"USDC\" &&\n namespace !== ChainNamespace.solana &&\n typeof onConvert === \"function\" && (\n <Button\n size={\"sm\"}\n variant={\"outlined\"}\n color={\"secondary\"}\n onClick={() => onConvert?.(id, token)}\n >\n {t(\"transfer.convert\")}\n </Button>\n )}\n {typeof onTransfer === \"function\" && (\n <Button\n size={\"sm\"}\n variant={\"outlined\"}\n color={\"secondary\"}\n onClick={() => onTransfer?.(id, token)}\n >\n {t(\"common.transfer\")}\n </Button>\n )}\n </Flex>\n );\n },\n },\n ];\n }, [t, tokensInfo, onTransfer, onConvert, namespace]);\n return columns;\n};\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport React, { useMemo } from \"react\";\nimport { useWalletConnector } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { ChainNamespace } from \"@orderly.network/types\";\nimport {\n Button,\n cn,\n TokenIcon,\n Text,\n formatAddress,\n DataFilter,\n modal,\n Flex,\n EmptyDataState,\n} from \"@orderly.network/ui\";\nimport { SelectOption } from \"@orderly.network/ui/src/select/withOptions\";\nimport type { useAssetsScriptReturn } from \"./assets.script\";\nimport { AccountType } from \"./assets.ui.desktop\";\n\nconst AccountTag: React.FC<{ name: string }> = ({ name }) => {\n return (\n <div className=\"oui-mt-2 oui-flex oui-h-[18px] oui-w-fit oui-items-center oui-rounded oui-bg-white/[0.06] oui-px-2 oui-text-2xs oui-font-semibold oui-text-base-contrast-36\">\n {name}\n </div>\n );\n};\n\ntype AssetMobileItemProps = {\n item: any;\n};\n\nconst AssetMobileItem: React.FC<AssetMobileItemProps> = (props) => {\n const { item } = props;\n const { t } = useTranslation();\n const { namespace } = useWalletConnector();\n return (\n <div className=\"oui-flex oui-flex-col oui-gap-2 oui-rounded-xl oui-bg-base-9 oui-p-2\">\n <Flex\n width={\"100%\"}\n justify={\"between\"}\n itemAlign={\"center\"}\n className=\"oui-gap-x-0.5\"\n >\n <Flex\n className=\"oui-w-1/3 oui-truncate\"\n itemAlign={\"start\"}\n direction={\"column\"}\n >\n <div className=\"oui-text-2xs oui-font-semibold oui-text-base-contrast-36\">\n {t(\"common.token\")}\n </div>\n <Flex\n gap={1}\n justify={\"start\"}\n itemAlign={\"center\"}\n className=\"oui-text-xs oui-font-semibold oui-text-base-contrast-80\"\n >\n <TokenIcon name={item.token} size=\"2xs\" />\n {item.token}\n </Flex>\n </Flex>\n <Flex\n className=\"oui-w-1/3 oui-truncate\"\n itemAlign={\"start\"}\n direction={\"column\"}\n >\n <div className=\"oui-text-2xs oui-font-semibold oui-text-base-contrast-36\">\n {t(\"common.qty\")}\n </div>\n <Text.numeral\n className=\"oui-truncate\"\n size=\"xs\"\n dp={6}\n padding={false}\n >\n {item.holding}\n </Text.numeral>\n </Flex>\n <Flex\n className=\"oui-w-1/3 oui-truncate\"\n itemAlign={\"start\"}\n direction={\"column\"}\n >\n <div className=\"oui-w-full oui-text-end oui-text-2xs oui-font-semibold oui-text-base-contrast-36\">\n {t(\"common.indexPrice\")}\n </div>\n <Flex\n gap={1}\n width={\"100%\"}\n justify={\"end\"}\n itemAlign={\"center\"}\n className=\"oui-text-end oui-font-semibold oui-text-base-contrast-80\"\n >\n <Text.numeral\n size=\"xs\"\n rule=\"price\"\n dp={6}\n currency=\"$\"\n padding={false}\n >\n {item.indexPrice}\n </Text.numeral>\n <div className=\"oui-text-end oui-text-2xs oui-text-base-contrast-36\">\n USDC\n </div>\n </Flex>\n </Flex>\n </Flex>\n <Flex\n width={\"100%\"}\n justify={\"between\"}\n itemAlign={\"center\"}\n className=\"oui-gap-x-0.5\"\n >\n <Flex\n className=\"oui-w-1/3 oui-truncate\"\n itemAlign={\"start\"}\n direction={\"column\"}\n >\n <div className=\"oui-text-2xs oui-font-semibold oui-text-base-contrast-36\">\n {t(\"portfolio.overview.column.assetValue\")}\n </div>\n <Text.numeral\n size=\"xs\"\n intensity={80}\n className=\"oui-truncate oui-font-semibold\"\n rule=\"price\"\n dp={6}\n currency=\"$\"\n padding={false}\n >\n {item.assetValue}\n </Text.numeral>\n </Flex>\n <Flex\n className=\"oui-w-1/3 oui-truncate\"\n itemAlign={\"start\"}\n direction={\"column\"}\n >\n <div className=\"oui-text-2xs oui-font-semibold oui-text-base-contrast-36\">\n {t(\"portfolio.overview.column.collateralRatio\")}\n </div>\n <Text.numeral size=\"xs\" dp={2} suffix=\"%\">\n {item.collateralRatio * 100}\n </Text.numeral>\n </Flex>\n <Flex\n className=\"oui-w-1/3 oui-truncate\"\n itemAlign={\"start\"}\n direction={\"column\"}\n >\n <div className=\"oui-w-full oui-text-end oui-text-2xs oui-font-semibold oui-text-base-contrast-36\">\n {t(\"transfer.deposit.collateralContribution\")}\n </div>\n <Flex\n gap={1}\n width={\"100%\"}\n justify={\"end\"}\n itemAlign={\"center\"}\n className=\"oui-text-end oui-font-semibold oui-text-base-contrast-80\"\n >\n <Text.numeral\n size=\"xs\"\n rule=\"price\"\n dp={6}\n currency=\"$\"\n padding={false}\n >\n {item.collateralContribution}\n </Text.numeral>\n <div className=\"oui-text-end oui-text-2xs oui-text-base-contrast-36\">\n USDC\n </div>\n </Flex>\n </Flex>\n </Flex>\n <Flex justify={\"between\"} itemAlign={\"center\"} gap={2}>\n {item.token !== \"USDC\" && namespace !== ChainNamespace.solana && (\n <Button\n fullWidth\n variant=\"outlined\"\n size=\"sm\"\n color=\"gray\"\n onClick={() => {\n modal.show(\"ConvertSheetId\", {\n accountId: item.account_id,\n token: item.token,\n });\n }}\n className={cn(\n \"oui-flex-1 oui-border-white/[0.36] oui-text-base-contrast-54\",\n )}\n >\n {t(\"transfer.convert\")}\n </Button>\n )}\n <Button\n fullWidth\n variant=\"outlined\"\n size=\"sm\"\n color=\"gray\"\n onClick={() => {\n modal.show(\"TransferSheetId\", {\n accountId: item.account_id,\n token: item.token,\n });\n }}\n className={cn(\n \"oui-flex-1 oui-border-white/[0.36] oui-text-base-contrast-54\",\n )}\n >\n {t(\"common.transfer\")}\n </Button>\n </Flex>\n </div>\n );\n};\n\nexport const AssetsTableMobile: React.FC<useAssetsScriptReturn> = (props) => {\n const { t } = useTranslation();\n\n const {\n assetsOptions,\n state,\n isMainAccount,\n dataSource,\n selectedAccount,\n selectedAsset,\n onFilter,\n } = props;\n\n const subAccounts = state.subAccounts ?? [];\n\n const ALL_ACCOUNTS: SelectOption = {\n label: t(\"common.allAccount\"),\n value: AccountType.ALL,\n };\n\n const MAIN_ACCOUNT: SelectOption = {\n label: t(\"common.mainAccount\"),\n value: AccountType.MAIN,\n };\n\n const ALL_ASSETS: SelectOption = {\n label: \"All assets\",\n value: \"all\",\n };\n\n const memoizedOptions = useMemo(() => {\n if (Array.isArray(subAccounts) && subAccounts.length) {\n return [\n ALL_ACCOUNTS,\n MAIN_ACCOUNT,\n ...subAccounts.map<SelectOption>((value) => ({\n value: value.id,\n label: value?.description || formatAddress(value?.id),\n })),\n ];\n }\n return [ALL_ACCOUNTS, MAIN_ACCOUNT];\n }, [subAccounts]);\n\n // Create asset options from holding data - optimized and consistent with desktop\n const memoizedAssets = useMemo(() => {\n return [ALL_ASSETS, ...assetsOptions];\n }, [assetsOptions]);\n\n if (!props.canTrade) {\n return (\n <Flex\n direction={\"column\"}\n height={\"100%\"}\n itemAlign={\"center\"}\n justify={\"center\"}\n mt={10}\n >\n <EmptyDataState />\n </Flex>\n );\n }\n\n return (\n <div className={cn(\"oui-flex oui-flex-col oui-gap-1 oui-px-1 oui-pb-4\")}>\n {isMainAccount && (\n <DataFilter\n onFilter={onFilter}\n className=\"oui-border-none oui-py-2\"\n items={[\n {\n size: \"sm\",\n type: \"picker\",\n name: \"account\",\n value: selectedAccount,\n options: memoizedOptions,\n },\n {\n size: \"sm\",\n type: \"picker\",\n name: \"asset\",\n value: selectedAsset,\n options: memoizedAssets,\n },\n ]}\n />\n )}\n <div className=\"oui-flex oui-flex-col oui-gap-1\">\n {dataSource?.map((assets, index) => {\n return (\n <React.Fragment key={`item-${index}`}>\n <AccountTag name={assets.description ?? \"sub account\"} />\n {Array.isArray(assets.children) &&\n assets.children.map((child) => (\n <AssetMobileItem\n item={child}\n key={`${child.token}-${child.account_id}`}\n />\n ))}\n </React.Fragment>\n );\n })}\n </div>\n </div>\n );\n};\n","import React from \"react\";\nimport { AssetsWidget } from \"./assetsPage/assets.widget\";\nimport type { AssetsWidgetProps } from \"./assetsPage/assets.widget\";\n\nexport type AssetsPageProps = AssetsWidgetProps;\n\nexport const AssetsPage: React.FC = () => {\n return <AssetsWidget />;\n};\n","export { HistoryPage } from \"./history.page\";\nexport { HistoryWidget } from \"./history.page\";\n","import React from \"react\";\nimport { HistoryDataGroupWidget } from \"../overview/historyDataGroup\";\n\nexport const HistoryWidget: React.FC = () => {\n return <HistoryDataGroupWidget />;\n};\n\nexport const HistoryPage: React.FC = () => {\n return <HistoryDataGroupWidget />;\n};\n"]}
|