@orderly.network/trading 2.6.3-alpha.0 → 2.7.0-alpha.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.
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/hooks/useTradingLocalStorage.ts","../src/hooks/usePositionsCount.ts","../src/hooks/usePendingOrderCount.ts","../src/hooks/index.ts","../src/provider/tradingPageContext.tsx","../src/components/desktop/dataList/dataList.script.tsx","../src/components/desktop/dataList/setting/setting.ui.tsx","../src/components/desktop/dataList/setting/setting.script.tsx","../src/components/desktop/dataList/setting/setting.widget.tsx","../src/components/desktop/dataList/setting/index.ts","../src/components/base/positionHeader/positionHeader.ui.tsx","../src/components/base/positionHeader/positionHeader.script.tsx","../src/components/base/positionHeader/positionHeader.widget.tsx","../src/components/base/positionHeader/index.ts","../src/components/desktop/dataList/dataList.ui.tsx","../src/components/desktop/dataList/dataList.widget.tsx","../src/components/desktop/dataList/index.ts","../src/components/base/lastTrades/lastTrades.ui.tsx","../src/components/base/lastTrades/lastTrades.script.tsx","../src/components/base/lastTrades/lastTrades.widget.tsx","../src/components/base/lastTrades/index.ts","../src/components/desktop/assetView/faucet/faucet.ui.tsx","../src/components/desktop/assetView/faucet/faucet.script.tsx","../src/components/desktop/assetView/faucet/faucet.widget.tsx","../src/components/desktop/assetView/assetView.ui.tsx","../src/components/desktop/assetView/assetView.script.tsx","../src/components/desktop/assetView/assetView.widget.tsx","../src/components/desktop/assetView/index.ts","../src/components/base/orderBook/orderContext.tsx","../src/components/base/orderBook/types.ts","../src/components/base/orderBook/cellBar.tsx","../src/components/desktop/orderBook/cell.desktop.tsx","../src/components/desktop/orderBook/listBox.desktop.tsx","../src/components/desktop/orderBook/asks.desktop.tsx","../src/components/desktop/orderBook/bids.desktop.tsx","../src/components/desktop/orderBook/depthSelect.desktop.tsx","../src/components/desktop/orderBook/header.desktop.tsx","../src/components/base/orderBook/midPriceView.tsx","../src/components/base/orderBook/markPrice.tsx","../src/components/desktop/orderBook/markPrice.desktop.tsx","../src/components/desktop/orderBook/index.desktop.tsx","../src/components/mobile/fundingRate/fundingRate.ui.tsx","../src/components/mobile/fundingRateModal/fundingRateModal.script.tsx","../src/components/mobile/fundingRateModal/fundingRateModal.ui.tsx","../src/components/mobile/fundingRateModal/fundingRateModal.widget.tsx","../src/components/mobile/fundingRate/fundingRate.script.tsx","../src/components/mobile/fundingRate/fundingRate.widget.tsx","../src/components/mobile/fundingRate/index.ts","../src/components/mobile/orderBook/cell.tsx","../src/components/mobile/orderBook/listBox.tsx","../src/components/mobile/orderBook/asks.tsx","../src/components/mobile/orderBook/bids.tsx","../src/components/mobile/orderBook/depthSelect.tsx","../src/components/mobile/orderBook/header.tsx","../src/components/mobile/orderBook/markPrice.tsx","../src/components/mobile/orderBook/index.tsx","../src/components/base/orderBook/orderBook.ui.tsx","../src/utils/utils.ts","../src/components/base/orderBook/orderBook.script.tsx","../src/components/base/orderBook/orderBook.widget.tsx","../src/components/base/orderBook/index.ts","../src/components/desktop/riskRate/riskRate.ui.tsx","../src/components/desktop/riskRate/riskRate.script.tsx","../src/components/desktop/riskRate/riskRate.widget.tsx","../src/components/desktop/riskRate/index.ts","../src/components/desktop/orderBookAndTrades/orderBookAndTrades.ui.tsx","../src/components/desktop/orderBookAndTrades/orderBookAndTrades.script.tsx","../src/components/desktop/orderBookAndTrades/orderBookAndTrades.widget.tsx","../src/components/desktop/orderBookAndTrades/index.ts","../src/components/desktop/layout/switchLayout.tsx","../src/components/mobile/topTab/topTab.script.tsx","../src/components/mobile/tradingview/tradingview.script.tsx","../src/components/base/icons.tsx","../src/components/mobile/tradingview/tradingview.ui.tsx","../src/components/mobile/tradingview/tradingview.widget.tsx","../src/components/mobile/lastTrades/lastTrades.widget.tsx","../src/components/mobile/tradeData/tradeData.ui.tsx","../src/components/mobile/tradeData/tradeData.script.tsx","../src/components/mobile/tradeData/tradeData.widget.tsx","../src/components/mobile/tradeData/index.ts","../src/components/mobile/topTab/topTab.ui.tsx","../src/components/mobile/topTab/topTab.widget.tsx","../src/components/mobile/topTab/index.ts","../src/components/mobile/orderBookAndEntry/orderBookAndEntry.ui.tsx","../src/components/mobile/orderBookAndEntry/orderBookAndEntry.script.tsx","../src/components/mobile/orderBookAndEntry/orderBookAndEntry.widget.tsx","../src/components/mobile/orderBookAndEntry/index.ts","../src/components/mobile/dataList/dataList.script.tsx","../src/components/mobile/dataList/dataList.ui.tsx","../src/components/mobile/dataList/dataList.widget.tsx","../src/components/mobile/dataList/index.ts","../src/index.ts","../src/components/desktop/layout/splitLayout/splitLayout.tsx","../src/components/desktop/layout/splitLayout/splitLineBar.tsx","../src/components/mobile/bottomNavBar/bottomNavBar.ui.tsx","../src/components/mobile/bottomNavBar/account/account.widget.tsx","../src/components/mobile/bottomNavBar/account/account.script.tsx","../src/components/mobile/accountSheet/accountSheet.ui.tsx","../src/components/mobile/accountSheet/icons.tsx","../src/components/mobile/accountSheet/accountSheet.script.tsx","../src/components/mobile/accountSheet/accountSheet.widget.tsx","../src/components/mobile/bottomNavBar/account/account.ui.tsx","../src/components/mobile/bottomNavBar/balance/balance.ui.tsx","../src/components/mobile/bottomNavBar/balance/balance.script.tsx","../src/components/mobile/bottomNavBar/balance/balance.widget.tsx","../src/components/mobile/bottomNavBar/chain/chain.ui.tsx","../src/components/mobile/bottomNavBar/chain/chain.script.tsx","../src/components/mobile/bottomNavBar/chain/chain.widget.tsx","../src/components/mobile/bottomNavBar/bottomNavBar.script.tsx","../src/components/mobile/bottomNavBar/bottomNavBar.widget.tsx","../src/components/mobile/portfolioSheet/portfolioSheet.ui.tsx","../src/components/mobile/portfolioSheet/portfolioSheet.script.tsx","../src/components/mobile/portfolioSheet/riskIndicator.tsx","../src/components/mobile/portfolioSheet/portfolioSheet.widget.tsx","../src/components/mobile/fundingRateModal/index.ts","../src/pages/trading/trading.ui.tsx","../src/pages/trading/trading.ui.desktop.tsx","../src/components/desktop/layout/removablePanel.tsx","../src/pages/trading/trading.script.tsx","../src/components/desktop/layout/useSplitPersistent.ts","../src/pages/trading/hooks/useFirstTimeDeposit.ts","../src/pages/trading/trading.ui.mobile.tsx","../src/pages/trading/trading.widget.tsx","../src/provider/tradingPageProvider.tsx","../src/pages/trading/trading.page.tsx"],"names":["useLocalStorage","useTradingLocalStorage","init_useTradingLocalStorage","__esmMin","props","unPnlPriceBasis","setUnPnlPriceBasic","pnlNotionalDecimalPrecision","setPnlNotionalDecimalPrecision","showAllSymbol","setShowAllSymbol","hideAssets","setHideAssets","useMemo","usePositionStream","useDataTap","usePositionsCount","init_usePositionsCount","symbol","data","count","useOrderStream","AlgoOrderRootType","OrderStatus","TabType","usePendingOrderCount","init_usePendingOrderCount","pendingOrdersPageSizeKey","tpslOrdersPageSizeKey","pendingOrders","pendingCount","tpslOrders","tpslCount","pendingOrderCount","tpSlOrderCount","init_hooks","createContext","useContext","TradingPageContext","useTradingPageContext","init_tradingPageContext","useDataListScript","init_dataList_script","current","sharePnLConfig","includedPendingOrder","localStorage","onSymbolChange","positionCount","useState","Button","Checkbox","Divider","DropdownMenuContent","DropdownMenuRoot","DropdownMenuTrigger","Flex","SettingFillIcon","Text","useTranslation","jsx","jsxs","Setting","UnPnlPriceBasisCheckBox","DecimalPrecisionCheckbox","RadioButton","SelIcon","UnselIcon","init_setting_ui","open","setOpen","t","checked","e","value","onValueChange","sel","label","onCheckChange","useSettingScript","init_setting_script","SettingWidget","init_setting_widget","state","setting_exports","__export","init_setting","Statistic","useScreen","Decimal","PositionHeader","MobileLayout","DesktopLayout","UnrealPnL","Notional","init_positionHeader_ui","isMobile","unrealPnLClsName","unrealPnLROIClsName","usePositionHeaderScript","init_positionHeader_script","inputs","calcMode","aggregated","unrealPnL","unrealPnlROI","notional","PositionHeaderWidget","init_positionHeader_widget","positionHeader_exports","init_positionHeader","React","Box","InfoCircleIcon","TabPanel","Tabs","Tooltip","DesktopOrderListWidget","LiquidationWidget","PositionHistoryWidget","PositionsWidget","LazySettingWidget","LazyPositionHeaderWidget","DataList","LiquidationTab","PositionsView","init_dataList_ui","mod","DataListWidget","init_dataList_widget","dataList_exports","init_dataList","cn","Grid","ListView","OrderSide","commifyOptional","LastTrades","Row","Header","List","init_lastTrades_ui","left","mid","right","classNames","item","index","useMarketTradeStream","useSymbolsInfo","useLastTradesScript","init_lastTrades_script","isLoading","config","base","quote","baseDp","quoteDp","LastTradesWidget","init_lastTrades_widget","lastTrades_exports","init_lastTrades","FaucetUi","init_faucet_ui","useAccount","useConfig","useMutation","useWalletConnector","AccountStatusEnum","ChainNamespace","isTestnet","modal","toast","useFaucetScript","connectedChain","namespace","account","operatorUrl","getTestUSDC","isMutating","loading","setLoading","showFaucet","message","res","resolve","error","init_faucet_script","FaucetWidget","init_faucet_widget","useCallback","useAppContext","ArrowDownShortIcon","EyeIcon","EyeCloseIcon","ChevronDownIcon","gradientTextVariants","AuthGuard","LTVRiskTooltipWidget","Fragment","calculateTextColor","useCurrentStatusText","TooltipContent","TotalValue","AssetDetail","LTVDetail","AssetValueList","AssetView","init_assetView_ui","val","wrongNetwork","disabledConnect","statusText","description","formula","totalValue","visible","onToggleVisibility","unit","rule","placeholder","freeCollateral","marginRatioVal","renderMMR","isConnected","currentLtv","optionsOpen","setOptionsOpen","toggleOpen","prevOpen","showLTV","networkId","isFirstTimeDeposit","onDeposit","onWithdraw","onTransfer","toggleVisible","isMainAccount","hasSubAccount","title","titleColor","titleClsName","transferButton","depositButton","withdrawButton","useAccountInstance","useEventEmitter","useCollateral","useMarginRatio","useComputedLTV","DepositAndWithdrawWithDialogId","TransferDialogId","useAssetViewScript","init_assetView_script","ee","marginRatio","mmr","positionsInfo","openDepositAndWithdraw","viewName","onSettle","setVisible","_freeCollateral","_marginRatioVal","_mmr","_totalValue","AssetViewWidget","init_assetView_widget","assetView_exports","init_assetView","OrderBookContext","useOrderBookContext","ORDERBOOK_COIN_TYPE_KEY","ORDERBOOK_MOBILE_COIN_TYPE_KEY","OrderBookProvider","init_orderContext","mode","setMode","totalMode","setTotalMode","memoizedValue","init_types","CellBar","init_cellBar","direction","transform","x","parseNumber","getPrecisionByNumber","DesktopOrderBookCell","init_cell_desktop","cellHeight","showTotal","onItemClick","depth","symbolInfo","currentHover","accumulated","accumulatedAmount","price","quantity","base_dp","quote_dp","coinType","width","dp","totalAmount","isPendingOrder","priceStr","TooltipTrigger","TooltipRoot","TooltipArrow","calcHintInfo","DesktopListBox","Tip","init_listBox_desktop","qty","amount","sumQty","sumQtyAmount","type","countQty","findMaxItem","len","priceDp","maxQty","a","b","hoverIndex","setHoverIndex","isHover","hintInfo","info","content","contentDp","DesktopAsks","init_asks_desktop","max","DesktopBids","init_bids_desktop","Select","DesktopDepthSelect","init_depthSelect_desktop","options","d","CaretDownIcon","CaretUpIcon","Popover","Option","DesktopHeader","Title","init_header_desktop","onClick","setCoinType","popoverOpen","TriggerIcon","children","className","justifyEnd","ArrowUpShortIcon","MiddlePriceView","init_midPriceView","markPrice","lastPrice","iconSize","prevLastPrice","middlePrice","down","up","SimpleDialog","MarkPriceView","FlagIcon","init_markPrice","DesktopMarkPrice","Spread","init_markPrice_desktop","asks","bids","spread","bid1","ask1","dValue","useEffect","useRef","EMPTY_LIST","Spinner","DesktopOrderBook","init_index_desktop","onDepthChange","divRef","setShowTotal","resizeObserver","entries","entry","targetDiv","FundingRate","init_fundingRate_ui","predFundingRate","countDown","useFundingDetails","useFundingRateModalScript","init_fundingRateModal_script","fundingPeriod","capFunding","floorFunding","FundingRateModal","init_fundingRateModal_ui","i18n","registerSimpleDialog","registerSimpleSheet","FundingRateModalWidget","FundingRateDialogId","FundingRateSheetId","init_fundingRateModal_widget","useFundingRate","useFundingRateScript","init_fundingRate_script","FundingRateWidget","init_fundingRate_widget","init_fundingRate","OrderBookCell","init_cell","coinUnit","setCoinUnit","renderCell","ListBox","init_listBox","Asks","init_asks","Bids","init_bids","Picker","DepthSelect","init_depthSelect","init_header","_","MarkPrice","OrderBook","init_orderBook","init_orderBook_ui","getBasicSymbolInfo","init_utils","useOrderbookStream","removeTrailingZeros","DEFAULT_CELL_HEIGHT","SPACE","useOrderBookScript","usePendingOrderStream","init_orderBook_script","height","setCellHeight","level","setLevel","allDepths","cellsHeight","restSpace","selDepth","depths","OrderBookWidget","init_orderBook_widget","orderBook_exports","EditIcon","LeverageWidgetWithDialogId","RiskRate","init_riskRate_ui","riskRate","riskRateColor","currentLeverage","maxLeverage","isHigh","isMedium","isLow","textColor","useLeverage","getRiskRateColor","useRiskRateScript","init_riskRate_script","curLeverage","riskRateNumber","_curLeverage","_maxLeverage","RiskRateWidget","init_riskRate_widget","riskRate_exports","init_riskRate","LazyLastTradesWidget","LazyOrderBookWidget","TwoColLayout","TabLayout","OrderBookAndTrades","init_orderBookAndTrades_ui","tab","containerRef","containerSize","useOrderBookAndTradesScript","init_orderBookAndTrades_script","setContainerSize","setTab","OrderBookAndTradesWidget","init_orderBookAndTrades_widget","orderBookAndTrades_exports","init_orderBookAndTrades","switchLayout_exports","LayoutIcon","OrderEntryIcon","SwitchLayout","SwitchLayoutDropDown","CloseIcon","DropdownMenuPortal","init_switchLayout","renderItem","position","useTopTabScript","init_topTab_script","useTradingviewScript","setHeight","Key","MaxHeight","dragging","setDragging","dragRef","boxRef","offsetY","setOffsetY","topRef","handleTouchStart","event","rect","handleTouchMove","newHeight","MinHeight","handleTouchEnd","drag","init_tradingview_script","KlineDragIcon","init_icons","TradingviewWidget","TradingviewUI","init_tradingview_ui","tradingview_widget_exports","init_tradingview_widget","lastTrades_widget_exports","MWebLastTrades","TradeData","init_tradeData_ui","showUSDC","useTickerStream","useTradeDataScript","init_tradeData_script","ticker","vol_24h","close","volume","openInterest","TradeDataWidget","init_tradeData_widget","tradeData_exports","init_tradeData","LazyTradingviewWidget","LazyMWebLastTrades","LazyTradeDataWidget","TopTab","ChevronIcon","init_topTab_ui","tradingViewConfig","TopTabWidget","init_topTab_widget","topTab_exports","init_topTab","OrderEntryWidget","OrderBookAndEntry","init_orderBookAndEntry_ui","div","useOrderBookAndEntryScript","init_orderBookAndEntry_script","OrderBookAndEntryWidget","init_orderBookAndEntry_widget","orderBookAndEntry_exports","init_orderBookAndEntry","subTab","setSubTab","cancelAllOrders","cancelAllTPSLOrders","MobileOrderListWidget","MobileLiquidationWidget","MobilePositionHistoryWidget","MobilePositionsWidget","OrdersView","SymbolControlHeader","HistoryTab","module","forwardRef","Split","SplitLineBar","onMouseDown","rest","disable","filterCls","cls","SplitLayout","ref","onSizeChange","barProps","ScanQRCodeWidget","ExtensionPositionEnum","ExtensionSlot","installExtension","ArrowRightShortIcon","HeadIcon","CopyIcon","USDCIcon","size","OrderlyIcon","AccountSheet","AccountInfo","ReferralInfo","TradingRewardsInfo","TWType","useChains","useCurEpochEstimate","useEpochInfo","useReferralInfo","useModal","useAccountSheetScript","linkDeviceStorage","accountId","address","hide","disconnect","chainId","showGetTestUSDC","chainName","useGetChains","onCopyAddress","affiliateCommission30D","traderCommission30D","isAffiliate","isTrader","onClickReferral","useReferral","curEpochId","estRewards","onClickTradingRewards","useTradingRewards","onDisconnect","gettingTestUSDC","_onClickReferral","_onClick","curEpochEstimate","list","curEpoch","mainChains","findByChainId","chain","AccountSheetWidget","useAccountScript","referral","tradingRewards","bottomSheetLeading","formatAddress","Account","MobileAccountMenuExtension","Balance","useBalanceScript","BalanceWidget","ChainIcon","ChainSelectorSheetId","Chain","r","useChainScript","currentChainId","setCurrentChainId","ChainWidget","BottomNavBar","renderContent","LinkDevice","showScanQRCode","showDialog","hideDialog","DesktopIcon","Dot","LinkIcon","MobileIcon","DotIcon","useBottomNavBarScript","BottomNavBarWidget","useId","Trans","ArrowLeftRightIcon","Input","inputFormatter","PlusIcon","ReduceIcon","RefreshIcon","useDebouncedCallback","DepositAndWithdrawWithSheetId","TransferSheetId","usePortfolioSheetScript","assets","useAssets","useMarginRatioAndLeverage","subAccounts","showSliderTip","setShowSliderTip","onSettlePnL","toggleHideAssets","totalCollateral","availableBalance","totalUnrealizedROI","update","leverageLevers","marks","leverage","setLeverage","step","onLeverageChange","onSave","err","onValueCommit","debouncedCommit","onInputChange","parsed","raw","clamped","prev","getMarginRatioColor","imr","high","low","RiskIndicator","PortfolioSheet","Asset","MarginRatio","Buttons","onUnsettleClick","clsName","PortfolioSheetWidget","SideMarketsWidget","SymbolInfoBarFullWidget","TradingviewFullscreenKey","DepositStatusWidget","RemovablePanel","showIndicator","TopIcon","MiddleIcon","BottomIcon","Icon","idx","IndicatorIcon","useMediaQuery","useSplitPersistent","key","defaulValue","dep","useAssetsHistory","AssetHistorySideEnum","AssetHistoryStatusEnum","useFirstTimeDeposit","unavailable","startTime","endTime","meta","scrollBarWidth","topBarHeight","bottomBarHeight","space","symbolInfoBarHeight","orderEntryMinWidth","orderEntryMaxWidth","orderbookMinWidth","orderbookMaxWidth","orderbookMinHeight","orderbookMaxHeight","tradindviewMinHeight","tradingViewMinWidth","dataListMaxHeight","dataListInitialHeight","ORDERLY_ORDER_ENTRY_SIDE_MARKETS_LAYOUT","ORDERLY_SIDE_MARKETS_MODE_KEY","useTradingScript","openMarketsSheet","setOpenMarketsSheet","restrictedInfo","onRouteChange","total","max2XL","min3XL","max4XL","layout","setLayout","canTrade","onShowPortfolioSheet","horizontalDraggable","positionsState","useOrderEntryPositions","marketsCollapseState","useMarketsCollapse","observerState","useObserverOrderEntry","marketsWidth","tradindviewMaxHeight","dataListMinHeight","splitSizeState","useSplitSize","tradingViewHeightState","useExtraHeight","map","resizeable","animating","setAnimating","panelSize","setPanelSize","onPanelSizeChange","collapsed","memoizedPanelSize","positions","setPositions","updatePositions","currentIdx","targetIdx","pos","i","showPositionIcon","mainSplitSize","setMainSplitSize","dataListSplitSize","setDataListSplitSize","orderBookSplitSize","setOrderbookSplitSize","dataListSplitHeightSM","setDataListSplitHeightSM","orderBookSplitHeightSM","setOrderbookSplitHeightSM","orderEntryHeight","setOrderEntryHeight","orderEntryViewRef","element","getOffsetSizeNum","tradingviewAndOrderbookSplitRef","max2XLSplitRef","extraHeight","setExtraHeight","dataListHeight","setDataListHeight","preSize","nextSize","boxHeight","splitTradingviewHeight","splitOrderbookHeight","tradingviewHeight","orderbookHeight","offset","splitDataListHeight","LazyRiskRateWidget","LazyAssetViewWidget","LazyDataListWidget","LazySwitchLayout","LazyOrderBookAndTradesWidget","onLayout","tradingViewFullScreen","minScreenHeight","minScreenHeightSM","marketsWidget","marketsView","symbolInfoBarView","library_path","restTradingViewConfig","tradingviewWidget","tradingView","orderbookWidget","orderbookView","dataListWidget","dataListView","assetsOrderEntryMargin","orderEntryWidget","orderEntryView","tradingViewAndOrderbookView","renderTradingViewAndOrderbookView","mainView","MarketsSheetWidget","SymbolInfoBarWidget","SimpleSheet","LazyTopTabWidget","LazyOrderBookAndEntryWidget","MaybeEqual","topBar","Trading","TradingWidget","TradingPageProvider","basicSymbol","TradingPage"],"mappings":"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","sourcesContent":["import { useLocalStorage } from \"@orderly.network/hooks\";\n\nexport const useTradingLocalStorage = (props?: {\n pnlNotionalDecimalPrecision?: number;\n}) => {\n const [unPnlPriceBasis, setUnPnlPriceBasic] = useLocalStorage(\n \"unPnlPriceBasis\",\n \"markPrice\",\n );\n const [pnlNotionalDecimalPrecision, setPnlNotionalDecimalPrecision] =\n useLocalStorage(\n \"pnlNotionalDecimalPrecision\",\n props?.pnlNotionalDecimalPrecision ?? 2,\n );\n const [showAllSymbol, setShowAllSymbol] = useLocalStorage(\n \"showAllSymbol\",\n true,\n );\n\n const [hideAssets, setHideAssets] = useLocalStorage(\"hideAssets\", false);\n\n return {\n unPnlPriceBasis,\n setUnPnlPriceBasic,\n pnlNotionalDecimalPrecision,\n setPnlNotionalDecimalPrecision,\n showAllSymbol,\n setShowAllSymbol,\n hideAssets,\n setHideAssets,\n };\n};\n","import { useMemo } from \"react\";\nimport { usePositionStream } from \"@orderly.network/hooks\";\nimport { useDataTap } from \"@orderly.network/react-app\";\nimport { useTradingLocalStorage } from \"./useTradingLocalStorage\";\n\nexport const usePositionsCount = (symbol?: string) => {\n const { showAllSymbol } = useTradingLocalStorage();\n const [data] = usePositionStream(showAllSymbol ? undefined : symbol);\n\n const count = useMemo(() => {\n return data.rows?.length;\n }, [data.rows?.length]);\n\n const positionCount = useDataTap(count) ?? 0;\n\n return {\n positionCount,\n };\n};\n","import { useOrderStream } from \"@orderly.network/hooks\";\nimport { useDataTap } from \"@orderly.network/react-app\";\nimport { AlgoOrderRootType, OrderStatus } from \"@orderly.network/types\";\nimport { TabType } from \"@orderly.network/ui-orders\";\nimport { useTradingLocalStorage } from \"./useTradingLocalStorage\";\n\nexport const usePendingOrderCount = (symbol?: string) => {\n const { showAllSymbol } = useTradingLocalStorage();\n\n const pendingOrdersPageSizeKey = `orderly_${TabType.pending}_pageSize`;\n const tpslOrdersPageSizeKey = `orderly_${TabType.tp_sl}_pageSize`;\n //\n // const [pendingOrderPageSize] = useLocalStorage(pendingOrdersPageSizeKey, 500);\n // const [tpslOrderPageSize] = useLocalStorage(tpslOrdersPageSizeKey, 500);\n\n const [pendingOrders, { total: pendingCount }] = useOrderStream(\n {\n symbol: showAllSymbol ? undefined : symbol,\n status: OrderStatus.INCOMPLETE,\n excludes: [AlgoOrderRootType.POSITIONAL_TP_SL, AlgoOrderRootType.TP_SL],\n // size: pendingOrderPageSize,\n size: 500,\n // sourceTypeAll: true,\n },\n {\n keeplive: true,\n },\n );\n\n const [tpslOrders, { total: tpslCount }] = useOrderStream(\n {\n symbol: showAllSymbol ? undefined : symbol,\n status: OrderStatus.INCOMPLETE,\n includes: [AlgoOrderRootType.POSITIONAL_TP_SL, AlgoOrderRootType.TP_SL],\n // size: tpslOrderPageSize,\n size: 500,\n // sourceTypeAll: true,\n },\n {\n keeplive: true,\n },\n );\n\n const pendingOrderCount = useDataTap(pendingCount) ?? 0;\n const tpSlOrderCount = useDataTap(tpslCount) ?? 0;\n\n return {\n pendingOrderCount,\n tpSlOrderCount,\n };\n};\n","export { useTradingLocalStorage } from \"./useTradingLocalStorage\";\nexport { usePositionsCount } from \"./usePositionsCount\";\nexport { usePendingOrderCount } from \"./usePendingOrderCount\";\n","import { createContext, useContext } from \"react\";\nimport { TradingPageState } from \"../types/types\";\n\nexport const TradingPageContext = createContext({} as TradingPageState);\n\nexport const useTradingPageContext = () => {\n return useContext(TradingPageContext);\n};\n","import { PositionsProps } from \"@orderly.network/ui-positions\";\nimport {\n usePendingOrderCount,\n usePositionsCount,\n useTradingLocalStorage,\n} from \"../../../hooks\";\nimport { useTradingPageContext } from \"../../../provider/tradingPageContext\";\n\nexport enum DataListTabType {\n positions = \"Positions\",\n pending = \"Pending\",\n tp_sl = \"TP/SL\",\n filled = \"Filled\",\n positionHistory = \"Position history\",\n orderHistory = \"Order history\",\n liquidation = \"Liquidation\",\n}\n\nexport const useDataListScript = (\n props: { current?: DataListTabType } & PositionsProps,\n) => {\n const {\n current,\n pnlNotionalDecimalPrecision,\n sharePnLConfig,\n symbol,\n includedPendingOrder,\n } = props;\n const localStorage = useTradingLocalStorage({\n pnlNotionalDecimalPrecision,\n });\n const { onSymbolChange } = useTradingPageContext();\n\n const { positionCount } = usePositionsCount(props.symbol);\n const { pendingOrderCount, tpSlOrderCount } = usePendingOrderCount(\n props.symbol,\n );\n\n return {\n current,\n sharePnLConfig,\n symbol,\n calcMode: localStorage.unPnlPriceBasis,\n includedPendingOrder,\n ...localStorage,\n positionCount,\n pendingOrderCount,\n tpSlOrderCount,\n onSymbolChange,\n };\n};\n\nexport type DataListState = ReturnType<typeof useDataListScript>;\n","import { FC, useCallback, useState } from \"react\";\nimport {\n Button,\n Checkbox,\n Divider,\n DropdownMenuContent,\n DropdownMenuRoot,\n DropdownMenuTrigger,\n Flex,\n SettingFillIcon,\n Text,\n} from \"@orderly.network/ui\";\nimport { SettingState } from \"./setting.script\";\nimport { useTranslation } from \"@orderly.network/i18n\";\n\nexport const Setting: FC<SettingState> = (props) => {\n const [open, setOpen] = useState(false);\n const { t } = useTranslation();\n\n return (\n <Flex gap={0}>\n <Flex gap={1}>\n <Checkbox\n id=\"oui-checkbox-hideOtherSymbols\"\n color=\"white\"\n checked={props.hideOtherSymbols}\n onCheckedChange={(checked: boolean) => {\n props.setHideOtherSymbols(checked);\n }}\n />\n <label\n className=\"oui-text-xs oui-text-base-contrast-54 oui-cursor-pointer\"\n htmlFor=\"oui-checkbox-hideOtherSymbols\"\n >\n {t(\"trading.hideOtherSymbols\")}\n </label>\n </Flex>\n\n <DropdownMenuRoot open={open} onOpenChange={setOpen}>\n <DropdownMenuTrigger asChild>\n <Button\n size=\"xs\"\n type=\"button\"\n variant=\"contained\"\n className=\"oui-bg-transparent hover:oui-bg-transparent\"\n >\n <SettingFillIcon\n size={16}\n color=\"white\"\n opacity={1}\n className=\"oui-text-white/[.36] hover:oui-text-white/80\"\n />\n </Button>\n </DropdownMenuTrigger>\n <DropdownMenuContent\n className=\"oui-px-5 oui-py-3 oui-w-[360px]\"\n alignOffset={2}\n align=\"end\"\n >\n <div className=\"oui-flex oui-flex-col oui-text-sm\">\n <Text className=\"oui-text-base oui-pb-3\">\n {t(\"trading.portfolioSettings\")}\n </Text>\n <Divider />\n <Text className=\"oui-pb-3 oui-text-base-contrast-54 oui-mt-2\">\n {t(\"trading.portfolioSettings.decimalPrecision\")}\n </Text>\n <DecimalPrecisionCheckbox\n value={props.pnlNotionalDecimalPrecision}\n onValueChange={(e) => {\n props.setPnlNotionalDecimalPrecision(e);\n setOpen(false);\n }}\n />\n <Divider className=\"oui-my-3\" />\n <Text className=\"oui-pb-3 oui-text-base-contrast-54 oui-mt-2\">\n {t(\"trading.portfolioSettings.unrealPnlPriceBasis\")}\n </Text>\n <UnPnlPriceBasisCheckBox\n value={props.unPnlPriceBasis}\n onValueChange={(e) => {\n props.setUnPnlPriceBasic(e);\n setOpen(false);\n }}\n />\n </div>\n </DropdownMenuContent>\n </DropdownMenuRoot>\n </Flex>\n );\n};\n\nconst UnPnlPriceBasisCheckBox = (props: {\n value: string;\n onValueChange: (value: string) => void;\n}) => {\n const { value, onValueChange } = props;\n const { t } = useTranslation();\n\n // \"markPrice\" | \"lastPrice\"\n return (\n <Flex gap={2}>\n <RadioButton\n sel={value === \"markPrice\"}\n label={t(\"common.markPrice\")}\n value={\"markPrice\"}\n onCheckChange={onValueChange}\n />\n <RadioButton\n sel={value === \"lastPrice\"}\n label={t(\"common.lastPrice\")}\n value={\"lastPrice\"}\n onCheckChange={onValueChange}\n />\n </Flex>\n );\n};\n\nconst DecimalPrecisionCheckbox = (props: {\n value: number;\n onValueChange: (value: number) => void;\n}) => {\n const { value, onValueChange } = props;\n return (\n <Flex gap={2}>\n <RadioButton\n sel={value === 0}\n label={1}\n value={0}\n onCheckChange={onValueChange}\n />\n <RadioButton\n sel={value === 1}\n label={0.1}\n value={1}\n onCheckChange={onValueChange}\n />\n <RadioButton\n sel={value === 2}\n label={0.01}\n value={2}\n onCheckChange={onValueChange}\n />\n </Flex>\n );\n};\n\n// const InnerCheckbox = (props: {\n// sel: boolean;\n// label: any;\n// value: any;\n// onCheckChange: (value: any) => void;\n// }) => {\n// const { sel, label, value, onCheckChange } = props;\n// return (\n// <Flex\n// onClick={(e) => {\n// onCheckChange(value);\n// e.stopPropagation();\n// }}\n// gap={1}\n// >\n// <Checkbox color=\"white\" checked={sel} />\n// <Text size=\"xs\" intensity={sel ? 98 : 54}>\n// {`${label}`}\n// </Text>\n// </Flex>\n// );\n// };\n\nconst RadioButton = (props: {\n sel: boolean;\n label: any;\n value: any;\n onCheckChange: (value: any) => void;\n}) => {\n const { sel, label, value, onCheckChange } = props;\n return (\n <Flex\n onClick={(e) => {\n onCheckChange(value);\n e.stopPropagation();\n }}\n gap={1}\n className=\"oui-cursor-pointer\"\n >\n {sel ? <SelIcon /> : <UnselIcon />}\n <Text size=\"2xs\" intensity={sel ? 98 : 54}>\n {label}\n </Text>\n </Flex>\n );\n};\n\nconst SelIcon = () => {\n return (\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 className=\"oui-fill-white\"\n >\n <path\n d=\"M8.01 1.333a6.667 6.667 0 1 0 0 13.333 6.667 6.667 0 0 0 0-13.333m0 1.333a5.334 5.334 0 1 1-.001 10.667 5.334 5.334 0 0 1 0-10.667\"\n fill=\"#fff\"\n fillOpacity=\".36\"\n />\n <circle cx=\"8\" cy=\"8\" r=\"3.333\" />\n </svg>\n );\n};\n\nconst UnselIcon = () => {\n return (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M8.01 1.333a6.667 6.667 0 1 0 0 13.333 6.667 6.667 0 0 0 0-13.333m0 1.333a5.334 5.334 0 1 1-.001 10.667 5.334 5.334 0 0 1 0-10.667\"\n fill=\"#fff\"\n fillOpacity=\".54\"\n />\n </svg>\n );\n};\n","import { SettingWidgetProps } from \"./setting.widget\";\n\nexport const useSettingScript = (props: SettingWidgetProps) => {\n return {\n ...props,\n };\n};\n\nexport type SettingState = ReturnType<typeof useSettingScript>;\n","import React from \"react\";\nimport { useSettingScript } from \"./setting.script\";\nimport { Setting } from \"./setting.ui\";\n\nexport type SettingWidgetProps = {\n pnlNotionalDecimalPrecision: any;\n setPnlNotionalDecimalPrecision: (value: number) => void;\n unPnlPriceBasis: any;\n setUnPnlPriceBasic: (value: string) => void;\n hideOtherSymbols: any;\n setHideOtherSymbols: (value: boolean) => void;\n};\n\nexport const SettingWidget: React.FC<SettingWidgetProps> = (props) => {\n const state = useSettingScript(props);\n return <Setting {...state} />;\n};\n","export { Setting } from \"./setting.ui\";\nexport { SettingWidget } from \"./setting.widget\";\n","import React from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n Checkbox,\n Divider,\n Flex,\n Statistic,\n Text,\n useScreen,\n} from \"@orderly.network/ui\";\nimport { Decimal } from \"@orderly.network/utils\";\nimport type { PositionHeaderState } from \"./positionHeader.script\";\n\nexport const PositionHeader: React.FC<PositionHeaderState> = (props) => {\n const { isMobile } = useScreen();\n return isMobile ? <MobileLayout {...props} /> : <DesktopLayout {...props} />;\n};\n\nconst MobileLayout: React.FC<PositionHeaderState> = (props) => {\n const { t } = useTranslation();\n\n return (\n <Flex\n direction={\"column\"}\n gap={2}\n width={\"100%\"}\n itemAlign={\"start\"}\n p={2}\n className=\"oui-rounded-b-xl oui-bg-base-9\"\n >\n <Flex width={\"100%\"} justify={\"between\"}>\n <UnrealPnL\n classNames={{\n label: \"oui-text-2xs oui-text-base-contrast-54\",\n root: \"oui-text-sm\",\n }}\n {...props}\n />\n <Notional\n classNames={{\n label: \"oui-text-2xs oui-text-base-contrast-54\",\n root: \"oui-text-sm\",\n }}\n {...props}\n />\n </Flex>\n <Divider className=\"oui-w-full\" />\n <Flex className=\"oui-cursor-pointer oui-gap-[2px]\">\n <Checkbox\n id=\"oui-checkbox-hideOtherSymbols\"\n color=\"white\"\n checked={!props.showAllSymbol}\n onCheckedChange={(checked: boolean) => {\n props.setShowAllSymbol(!checked);\n }}\n />\n\n <label\n className=\"oui-text-2xs oui-text-base-contrast-54 oui-cursor-pointer\"\n htmlFor=\"oui-checkbox-hideOtherSymbols\"\n >\n {t(\"trading.hideOtherSymbols\")}\n </label>\n </Flex>\n </Flex>\n );\n};\n\nconst DesktopLayout: React.FC<PositionHeaderState> = (props) => {\n return (\n <Flex py={2} px={3} gap={6} width={\"100%\"} justify={\"start\"}>\n <UnrealPnL\n {...props}\n classNames={{ label: \"oui-text-base-contrast-54\" }}\n />\n <Notional\n {...props}\n classNames={{ label: \"oui-text-base-contrast-54\" }}\n />\n </Flex>\n );\n};\n\nconst UnrealPnL: React.FC<\n PositionHeaderState & {\n classNames?: { root?: string; label?: string; value?: string };\n }\n> = (props) => {\n const { t } = useTranslation();\n\n const unrealPnLClsName =\n typeof props.unrealPnL === \"number\"\n ? props.unrealPnL >= 0\n ? \"oui-text-trade-profit\"\n : \"oui-text-trade-loss\"\n : \"oui-text-base-contrast-80\";\n\n const unrealPnLROIClsName =\n typeof props.unrealPnL === \"number\" && props.unrealPnlROI\n ? props.unrealPnlROI >= 0\n ? \"oui-text-success-darken\"\n : \"oui-text-danger-darken\"\n : \"oui-text-base-contrast-80\";\n\n return (\n <Statistic label={t(\"common.unrealizedPnl\")} classNames={props.classNames}>\n <Flex gap={1}>\n <Text.numeral\n dp={props.pnlNotionalDecimalPrecision}\n rm={Decimal.ROUND_DOWN}\n intensity={80}\n className={unrealPnLClsName}\n >\n {props.unrealPnL ?? \"--\"}\n </Text.numeral>\n {typeof props.unrealPnlROI !== \"undefined\" && (\n <Text.numeral\n prefix=\"(\"\n suffix=\")\"\n rule=\"percentages\"\n size=\"2xs\"\n dp={props.pnlNotionalDecimalPrecision}\n rm={Decimal.ROUND_DOWN}\n className={unrealPnLROIClsName}\n >\n {props.unrealPnlROI}\n </Text.numeral>\n )}\n </Flex>\n </Statistic>\n );\n};\n\nconst Notional: React.FC<\n PositionHeaderState & {\n classNames?: { root?: string; label?: string; value?: string };\n }\n> = (props) => {\n const { t } = useTranslation();\n return (\n <Statistic label={t(\"common.notional\")} classNames={props.classNames}>\n <Text.numeral\n dp={props.pnlNotionalDecimalPrecision}\n rm={Decimal.ROUND_DOWN}\n intensity={80}\n >\n {props.notional ?? \"--\"}\n </Text.numeral>\n </Statistic>\n );\n};\n","import { usePositionStream } from \"@orderly.network/hooks\";\nimport { useDataTap } from \"@orderly.network/react-app\";\nimport { useTradingLocalStorage } from \"../../../hooks\";\n\nexport const usePositionHeaderScript = (inputs: {\n pnlNotionalDecimalPrecision?: number;\n unPnlPriceBasis: \"markPrice\" | \"lastPrice\";\n symbol?: string;\n}) => {\n const { pnlNotionalDecimalPrecision, unPnlPriceBasis, symbol } = inputs;\n const calcMode = unPnlPriceBasis;\n\n const [data] = usePositionStream(symbol, {\n calcMode,\n });\n const aggregated = useDataTap(data.aggregated);\n\n const unrealPnL = aggregated?.total_unreal_pnl;\n const unrealPnlROI = aggregated?.unrealPnlROI;\n const notional = aggregated?.notional;\n const { showAllSymbol, setShowAllSymbol } = useTradingLocalStorage();\n\n return {\n pnlNotionalDecimalPrecision,\n unrealPnL,\n unrealPnlROI,\n notional,\n showAllSymbol,\n setShowAllSymbol,\n };\n};\n\nexport type PositionHeaderState = ReturnType<typeof usePositionHeaderScript>;\n","import React from \"react\";\nimport { usePositionHeaderScript } from \"./positionHeader.script\";\nimport { PositionHeader } from \"./positionHeader.ui\";\n\nexport const PositionHeaderWidget: React.FC<{\n pnlNotionalDecimalPrecision?: number;\n unPnlPriceBasis: \"markPrice\" | \"lastPrice\";\n symbol?: string;\n}> = (props) => {\n const state = usePositionHeaderScript(props);\n return <PositionHeader {...state} />;\n};\n","export { PositionHeader } from \"./positionHeader.ui\";\nexport { PositionHeaderWidget } from \"./positionHeader.widget\";\n","import { FC, SVGProps } from \"react\";\nimport React from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { OrderStatus } from \"@orderly.network/types\";\nimport {\n Box,\n Divider,\n Flex,\n InfoCircleIcon,\n TabPanel,\n Tabs,\n Tooltip,\n} from \"@orderly.network/ui\";\nimport { DesktopOrderListWidget, TabType } from \"@orderly.network/ui-orders\";\nimport {\n LiquidationWidget,\n PositionHistoryWidget,\n PositionsWidget,\n} from \"@orderly.network/ui-positions\";\nimport { DataListState, DataListTabType } from \"./dataList.script\";\n\nconst LazySettingWidget = React.lazy(() =>\n import(\"./setting\").then((mod) => {\n return { default: mod.SettingWidget };\n }),\n);\n\nconst LazyPositionHeaderWidget = React.lazy(() =>\n import(\"../../base/positionHeader\").then((mod) => {\n return { default: mod.PositionHeaderWidget };\n }),\n);\n\nexport const DataList: FC<DataListState> = (props) => {\n const { t } = useTranslation();\n return (\n <Tabs\n defaultValue={props.current || DataListTabType.positions}\n variant=\"contained\"\n trailing={\n <React.Suspense fallback={null}>\n <LazySettingWidget\n pnlNotionalDecimalPrecision={props.pnlNotionalDecimalPrecision}\n setPnlNotionalDecimalPrecision={\n props.setPnlNotionalDecimalPrecision\n }\n unPnlPriceBasis={props.unPnlPriceBasis}\n setUnPnlPriceBasic={props.setUnPnlPriceBasic}\n hideOtherSymbols={!props.showAllSymbol}\n setHideOtherSymbols={(value: boolean) =>\n props.setShowAllSymbol(!value)\n }\n />\n </React.Suspense>\n }\n size=\"lg\"\n className=\"oui-h-full\"\n classNames={{\n // tabsList: \"oui-px-3\",\n tabsContent: \"oui-h-[calc(100%_-_32px)]\",\n trigger: \"oui-group\",\n }}\n >\n <TabPanel\n testid=\"oui-testid-dataList-position-tab\"\n value={DataListTabType.positions}\n title={`${t(\"common.positions\")} ${\n (props.positionCount ?? 0) > 0 ? `(${props.positionCount})` : \"\"\n }`}\n >\n <PositionsView {...props} />\n </TabPanel>\n <TabPanel\n testid=\"oui-testid-dataList-pending-tab\"\n value={DataListTabType.pending}\n title={`${t(\"orders.status.pending\")} ${\n (props.pendingOrderCount ?? 0) > 0\n ? `(${props.pendingOrderCount})`\n : \"\"\n }`}\n >\n <DesktopOrderListWidget\n type={TabType.pending}\n ordersStatus={OrderStatus.INCOMPLETE}\n symbol={!!props.showAllSymbol ? undefined : props.symbol}\n onSymbolChange={props.onSymbolChange}\n testIds={{\n tableBody: \"oui-testid-dataList-pending-table-body\",\n }}\n />\n </TabPanel>\n <TabPanel\n testid=\"oui-testid-dataList-tpsl-tab\"\n value={DataListTabType.tp_sl}\n title={`${t(\"common.tpsl\")} ${\n (props.tpSlOrderCount ?? 0) > 0 ? `(${props.tpSlOrderCount})` : \"\"\n }`}\n >\n <DesktopOrderListWidget\n type={TabType.tp_sl}\n ordersStatus={OrderStatus.INCOMPLETE}\n symbol={!!props.showAllSymbol ? undefined : props.symbol}\n onSymbolChange={props.onSymbolChange}\n testIds={{\n tableBody: \"oui-testid-dataList-tpsl-table-body\",\n }}\n />\n </TabPanel>\n <TabPanel\n testid=\"oui-testid-dataList-filled-tab\"\n value={DataListTabType.filled}\n title={t(\"orders.status.filled\")}\n >\n <DesktopOrderListWidget\n type={TabType.filled}\n symbol={!!props.showAllSymbol ? undefined : props.symbol}\n pnlNotionalDecimalPrecision={props.pnlNotionalDecimalPrecision}\n ordersStatus={OrderStatus.FILLED}\n onSymbolChange={props.onSymbolChange}\n testIds={{\n tableBody: \"oui-testid-dataList-filled-table-body\",\n }}\n sharePnLConfig={props.sharePnLConfig}\n />\n </TabPanel>\n <TabPanel\n testid=\"oui-testid-dataList-positionHistory-tab\"\n value={DataListTabType.positionHistory}\n title={t(\"positions.positionHistory\")}\n >\n <PositionHistoryWidget\n pnlNotionalDecimalPrecision={props.pnlNotionalDecimalPrecision}\n symbol={!!props.showAllSymbol ? undefined : props.symbol}\n onSymbolChange={props.onSymbolChange}\n sharePnLConfig={props.sharePnLConfig}\n />\n </TabPanel>\n <TabPanel\n testid=\"oui-testid-dataList-orderHistory-tab\"\n value={DataListTabType.orderHistory}\n title={t(\"orders.orderHistory\")}\n >\n <DesktopOrderListWidget\n type={TabType.orderHistory}\n pnlNotionalDecimalPrecision={props.pnlNotionalDecimalPrecision}\n symbol={!!props.showAllSymbol ? undefined : props.symbol}\n onSymbolChange={props.onSymbolChange}\n testIds={{\n tableBody: \"oui-testid-dataList-orderHistory-table-body\",\n }}\n sharePnLConfig={props.sharePnLConfig}\n />\n </TabPanel>\n <TabPanel\n testid=\"oui-testid-dataList-liquidation-tab\"\n value={DataListTabType.liquidation}\n title={<LiquidationTab />}\n >\n <LiquidationWidget\n symbol={!!props.showAllSymbol ? undefined : props.symbol}\n />\n </TabPanel>\n </Tabs>\n );\n};\n\nexport const LiquidationTab = () => {\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\nconst PositionsView: FC<DataListState> = (props) => {\n return (\n <Flex direction=\"column\" width=\"100%\" height=\"100%\">\n <React.Suspense fallback={null}>\n <LazyPositionHeaderWidget\n pnlNotionalDecimalPrecision={props.pnlNotionalDecimalPrecision}\n symbol={!!props.showAllSymbol ? undefined : props.symbol}\n unPnlPriceBasis={props.unPnlPriceBasis}\n />\n </React.Suspense>\n <Divider className=\"oui-w-full\" />\n <Box className=\"oui-h-[calc(100%_-_60px)]\" width=\"100%\">\n <PositionsWidget\n symbol={!!props.showAllSymbol ? undefined : props.symbol}\n pnlNotionalDecimalPrecision={props.pnlNotionalDecimalPrecision}\n sharePnLConfig={props.sharePnLConfig}\n calcMode={props.calcMode}\n includedPendingOrder={props.includedPendingOrder}\n onSymbolChange={props.onSymbolChange}\n />\n </Box>\n </Flex>\n );\n};\n","import React from \"react\";\nimport { PositionsProps } from \"@orderly.network/ui-positions\";\nimport { DataListTabType, useDataListScript } from \"./dataList.script\";\nimport { DataList } from \"./dataList.ui\";\n\nexport const DataListWidget: React.FC<\n { current?: DataListTabType } & PositionsProps\n> = (props) => {\n const state = useDataListScript(props);\n return <DataList {...state} />;\n};\n","export { DataList } from \"./dataList.ui\";\nexport { DataListWidget } from \"./dataList.widget\";\n","import React, { FC, ReactNode } from \"react\";\nimport { Box, cn, Grid, ListView, Text } from \"@orderly.network/ui\";\nimport { LastTradesState } from \"./lastTrades.script\";\nimport { OrderSide } from \"@orderly.network/types\";\nimport { commifyOptional } from \"@orderly.network/utils\";\nimport { useTranslation } from \"@orderly.network/i18n\";\n\nexport const LastTrades: FC<\n LastTradesState & {\n classNames?: {\n root?: string;\n list?: string;\n listHeader?: string;\n listItem?: {\n left?: string;\n mid?: string;\n right?: string;\n };\n };\n style?: React.CSSProperties;\n }\n> = (props) => {\n return (\n <Box\n className={cn(\n \"oui-grid oui-grid-rows=[auto,1fr] oui-h-full oui-w-full\",\n props.classNames?.root\n )}\n style={props.style}\n >\n <Box className=\"oui-pr-1\">\n <Header\n base={props.base}\n quote={props.quote}\n className={props.classNames?.listHeader}\n />\n </Box>\n <List\n data={props.data}\n isLoading={props.isLoading}\n baseDp={props.baseDp}\n quoteDp={props.quoteDp}\n classNames={props.classNames?.listItem}\n className={props.classNames?.list}\n />\n </Box>\n );\n};\n\nconst Row = (props: {\n key?: React.Key | null;\n classNames?: {\n root?: string;\n left?: string;\n mid?: string;\n right?: string;\n };\n left: ReactNode | string;\n mid: ReactNode | string;\n right: ReactNode | string;\n}) => {\n const { left, mid, right, classNames } = props;\n return (\n // <Flex\n // key={key}\n // height={20}\n // gap={2}\n // width={\"100%\"}\n // className={cn(\"oui-text-xs oui-tabular-nums\", classNames?.root)}\n // >\n // <Box className={cn(\"oui-flex-1\", classNames?.left)}>{left}</Box>\n // <Box className={cn(\"oui-flex-1\", classNames?.mid)}>{mid}</Box>\n // <Box className={cn(\"oui-flex-1 oui-text-right\", classNames?.right)}>\n // {right}\n // </Box>\n // </Flex>\n\n <Grid\n cols={3}\n gapX={2}\n width=\"100%\"\n className={cn(\"oui-text-xs oui-tabular-nums\", classNames?.root)}\n >\n <div className={cn(\"oui-flex-1\", classNames?.left)}>{left}</div>\n <div className={cn(\"oui-flex-1\", classNames?.mid)}>{mid}</div>\n <div className={cn(\"oui-flex-1 oui-text-right\", classNames?.right)}>\n {right}\n </div>\n </Grid>\n );\n};\n\nconst Header = (props: { base: string; quote: string; className?: string }) => {\n const { t } = useTranslation();\n return (\n <Row\n left={t(\"common.time\")}\n mid={`${t(\"common.price\")}(${props.quote})`}\n right={`${t(\"common.qty\")}(${props.base})`}\n classNames={{\n root: cn(\n \"oui-text-base-contrast-54 oui-h-[32px] oui-sticky\",\n props.className\n ),\n }}\n />\n );\n};\n\nconst List = (props: {\n data?: any[];\n isLoading?: boolean;\n baseDp: number;\n quoteDp: number;\n classNames?: {\n left?: string;\n mid?: string;\n right?: string;\n };\n className?: string;\n}) => {\n return (\n <ListView\n dataSource={props.data}\n className={cn(\n \"oui-last-trades-list\",\n \"oui-w-full oui-h-full\",\n props.className,\n \"oui-overflow-auto\"\n )}\n contentClassName=\"!oui-space-y-0 oui-pr-[-4px]\"\n renderItem={(item, index) => {\n return (\n <Row\n key={index}\n left={\n <Text.formatted rule={\"date\"} formatString=\"HH:mm:ss\">\n {item?.ts}\n </Text.formatted>\n }\n mid={commifyOptional(item?.price, { fix: props.quoteDp })}\n right={commifyOptional(item?.size, { fix: props.baseDp })}\n classNames={{\n left: cn(\"oui-text-base-contrast-80\", props.classNames?.left),\n right: cn(\n item.side === OrderSide.BUY\n ? \"oui-text-trade-profit\"\n : \"oui-text-trade-loss\",\n props.classNames?.mid\n ),\n mid: cn(\n item.side === OrderSide.BUY\n ? \"oui-text-trade-profit\"\n : \"oui-text-trade-loss\",\n props.classNames?.right\n ),\n }}\n />\n );\n }}\n />\n );\n};\n","import { useMarketTradeStream, useSymbolsInfo } from \"@orderly.network/hooks\";\n\nexport const useLastTradesScript = (symbol: string) => {\n const { data, isLoading } = useMarketTradeStream(symbol);\n // const { quote, quote_dp, base, base_dp } = useContext(SymbolContext);\n const config = useSymbolsInfo()?.[symbol];\n const base = config?.(\"base\");\n const quote = config?.(\"quote\");\n const baseDp = config?.(\"base_dp\");\n const quoteDp = config?.(\"quote_dp\");\n// console.log(\"base, quote\", base, quote, \"baseDp, quoteDp\", baseDp, quoteDp);\n\n return {\n base,\n quote,\n data,\n isLoading,\n baseDp,\n quoteDp,\n };\n};\n\nexport type LastTradesState = ReturnType<typeof useLastTradesScript>;\n","import React from \"react\";\nimport { useLastTradesScript } from \"./lastTrades.script\";\nimport { LastTrades } from \"./lastTrades.ui\";\n\nexport const LastTradesWidget: React.FC<{\n symbol: string;\n classNames?: {\n root?: string;\n list?: string;\n listHeader?: string;\n listItem?: { left?: string; mid?: string; right?: string };\n };\n style?: React.CSSProperties;\n}> = (props) => {\n const state = useLastTradesScript(props.symbol);\n return (\n <LastTrades {...state} classNames={props.classNames} style={props.style} />\n );\n};\n","export { LastTrades } from \"./lastTrades.ui\";\nexport { LastTradesWidget } from \"./lastTrades.widget\";\n","import { useTranslation } from \"@orderly.network/i18n\";\nimport { Button } from \"@orderly.network/ui\";\nimport { FaucetState } from \"./faucet.script\";\n\nexport function FaucetUi(props: FaucetState) {\n const { t } = useTranslation();\n\n if (!props.showFaucet) {\n return null;\n }\n\n return (\n <Button\n variant=\"outlined\"\n fullWidth\n size=\"md\"\n onClick={props.getFaucet}\n loading={props.loading}\n className=\"oui-text-primary-light oui-border-primary-light oui-rounded\"\n data-testid=\"oui-testid-assetView-getFaucet-button\"\n >\n {t(\"trading.faucet.getTestUSDC\")}\n </Button>\n );\n}\n","import { useMemo, useState } from \"react\";\nimport {\n useAccount,\n useConfig,\n useMutation,\n useWalletConnector,\n} from \"@orderly.network/hooks\";\nimport { AccountStatusEnum, ChainNamespace } from \"@orderly.network/types\";\nimport { isTestnet } from \"@orderly.network/utils\";\nimport { modal, toast } from \"@orderly.network/ui\";\nimport { useTranslation } from \"@orderly.network/i18n\";\n\nexport function useFaucetScript() {\n const { t } = useTranslation();\n const { connectedChain, namespace } = useWalletConnector();\n const { state, account } = useAccount();\n const config = useConfig();\n const operatorUrl = config.get<string>(\"operatorUrl\");\n\n const [getTestUSDC, { isMutating }] = useMutation(\n `${operatorUrl}/v1/faucet/usdc`\n );\n const [loading, setLoading] = useState<boolean>(false);\n\n const showFaucet = useMemo(() => {\n if (!connectedChain || !connectedChain.id) {\n return false;\n }\n return (\n (state.status === AccountStatusEnum.EnableTrading ||\n state.status === AccountStatusEnum.EnableTradingWithoutConnected) &&\n isTestnet(parseInt(connectedChain.id as string))\n );\n }, [state, connectedChain]);\n\n const getFaucet = () => {\n if (loading) {\n return;\n }\n setLoading(true);\n const message = t(\"trading.faucet.getTestUSDC.success\", {\n quantity: namespace === ChainNamespace.solana ? \"100\" : \"1,000\",\n });\n\n return getTestUSDC({\n chain_id: account.walletAdapter?.chainId.toString(),\n user_address: state.address,\n broker_id: config.get(\"brokerId\"),\n }).then(\n (res) => {\n setLoading(false);\n if (res.success) {\n return modal.alert({\n title: t(\"trading.faucet.getTestUSDC\"),\n message,\n onOk: () => {\n return new Promise((resolve) => resolve(true));\n },\n });\n }\n res.message && toast.error(res.message);\n },\n (error: Error) => {\n toast.error(error.message);\n }\n );\n };\n return { getFaucet, showFaucet, loading };\n}\n\nexport type FaucetState = ReturnType<typeof useFaucetScript>;\n","import { FaucetUi } from \"./faucet.ui\";\nimport { useFaucetScript } from \"./faucet.script\";\n\nexport function FaucetWidget() {\n const state = useFaucetScript();\n return (\n <FaucetUi {...state}/>\n )\n}","import { FC, useMemo, useState, useCallback, ReactNode } from \"react\";\nimport { useAccount, useLocalStorage } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { useAppContext } from \"@orderly.network/react-app\";\nimport { AccountStatusEnum } from \"@orderly.network/types\";\nimport {\n Flex,\n Text,\n Box,\n Button,\n ArrowDownShortIcon,\n EyeIcon,\n EyeCloseIcon,\n ChevronDownIcon,\n Tooltip,\n Divider,\n gradientTextVariants,\n cn,\n} from \"@orderly.network/ui\";\nimport { AuthGuard } from \"@orderly.network/ui-connector\";\nimport { LTVRiskTooltipWidget } from \"@orderly.network/ui-order-entry\";\nimport { AssetViewState } from \"./assetView.script\";\nimport { FaucetWidget } from \"./faucet/faucet.widget\";\n\ninterface StatusInfo {\n title: string;\n description: string;\n titleColor?: any;\n titleClsName?: string;\n}\n\ninterface TooltipContentProps {\n description: ReactNode;\n formula: ReactNode;\n}\n\ninterface TotalValueProps {\n totalValue?: number;\n visible?: boolean;\n onToggleVisibility?: () => void;\n}\n\ninterface AssetDetailProps {\n label: string;\n description?: ReactNode;\n formula?: ReactNode;\n visible: boolean;\n value?: number | string;\n unit?: string;\n rule?: \"percentages\";\n isConnected?: boolean;\n showPercentage?: boolean;\n placeholder?: string;\n}\n\ninterface AssetValueListProps {\n visible?: boolean;\n freeCollateral?: number | null;\n marginRatioVal?: number;\n renderMMR?: string | number;\n isConnected: boolean;\n currentLtv?: string | number;\n}\n\nconst calculateTextColor = (val: number): string => {\n if (val >= 0 && val < 50) {\n return \"oui-text-success\";\n } else if (val >= 50 && val < 80) {\n return \"oui-text-warning\";\n } else if (val >= 80) {\n return \"oui-text-danger\";\n } else {\n return \"\";\n }\n};\n\nconst useCurrentStatusText = (): StatusInfo => {\n const { state } = useAccount();\n const { wrongNetwork, disabledConnect } = useAppContext();\n const { t } = useTranslation();\n\n return useMemo(() => {\n const statusText = {\n wrongNetwork: {\n title: t(\"connector.wrongNetwork\"),\n description: t(\"connector.wrongNetwork.tooltip\"),\n titleColor: \"warning\",\n },\n connectWallet: {\n title: t(\"connector.connectWallet\"),\n description: t(\"connector.trade.connectWallet.tooltip\"),\n titleClsName:\n \"oui-text-transparent oui-bg-clip-text oui-gradient-brand\",\n },\n createAccount: {\n title: t(\"connector.createAccount\"),\n description: t(\"connector.trade.createAccount.tooltip\"),\n titleColor: \"primary\",\n },\n enableTrading: {\n title: t(\"connector.enableTrading\"),\n description: t(\"connector.trade.enableTrading.tooltip\"),\n titleColor: \"primary\",\n },\n empty: {\n title: \"\",\n description: \"\",\n },\n };\n\n if (disabledConnect) {\n return statusText.connectWallet;\n }\n\n if (wrongNetwork) {\n return statusText.wrongNetwork;\n }\n\n // EnableTradingWithoutConnected is enabled trading status, so we don't need to show anything\n if (state.status === AccountStatusEnum.EnableTradingWithoutConnected) {\n return statusText.empty;\n }\n\n if (state.status <= AccountStatusEnum.NotConnected) {\n return statusText.connectWallet;\n }\n\n if (state.status <= AccountStatusEnum.NotSignedIn) {\n return statusText.createAccount;\n }\n\n if (state.status < AccountStatusEnum.EnableTrading) {\n return statusText.enableTrading;\n }\n\n return statusText.empty;\n }, [t, state.status, wrongNetwork, disabledConnect]);\n};\n\nexport const TooltipContent: FC<TooltipContentProps> = (props) => {\n const { description, formula } = props;\n return (\n <div className=\"oui-min-w-[204px] oui-max-w-[240px] oui-text-2xs oui-leading-normal oui-text-base-contrast-80\">\n {typeof description !== \"undefined\" && description !== null && (\n <span>{description}</span>\n )}\n <Divider className=\"oui-border-white/10\" my={2} />\n {typeof formula !== \"undefined\" && formula !== null && (\n <span>{formula}</span>\n )}\n </div>\n );\n};\n\nconst TotalValue: FC<TotalValueProps> = (props) => {\n const { t } = useTranslation();\n const { totalValue, visible = true, onToggleVisibility } = props;\n return (\n <Flex\n direction=\"column\"\n gap={1}\n className=\"oui-text-2xs\"\n itemAlign=\"center\"\n >\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 <Flex gap={1} itemAlign=\"center\">\n <Text size=\"2xs\" color=\"neutral\" weight=\"semibold\">\n {`${t(\"trading.asset.myAssets\")} (USDC)`}\n </Text>\n <button onClick={onToggleVisibility}>\n {visible ? (\n <EyeIcon size={18} className=\"oui-text-base-contrast-54\" />\n ) : (\n <EyeCloseIcon size={18} className=\"oui-text-base-contrast-54\" />\n )}\n </button>\n </Flex>\n </Flex>\n );\n};\n\nconst AssetDetail: FC<AssetDetailProps> = (props) => {\n const {\n label,\n description,\n formula,\n visible,\n value,\n unit,\n rule,\n placeholder,\n } = props;\n return (\n <Flex justify=\"between\">\n <Tooltip\n className={\"\"}\n content={<TooltipContent description={description} formula={formula} />}\n >\n <Text\n size=\"2xs\"\n color=\"neutral\"\n weight=\"semibold\"\n className=\"oui-cursor-pointer oui-border-b oui-border-dashed oui-border-line-12\"\n >\n {label}\n </Text>\n </Tooltip>\n <Text.numeral\n visible={visible}\n size=\"2xs\"\n unit={unit}\n unitClassName=\"oui-text-base-contrast-36 oui-ml-0.5\"\n as=\"div\"\n rule={rule}\n padding={false}\n dp={2}\n // suffix={value && unit}\n placeholder={placeholder}\n >\n {value || \"--\"}\n </Text.numeral>\n </Flex>\n );\n};\n\nconst LTVDetail: FC<Pick<AssetDetailProps, \"value\" | \"visible\">> = (props) => {\n const { visible, value } = props;\n const { t } = useTranslation();\n return (\n <Flex justify=\"between\">\n <Tooltip\n className={cn(\"oui-bg-base-6 oui-p-2\")}\n content={<LTVRiskTooltipWidget />}\n >\n <Text\n size=\"2xs\"\n color=\"neutral\"\n weight=\"semibold\"\n className=\"oui-cursor-pointer oui-border-b oui-border-dashed oui-border-line-12\"\n >\n {t(\"transfer.LTV\")}\n </Text>\n </Tooltip>\n <Text\n size=\"2xs\"\n className={cn(\n \"select-none\",\n visible && calculateTextColor(Number(value)),\n )}\n >\n {visible ? `${value}%` : \"*****\"}\n </Text>\n </Flex>\n );\n};\n\nconst AssetValueList: FC<AssetValueListProps> = (props) => {\n const {\n visible = true,\n freeCollateral,\n marginRatioVal,\n renderMMR,\n isConnected,\n currentLtv,\n } = props;\n\n const [optionsOpen, setOptionsOpen] = useLocalStorage(\n \"orderly_entry_asset_list_open\",\n false,\n );\n const [open, setOpen] = useState<boolean>(optionsOpen);\n\n const { t } = useTranslation();\n\n const toggleOpen = useCallback(() => {\n setOpen((prevOpen) => !prevOpen);\n setTimeout(() => {\n setOptionsOpen(!open);\n }, 0);\n }, []);\n\n const showLTV =\n typeof currentLtv === \"number\" &&\n !Number.isNaN(currentLtv) &&\n currentLtv > 0;\n\n return (\n <Box className=\"oui-group\">\n <Flex\n justify=\"center\"\n gap={1}\n itemAlign=\"center\"\n className=\"oui-cursor-pointer\"\n onClick={toggleOpen}\n >\n <Divider className=\"oui-flex-1\" />\n <ChevronDownIcon\n size={12}\n color=\"white\"\n className={cn(\"oui-transition-transform\", open && \"oui-rotate-180\")}\n />\n <Divider className=\"oui-flex-1\" />\n </Flex>\n <Box\n style={{ transform: \"translateZ(0)\" }}\n className={cn(\n \"oui-select-none oui-space-y-1.5 oui-overflow-hidden\",\n \"oui-transition-[max-height] oui-duration-150\",\n \"group-hover:oui-will-change-[max-height]\",\n open\n ? showLTV\n ? \"oui-max-h-[94px]\"\n : \"oui-max-h-[69px]\"\n : \"oui-max-h-0\",\n )}\n >\n <AssetDetail\n label={t(\"trading.asset.freeCollateral\")}\n description={t(\"trading.asset.freeCollateral.tooltip\")}\n formula={t(\"trading.asset.freeCollateral.formula\")}\n visible={visible}\n // TODO: change AssetDetail value\n value={freeCollateral! === 0 ? (\"0\" as any) : freeCollateral}\n unit=\"USDC\"\n />\n <AssetDetail\n label={t(\"trading.asset.marginRatio\")}\n description={t(\"trading.asset.marginRatio.tooltip\")}\n formula={t(\"trading.asset.marginRatio.formula\")}\n visible={visible}\n value={marginRatioVal}\n isConnected={isConnected}\n rule=\"percentages\"\n showPercentage={true}\n placeholder=\"--%\"\n />\n <AssetDetail\n label={t(\"trading.asset.maintenanceMarginRatio\")}\n description={t(\"trading.asset.maintenanceMarginRatio.tooltip\")}\n formula={t(\"trading.asset.maintenanceMarginRatio.formula\")}\n visible={visible}\n value={renderMMR}\n rule=\"percentages\"\n showPercentage={true}\n placeholder=\"--%\"\n />\n {showLTV && <LTVDetail visible={visible} value={currentLtv} />}\n </Box>\n </Box>\n );\n};\n\nexport const AssetView: FC<\n AssetViewState & { isFirstTimeDeposit?: boolean }\n> = ({\n networkId,\n isFirstTimeDeposit,\n totalValue,\n onDeposit,\n onWithdraw,\n onTransfer,\n toggleVisible,\n visible,\n freeCollateral,\n marginRatioVal,\n renderMMR,\n isConnected,\n isMainAccount,\n hasSubAccount,\n currentLtv,\n}) => {\n const { title, description, titleColor, titleClsName } =\n useCurrentStatusText();\n\n const { t } = useTranslation();\n\n const transferButton = hasSubAccount && (\n <Button\n fullWidth\n color=\"secondary\"\n size=\"md\"\n onClick={onTransfer}\n data-testid=\"oui-testid-assetView-transfer-button\"\n >\n <Text>{t(\"common.transfer\")}</Text>\n </Button>\n );\n\n const depositButton = isMainAccount && (\n <Button\n data-testid=\"oui-testid-assetView-deposit-button\"\n fullWidth\n size=\"md\"\n onClick={onDeposit}\n >\n {!hasSubAccount && <ArrowDownShortIcon color=\"white\" opacity={1} />}\n <Text>{t(\"common.deposit\")}</Text>\n </Button>\n );\n\n const withdrawButton = isMainAccount && (\n <Button\n fullWidth\n color=\"secondary\"\n size=\"md\"\n onClick={onWithdraw}\n data-testid=\"oui-testid-assetView-withdraw-button\"\n >\n {!hasSubAccount && (\n <ArrowDownShortIcon\n color=\"white\"\n opacity={1}\n className=\"oui-rotate-180\"\n />\n )}\n <Text>{t(\"common.withdraw\")}</Text>\n </Button>\n );\n\n return (\n <Box className=\"oui-relative\">\n {title && description && (\n <Flex direction=\"column\" gap={1} className=\"oui-mb-[32px]\">\n <Text\n size=\"lg\"\n weight=\"bold\"\n color={titleColor || \"inherit\"}\n className={titleClsName}\n >\n {title}\n </Text>\n <Text\n size=\"2xs\"\n color=\"neutral\"\n weight=\"semibold\"\n className=\"oui-text-center\"\n >\n {description}\n </Text>\n </Flex>\n )}\n <AuthGuard\n networkId={networkId}\n buttonProps={{ size: \"md\", fullWidth: true }}\n >\n {isFirstTimeDeposit && isMainAccount ? (\n <>\n <Box>\n <Flex direction=\"column\" gap={1} className=\"oui-mb-[32px]\">\n <Text.gradient size=\"lg\" weight=\"bold\" color=\"brand\">\n {t(\"trading.asset.startTrading\")}\n </Text.gradient>\n <Text size=\"2xs\" color=\"neutral\" weight=\"semibold\">\n {t(\"trading.asset.startTrading.description\")}\n </Text>\n </Flex>\n </Box>\n <Button\n data-testid=\"oui-testid-assetView-deposit-button\"\n fullWidth\n size=\"md\"\n onClick={onDeposit}\n >\n <ArrowDownShortIcon color=\"white\" opacity={1} />\n <Text>{t(\"common.deposit\")}</Text>\n </Button>\n\n <Box className=\"oui-mt-3\">\n <FaucetWidget />\n </Box>\n </>\n ) : (\n <Box className=\"oui-space-y-4\">\n <TotalValue\n totalValue={totalValue}\n visible={visible}\n onToggleVisibility={toggleVisible}\n />\n <AssetValueList\n visible={visible}\n freeCollateral={freeCollateral}\n marginRatioVal={marginRatioVal}\n renderMMR={renderMMR}\n isConnected={isConnected}\n currentLtv={currentLtv}\n />\n <Flex\n gap={isMainAccount ? (hasSubAccount ? 2 : 3) : 0}\n itemAlign=\"center\"\n >\n {isMainAccount ? (\n <>\n {depositButton}\n {transferButton}\n {withdrawButton}\n </>\n ) : (\n transferButton\n )}\n </Flex>\n {isMainAccount && <FaucetWidget />}\n </Box>\n )}\n </AuthGuard>\n <div\n className={cn(\n \"oui-absolute oui-inset-0 oui-rotate-180\",\n \"oui-pointer-events-none oui-rounded-2xl oui-blur-[200px]\",\n )}\n style={{\n background:\n \"conic-gradient(from -40.91deg at 40.63% 50.41%, rgba(159, 115, 241, 0) -48.92deg, rgba(242, 98, 181, 0) 125.18deg, #5FC5FF 193.41deg, #FFAC89 216.02deg, #8155FF 236.07deg, #789DFF 259.95deg, rgba(159, 115, 241, 0) 311.08deg, rgba(242, 98, 181, 0) 485.18deg)\",\n }}\n />\n </Box>\n );\n};\n","import { useCallback, useMemo } from \"react\";\nimport {\n useAccountInstance,\n useEventEmitter,\n useLocalStorage,\n useAccount,\n useConfig,\n useCollateral,\n useMarginRatio,\n usePositionStream,\n useComputedLTV,\n} from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { useDataTap } from \"@orderly.network/react-app\";\nimport { AccountStatusEnum, NetworkId } from \"@orderly.network/types\";\nimport { modal, toast } from \"@orderly.network/ui\";\nimport {\n DepositAndWithdrawWithDialogId,\n TransferDialogId,\n} from \"@orderly.network/ui-transfer\";\n\nexport const useAssetViewScript = () => {\n const { t } = useTranslation();\n const account = useAccountInstance();\n const ee = useEventEmitter();\n\n const { totalValue } = useCollateral({\n dp: 2,\n });\n\n const networkId = useConfig(\"networkId\") as NetworkId;\n const { state, isMainAccount } = useAccount();\n const { freeCollateral } = useCollateral({\n dp: 2,\n });\n const { marginRatio, mmr } = useMarginRatio();\n const isConnected = state.status >= AccountStatusEnum.Connected;\n const [{ aggregated }, positionsInfo] = usePositionStream();\n const marginRatioVal = useMemo(() => {\n return Math.min(\n 10,\n aggregated.notional === 0\n ? positionsInfo[\"margin_ratio\"](10)!\n : marginRatio,\n );\n }, [marginRatio, aggregated]);\n\n // const renderMMR = useMemo(() => {\n // if (!mmr) {\n // return \"\";\n // }\n // const bigMMR = new Decimal(mmr);\n // return bigMMR.mul(100).todp(2, 0).toFixed(2);\n // }, [mmr]);\n\n const openDepositAndWithdraw = useCallback(\n (viewName: \"deposit\" | \"withdraw\") => {\n // desktop always show dialog\n return modal.show(DepositAndWithdrawWithDialogId, {\n activeTab: viewName,\n });\n },\n [],\n );\n\n const onDeposit = useCallback(async () => {\n return openDepositAndWithdraw(\"deposit\");\n }, []);\n\n const onWithdraw = useCallback(async () => {\n return openDepositAndWithdraw(\"withdraw\");\n }, []);\n\n const onTransfer = useCallback(async () => {\n return modal.show(TransferDialogId);\n }, []);\n\n const onSettle = useCallback(async () => {\n return account\n .settle()\n .catch((e) => {\n if (e.code === -1104) {\n toast.error(t(\"settle.settlement.error\"));\n return Promise.reject(e);\n }\n if (\n e.message.indexOf(\n \"Signing off chain messages with Ledger is not yet supported\",\n ) !== -1\n ) {\n ee.emit(\"wallet:sign-message-with-ledger-error\", {\n message: e.message,\n userAddress: account.address,\n });\n }\n })\n .then((res) => {\n toast.success(t(\"settle.settlement.requested\"));\n return Promise.resolve(res);\n });\n }, [account, t]);\n\n const [visible, setVisible] = useLocalStorage<boolean>(\n \"orderly_assets_visible\",\n true,\n );\n\n const toggleVisible = useCallback(() => {\n // @ts-ignore\n setVisible((visible: boolean) => {\n return !visible;\n });\n }, [visible]);\n\n const currentLtv = useComputedLTV();\n const _freeCollateral = useDataTap(freeCollateral) ?? undefined;\n const _marginRatioVal = useDataTap(marginRatioVal) ?? undefined;\n const _mmr = useDataTap(mmr) ?? undefined;\n const _totalValue = useDataTap(totalValue) ?? undefined;\n\n return {\n onDeposit,\n onWithdraw,\n onTransfer,\n onSettle,\n visible,\n toggleVisible,\n networkId,\n totalValue: _totalValue,\n status: state.status,\n freeCollateral: _freeCollateral,\n marginRatioVal: _marginRatioVal,\n renderMMR: _mmr,\n isConnected,\n isMainAccount,\n hasSubAccount: !!state.subAccounts?.length,\n currentLtv,\n };\n};\n\nexport type AssetViewState = ReturnType<typeof useAssetViewScript>;\n","import React from \"react\";\nimport { useAssetViewScript } from \"./assetView.script\";\nimport { AssetView } from \"./assetView.ui\";\n\ntype AssetViewWidgetProps = {\n isFirstTimeDeposit?: boolean;\n};\n\nexport const AssetViewWidget: React.FC<AssetViewWidgetProps> = (props) => {\n const state = useAssetViewScript();\n return <AssetView {...state} isFirstTimeDeposit={props.isFirstTimeDeposit} />;\n};\n","export { AssetView } from \"./assetView.ui\";\nexport { AssetViewWidget } from \"./assetView.widget\";\n","import React, {\n createContext,\n FC,\n PropsWithChildren,\n useContext,\n useState,\n} from \"react\";\nimport { BasicSymbolInfo } from \"../../../types/types\";\nimport { QtyMode, TotalMode } from \"./types\";\n\nexport interface OrderBookContextValue {\n cellHeight: number;\n mode: QtyMode;\n depth?: string;\n onModeChange?: (mode: QtyMode) => void;\n onItemClick?: (item: number[]) => void;\n showTotal: boolean;\n totalMode: TotalMode;\n pendingOrders: ReadonlyArray<number> | number[];\n onTotalModeChange?: (mode: TotalMode) => void;\n symbolInfo: BasicSymbolInfo;\n}\n\nexport const OrderBookContext = createContext({\n cellHeight: 22,\n} as OrderBookContextValue);\n\nexport const useOrderBookContext = () => useContext(OrderBookContext);\n\nexport const ORDERBOOK_COIN_TYPE_KEY = \"orderbook_coin_type\";\n\nexport const ORDERBOOK_MOBILE_COIN_TYPE_KEY = \"orderbook_mobile_coin_unit\";\n\ninterface OrderBookProviderProps {\n cellHeight: number;\n depth?: string;\n showTotal: boolean;\n pendingOrders: ReadonlyArray<number> | number[];\n onItemClick?: (item: number[]) => void;\n symbolInfo: BasicSymbolInfo;\n}\n\nexport const OrderBookProvider: FC<\n PropsWithChildren<OrderBookProviderProps>\n> = (props) => {\n const [mode, setMode] = useState<QtyMode>(\"quantity\");\n const [totalMode, setTotalMode] = useState<QtyMode>(\"quantity\");\n const memoizedValue = React.useMemo<OrderBookContextValue>(() => {\n return {\n cellHeight: props.cellHeight,\n onItemClick: props.onItemClick,\n mode,\n totalMode: totalMode || \"quantity\",\n depth: props.depth,\n onModeChange: setMode,\n onTotalModeChange: setTotalMode,\n showTotal: props.showTotal || false,\n pendingOrders: props.pendingOrders,\n symbolInfo: props.symbolInfo,\n };\n }, [\n mode,\n props.cellHeight,\n props.depth,\n props.onItemClick,\n props.pendingOrders,\n props.showTotal,\n props.symbolInfo,\n totalMode,\n ]);\n return (\n <OrderBookContext.Provider value={memoizedValue}>\n {props.children}\n </OrderBookContext.Provider>\n );\n};\n","export type QtyMode = \"quantity\" | \"amount\";\nexport type TotalMode = \"quantity\" | \"amount\";\n\nexport enum OrderBookCellType {\n BID = \"bid\",\n ASK = \"ask\",\n}\n","import { cn } from \"@orderly.network/ui\";\nimport { FC, useMemo } from \"react\";\n\nexport enum CellBarDirection {\n LEFT_TO_RIGHT,\n RIGHT_TO_LEFT,\n}\n\ninterface CellBarProps {\n width: number;\n className?: string;\n direction?: CellBarDirection\n}\n\nexport const CellBar: FC<CellBarProps> = (props) => {\n const { direction = CellBarDirection.RIGHT_TO_LEFT } = props;\n const transform = useMemo(() => {\n const x = Math.max(props.width, 0);\n if (direction === CellBarDirection.LEFT_TO_RIGHT) {\n return { transform: `translateX(${x}%)` };\n }\n return { transform: `translateX(-${x}%)` };\n \n }, [props.width]);\n\n return (\n <div\n className={cn(\n \"oui-absolute oui-right-[-100%] oui-top-0 oui-h-full oui-w-full oui-transition-transform oui-pointer-events-none\",\n direction === CellBarDirection.LEFT_TO_RIGHT && \"oui-left-[-100%]\",\n props.className\n )}\n style={transform}\n />\n );\n};\n","import { FC, useMemo } from \"react\";\nimport { useLocalStorage } from \"@orderly.network/hooks\";\nimport { cn, Divider, parseNumber, Text } from \"@orderly.network/ui\";\nimport { getPrecisionByNumber } from \"@orderly.network/utils\";\nimport { BasicSymbolInfo } from \"../../../types/types\";\nimport { CellBar, CellBarDirection } from \"../../base/orderBook/cellBar\";\nimport {\n ORDERBOOK_COIN_TYPE_KEY,\n useOrderBookContext,\n} from \"../../base/orderBook/orderContext\";\nimport { OrderBookCellType } from \"../../base/orderBook/types\";\n\nexport interface DesktopOrderBookCellProps {\n background: string;\n maxQty: number;\n price: number;\n quantity: number;\n // size: number;\n count: number;\n accumulated: number;\n accumulatedAmount: number;\n type: OrderBookCellType;\n symbolInfo: BasicSymbolInfo;\n base: string;\n quote: string;\n isHover: boolean;\n currentHover: boolean;\n onMouseEnter: () => void;\n onMouseLeave: () => void;\n}\n\nexport const DesktopOrderBookCell: FC<DesktopOrderBookCellProps> = (props) => {\n const { cellHeight, showTotal, onItemClick, depth, pendingOrders } =\n useOrderBookContext();\n const {\n symbolInfo,\n currentHover,\n accumulated,\n accumulatedAmount,\n count,\n price,\n quantity,\n base,\n quote,\n } = props;\n\n const { base_dp, quote_dp } = symbolInfo;\n\n const [coinType] = useLocalStorage<string>(ORDERBOOK_COIN_TYPE_KEY, base);\n\n const width = Number.isNaN(price) ? 0 : (accumulated / count) * 100;\n\n const dp = useMemo(() => {\n return getPrecisionByNumber(depth || `${quote_dp}`);\n }, [depth, quote_dp]);\n\n const totalAmount = Number.isNaN(accumulated)\n ? \"-\"\n : accumulatedAmount?.toString();\n\n const isPendingOrder = useMemo(() => {\n const priceStr = parseNumber(price, { dp: dp, padding: true });\n return pendingOrders.some(\n (item) => priceStr === parseNumber(item, { dp: dp, padding: true }),\n );\n }, [pendingOrders, price, dp]);\n\n return (\n <div\n className=\"oui-relative oui-flex oui-cursor-pointer oui-flex-row oui-justify-between oui-pl-3 oui-text-xs oui-tabular-nums oui-text-base-contrast-80\"\n style={{ height: `${cellHeight}px` }}\n onClick={() => {\n if (Number.isNaN(price) || Number.isNaN(quantity)) {\n return;\n }\n onItemClick?.([price, quantity]);\n }}\n onMouseEnter={props.onMouseEnter}\n onMouseLeave={props.onMouseLeave}\n >\n <div\n className={cn(\n \"oui-mr-2 oui-flex oui-basis-7/12 oui-flex-row oui-items-center\",\n showTotal && \"oui-basis-5/12\",\n )}\n >\n <div\n className={cn(\n \"oui-flex-1 oui-text-left\",\n props.type === OrderBookCellType.ASK\n ? \"oui-text-trade-loss\"\n : \"oui-text-trade-profit\",\n )}\n >\n <Text.numeral dp={dp}>{price}</Text.numeral>\n </div>\n <div className=\"oui-flex-1 oui-text-right oui-text-base-contrast-80\">\n <Text.numeral dp={base_dp}>{quantity}</Text.numeral>\n </div>\n </div>\n <div\n className={cn(\n \"oui-fex-row oui-relative oui-flex oui-basis-5/12 oui-items-center oui-justify-end oui-overflow-hidden\",\n showTotal && \"oui-basis-7/12\",\n )}\n >\n {showTotal ? (\n <>\n <div className={cn(\"oui-flex-1 oui-pr-3 oui-text-right\")}>\n <Text.numeral dp={base_dp} className=\"oui-z-10\">\n {accumulated}\n </Text.numeral>\n </div>\n <div className={cn(\"oui-flex-1 oui-pr-3 oui-text-right\")}>\n <Text.numeral dp={0} className=\"oui-z-10\">\n {totalAmount}\n </Text.numeral>\n </div>\n </>\n ) : (\n <div className={cn(\"oui-flex-1 oui-pr-3 oui-text-right\")}>\n {coinType === base && (\n <Text.numeral dp={base_dp} className=\"oui-z-10\">\n {accumulated}\n </Text.numeral>\n )}\n {coinType === quote && (\n <Text.numeral dp={0} className=\"oui-z-10\">\n {totalAmount}\n </Text.numeral>\n )}\n </div>\n )}\n <CellBar\n width={width}\n direction={CellBarDirection.LEFT_TO_RIGHT}\n className={\n props.type === OrderBookCellType.ASK\n ? \"oui-bg-trade-loss/10\"\n : \"oui-bg-trade-profit/10\"\n }\n />\n </div>\n\n {isPendingOrder && (\n <div\n className={cn(\n \"oui-pointer-events-none oui-absolute oui-left-[4px] oui-size-[4px] oui-rounded-full\",\n props.type === OrderBookCellType.ASK && \"oui-bg-trade-loss\",\n props.type === OrderBookCellType.BID && \"oui-bg-trade-profit\",\n )}\n style={{ top: `${cellHeight / 2 - 2}px` }}\n />\n )}\n\n {props.isHover && (\n <div className=\"oui-absolute oui-inset-0 oui-bg-white oui-opacity-[.12]\" />\n )}\n {currentHover && (\n <div\n className={cn(\n \"oui-absolute oui-inset-x-0\",\n props.type === OrderBookCellType.ASK && \"oui-top-0\",\n props.type === OrderBookCellType.BID && \"oui-bottom-0\",\n )}\n >\n <Divider\n lineStyle=\"dashed\"\n className={cn(\n \"oui-w-full\",\n props.type === OrderBookCellType.BID && \"oui-border-trade-profit\",\n props.type === OrderBookCellType.ASK && \"oui-border-trade-loss\",\n )}\n />\n </div>\n )}\n </div>\n );\n};\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport React, { useCallback, useMemo, useState } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n TooltipContent,\n TooltipTrigger,\n Text,\n TooltipRoot,\n TooltipArrow,\n cn,\n} from \"@orderly.network/ui\";\nimport { Decimal } from \"@orderly.network/utils\";\nimport { BasicSymbolInfo } from \"../../../types/types\";\nimport { useOrderBookContext } from \"../../base/orderBook/orderContext\";\nimport { OrderBookCellType } from \"../../base/orderBook/types\";\nimport { DesktopOrderBookCell } from \"./cell.desktop\";\n\ninterface DesktopListBoxProps {\n type: OrderBookCellType;\n data: number[][];\n countQty: number;\n}\n\nconst calcHintInfo = (item: number[] | null) => {\n if (!item) {\n return { sumQty: 0, sumQtyAmount: 0, avgPrice: 0 };\n }\n const [, , qty, amount] = item;\n const sumQty = !Number.isNaN(qty) ? qty : 0;\n const sumQtyAmount = !Number.isNaN(amount) ? amount : 0;\n return {\n sumQty: sumQty,\n sumQtyAmount: sumQtyAmount,\n avgPrice:\n sumQtyAmount === 0 || sumQty === 0\n ? 0\n : new Decimal(sumQtyAmount).div(sumQty).toNumber(),\n };\n};\n\nexport const DesktopListBox: React.FC<DesktopListBoxProps> = (props) => {\n const { data, type, countQty } = props;\n const { symbolInfo, depth } = useOrderBookContext();\n\n const findMaxItem = useCallback(() => {\n if (!data?.length) {\n return null;\n }\n if (type === OrderBookCellType.ASK) {\n const index = data.findIndex((item) => !Number.isNaN(item[0]));\n if (index !== -1) {\n return data[index];\n }\n return null;\n } else {\n const len = data.length;\n for (let index = len - 1; index >= 0; index--) {\n const item = data[index];\n if (!Number.isNaN(item[0])) {\n return item;\n }\n }\n return null;\n }\n }, [data, type]);\n\n const priceDp = useMemo(() => {\n if (depth?.toString().includes(\".\")) {\n return depth.toString().split(\".\")[1].length;\n }\n return 0;\n }, [depth]);\n\n const maxQty = useMemo(() => {\n return data.reduce((a, b) => Math.max(a, b[1]), 0);\n }, [data]);\n\n const [hoverIndex, setHoverIndex] = useState<number>(-1);\n\n return (\n <div className=\"oui-order-book-list oui-flex oui-flex-col oui-gap-px\">\n {data.map((item, index) => {\n return (\n <Tip\n key={index}\n index={index}\n item={item}\n countQty={countQty}\n setHoverIndex={setHoverIndex}\n hoverIndex={hoverIndex}\n type={type}\n maxQty={maxQty}\n priceDp={priceDp}\n symbolInfo={symbolInfo}\n findMaxItem={findMaxItem}\n />\n );\n })}\n </div>\n );\n};\n\nconst Tip: React.FC<{\n index: number;\n item: any;\n countQty: number;\n setHoverIndex: any;\n type: OrderBookCellType;\n maxQty: number;\n hoverIndex: number;\n priceDp: number;\n // base: any;\n // quote: any;\n // baseDp: number;\n // quoteDp: number;\n findMaxItem: () => number[] | null;\n symbolInfo: BasicSymbolInfo;\n}> = (props) => {\n const {\n index,\n item,\n setHoverIndex,\n type,\n maxQty,\n hoverIndex,\n priceDp,\n countQty,\n symbolInfo,\n findMaxItem,\n } = props;\n\n const { base, quote, base_dp: baseDp, quote_dp: quoteDp } = symbolInfo;\n const { t } = useTranslation();\n\n const isHover =\n hoverIndex !== -1\n ? type === OrderBookCellType.ASK\n ? index >= hoverIndex\n : index <= hoverIndex\n : false;\n\n const [open, setOpen] = useState(false);\n\n const hintInfo = useMemo(() => {\n const info = calcHintInfo(item);\n return info.avgPrice === 0 ? calcHintInfo(findMaxItem()) : info;\n }, [item, findMaxItem]);\n\n return (\n <TooltipRoot open={open} onOpenChange={setOpen}>\n <TooltipTrigger>\n <DesktopOrderBookCell\n background={\"\"}\n price={item[0]}\n quantity={item[1]}\n accumulated={item[2]}\n count={countQty}\n type={type}\n accumulatedAmount={item[3]}\n maxQty={maxQty}\n isHover={isHover}\n currentHover={hoverIndex === index}\n symbolInfo={symbolInfo}\n base={base}\n quote={quote}\n onMouseEnter={() => {\n setHoverIndex(index);\n setOpen(true);\n }}\n onMouseLeave={() => {\n setHoverIndex(-1);\n setOpen(false);\n }}\n />\n </TooltipTrigger>\n <TooltipContent\n className={cn(\n \"oui-rounded-base oui-flex oui-w-full oui-max-w-[400px] oui-flex-col oui-gap-2 oui-bg-base-6 oui-p-3 oui-text-2xs oui-shadow-md\",\n // type === OrderBookCellType.ASK ? `oui-mb-${30}` : \"oui-mt-0\"\n )}\n align={type === OrderBookCellType.ASK ? \"end\" : \"start\"}\n alignOffset={-25.4}\n side=\"left\"\n sideOffset={2}\n onPointerEnter={(e) => e.preventDefault()}\n >\n <Row\n title={`${t(\"common.avgPrice\")}≈`}\n content={hintInfo.avgPrice}\n // contentDp={priceDp}\n contentDp={quoteDp}\n />\n <Row\n title={`${t(\"trading.orderBook.sum\")} (${base})`}\n content={hintInfo.sumQty}\n contentDp={baseDp}\n />\n <Row\n title={`${t(\"trading.orderBook.sum\")} (${quote})`}\n content={hintInfo.sumQtyAmount}\n contentDp={quoteDp}\n />\n <TooltipArrow\n className=\"oui-fill-base-6\"\n style={{\n transform:\n type === OrderBookCellType.ASK\n ? \"translateX(80%)\"\n : \"translateX(-80%)\",\n }}\n />\n </TooltipContent>\n </TooltipRoot>\n );\n};\n\nconst Row: React.FC<{ title: string; content: number; contentDp: number }> = (\n props,\n) => {\n const { title, content, contentDp } = props;\n return (\n <div className=\"oui-flex oui-flex-row oui-justify-between oui-gap-4\">\n <div className=\"oui-select-none oui-text-base-contrast-36\">{title}</div>\n <div className=\"oui-text-end\">\n <Text.numeral dp={contentDp}>{content}</Text.numeral>\n </div>\n </div>\n );\n};\n","import { FC, useMemo } from \"react\";\nimport { OrderBookCellType } from \"../../base/orderBook/types\";\nimport { DesktopListBox } from \"./listBox.desktop\";\n\nexport interface Props {\n data: number[][];\n}\n\nexport const DesktopAsks: FC<Props> = (props) => {\n const { data } = props;\n const countQty = useMemo(() => {\n let max = Number.NaN;\n const len = data.length;\n let index = 0;\n\n while (Number.isNaN(max) && index < len) {\n max = data[index][2];\n index++;\n }\n\n return max;\n }, [data]);\n\n return (\n <DesktopListBox\n type={OrderBookCellType.ASK}\n data={data}\n countQty={countQty}\n />\n );\n};\n","import { FC, useMemo } from \"react\";\nimport { OrderBookCellType } from \"../../base/orderBook/types\";\nimport { DesktopListBox } from \"./listBox.desktop\";\n\nexport interface Props {\n data: any[];\n}\n\nexport const DesktopBids: FC<Props> = (props) => {\n const { data } = props;\n const countQty = useMemo(() => {\n let max = Number.NaN;\n // let len = data.length;\n let index = data.length - 1;\n\n while (Number.isNaN(max) && index > 0) {\n max = data[index][2];\n index--;\n }\n\n return max;\n // return data.length > 0 ? data[data.length - 1][2] : 0;\n }, [data]);\n return (\n <DesktopListBox\n type={OrderBookCellType.BID}\n data={data}\n countQty={countQty}\n />\n );\n};\n","import { Box, Select } from \"@orderly.network/ui\";\nimport { FC, useMemo } from \"react\";\n\ninterface DesktopDepthSelectProps {\n depths: string[];\n value?: string;\n onChange?: (depth: number) => void;\n}\n\nexport const DesktopDepthSelect: FC<DesktopDepthSelectProps> = (props) => {\n const options = useMemo(() => {\n return props.depths.map((d) => ({\n value: d,\n label: `${d}`,\n }));\n }, [props.depths]);\n\n return (\n <Box pl={3} width={97} className=\"oui-py-[10px]\">\n <Select.options\n options={options}\n size={\"xs\"}\n value={props.value}\n onValueChange={(value: any) => {\n props.onChange?.(value);\n }}\n />\n </Box>\n );\n};\n","import React, { FC, ReactNode } from \"react\";\nimport { useLocalStorage } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n Box,\n CaretDownIcon,\n CaretUpIcon,\n cn,\n Flex,\n Popover,\n} from \"@orderly.network/ui\";\nimport {\n ORDERBOOK_COIN_TYPE_KEY,\n useOrderBookContext,\n} from \"../../base/orderBook/orderContext\";\n\ninterface DesktopHeaderProps {\n quote: string;\n base: string;\n}\n\nconst Option: React.FC<{\n item: string;\n base: string;\n onClick: React.MouseEventHandler<HTMLElement>;\n}> = (props) => {\n const { item, base, onClick } = props;\n const { t } = useTranslation();\n const [coinType, setCoinType] = useLocalStorage(\n ORDERBOOK_COIN_TYPE_KEY,\n base,\n );\n return (\n <Flex\n justify=\"between\"\n itemAlign=\"center\"\n className={cn(\n \"oui-w-full oui-px-2 oui-py-[3px]\",\n \"oui-cursor-pointer\",\n \"oui-text-xs\",\n \"oui-text-base-contrast-54\",\n \"hover:oui-bg-base-6\",\n \"oui-rounded-[3px]\",\n \"oui-transition-all\",\n coinType === item && \"oui-bg-base-5\",\n )}\n onClick={(e) => {\n setCoinType(item);\n onClick(e);\n }}\n >\n {t(\"common.total\")}({item})\n <div\n className={cn(\n \"oui-transition-all\",\n \"oui-w-1\",\n \"oui-h-1\",\n \"oui-rounded-full\",\n \"oui-bg-gradient-to-r\",\n coinType === item &&\n \"oui-from-[rgb(var(--oui-gradient-brand-start))] oui-to-[rgb(var(--oui-gradient-brand-end))]\",\n )}\n />\n </Flex>\n );\n};\n\nexport const DesktopHeader: FC<DesktopHeaderProps> = (props) => {\n const { base, quote = \"USDC\" } = props;\n const { showTotal } = useOrderBookContext();\n const { t } = useTranslation();\n const [popoverOpen, setOpen] = React.useState<boolean>(false);\n const [coinType] = useLocalStorage(ORDERBOOK_COIN_TYPE_KEY, base);\n const TriggerIcon = popoverOpen ? CaretUpIcon : CaretDownIcon;\n return (\n <Flex pl={3} justify={\"between\"} className=\"oui-py-[6px]\">\n <Flex\n gap={1}\n className={cn(\"oui-basis-7/12\", showTotal && \"oui-basis-1/2\")}\n >\n <Box width={\"100%\"}>\n <Title\n id=\"oui-order-book-header-price\"\n className=\"oui-text-base-contrast-36\"\n >\n {`${t(\"common.price\")}(${quote})`}\n </Title>\n </Box>\n <Box width={\"100%\"}>\n <Title\n justifyEnd\n id=\"oui-order-book-header-qty\"\n className=\"oui-text-base-contrast-36\"\n >\n {`${t(\"common.qty\")}(${base})`}\n </Title>\n </Box>\n </Flex>\n <Flex\n gap={1}\n pr={3}\n className={cn(\"oui-basis-5/12\", showTotal && \"oui-basis-1/2\")}\n >\n {showTotal ? (\n <>\n <Box className=\"oui-text-base-contrast-36\" width={\"100%\"}>\n <Title id=\"oui-order-book-header-total-quote\" justifyEnd>\n {`${t(\"common.total\")}(${base})`}\n </Title>\n </Box>\n <Box className=\"oui-text-base-contrast-36\" width={\"100%\"}>\n <Title justifyEnd id=\"oui-order-book-header-total-base\">\n {`${t(\"common.total\")}(${quote})`}\n </Title>\n </Box>\n </>\n ) : (\n <Box width={\"100%\"}>\n <Popover\n open={popoverOpen}\n onOpenChange={setOpen}\n contentProps={{ className: cn(\"oui-w-28 oui-p-1\") }}\n content={\n <Flex\n direction=\"column\"\n itemAlign=\"start\"\n className={cn(\"oui-w-full oui-gap-0.5\")}\n >\n {[base, quote].map((item) => {\n return (\n <Option\n key={`type-${item}`}\n item={item}\n base={base}\n onClick={() => setOpen(false)}\n />\n );\n })}\n </Flex>\n }\n >\n <Flex\n justify=\"end\"\n itemAlign=\"center\"\n className=\"oui-cursor-pointer oui-select-none oui-text-base-contrast-36 oui-transition-all hover:oui-text-base-contrast\"\n >\n <Title justifyEnd id=\"oui-order-book-header-total-base\">\n {`${t(\"common.total\")}(${coinType})`}\n </Title>\n <TriggerIcon\n color=\"inherit\"\n className=\"oui-size-4 oui-text-3xs\"\n />\n </Flex>\n </Popover>\n </Box>\n )}\n </Flex>\n </Flex>\n );\n};\n\nconst Title: FC<{\n justifyEnd?: boolean;\n id?: string;\n children: ReactNode;\n className?: string;\n}> = (props) => {\n const { children, className, justifyEnd = false } = props;\n return (\n <Flex\n id={props.id}\n className={cn(\n className,\n \"oui-items-end oui-text-xs\",\n justifyEnd && \"oui-justify-end\",\n )}\n >\n {children}\n </Flex>\n );\n};\n","import {\n ArrowDownShortIcon,\n ArrowUpShortIcon,\n Box,\n cn,\n Flex,\n Text,\n} from \"@orderly.network/ui\";\nimport { FC } from \"react\";\n\n/**\n * default style is desktop effect\n */\nexport const MiddlePriceView: FC<{\n markPrice: number;\n lastPrice: number[];\n quote_dp: number;\n className?: string;\n iconSize?: number;\n}> = (props) => {\n const {\n markPrice = 0,\n lastPrice,\n quote_dp,\n className,\n iconSize = 18,\n } = props;\n\n const [prevLastPrice, middlePrice] = lastPrice;\n\n const down = middlePrice < prevLastPrice;\n const up = middlePrice > prevLastPrice;\n\n return (\n <Flex\n gap={1}\n className={cn(\n up ? \"oui-text-trade-profit\" : down ? \"oui-text-trade-loss\" : \"\",\n className\n )}\n >\n <Text.numeral dp={quote_dp} intensity={98}>\n {middlePrice}\n </Text.numeral>\n <Box width={19}>\n {down && (\n <ArrowDownShortIcon size={iconSize} color=\"danger\" opacity={1} />\n )}\n {up && <ArrowUpShortIcon size={iconSize} color=\"success\" opacity={1} />}\n </Box>\n </Flex>\n );\n};\n","import { FC, useState } from \"react\";\nimport {\n Tooltip,\n cn,\n Flex,\n Text,\n SimpleDialog,\n useScreen,\n} from \"@orderly.network/ui\";\nimport { useTranslation } from \"@orderly.network/i18n\";\n\n/**\n * default style is desktop effect\n */\nexport const MarkPriceView: FC<{\n markPrice: number;\n quote_dp: number;\n className?: string;\n iconSize?: number;\n}> = (props) => {\n const { isMobile } = useScreen();\n\n return isMobile ? <MobileLayout {...props} /> : <DesktopLayout {...props} />;\n};\n\nconst DesktopLayout: FC<{\n markPrice: number;\n quote_dp: number;\n className?: string;\n iconSize?: number;\n}> = (props) => {\n const { quote_dp, className, iconSize = 18 } = props;\n const { t } = useTranslation();\n return (\n <Tooltip\n content={t(\"trading.orderBook.markPrice.tooltip\")}\n className=\"oui-max-w-[270px]\"\n >\n <Flex\n gap={1}\n className={cn(\"oui-cursor-pointer oui-text-2xs\", className)}\n >\n <FlagIcon size={iconSize} />\n <Text.numeral\n dp={quote_dp}\n color=\"warning\"\n className=\"oui-underline oui-text-base oui-decoration-dashed oui-decoration-1 oui-underline-offset-4 oui-decoration-warning-darken\"\n >\n {props.markPrice}\n </Text.numeral>\n </Flex>\n </Tooltip>\n );\n};\n\nconst MobileLayout: FC<{\n markPrice: number;\n quote_dp: number;\n className?: string;\n iconSize?: number;\n}> = (props) => {\n const { quote_dp, className, iconSize = 18 } = props;\n const [open, setOpen] = useState(false);\n const { t } = useTranslation();\n return (\n <>\n <Flex\n gap={1}\n className={cn(\"oui-cursor-pointer oui-text-2xs\", className)}\n onClick={() => {\n setOpen(true);\n }}\n >\n <FlagIcon size={iconSize} />\n <Text.numeral\n dp={quote_dp}\n color=\"warning\"\n className=\"oui-underline oui-decoration-dashed oui-decoration-1 oui-underline-offset-4 oui-decoration-warning-darken\"\n >\n {props.markPrice}\n </Text.numeral>\n </Flex>\n <SimpleDialog\n size=\"xs\"\n open={open}\n onOpenChange={setOpen}\n title={t(\"common.tips\")}\n actions={{\n primary: {\n label: t(\"common.ok\"),\n onClick: () => setOpen(false),\n },\n }}\n >\n <Text>{t(\"trading.orderBook.markPrice.tooltip\")}</Text>\n </SimpleDialog>\n </>\n );\n};\n\nconst FlagIcon = (props: { size: number }) => {\n return (\n <svg\n width={props.size}\n height={props.size}\n viewBox=\"0 0 18 18\"\n fill=\"currenColor\"\n xmlns=\"http://www.w3.org/2000/svg\"\n className=\"oui-fill-warning-darken\"\n >\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M3.75 1.5a.75.75 0 0 1 .75.75h6a.75.75 0 0 1 .75.75v1.5h3a.75.75 0 0 1 .75.75V12a.75.75 0 0 1-.75.75H7.5a.75.75 0 0 1-.75-.75v-1.5H4.5v5.25a.75.75 0 0 1-1.5 0V2.25a.75.75 0 0 1 .75-.75M4.5 9h5.25V3.75H4.5zm6.75-3v3.75a.75.75 0 0 1-.75.75H8.25v.75h5.25V6z\"\n // fill=\"#FF7D00\"\n />\n </svg>\n );\n};\n","import { FC, useMemo } from \"react\";\nimport { Decimal } from \"@orderly.network/utils\";\nimport { cn, Flex, Text, Tooltip } from \"@orderly.network/ui\";\nimport { BasicSymbolInfo } from \"../../../types/types\";\nimport { useOrderBookContext } from \"../../base/orderBook/orderContext\";\nimport { MiddlePriceView } from \"../../base/orderBook/midPriceView\";\nimport { MarkPriceView } from \"../../base/orderBook/markPrice\";\nimport { useTranslation } from \"@orderly.network/i18n\";\ninterface DesktopMarkPriceProps {\n markPrice: number;\n lastPrice: number[];\n asks: number[][];\n bids: number[][];\n symbolInfo: BasicSymbolInfo;\n}\n\nexport const DesktopMarkPrice: FC<DesktopMarkPriceProps> = (props) => {\n const { markPrice = 0, lastPrice, asks, bids, symbolInfo } = props;\n const { showTotal } = useOrderBookContext();\n\n return (\n <div className=\"oui-flex oui-flex-row oui-pl-3 oui-tabular-nums oui-justify-between oui-text-base-contrast-80 oui-text-xs oui-relative oui-cursor-pointer oui-py-[6px]\">\n <div\n className={cn(\n \"oui-basis-7/12 oui-flex oui-flex-row oui-items-center oui-mr-2 oui-justify-between\",\n showTotal && \"oui-basis-5/12\"\n )}\n >\n <MiddlePriceView\n markPrice={markPrice}\n lastPrice={lastPrice}\n quote_dp={symbolInfo.quote_dp}\n className=\"oui-text-base\"\n />\n <MarkPriceView markPrice={markPrice} quote_dp={symbolInfo.quote_dp} />\n </div>\n <div\n className={cn(\n \"oui-basis-5/12 oui-flex oui-items-center oui-fex-row oui-overflow-hidden oui-relative oui-justify-end\",\n showTotal && \"oui-basis-7/12\",\n \"oui-pr-3\"\n )}\n >\n <Spread asks={asks} bids={bids} />\n </div>\n </div>\n );\n};\n\nconst Spread: FC<{\n asks: number[][];\n bids: number[][];\n}> = (props) => {\n const { asks, bids } = props;\n\n const { t } = useTranslation();\n\n const spread = useMemo(() => {\n if (bids.length === 0 && asks.length === 0) {\n return 0;\n }\n const bid1 = Number.isNaN(bids[0][0]) ? 0 : bids[0][0];\n const index = asks.reverse().findIndex((item) => !Number.isNaN(item[0]));\n\n let ask1 = 0.0;\n if (index !== -1) {\n ask1 = Number.isNaN(asks[index][0]) ? 0 : asks[index][0];\n }\n const dValue = new Decimal(ask1)\n .sub(bid1)\n .div(new Decimal(ask1).add(bid1).div(2));\n // 0.00006416604461251195\n // 0.000065\n // 0.0065\n return Math.ceil(dValue.toNumber() * 1000000 + 0.1) / 10000;\n }, [asks, bids]);\n\n return (\n <div>\n <Tooltip\n content={t(\"trading.orderBook.spreadRatio.tooltip\")}\n className=\"oui-max-w-[240px]\"\n >\n <Text\n size=\"2xs\"\n intensity={36}\n className={\n \"oui-cursor-pointer oui-underline oui-decoration-dashed oui-decoration-1 oui-underline-offset-4 oui-decoration-base-contrast-36\"\n }\n >\n {`${spread}%`}\n </Text>\n </Tooltip>\n </div>\n );\n};\n","import { FC, useEffect, useRef, useState } from \"react\";\nimport { useLocalStorage } from \"@orderly.network/hooks\";\nimport { EMPTY_LIST } from \"@orderly.network/types\";\nimport { cn, Grid, Spinner } from \"@orderly.network/ui\";\nimport { BasicSymbolInfo } from \"../../../types/types\";\nimport {\n ORDERBOOK_COIN_TYPE_KEY,\n OrderBookProvider,\n} from \"../../base/orderBook/orderContext\";\nimport { DesktopAsks } from \"./asks.desktop\";\nimport { DesktopBids } from \"./bids.desktop\";\nimport { DesktopDepthSelect } from \"./depthSelect.desktop\";\nimport { DesktopHeader } from \"./header.desktop\";\nimport { DesktopMarkPrice } from \"./markPrice.desktop\";\n\nexport interface DesktopOrderBookProps {\n asks: any[];\n bids: any[];\n markPrice: number;\n lastPrice: number[];\n onItemClick?: (item: number[]) => void;\n depths: string[];\n activeDepth?: string;\n onDepthChange?: (depth: number) => void;\n //\n autoSize?: boolean;\n level?: number;\n base: string;\n quote: string;\n\n isLoading?: boolean;\n\n cellHeight?: number;\n\n className?: string;\n pendingOrders?: number[];\n symbolInfo: BasicSymbolInfo;\n}\n\nexport const DesktopOrderBook: FC<DesktopOrderBookProps> = (props) => {\n const { lastPrice, markPrice, quote, base, isLoading, onDepthChange } = props;\n\n const divRef = useRef<HTMLDivElement>(null);\n\n const [showTotal, setShowTotal] = useState(false);\n\n const [coinType, setCoinType] = useLocalStorage(\n ORDERBOOK_COIN_TYPE_KEY,\n base,\n );\n\n useEffect(() => {\n if (coinType !== quote && base) {\n setCoinType(base);\n }\n }, [base, quote]);\n\n useEffect(() => {\n const resizeObserver = new ResizeObserver((entries) => {\n for (const entry of entries) {\n const { inlineSize: width } = entry.borderBoxSize[0];\n setShowTotal(width >= 360);\n }\n });\n\n const targetDiv = divRef.current;\n\n if (targetDiv) {\n resizeObserver.observe(targetDiv);\n }\n\n return () => {\n if (targetDiv) {\n resizeObserver.unobserve(targetDiv);\n }\n };\n }, []);\n\n return (\n <OrderBookProvider\n cellHeight={props.cellHeight ?? 20}\n onItemClick={props.onItemClick}\n depth={props.activeDepth}\n showTotal={showTotal}\n pendingOrders={props.pendingOrders || EMPTY_LIST}\n symbolInfo={props.symbolInfo}\n >\n <Grid\n cols={1}\n rows={5}\n id=\"oui-orderbook-desktop\"\n ref={divRef}\n className=\"oui-relative oui-size-full oui-grid-rows-[auto,auto,1fr,auto,1fr]\"\n >\n <DesktopDepthSelect\n depths={props.depths}\n value={props.activeDepth}\n onChange={onDepthChange}\n />\n <DesktopHeader quote={quote} base={base} />\n <DesktopAsks data={[...props.asks]} />\n <DesktopMarkPrice\n lastPrice={lastPrice}\n markPrice={markPrice}\n // ======================================================================\n // == 🔥🔥🔥🔥🔥🔥🔥 DO NOT MODIFY THIS 🔥🔥🔥🔥🔥🔥🔥 ==\n // ======================================================================\n // Use shallow copy here to avoid mutating the original props array when sorting or modifying inside the component.\n // Note: This only clones the array itself, not the element objects.\n asks={[...props.asks]}\n bids={[...props.bids]}\n symbolInfo={props.symbolInfo}\n />\n <DesktopBids data={[...props.bids]} />\n {isLoading && (\n <div className=\"oui-bg-bg-8/70 oui-absolute oui-inset-0 oui-z-10 oui-flex oui-items-center oui-justify-center\">\n <Spinner />\n </div>\n )}\n </Grid>\n </OrderBookProvider>\n );\n};\n","import { FC } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { Flex, Text } from \"@orderly.network/ui\";\nimport { FundingRateState } from \"./fundingRate.script\";\n\nexport const FundingRate: FC<FundingRateState> = (props) => {\n const { data, onClick } = props;\n const predFundingRate = data.est_funding_rate;\n const countDown = data.countDown;\n const { t } = useTranslation();\n return (\n <Flex direction={\"column\"} itemAlign={\"start\"} pb={2}>\n <Text\n size=\"2xs\"\n intensity={36}\n className=\"oui-cursor-pointer oui-underline oui-decoration-line-16 oui-decoration-dashed oui-underline-offset-4\"\n onClick={onClick}\n >\n {t(\"trading.fundingRate.predFundingRate\")}\n </Text>\n {predFundingRate === null ? (\n \"--\"\n ) : (\n <div className=\"orderly-flex orderly-gap-1 oui-text-2xs oui-text-base-contrast-36\">\n {/* <span className=\"orderly-text-warning-darken\">{`${predFundingRate}%`}</span> */}\n <Text.numeral coloring suffix=\"%\" dp={4}>\n {predFundingRate ?? \"--\"}\n </Text.numeral>\n <span>{\" in\"}</span>\n <span>{\" \" + countDown}</span>\n </div>\n )}\n </Flex>\n );\n};\n","import { useMemo } from \"react\";\nimport { useFundingDetails } from \"@orderly.network/hooks\";\nimport { Decimal } from \"@orderly.network/utils\";\n\ninterface FundingRateOptions {\n symbol: string;\n}\n\nexport const useFundingRateModalScript = (options: FundingRateOptions) => {\n const { data, isLoading } = useFundingDetails(options.symbol);\n\n const fundingPeriod = useMemo(() => {\n if (!data || isLoading) {\n return \"-\";\n }\n return `${data.funding_period}h`;\n }, [data, isLoading]);\n\n const capFunding = useMemo(() => {\n if (!data || isLoading) {\n return \"-\";\n }\n return `${new Decimal(data.cap_funding).mul(100).toNumber()}%`;\n }, [data, isLoading]);\n\n const floorFunding = useMemo(() => {\n if (!data || isLoading) {\n return \"-\";\n }\n return `${new Decimal(data.floor_funding).mul(100).toNumber()}%`;\n }, [data, isLoading]);\n\n return { fundingPeriod, capFunding, floorFunding };\n};\n\nexport type FundingRateModalState = ReturnType<\n typeof useFundingRateModalScript\n>;\n","import React from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { Flex, Text, Divider } from \"@orderly.network/ui\";\nimport type { FundingRateModalState } from \"./fundingRateModal.script\";\n\nexport const FundingRateModal: React.FC<FundingRateModalState> = (props) => {\n const { t } = useTranslation();\n const { fundingPeriod, capFunding, floorFunding } = props;\n return (\n <Flex width={\"100%\"} itemAlign={\"center\"} direction=\"column\" gap={1}>\n <Flex justify=\"between\" itemAlign={\"center\"} width={\"100%\"}>\n <Text intensity={54}>\n {t(\"trading.fundingRate.predFundingRate.interval\")}\n </Text>\n <Text intensity={80}>{fundingPeriod}</Text>\n </Flex>\n <Flex justify=\"between\" itemAlign={\"center\"} width={\"100%\"}>\n <Text intensity={54}>\n {t(\"trading.fundingRate.predFundingRate.cap\")} /\n {t(\"trading.fundingRate.predFundingRate.floor\")}\n </Text>\n <Text intensity={80}>\n {capFunding} / {floorFunding}\n </Text>\n </Flex>\n <Divider my={4} className=\"oui-w-full\" intensity={8} />\n {t(\"markets.symbolInfoBar.predFundingRate.tooltip\")}\n </Flex>\n );\n};\n","import React from \"react\";\nimport { i18n } from \"@orderly.network/i18n\";\nimport { registerSimpleDialog, registerSimpleSheet } from \"@orderly.network/ui\";\nimport { useFundingRateModalScript } from \"./fundingRateModal.script\";\nimport { FundingRateModal } from \"./fundingRateModal.ui\";\n\nexport const FundingRateModalWidget: React.FC<{ symbol: string }> = (props) => {\n const state = useFundingRateModalScript(props);\n return <FundingRateModal {...state} />;\n};\n\nexport const FundingRateDialogId = \"FundingRateDialogId\";\nexport const FundingRateSheetId = \"FundingRateSheetId\";\n\nregisterSimpleDialog(FundingRateDialogId, FundingRateModalWidget, {\n size: \"md\",\n classNames: { content: \"oui-border oui-border-line-6\" },\n title: () => i18n.t(\"funding.fundingRate\"),\n});\n\nregisterSimpleSheet(FundingRateSheetId, FundingRateModalWidget, {\n title: () => i18n.t(\"funding.fundingRate\"),\n});\n","import { useCallback } from \"react\";\nimport { useFundingRate } from \"@orderly.network/hooks\";\nimport { modal } from \"@orderly.network/ui\";\nimport { FundingRateDialogId } from \"../fundingRateModal/fundingRateModal.widget\";\n\nexport const useFundingRateScript = (symbol: string) => {\n const data = useFundingRate(symbol);\n const onClick = useCallback<React.MouseEventHandler<HTMLElement>>(() => {\n modal.show(FundingRateDialogId, { symbol });\n }, [symbol]);\n return {\n data,\n onClick,\n };\n};\n\nexport type FundingRateState = ReturnType<typeof useFundingRateScript>;\n","import React from \"react\";\nimport { useFundingRateScript } from \"./fundingRate.script\";\nimport { FundingRate } from \"./fundingRate.ui\";\n\nexport const FundingRateWidget: React.FC<{ symbol: string }> = (props) => {\n const state = useFundingRateScript(props.symbol);\n return <FundingRate {...state} />;\n};\n","export { FundingRate } from \"./fundingRate.ui\";\nexport { FundingRateWidget } from \"./fundingRate.widget\";\nexport { useFundingRateScript } from \"./fundingRate.script\";\n","import { FC, useContext, useMemo } from \"react\";\nimport { useLocalStorage } from \"@orderly.network/hooks\";\nimport { Box, cn, Flex, Text } from \"@orderly.network/ui\";\nimport { getPrecisionByNumber } from \"@orderly.network/utils\";\nimport { CellBar } from \"../../base/orderBook/cellBar\";\nimport {\n ORDERBOOK_MOBILE_COIN_TYPE_KEY,\n OrderBookContext,\n} from \"../../base/orderBook/orderContext\";\nimport { OrderBookCellType, QtyMode } from \"../../base/orderBook/types\";\n\nexport interface OrderBookCellProps {\n background: string;\n price: number;\n quantity: number;\n accumulatedAmount: number;\n // size: number;\n count: number;\n accumulated: number;\n type: OrderBookCellType;\n mode: QtyMode;\n}\n\nexport const OrderBookCell: FC<OrderBookCellProps> = (props) => {\n const { accumulated, count, quantity, price, type, accumulatedAmount } =\n props;\n\n const width = (accumulated / count) * 100;\n\n const { cellHeight, onItemClick, depth, symbolInfo } =\n useContext(OrderBookContext);\n\n const { base_dp, quote_dp, base, quote } = symbolInfo;\n\n const [coinUnit, setCoinUnit] = useLocalStorage<\"qty\" | \"base\" | \"quote\">(\n ORDERBOOK_MOBILE_COIN_TYPE_KEY,\n \"qty\",\n );\n\n const totalAmount = Number.isNaN(accumulated)\n ? \"-\"\n : accumulatedAmount?.toString();\n\n const dp = useMemo(() => {\n return getPrecisionByNumber(depth || `${quote_dp}`);\n }, [depth, quote_dp]);\n\n const renderCell = () => {\n switch (coinUnit) {\n case \"base\":\n return (\n <Text.numeral className=\"oui-text-base-contrast-80\" dp={base_dp}>\n {accumulated}\n </Text.numeral>\n );\n case \"quote\":\n return (\n <Text.numeral className=\"oui-text-base-contrast-80\" dp={0}>\n {totalAmount}\n </Text.numeral>\n );\n default:\n return (\n <Text.numeral className=\"oui-text-base-contrast-80\" dp={base_dp}>\n {Number.isNaN(quantity) ? \"-\" : quantity}\n </Text.numeral>\n );\n }\n };\n\n return (\n <Box\n className={cn(\n \"oui-relative oui-w-full oui-cursor-pointer oui-overflow-hidden oui-text-2xs oui-tabular-nums\",\n )}\n style={{ height: `${cellHeight}px` }}\n onClick={() => {\n if (Number.isNaN(price) || Number.isNaN(quantity)) {\n return;\n }\n onItemClick?.([price, quantity]);\n }}\n >\n <Flex itemAlign=\"center\" justify={\"between\"}>\n <Text.numeral\n color={type === OrderBookCellType.BID ? \"buy\" : \"sell\"}\n dp={dp}\n >\n {price}\n </Text.numeral>\n {renderCell()}\n </Flex>\n {Number.isNaN(width) ? null : (\n <CellBar\n width={width}\n className={cn(\n type === OrderBookCellType.ASK\n ? \"oui-bg-trade-loss/20\"\n : \"oui-bg-trade-profit/20\",\n )}\n />\n )}\n </Box>\n );\n};\n","import { FC } from \"react\";\nimport { Box } from \"@orderly.network/ui\";\nimport { useOrderBookContext } from \"../../base/orderBook/orderContext\";\nimport { OrderBookCellType } from \"../../base/orderBook/types\";\nimport { OrderBookCell } from \"./cell\";\n\ninterface OrderBookListProps {\n type: OrderBookCellType;\n data: number[][];\n countQty: number;\n}\n\nexport const ListBox: FC<OrderBookListProps> = (props) => {\n const { data } = props;\n const { mode } = useOrderBookContext();\n return (\n <Box className=\"oui-order-book-list oui-flex oui-w-full oui-flex-col oui-gap-px\">\n {data.map((item, index) => {\n return (\n <OrderBookCell\n key={`item-${index}`}\n background={\"\"}\n price={item[0]}\n quantity={item[1]}\n accumulated={item[2]}\n accumulatedAmount={item[3]}\n count={props.countQty}\n type={props.type}\n mode={mode}\n />\n );\n })}\n </Box>\n );\n};\n","import { FC, useMemo } from \"react\";\nimport { OrderBookCellType } from \"../../base/orderBook/types\";\nimport { ListBox } from \"./listBox\";\n\nexport interface Props {\n data: number[][];\n}\nexport const Asks: FC<Props> = (props) => {\n const { data } = props;\n const countQty = useMemo(() => {\n const len = data.length;\n let max = Number.NaN;\n\n let index = 0;\n\n while (Number.isNaN(max) && index < len) {\n max = data[index][2];\n index++;\n }\n\n return max;\n }, [data]);\n return (\n <ListBox type={OrderBookCellType.ASK} data={data} countQty={countQty} />\n );\n};\n","import { FC, useMemo } from \"react\";\nimport { OrderBookCellType } from \"../../base/orderBook/types\";\nimport { ListBox } from \"./listBox\";\n\nexport interface Props {\n data: any[];\n}\n\nexport const Bids: FC<Props> = (props) => {\n const { data } = props;\n const countQty = useMemo(() => {\n let max = Number.NaN;\n // let len = data.length;\n let index = data.length - 1;\n\n while (Number.isNaN(max) && index > 0) {\n max = data[index][2];\n index--;\n }\n\n return max;\n // return data.length > 0 ? data[data.length - 1][2] : 0;\n }, [data]);\n\n return (\n <ListBox type={OrderBookCellType.BID} data={data} countQty={countQty} />\n );\n};\n","import { FC, useMemo } from \"react\";\nimport { Box, Picker } from \"@orderly.network/ui\";\n\ninterface DepthSelectProps {\n depth: ReadonlyArray<string> | string[];\n value?: string;\n onChange?: (depth: number) => void;\n}\n\nexport const DepthSelect: FC<DepthSelectProps> = (props) => {\n const options = useMemo(() => {\n return props.depth.map((d) => ({\n value: d,\n label: `${d}`,\n }));\n }, [props.depth]);\n return (\n <Box id=\"oui-order-book-depth\" className=\"oui-w-full oui-pt-2\">\n {/* <Select size={\"small\"} value={\"0.001\"} /> */}\n <Picker\n options={options}\n fullWidth\n size={\"sm\"}\n value={props.value}\n className=\"oui-text-2xs oui-text-base-contrast-54\"\n onValueChange={(value) => {\n //\n props.onChange?.(value);\n }}\n />\n </Box>\n );\n};\n","import React, { FC, useMemo } from \"react\";\nimport { useLocalStorage } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n CaretDownIcon,\n CaretUpIcon,\n Flex,\n Picker,\n Text,\n} from \"@orderly.network/ui\";\nimport { SelectOption } from \"@orderly.network/ui/src/select/withOptions\";\nimport { ORDERBOOK_MOBILE_COIN_TYPE_KEY } from \"../../base/orderBook/orderContext\";\n\ninterface Props {\n quote: string;\n base: string;\n}\n\nexport const Header: FC<Props> = (props) => {\n const { t } = useTranslation();\n\n const { base, quote } = props;\n\n const [coinUnit, setCoinUnit] = useLocalStorage<\"qty\" | \"base\" | \"quote\">(\n ORDERBOOK_MOBILE_COIN_TYPE_KEY,\n \"qty\",\n );\n\n const options = useMemo<SelectOption[]>(() => {\n return [\n {\n value: \"qty\",\n label: `${t(\"common.quantity\")}(${base})`,\n data: [t(\"common.quantity\"), base],\n },\n {\n value: \"base\",\n label: `${t(\"common.total\")}(${base})`,\n data: [t(\"common.total\"), base],\n },\n {\n value: \"quote\",\n label: `${t(\"common.total\")}(${quote})`,\n data: [t(\"common.total\"), quote],\n },\n ];\n }, [t, base, quote]);\n\n return (\n <Flex\n justify={\"between\"}\n width={\"100%\"}\n className=\"oui-py-[5px] oui-text-2xs oui-text-base-contrast-36\"\n >\n <Flex\n direction={\"column\"}\n itemAlign={\"start\"}\n id=\"oui-order-book-header-price\"\n >\n <Text>{t(\"common.price\")}</Text>\n <Text>{`(${quote})`}</Text>\n </Flex>\n <Picker\n size=\"sm\"\n value={coinUnit}\n onValueChange={setCoinUnit}\n options={options}\n valueRenderer={(_, { open, data }) => {\n return (\n <Flex justify=\"between\" itemAlign=\"center\" gap={1}>\n {Array.isArray(data) && (\n <Flex direction={\"column\"} itemAlign={\"end\"}>\n {data[0] && <Text>{data[0]}</Text>}\n {data[1] && <Text>({data[1]})</Text>}\n </Flex>\n )}\n {open ? (\n <CaretUpIcon size={14} color=\"inherit\" />\n ) : (\n <CaretDownIcon size={14} color=\"inherit\" />\n )}\n </Flex>\n );\n }}\n />\n </Flex>\n );\n};\n","import { FC } from \"react\";\nimport { Flex } from \"@orderly.network/ui\";\nimport { MarkPriceView } from \"../../base/orderBook/markPrice\";\nimport { MiddlePriceView } from \"../../base/orderBook/midPriceView\";\nimport { useOrderBookContext } from \"../../base/orderBook/orderContext\";\n\ninterface MarkPriceProps {\n markPrice: number;\n lastPrice: number[];\n}\n\nexport const MarkPrice: FC<MarkPriceProps> = (props) => {\n const { symbolInfo } = useOrderBookContext();\n\n const { quote_dp } = symbolInfo;\n\n return (\n <Flex\n id=\"oui-order-book-mark-price\"\n className=\"oui-py-[6px]\"\n width={\"100%\"}\n justify={\"between\"}\n >\n <MiddlePriceView\n markPrice={props.markPrice}\n lastPrice={props.lastPrice}\n quote_dp={quote_dp}\n className=\"oui-text-sm\"\n iconSize={14}\n />\n <MarkPriceView\n markPrice={props.markPrice}\n quote_dp={quote_dp}\n className=\"oui-text-2xs\"\n iconSize={12}\n />\n </Flex>\n );\n};\n","import { FC, useEffect } from \"react\";\nimport { useLocalStorage } from \"@orderly.network/hooks\";\nimport { EMPTY_LIST } from \"@orderly.network/types\";\nimport { cn, Flex, Spinner } from \"@orderly.network/ui\";\nimport { BasicSymbolInfo } from \"../../../types/types\";\nimport {\n ORDERBOOK_MOBILE_COIN_TYPE_KEY,\n OrderBookProvider,\n} from \"../../base/orderBook/orderContext\";\nimport { FundingRateWidget } from \"../fundingRate\";\nimport { Asks } from \"./asks\";\nimport { Bids } from \"./bids\";\nimport { DepthSelect } from \"./depthSelect\";\nimport { Header } from \"./header\";\nimport { MarkPrice } from \"./markPrice\";\n\nexport interface OrderBookProps {\n asks: any[];\n bids: any[];\n markPrice: number;\n lastPrice: number[];\n onItemClick?: (item: number[]) => void;\n depths?: string[];\n activeDepth?: string;\n onDepthChange?: (depth: number) => void;\n //\n autoSize?: boolean;\n level?: number;\n base: string;\n quote: string;\n\n isLoading?: boolean;\n\n cellHeight?: number;\n\n className?: string;\n symbolInfo: BasicSymbolInfo;\n}\n\nexport const OrderBook: FC<OrderBookProps> = (props) => {\n const { lastPrice, markPrice, quote, base, isLoading, onDepthChange } = props;\n\n const symbol = `PERP_${props.symbolInfo.base}_${props.symbolInfo.quote}`;\n\n const [coinUnit, setCoinUnit] = useLocalStorage<\"qty\" | \"base\" | \"quote\">(\n ORDERBOOK_MOBILE_COIN_TYPE_KEY,\n \"qty\",\n );\n\n return (\n <OrderBookProvider\n cellHeight={props.cellHeight ?? 20}\n onItemClick={props.onItemClick}\n depth={props.activeDepth}\n pendingOrders={EMPTY_LIST}\n showTotal={false}\n symbolInfo={props.symbolInfo}\n >\n <Flex\n direction={\"column\"}\n p={2}\n id=\"oui-orderbook-mobile\"\n className={cn(\"oui-relative oui-size-full\", props.className)}\n justify={\"start\"}\n itemAlign={\"start\"}\n >\n <FundingRateWidget symbol={symbol} />\n <Header quote={quote} base={base} />\n <Asks data={props.asks} />\n <MarkPrice lastPrice={lastPrice} markPrice={markPrice} />\n <Bids data={props.bids} />\n <DepthSelect\n depth={props.depths || EMPTY_LIST}\n value={props.activeDepth}\n onChange={onDepthChange}\n />\n {isLoading && (\n <div className=\"oui-bg-base-800/70 oui-absolute oui-inset-0 oui-z-10 oui-flex oui-h-full oui-min-h-[420px] oui-items-center oui-justify-center\">\n <Spinner />\n </div>\n )}\n </Flex>\n </OrderBookProvider>\n );\n};\n","import React from \"react\";\nimport { Box } from \"@orderly.network/ui\";\nimport { DesktopOrderBook } from \"../../desktop/orderBook/index.desktop\";\nimport { OrderBook as MWebOrderBook } from \"../../mobile/orderBook\";\nimport type { OrderBookState } from \"./orderBook.script\";\n\nexport const OrderBook: React.FC<OrderBookState & { className?: string }> = (\n props,\n) => {\n return (\n <Box className=\"oui-font-semibold\" width={\"100%\"} height={\"100%\"}>\n {props.isMobile ? (\n <MWebOrderBook\n level={props.level}\n asks={props.asks!}\n bids={props.bids!}\n markPrice={props.markPrice!}\n lastPrice={props.lastPrice!}\n depths={props.depths}\n activeDepth={props.selDepth}\n base={props.base}\n quote={props.quote}\n isLoading={props.isLoading}\n onItemClick={props.onItemClick}\n cellHeight={props.cellHeight}\n onDepthChange={props.onDepthChange}\n className={props.className}\n symbolInfo={props.symbolInfo}\n />\n ) : (\n <DesktopOrderBook\n level={props.level}\n asks={props.asks!}\n bids={props.bids!}\n markPrice={props.markPrice!}\n lastPrice={props.lastPrice!}\n depths={props.depths}\n activeDepth={props.selDepth}\n base={props.base}\n quote={props.quote}\n isLoading={props.isLoading}\n onItemClick={props.onItemClick}\n cellHeight={props.cellHeight}\n onDepthChange={props.onDepthChange}\n className={props.className}\n pendingOrders={props.pendingOrders}\n symbolInfo={props.symbolInfo}\n />\n )}\n </Box>\n );\n};\n","import type { API } from \"@orderly.network/types\";\nimport type { BasicSymbolInfo } from \"../types/types\";\n\ntype ValueOf<T> = T[keyof T];\n\nexport const getBasicSymbolInfo = (\n symbolInfo: (\n key?: keyof API.SymbolExt,\n defaultValue?: ValueOf<API.SymbolExt>,\n ) => any,\n): BasicSymbolInfo => {\n return {\n base_dp: symbolInfo(\"base_dp\"),\n quote_dp: symbolInfo(\"quote_dp\"),\n base_tick: symbolInfo(\"base_tick\"),\n base: symbolInfo(\"base\"),\n quote: symbolInfo(\"quote\"),\n };\n};\n","import { useEffect, useMemo, useState } from \"react\";\nimport {\n useOrderbookStream,\n useOrderStream,\n useSymbolsInfo,\n} from \"@orderly.network/hooks\";\nimport { OrderStatus } from \"@orderly.network/types\";\nimport { useScreen } from \"@orderly.network/ui\";\nimport { removeTrailingZeros } from \"@orderly.network/utils\";\nimport { getBasicSymbolInfo } from \"../../../utils/utils\";\n\nconst CELL_MAX = 30;\n\nconst DEFAULT_CELL_HEIGHT = 20;\n\nconst SPACE = 104;\n\nexport const useOrderBookScript = (props: {\n symbol: string;\n height?: number;\n}) => {\n const { symbol, height } = props;\n const symbolInfo = useSymbolsInfo()[symbol];\n\n const [cellHeight, setCellHeight] = useState(DEFAULT_CELL_HEIGHT);\n\n const [level, setLevel] = useState(10);\n const { base, quote, quote_dp } = getBasicSymbolInfo(symbolInfo);\n // const counter = useRef(0);\n\n const [data, { onDepthChange, isLoading, onItemClick, depth, allDepths }] =\n useOrderbookStream(symbol, undefined, { level });\n\n // useEffect(() => {\n // counter.current = 0;\n // }, [symbol]);\n\n const pendingOrders = usePendingOrderStream(symbol);\n useEffect(() => {\n if (height) {\n // setCellHeight(height.content / level);\n const level = Math.floor(\n (height - SPACE) / ((DEFAULT_CELL_HEIGHT + 1) * 2),\n );\n\n const cellsHeight = (DEFAULT_CELL_HEIGHT + 1) * 2 * level;\n\n const restSpace = height - SPACE - cellsHeight;\n\n if (restSpace > 10) {\n setCellHeight(DEFAULT_CELL_HEIGHT + restSpace / level / 2);\n } else {\n setCellHeight(DEFAULT_CELL_HEIGHT);\n }\n\n setLevel(level);\n }\n }, [height]);\n\n const selDepth = useMemo(() => {\n if (typeof depth === \"undefined\" || typeof quote_dp === \"undefined\") {\n return undefined;\n }\n // // FIXME: hardcode for now, need to optimize it\n // counter.current++;\n // if (counter.current === 1 && DEFAULT_DEPTH[symbol]) {\n // return DEFAULT_DEPTH[symbol];\n // }\n\n return removeTrailingZeros(depth);\n }, [depth, quote_dp, symbol]);\n\n const depths = useMemo(() => {\n return allDepths?.map((e) => removeTrailingZeros(e)) || [];\n }, [allDepths, quote_dp]);\n\n const { isMobile } = useScreen();\n\n return {\n level,\n asks: data?.asks,\n bids: data?.bids,\n markPrice: data?.markPrice,\n lastPrice: data?.middlePrice,\n depths,\n selDepth,\n base,\n quote,\n isLoading,\n onItemClick,\n cellHeight,\n onDepthChange,\n pendingOrders,\n symbolInfo: getBasicSymbolInfo(symbolInfo),\n isMobile,\n };\n};\n\nexport const usePendingOrderStream = (symbol: string): number[] => {\n const [data] = useOrderStream({\n status: OrderStatus.INCOMPLETE,\n symbol: symbol,\n });\n\n const pendingOrders = useMemo(() => {\n const info = data\n ?.filter((item) => item.symbol === symbol)\n .reduce((a, b) => {\n // TODO: check if this is the correct price, when the data is from WS, it crashes\n const price = b.price || b.trigger_price || 0;\n return [...a, price];\n }, []);\n\n return info;\n }, [data, symbol]);\n\n return pendingOrders;\n};\n\nexport type OrderBookState = ReturnType<typeof useOrderBookScript>;\n","import React from \"react\";\nimport { useOrderBookScript } from \"./orderBook.script\";\nimport { OrderBook } from \"./orderBook.ui\";\n\ninterface OrderBookWidgetProps {\n className?: string;\n symbol: string;\n height?: number;\n}\n\nexport const OrderBookWidget: React.FC<OrderBookWidgetProps> = (props) => {\n const { className, symbol, height } = props;\n const state = useOrderBookScript({ symbol, height });\n return <OrderBook {...state} className={className} />;\n};\n","export { OrderBook } from \"./orderBook.ui\";\nexport { OrderBookWidget } from \"./orderBook.widget\";\nexport { useOrderBookScript } from \"./orderBook.script\";\n","import React, { FC } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { useAppContext } from \"@orderly.network/react-app\";\nimport {\n Flex,\n Text,\n Box,\n Tooltip,\n modal,\n gradientTextVariants,\n cn,\n EditIcon,\n} from \"@orderly.network/ui\";\nimport { LeverageWidgetWithDialogId } from \"@orderly.network/ui-leverage\";\nimport { TooltipContent } from \"../assetView/assetView.ui\";\nimport { RiskRateState } from \"./riskRate.script\";\n\nexport const RiskRate: FC<RiskRateState> = (props) => {\n const { riskRate, riskRateColor, currentLeverage, maxLeverage } = props;\n const { isHigh, isMedium, isLow } = riskRateColor;\n const { wrongNetwork } = useAppContext();\n const { t } = useTranslation();\n\n const textColor = wrongNetwork\n ? \"\"\n : isHigh\n ? \"oui-text-danger\"\n : isMedium\n ? \"oui-text-warning-darken\"\n : isLow\n ? gradientTextVariants({ color: \"brand\" })\n : \"\";\n\n const boxClsName = wrongNetwork\n ? \"oui-bg-gradient-to-r oui-opacity-20 oui-from-[#26fefe] oui-via-[#ff7d00] oui-to-[#d92d6b] oui-h-1.5 oui-rounded-full\"\n : isHigh\n ? \"oui-bg-gradient-to-tr oui-from-[#791438] oui-to-[#ff447c] oui-h-1.5 oui-rounded-full\"\n : isMedium\n ? \"oui-bg-gradient-to-tr oui-from-[#792e00] oui-to-[#ffb65d] oui-h-1.5 oui-rounded-full\"\n : isLow\n ? \"oui-bg-gradient-to-tr oui-from-[#59b0fe] oui-to-[#26fefe] oui-h-1.5 oui-rounded-full\"\n : \"oui-bg-gradient-to-r oui-opacity-20 oui-from-[#26fefe] oui-via-[#ff7d00] oui-to-[#d92d6b] oui-h-1.5 oui-rounded-full\";\n\n return (\n <Box data-risk={\"\"} className=\"oui-space-y-2\">\n <Flex\n itemAlign=\"center\"\n justify=\"start\"\n className=\"oui-w-full oui-bg-base-6 oui-rounded-full oui-h-2 oui-px-[1px]\"\n >\n <Box\n className={boxClsName}\n style={\n riskRate && riskRate !== \"--\"\n ? { width: riskRate }\n : { width: \"100%\" }\n }\n />\n </Flex>\n\n <Flex className=\"oui-gap-2\" justify=\"between\">\n <Flex direction=\"column\">\n <Tooltip\n content={\n <TooltipContent\n description={t(\"trading.riskRate.tooltip\")}\n formula={t(\"trading.riskRate.formula\")}\n />\n }\n >\n <Text\n size=\"2xs\"\n color=\"neutral\"\n weight=\"semibold\"\n className={cn(\n \"oui-cursor-pointer\",\n \"oui-border-b oui-border-dashed oui-border-b-white/10\",\n )}\n >\n {t(\"trading.riskRate\")}\n </Text>\n </Tooltip>\n <Text\n size=\"xs\"\n color=\"neutral\"\n weight=\"semibold\"\n className={cn(textColor)}\n >\n {riskRate ?? \"--\"}\n </Text>\n </Flex>\n\n <Flex direction=\"column\">\n <Text\n size=\"2xs\"\n color=\"neutral\"\n weight=\"semibold\"\n className={cn(\n \"oui-cursor-pointer\",\n // add extra bottom border to make height same as risk rate text\n \"oui-border-b oui-border-b-transparent\",\n )}\n >\n {t(\"leverage.maxAccountLeverage\")}\n </Text>\n <Flex className=\"oui-gap-1\">\n <Text.numeral\n dp={2}\n padding={false}\n suffix={currentLeverage ? \"x\" : undefined}\n >\n {currentLeverage ?? \"--\"}\n </Text.numeral>\n\n <span className={\"oui-text-base-contrast-54\"}>/</span>\n\n <button\n className=\"oui-flex oui-items-center oui-gap-1\"\n onClick={() => {\n modal.show(LeverageWidgetWithDialogId, { currentLeverage: 5 });\n }}\n data-testid=\"oui-testid-riskRate-leverage-button\"\n >\n <Text.numeral\n dp={2}\n padding={false}\n suffix={maxLeverage ? \"x\" : undefined}\n data-testid=\"oui-testid-riskRate-leverage-value\"\n >\n {maxLeverage ?? \"--\"}\n </Text.numeral>\n\n {typeof maxLeverage !== \"undefined\" && maxLeverage !== null && (\n <EditIcon size={12} color=\"white\" />\n )}\n </button>\n </Flex>\n </Flex>\n </Flex>\n </Box>\n );\n};\n","import { useMemo } from \"react\";\nimport {\n useAccount,\n useLeverage,\n useMarginRatio,\n} from \"@orderly.network/hooks\";\nimport { useDataTap } from \"@orderly.network/react-app\";\nimport { AccountStatusEnum } from \"@orderly.network/types\";\nimport { Decimal } from \"@orderly.network/utils\";\n\nconst getRiskRateColor = (riskRate: null | number) => {\n if (riskRate === null) {\n return { isHigh: false, isMedium: false, isLow: false, isDefault: true };\n }\n\n const isLow = riskRate < 40;\n const isMedium = riskRate >= 40 && riskRate < 80;\n const isHigh = riskRate >= 80;\n const isDefault = !isLow && !isMedium && !isHigh;\n\n return { isHigh, isMedium, isLow, isDefault };\n};\n\nexport const useRiskRateScript = () => {\n const { state } = useAccount();\n\n const isConnected =\n state.status >= AccountStatusEnum.EnableTrading ||\n state.status === AccountStatusEnum.EnableTradingWithoutConnected;\n const { marginRatio, currentLeverage, mmr } = useMarginRatio();\n\n const { curLeverage } = useLeverage();\n\n const riskRate = useMemo(() => {\n if (!isConnected || marginRatio === null || mmr === null) {\n return \"--\";\n }\n\n if (marginRatio === 0 || mmr === 0) {\n return \"0%\";\n }\n\n const calculatedRiskRate = new Decimal(mmr)\n .div(marginRatio)\n .mul(100)\n .todp(2, Decimal.ROUND_UP);\n\n // Remove trailing zeroes and add percentage sign\n return `${calculatedRiskRate.toString().replace(/\\.?0+$/, \"\")}%`;\n }, [isConnected, marginRatio, mmr]);\n\n const riskRateNumber = riskRate === \"--\" ? null : parseFloat(riskRate);\n\n const riskRateColor = useMemo(() => {\n return getRiskRateColor(riskRateNumber);\n }, [riskRateNumber]);\n\n const _curLeverage = useDataTap(currentLeverage);\n const _maxLeverage = useDataTap(curLeverage);\n const _riskRate = useDataTap(riskRate);\n\n return {\n riskRate: _riskRate,\n riskRateColor,\n isConnected,\n currentLeverage: _curLeverage,\n maxLeverage: _maxLeverage,\n };\n};\n\nexport type RiskRateState = ReturnType<typeof useRiskRateScript>;\n","import React from \"react\";\nimport { useRiskRateScript } from \"./riskRate.script\";\nimport { RiskRate } from \"./riskRate.ui\";\n\nexport const RiskRateWidget: React.FC = () => {\n const state = useRiskRateScript();\n return <RiskRate {...state} />;\n};\n","export { RiskRate } from \"./riskRate.ui\";\nexport { RiskRateWidget } from \"./riskRate.widget\";\n","import React from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { Box, cn, Flex, Grid, TabPanel, Tabs, Text } from \"@orderly.network/ui\";\nimport type { OrderBookAndTradesState } from \"./orderBookAndTrades.script\";\n\nconst LazyLastTradesWidget = React.lazy(() =>\n import(\"../../base/lastTrades\").then((mod) => {\n return {\n default: mod.LastTradesWidget,\n };\n }),\n);\n\nconst LazyOrderBookWidget = React.lazy(() =>\n import(\"../../base/orderBook\").then((mod) => {\n return {\n default: mod.OrderBookWidget,\n };\n }),\n);\n\nconst TwoColLayout: React.FC<OrderBookAndTradesState> = (props) => {\n const { t } = useTranslation();\n return (\n <Grid\n cols={2}\n width={\"100%\"}\n gap={3}\n className=\"oui-auto-rows-fr\"\n style={{\n height: props.containerSize?.height,\n }}\n >\n <Flex\n direction={\"column\"}\n itemAlign={\"start\"}\n // pl={3}\n pt={3}\n pb={3}\n r=\"2xl\"\n className=\"oui-bg-base-9\"\n >\n <Title\n title={t(\"trading.orderBook\")}\n className=\"oui-pl-3 oui-text-sm\"\n />\n <React.Suspense fallback={null}>\n <LazyOrderBookWidget\n symbol={props.symbol}\n height={\n props.containerSize\n ? props.containerSize.height - 29 - 24\n : undefined\n }\n />\n </React.Suspense>\n </Flex>\n <Flex\n direction={\"column\"}\n itemAlign={\"start\"}\n py={3}\n r=\"2xl\"\n className=\"oui-bg-base-9 oui-h-full\"\n >\n <Title\n title={t(\"trading.lastTrades\")}\n className=\"oui-text-sm oui-px-3\"\n />\n <React.Suspense fallback={null}>\n <LazyLastTradesWidget\n symbol={props.symbol}\n style={{\n height:\n props.containerSize && props.containerSize.height - 29 - 24,\n }}\n classNames={{ listHeader: \"oui-px-3\", list: \"oui-px-3\" }}\n />\n </React.Suspense>\n </Flex>\n </Grid>\n );\n};\n\nconst TabLayout: React.FC<OrderBookAndTradesState> = (props) => {\n const { t } = useTranslation();\n\n return (\n <Box\n // pl={3}\n pt={3}\n pb={3}\n pr={0}\n r=\"2xl\"\n className=\"oui-bg-base-9\"\n style={{ maxHeight: props.containerSize?.height }}\n >\n <Tabs\n value={props.tab}\n variant=\"contained\"\n onValueChange={(tab) => {\n props.setTab(tab as any);\n }}\n classNames={{\n tabsList: \"oui-pl-3\",\n // tabsContent: props.tab === \"lastTrades\" ? 'oui-pl-3' : ''\n }}\n size=\"lg\"\n >\n <TabPanel value=\"orderBook\" title={t(\"trading.orderBook\")}>\n <React.Suspense fallback={null}>\n <LazyOrderBookWidget\n symbol={props.symbol}\n height={\n props.containerSize\n ? props.containerSize.height - 29 - 18\n : undefined\n }\n />\n </React.Suspense>\n </TabPanel>\n <TabPanel value=\"lastTrades\" title={t(\"trading.lastTrades\")}>\n <React.Suspense fallback={null}>\n <LazyLastTradesWidget\n symbol={props.symbol}\n style={{\n height:\n props.containerSize && props.containerSize.height - 29 - 18,\n }}\n classNames={{\n root: \"oui-pt-[6px]\",\n listHeader: \"oui-px-3\",\n list: \"oui-px-3\",\n }}\n />\n </React.Suspense>\n </TabPanel>\n </Tabs>\n </Box>\n );\n};\n\nconst Title: React.FC<{ title: string; className?: string }> = (props) => {\n return (\n <Text\n size=\"base\"\n intensity={80}\n className={cn(\"oui-pb-[5px]\", props.className)}\n >\n {props.title}\n </Text>\n );\n};\n\nexport const OrderBookAndTrades: React.FC<OrderBookAndTradesState> = (\n props,\n) => {\n const { containerRef, containerSize } = props;\n return (\n <div ref={containerRef} className=\"oui-h-full\">\n {(containerSize?.width ?? 0) >= 572 ? (\n <TwoColLayout {...props} />\n ) : (\n <TabLayout {...props} />\n )}\n </div>\n );\n};\n","import { useEffect, useRef, useState } from \"react\";\n\nexport const useOrderBookAndTradesScript = (symbol: string) => {\n const [containerSize, setContainerSize] = useState<\n | {\n width: number;\n height: number;\n }\n | undefined\n >(undefined);\n\n const [tab, setTab] = useState<\"orderBook\" | \"lastTrades\">(\"orderBook\");\n\n const containerRef = useRef<HTMLDivElement>(null);\n\n useEffect(() => {\n const resizeObserver = new ResizeObserver((entries) => {\n for (const entry of entries) {\n const { width, height } = entry.contentRect;\n setContainerSize({\n width,\n height,\n });\n }\n });\n\n const targetDiv = containerRef.current;\n\n if (targetDiv) {\n resizeObserver.observe(targetDiv);\n }\n\n return () => {\n if (targetDiv) {\n resizeObserver.unobserve(targetDiv);\n }\n };\n }, []);\n\n return {\n symbol,\n containerSize,\n containerRef: containerRef,\n tab,\n setTab,\n };\n};\n\nexport type OrderBookAndTradesState = ReturnType<\n typeof useOrderBookAndTradesScript\n>;\n","import React from \"react\";\nimport { useOrderBookAndTradesScript } from \"./orderBookAndTrades.script\";\nimport { OrderBookAndTrades } from \"./orderBookAndTrades.ui\";\n\nexport const OrderBookAndTradesWidget: React.FC<{ symbol: string }> = (\n props,\n) => {\n const state = useOrderBookAndTradesScript(props.symbol);\n return <OrderBookAndTrades {...state} />;\n};\n","export { OrderBookAndTrades } from \"./orderBookAndTrades.ui\";\nexport { OrderBookAndTradesWidget } from \"./orderBookAndTrades.widget\";\nexport { useOrderBookAndTradesScript } from \"./orderBookAndTrades.script\";\n","import { FC, PropsWithChildren, SVGProps, useState } from \"react\";\nimport {\n Box,\n CloseIcon,\n cn,\n Divider,\n DropdownMenuContent,\n DropdownMenuPortal,\n DropdownMenuRoot,\n DropdownMenuTrigger,\n Flex,\n Text,\n} from \"@orderly.network/ui\";\nimport { useTranslation } from \"@orderly.network/i18n\";\n\nexport type LayoutPosition = \"left\" | \"right\";\n\nexport type SwitchLayoutProps = {\n layout?: LayoutPosition;\n onLayout?: (layout: LayoutPosition) => void;\n};\n\nexport const SwitchLayout: FC<SwitchLayoutProps> = (props) => {\n const { t } = useTranslation();\n return (\n <SwitchLayoutDropDown {...props}>\n <Flex\n px={3}\n className={cn(\n \"oui-rounded-md\",\n \"oui-h-[28px]\",\n \"oui-cursor-pointer oui-transition-all\",\n \"oui-bg-base-6 hover:oui-bg-base-4\",\n \"oui-text-base-contrast-54 hover:oui-text-base-contrast-80\"\n )}\n gapX={1}\n ml={3}\n justify=\"center\"\n itemAlign=\"center\"\n >\n <LayoutIcon />\n <Text size=\"2xs\" weight=\"semibold\">\n {t(\"trading.layout\")}\n </Text>\n </Flex>\n </SwitchLayoutDropDown>\n );\n};\n\nexport const SwitchLayoutDropDown: FC<PropsWithChildren<SwitchLayoutProps>> = (\n props\n) => {\n const [open, setOpen] = useState(false);\n const { t } = useTranslation();\n const renderItem = (position: LayoutPosition) => {\n return (\n <Flex\n direction=\"column\"\n gapY={2}\n onClick={() => {\n props.onLayout?.(position);\n setOpen(false);\n }}\n className=\"oui-group\"\n >\n <Flex\n justify={position === \"right\" ? \"end\" : \"start\"}\n className={cn(\n \"oui-w-[148px] oui-h-[100px]\",\n \"oui-bg-base-10 oui-rounded-[10px]\",\n \"oui-border-[4px] oui-border-base-5 group-hover:oui-border-primary-light\",\n props.layout === position && \"!oui-border-primary-light\"\n )}\n >\n <Box p={1}>\n <OrderEntryIcon />\n </Box>\n </Flex>\n <Text\n size=\"2xs\"\n intensity={54}\n className={cn(\n \"oui-text-base-contrast-54 group-hover:oui-text-base-contrast-80\",\n props.layout === position && \"oui-text-base-contrast-80\"\n )}\n >\n {position === \"right\"\n ? t(\"trading.layout.right\")\n : t(\"trading.layout.left\")}\n </Text>\n </Flex>\n );\n };\n\n const content = (\n <>\n <Flex\n itemAlign=\"center\"\n justify=\"between\"\n mt={3}\n className=\"oui-mb-[10px]\"\n >\n <Text size=\"base\" intensity={98}>\n {t(\"trading.layout\")}\n </Text>\n <CloseIcon\n size={16}\n className=\"oui-text-base-contrast-80 oui-cursor-pointer\"\n opacity={0.98}\n onClick={() => {\n setOpen(false);\n }}\n />\n </Flex>\n <Divider />\n <Flex gapX={6} mt={5}>\n {renderItem(\"right\")}\n {renderItem(\"left\")}\n </Flex>\n </>\n );\n\n return (\n <DropdownMenuRoot open={open} onOpenChange={setOpen}>\n <DropdownMenuTrigger asChild>{props.children}</DropdownMenuTrigger>\n <DropdownMenuPortal>\n <DropdownMenuContent\n onCloseAutoFocus={(e) => e.preventDefault()}\n onClick={(e) => e.stopPropagation()}\n align=\"end\"\n className={cn(\n \"oui-bg-base-8 oui-p-5 oui-pt-0 oui-w-[360px] oui-font-semibold\"\n )}\n >\n {content}\n </DropdownMenuContent>\n </DropdownMenuPortal>\n </DropdownMenuRoot>\n );\n};\n\nexport const LayoutIcon: FC<SVGProps<SVGSVGElement>> = (props) => (\n <svg\n width=\"17\"\n height=\"16\"\n viewBox=\"0 0 17 16\"\n fill=\"currentColor\"\n xmlns=\"http://www.w3.org/2000/svg\"\n {...props}\n >\n <path d=\"M3.832 1.994c-.736 0-1.333.597-1.333 1.333v9.334c0 .737.597 1.333 1.333 1.333H6.5c.737 0 1.333-.596 1.333-1.333V3.327c0-.736-.596-1.333-1.333-1.333zm6.667 0c-.737 0-1.333.597-1.333 1.333v2.667c0 .737.596 1.333 1.333 1.333h2.667c.736 0 1.333-.596 1.333-1.333V3.327c0-.736-.597-1.333-1.333-1.333zm.437 6.679a2.7 2.7 0 0 0-1.033.607.284.284 0 0 0-.061.339c.222.411-.01.851-.512.876a.29.29 0 0 0-.26.217c-.05.207-.07.38-.07.608 0 .19.02.407.06.599a.28.28 0 0 0 .252.217c.506.044.756.429.53.92a.28.28 0 0 0 .06.321c.296.273.635.466 1.034.59a.285.285 0 0 0 .312-.104c.31-.427.757-.428 1.05 0a.28.28 0 0 0 .313.113 2.8 2.8 0 0 0 1.042-.599.28.28 0 0 0 .06-.33c-.23-.466.035-.894.513-.902a.28.28 0 0 0 .269-.209c.048-.199.06-.372.06-.616q0-.316-.069-.616a.276.276 0 0 0-.27-.217c-.469-.001-.732-.463-.502-.868a.27.27 0 0 0-.053-.339 2.8 2.8 0 0 0-1.059-.607.274.274 0 0 0-.312.112c-.268.417-.77.425-1.033.009a.284.284 0 0 0-.321-.121m.842 1.536a1.111 1.111 0 1 1 0 2.222 1.111 1.111 0 0 1 0-2.222\" />\n </svg>\n);\n\nexport const OrderEntryIcon: FC<SVGProps<SVGSVGElement>> = (props) => (\n <svg\n width=\"36\"\n height=\"84\"\n viewBox=\"0 0 36 84\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <rect width=\"36\" height=\"17\" rx=\"2\" fill=\"#181C23\" />\n <rect y=\"19\" width=\"36\" height=\"54\" rx=\"2\" fill=\"#181C23\" />\n <rect y=\"75\" width=\"36\" height=\"9\" rx=\"2\" fill=\"#181C23\" />\n <rect\n x=\"3\"\n y=\"79\"\n width=\"30\"\n height=\"1\"\n rx=\"0.5\"\n fill=\"url(#paint0_linear_17647_26849)\"\n />\n <rect x=\"3\" y=\"22\" width=\"14\" height=\"6\" rx=\"2\" fill=\"#008676\" />\n <rect x=\"19\" y=\"22\" width=\"14\" height=\"6\" rx=\"2\" fill=\"#D92D6B\" />\n <rect x=\"3\" y=\"11\" width=\"14\" height=\"3\" rx=\"1.5\" fill=\"#333948\" />\n <rect x=\"19\" y=\"11\" width=\"14\" height=\"3\" rx=\"1.5\" fill=\"#335FFC\" />\n <rect x=\"3\" y=\"62\" width=\"30\" height=\"8\" rx=\"2\" fill=\"#008676\" />\n <defs>\n <linearGradient\n id=\"paint0_linear_17647_26849\"\n x1=\"33\"\n y1=\"79.5\"\n x2=\"3\"\n y2=\"79.5\"\n gradientUnits=\"userSpaceOnUse\"\n >\n <stop stopColor=\"#59B0FE\" />\n <stop offset=\"1\" stopColor=\"#26FEFE\" />\n </linearGradient>\n </defs>\n </svg>\n);\n","import { useState } from \"react\";\nimport { useTradingPageContext } from \"../../../provider/tradingPageContext\";\n\nexport enum TopTabType {\n chart = \"chart\",\n trades = \"trades\",\n data = \"data\",\n}\n\nexport const useTopTabScript = () => {\n const [tab, setTab] = useState<TopTabType>(TopTabType.chart);\n const { symbol } = useTradingPageContext();\n const [visible, setVisible] = useState(true);\n\n const toggleContentVisible = () => {\n setVisible((e) => !e);\n };\n\n return {\n tab,\n setTab,\n symbol,\n toggleContentVisible,\n setVisible,\n visible,\n };\n};\n\nexport type TopTabState = ReturnType<typeof useTopTabScript>;\n","import React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport { useLocalStorage } from \"@orderly.network/hooks\";\nimport { TradingviewWidgetProps } from \"./tradingview.widget\";\n\nconst MaxHeight = 354;\nconst MinHeight = 234;\nconst Key = \"TRADINGVIEW_MOBILE_HEIGHT\";\n\nexport function useTradingviewScript(props: TradingviewWidgetProps) {\n const [height, setHeight] = useLocalStorage(Key, MaxHeight);\n const [dragging, setDragging] = useState(false);\n const dragRef = useRef<HTMLDivElement>(null);\n const boxRef = useRef<HTMLDivElement>(null);\n const [offsetY, setOffsetY] = useState(0);\n const topRef = useRef<number>(0);\n\n const handleTouchStart = useCallback((e: TouchEvent) => {\n if (!boxRef.current) {\n return;\n }\n setDragging(true);\n const event = e.touches[0];\n const rect = boxRef.current.getBoundingClientRect();\n e.stopPropagation();\n e.preventDefault();\n\n const offsetY = event.clientY - rect.bottom;\n topRef.current = rect.top;\n setOffsetY(offsetY);\n }, []);\n\n const handleTouchMove = useCallback(\n (e: TouchEvent) => {\n if (!boxRef.current) {\n return;\n }\n if (dragging) {\n e.stopPropagation();\n e.preventDefault();\n\n const event = e.touches[0];\n\n const newHeight = event.clientY - topRef.current - offsetY;\n setHeight(\n Math.min(Math.max(Math.round(newHeight), MinHeight), MaxHeight),\n );\n return false;\n }\n },\n [dragging, offsetY],\n );\n\n const handleTouchEnd = useCallback(() => {\n setDragging(false);\n }, []);\n\n useEffect(() => {\n const drag = dragRef.current;\n if (!drag) {\n return;\n }\n\n drag.addEventListener(\"touchstart\", handleTouchStart);\n\n return () => {\n drag.removeEventListener(\"touchstart\", handleTouchStart);\n };\n }, [handleTouchStart]);\n\n useEffect(() => {\n document.addEventListener(\"touchmove\", handleTouchMove, { passive: false });\n document.addEventListener(\"touchend\", handleTouchEnd);\n\n return () => {\n document.removeEventListener(\"touchmove\", handleTouchMove);\n document.removeEventListener(\"touchend\", handleTouchEnd);\n };\n }, [dragging, handleTouchMove, handleTouchEnd]);\n return {\n ...props,\n\n height,\n dragging,\n dragRef,\n boxRef,\n };\n}\n\nexport type TradingviewState = ReturnType<typeof useTradingviewScript>;\n","import React, { FC, SVGProps } from \"react\";\n\nexport const KlineDragIcon: FC<SVGProps<SVGSVGElement>> = (props) => (\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 {...props}\n >\n <g id=\"Arrows-expand\">\n <path\n id=\"Vector\"\n d=\"M5.9989 1.00708C5.8709 1.00708 5.7369 1.05008 5.6394 1.14758L3.7959 3.00708L4.4989 3.71008L5.4989 2.72607V4.50708C5.4989 4.78308 5.7229 5.00708 5.9989 5.00708C6.2749 5.00708 6.4989 4.78308 6.4989 4.50708V2.72607L7.4989 3.71008L8.2019 3.00708L6.3584 1.14758C6.2604 1.05008 6.1269 1.00708 5.9989 1.00708ZM5.9989 7.00707C5.7229 7.00707 5.4989 7.23107 5.4989 7.50707V9.28808L4.4989 8.30407L3.7959 9.00707L5.6394 10.8666C5.8349 11.0616 6.1629 11.0616 6.3584 10.8666L8.2019 9.00707L7.4989 8.30407L6.4989 9.28808V7.50707C6.4989 7.23107 6.2749 7.00707 5.9989 7.00707Z\"\n />\n </g>\n </svg>\n);\n","import React from \"react\";\nimport { cn } from \"@orderly.network/ui\";\nimport { TradingviewWidget } from \"@orderly.network/ui-tradingview\";\nimport { KlineDragIcon } from \"../../base/icons\";\nimport type { TradingviewState } from \"./tradingview.script\";\n\nexport const TradingviewUI: React.FC<TradingviewState> = (props) => {\n return (\n <div\n className=\"oui-pb-1 oui-flex oui-flex-col oui-gap-1\"\n style={{ height: props.height }}\n ref={props.boxRef}\n >\n <div className=\"oui-w-full oui-h-full\">\n <TradingviewWidget\n symbol={props.symbol}\n libraryPath={props.tradingViewConfig?.library_path}\n mode={3}\n scriptSRC={props.tradingViewConfig?.scriptSRC}\n customCssUrl={props.tradingViewConfig?.customCssUrl}\n {...props.tradingViewConfig}\n />\n </div>\n <div className=\"oui-relative oui-w-full\">\n <div\n ref={props.dragRef}\n className={cn(\n \"oui-h-[1px] oui-absolute oui-left-0 oui-right-0 oui-bottom-0 oui-top-0 oui-z-10 oui-mt-[7px] oui-bg-base-contrast-12\",\n props.dragging && \"oui-bg-primary \",\n )}\n >\n <KlineDragIcon\n className={cn(\n \"oui-w-3 oui-h-3 oui-absolute oui-left-1/2 -oui-top-[5px] -oui-translate-y-[0.5px] oui-text-base-contrast-12\",\n props.dragging && \" oui-text-primary\",\n )}\n />\n </div>\n </div>\n </div>\n );\n};\n","import React from \"react\";\nimport { TradingViewConfigInterface } from \"../../../types/types\";\nimport { useTradingviewScript } from \"./tradingview.script\";\nimport { TradingviewUI } from \"./tradingview.ui\";\n\nexport interface TradingviewWidgetProps {\n symbol: string;\n tradingViewConfig: TradingViewConfigInterface;\n}\n\nexport const TradingviewWidget: React.FC<TradingviewWidgetProps> = (props) => {\n const state = useTradingviewScript(props);\n return <TradingviewUI {...state} />;\n};\n","import React from \"react\";\nimport { LastTradesWidget } from \"../../base/lastTrades\";\n\nexport const MWebLastTrades: React.FC<{ symbol: string }> = (props) => {\n return (\n <LastTradesWidget\n symbol={props.symbol}\n classNames={{\n root: \"oui-px-3 \",\n list: \"oui-min-h-[141px] oui-max-h-[202px] oui-w-full\",\n listHeader: \"oui-text-xs oui-text-base-contrast-36\",\n listItem: {\n left: \"oui-text-xs\",\n mid: \"oui-text-xs\",\n right: \"oui-text-xs\",\n },\n }}\n />\n );\n};\n","import { FC } from \"react\";\nimport { Flex, Text } from \"@orderly.network/ui\";\nimport { TradeDataState } from \"./tradeData.script\";\nimport { useTranslation } from \"@orderly.network/i18n\";\n\nexport const TradeData: FC<TradeDataState> = (props) => {\n const { t } = useTranslation();\n\n return (\n <Flex direction={\"column\"} gap={2}>\n <Row\n title={t(\"common.markPrice\")}\n value={props.ticker?.mark_price}\n dp={props.symbolInfo.quote_dp}\n />\n <Row\n title={t(\"common.indexPrice\")}\n value={props.ticker?.index_price}\n dp={props.symbolInfo.quote_dp}\n />\n <Row\n title={t(\"markets.column.24hVolume\")}\n value={props.vol_24h}\n dp={props.symbolInfo.quote_dp}\n rule=\"human\"\n showUSDC\n />\n <Row\n title={t(\"trading.column.24High\")}\n value={props.ticker?.[\"24h_high\"]}\n dp={props.symbolInfo.quote_dp}\n />\n <Row\n title={t(\"trading.column.24Low\")}\n value={props.ticker?.[\"24h_low\"]}\n dp={props.symbolInfo.quote_dp}\n />\n <Row\n title={t(\"markets.openInterest\")}\n value={props.openInterest}\n dp={props.symbolInfo.quote_dp}\n rule=\"human\"\n showUSDC\n />\n </Flex>\n );\n};\n\nconst Row = (props: {\n title: string;\n value: any;\n dp?: number;\n rule?: \"percentages\" | \"price\" | \"human\";\n showUSDC?: boolean;\n}) => {\n const { title, value, showUSDC, dp, rule = \"price\" } = props;\n return (\n <Flex justify={\"between\"} width={\"100%\"} className=\"oui-text-xs\">\n <Text intensity={36}>{title}</Text>\n <Flex gap={1}>\n <Text.numeral rule={rule} dp={dp} intensity={80}>\n {value}\n </Text.numeral>\n {showUSDC && <Text intensity={36}>USDC</Text>}\n </Flex>\n </Flex>\n );\n};\n","import { useMemo } from \"react\";\nimport { useTickerStream } from \"@orderly.network/hooks\";\nimport { Decimal } from \"@orderly.network/utils\";\nimport { useTradingPageContext } from \"../../../provider/tradingPageContext\";\n\nexport const useTradeDataScript = (props: { symbol: string }) => {\n const { symbol } = props;\n const ticker = useTickerStream(symbol);\n const { symbolInfo } = useTradingPageContext();\n const vol_24h = useMemo(() => {\n const close = ticker?.[\"24h_close\"];\n const volume = ticker?.[\"24h_volume\"];\n if (close && volume && !isNaN(close) && !isNaN(volume)) {\n return new Decimal(close)\n .mul(volume)\n .toFixed(symbolInfo.quote_dp, Decimal.ROUND_DOWN);\n }\n return undefined;\n }, [ticker]);\n\n const openInterest = useMemo(() => {\n const markPrice = ticker?.[\"mark_price\"];\n const openInterest = ticker?.[\"open_interest\"];\n if (markPrice && openInterest && !isNaN(markPrice)) {\n return new Decimal(markPrice)\n .mul(Number(openInterest))\n .toFixed(symbolInfo.quote_dp, Decimal.ROUND_DOWN);\n }\n return undefined;\n }, [ticker]);\n return {\n ticker,\n symbolInfo,\n vol_24h,\n openInterest,\n };\n};\n\nexport type TradeDataState = ReturnType<typeof useTradeDataScript>;\n","import React from \"react\";\nimport { useTradeDataScript } from \"./tradeData.script\";\nimport { TradeData } from \"./tradeData.ui\";\n\nexport const TradeDataWidget: React.FC<{ symbol: string }> = (props) => {\n const state = useTradeDataScript(props);\n return <TradeData {...state} />;\n};\n","export { TradeData } from \"./tradeData.ui\";\nexport { TradeDataWidget } from \"./tradeData.widget\";\nexport { useTradeDataScript } from \"./tradeData.script\";\n","import React from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { Box, cn, TabPanel, Tabs } from \"@orderly.network/ui\";\nimport { useTradingPageContext } from \"../../../provider/tradingPageContext\";\nimport { TopTabState, TopTabType } from \"./topTab.script\";\n\nconst LazyTradingviewWidget = React.lazy(() =>\n import(\"../tradingview/tradingview.widget\").then((mod) => {\n return { default: mod.TradingviewWidget };\n }),\n);\n\nconst LazyMWebLastTrades = React.lazy(() =>\n import(\"../lastTrades/lastTrades.widget\").then((mod) => {\n return { default: mod.MWebLastTrades };\n }),\n);\n\nconst LazyTradeDataWidget = React.lazy(() =>\n import(\"../tradeData\").then((mod) => {\n return { default: mod.TradeDataWidget };\n }),\n);\n\nexport const TopTab: React.FC<TopTabState & { className?: string }> = (\n props,\n) => {\n const { t } = useTranslation();\n const { tradingViewConfig } = useTradingPageContext();\n\n return (\n <Tabs\n variant=\"contained\"\n value={props.tab}\n contentVisible={props.visible}\n onValueChange={(e) => {\n props.setTab(e as TopTabType);\n props.setVisible(true);\n }}\n className={props.className}\n classNames={{\n tabsList: \"oui-p-2\",\n tabsContent: \"oui-min-h-[176px] oui-max-h-[396px]\",\n }}\n style={{\n marginBottom: props.tab === TopTabType.chart ? \"8px\" : 0,\n }}\n trailing={\n <button className=\"oui-px-5\" onClick={props.toggleContentVisible}>\n <ChevronIcon\n className={props.visible ? \"oui-rotate-0\" : \"oui-rotate-180\"}\n />\n </button>\n }\n >\n <TabPanel title={t(\"trading.tabs.chart\")} value={TopTabType.chart}>\n <React.Suspense fallback={null}>\n <LazyTradingviewWidget\n symbol={props.symbol}\n tradingViewConfig={tradingViewConfig}\n />\n </React.Suspense>\n </TabPanel>\n <TabPanel title={t(\"trading.tabs.trades\")} value={TopTabType.trades}>\n <React.Suspense fallback={null}>\n <LazyMWebLastTrades symbol={props.symbol} />\n </React.Suspense>\n </TabPanel>\n <TabPanel title={t(\"trading.tabs.data\")} value={TopTabType.data}>\n <Box px={3}>\n <React.Suspense fallback={null}>\n <LazyTradeDataWidget symbol={props.symbol} />\n </React.Suspense>\n </Box>\n </TabPanel>\n </Tabs>\n );\n};\n\nconst ChevronIcon: React.FC<{ className?: string }> = (props) => {\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 className={cn(\n \"oui-fill-base-contrast-54 hover:oui-fill-base-contrast-80\",\n props.className,\n )}\n >\n <path\n d=\"M5.721 4.585 2.726 6.578a.51.51 0 0 0-.14.7.51.51 0 0 0 .702.14l2.714-1.806 2.715 1.806c.23.153.549.089.702-.14a.51.51 0 0 0-.14-.7L6.283 4.585a.51.51 0 0 0-.562 0\"\n // fill=\"url(#a)\"\n />\n <defs>\n {/* <linearGradient\n id=\"a\"\n x1=\"9.502\"\n y1=\"6.001\"\n x2=\"2.502\"\n y2=\"6.001\"\n gradientUnits=\"userSpaceOnUse\"\n >\n <stop stopColor=\"rgb(var(--oui-gradient-brand-end))\" />\n <stop offset=\"1\" stopColor=\"rgb(var(--oui-gradient-brand-start))\" />\n </linearGradient> */}\n </defs>\n </svg>\n );\n};\n","import React from \"react\";\nimport { useTopTabScript } from \"./topTab.script\";\nimport { TopTab } from \"./topTab.ui\";\n\nexport const TopTabWidget: React.FC<{ className?: string }> = (props) => {\n const state = useTopTabScript();\n return <TopTab className={props.className} {...state} />;\n};\n","export { TopTab } from \"./topTab.ui\";\nexport { TopTabWidget } from \"./topTab.widget\";\nexport { useTopTabScript } from \"./topTab.script\";\n","import React, { useEffect, useRef, useState } from \"react\";\nimport { cn } from \"@orderly.network/ui\";\nimport { OrderEntryWidget } from \"@orderly.network/ui-order-entry\";\nimport type { OrderBookAndEntryState } from \"./orderBookAndEntry.script\";\n\nconst LazyOrderBookWidget = React.lazy(() =>\n import(\"../../base/orderBook\").then((mod) => {\n return { default: mod.OrderBookWidget };\n }),\n);\n\nexport const OrderBookAndEntry: React.FC<\n OrderBookAndEntryState & { className?: string }\n> = (props) => {\n const [height, setHeight] = useState(0);\n const divRef = useRef(null);\n\n useEffect(() => {\n const div = divRef.current;\n if (!div) {\n return;\n }\n const resizeObserver = new ResizeObserver((entries) => {\n for (const entry of entries) {\n setHeight(entry.contentRect.height);\n }\n });\n resizeObserver.observe(div);\n return () => {\n resizeObserver.unobserve(div);\n };\n }, []);\n return (\n <div\n className={cn(\n \"oui-mx-1 oui-grid oui-grid-cols-[4fr,6fr] oui-gap-1 \",\n props.className,\n )}\n >\n <div\n className=\"oui-rounded-xl oui-bg-base-9\"\n style={{ height: `${height + 16}px` }}\n >\n <React.Suspense fallback={null}>\n <LazyOrderBookWidget\n symbol={props.symbol}\n height={height ? height - 44 : undefined}\n />\n </React.Suspense>\n </div>\n <div className=\"oui-rounded-xl oui-bg-base-9 oui-p-2\">\n <OrderEntryWidget symbol={props.symbol} containerRef={divRef} />\n </div>\n </div>\n );\n};\n","import { useTradingPageContext } from \"../../../provider/tradingPageContext\";\n\nexport const useOrderBookAndEntryScript = () => {\n const { symbol } = useTradingPageContext();\n return {\n symbol,\n };\n};\n\nexport type OrderBookAndEntryState = ReturnType<\n typeof useOrderBookAndEntryScript\n>;\n","import React from \"react\";\nimport { useOrderBookAndEntryScript } from \"./orderBookAndEntry.script\";\nimport { OrderBookAndEntry } from \"./orderBookAndEntry.ui\";\n\nexport const OrderBookAndEntryWidget: React.FC<{ className?: string }> = (\n props,\n) => {\n const state = useOrderBookAndEntryScript();\n return <OrderBookAndEntry className={props.className} {...state} />;\n};\n","export { OrderBookAndEntry } from \"./orderBookAndEntry.ui\";\nexport { OrderBookAndEntryWidget } from \"./orderBookAndEntry.widget\";\nexport { useOrderBookAndEntryScript } from \"./orderBookAndEntry.script\";\n","import { useState } from \"react\";\nimport { useOrderStream } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { modal, Text } from \"@orderly.network/ui\";\nimport { TabType } from \"@orderly.network/ui-orders\";\nimport { SharePnLConfig } from \"@orderly.network/ui-share\";\nimport {\n usePendingOrderCount,\n usePositionsCount,\n useTradingLocalStorage,\n} from \"../../../hooks\";\nimport { useTradingPageContext } from \"../../../provider/tradingPageContext\";\n\nexport enum DataListTabType {\n position = \"Position\",\n pending = \"Pending\",\n tp_sl = \"TP/SL\",\n history = \"History\",\n liquidation = \"Liquidation\",\n}\n\nexport enum DataListTabSubType {\n positionHistory = \"Position history\",\n orderHistory = \"Order history\",\n}\n\nexport const useDataListScript = (props: {\n symbol: string;\n className?: string;\n sharePnLConfig?: SharePnLConfig;\n}) => {\n const { symbol, sharePnLConfig } = props;\n const [tab, setTab] = useState<DataListTabType>(DataListTabType.position);\n const [subTab, setSubTab] = useState<DataListTabSubType>(\n DataListTabSubType.positionHistory,\n );\n const { t } = useTranslation();\n\n const { onSymbolChange } = useTradingPageContext();\n const localStorage = useTradingLocalStorage();\n\n const [_, { cancelAllOrders, cancelAllTPSLOrders }] = useOrderStream({});\n const { positionCount } = usePositionsCount(symbol);\n const { pendingOrderCount, tpSlOrderCount } = usePendingOrderCount(symbol);\n\n const onCloseAll = (type: TabType) => {\n const title =\n type === TabType.pending\n ? t(\"orders.pending.cancelAll\")\n : type === TabType.tp_sl\n ? t(\"orders.tpsl.cancelAll\")\n : \"\";\n const content =\n type === TabType.pending\n ? t(\"orders.pending.cancelAll.description\")\n : type === TabType.tp_sl\n ? t(\"orders.tpsl.cancelAll.description\")\n : \"\";\n modal.confirm({\n title: title,\n content: <Text size=\"2xs\">{content}</Text>,\n\n onOk: async () => {\n try {\n // await cancelAll(null, { source_type: \"ALL\" });\n if (tab === DataListTabType.tp_sl) {\n await cancelAllTPSLOrders();\n } else {\n await cancelAllOrders();\n }\n return Promise.resolve(true);\n } catch (error) {\n // @ts-ignore\n if (error?.message !== undefined) {\n // @ts-ignore\n toast.error(error.message);\n }\n return Promise.resolve(false);\n } finally {\n Promise.resolve();\n }\n },\n });\n };\n\n return {\n tab,\n setTab,\n subTab,\n setSubTab,\n sharePnLConfig,\n symbol,\n positionCount,\n pendingOrderCount,\n tpSlOrderCount,\n ...localStorage,\n onCloseAll,\n onSymbolChange,\n };\n};\n\nexport type DataListState = ReturnType<typeof useDataListScript>;\n","import React from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { OrderStatus } from \"@orderly.network/types\";\nimport {\n Button,\n Checkbox,\n Divider,\n Flex,\n TabPanel,\n Tabs,\n Text,\n} from \"@orderly.network/ui\";\nimport { MobileOrderListWidget, TabType } from \"@orderly.network/ui-orders\";\nimport {\n MobileLiquidationWidget,\n MobilePositionHistoryWidget,\n MobilePositionsWidget,\n} from \"@orderly.network/ui-positions\";\nimport {\n DataListState,\n DataListTabSubType,\n DataListTabType,\n} from \"./dataList.script\";\n\nconst LazyPositionHeaderWidget = React.lazy(() =>\n import(\"../../base/positionHeader\").then((module) => {\n return { default: module.PositionHeaderWidget };\n }),\n);\n\nexport const DataList: React.FC<DataListState & { className?: string }> = (\n props,\n) => {\n const { t } = useTranslation();\n\n return (\n <Tabs\n value={props.tab}\n onValueChange={(e: any) => props.setTab(e)}\n size=\"lg\"\n className={props.className}\n classNames={{\n tabsList:\n \"oui-bg-base-9 oui-rounded-t-xl oui-p-2 oui-overflow-x-scroll oui-hide-scrollbar\",\n }}\n >\n <TabPanel\n title={`${t(\"common.positions\")} ${\n (props.positionCount ?? 0) > 0 ? `(${props.positionCount})` : \"\"\n }`}\n value={DataListTabType.position}\n >\n <PositionsView {...props} />\n </TabPanel>\n <TabPanel\n title={`${t(\"orders.status.pending\")} ${\n (props.pendingOrderCount ?? 0) > 0\n ? `(${props.pendingOrderCount})`\n : \"\"\n }`}\n value={DataListTabType.pending}\n >\n <OrdersView\n type={TabType.pending}\n ordersStatus={OrderStatus.INCOMPLETE}\n {...props}\n />\n </TabPanel>\n <TabPanel\n title={`${t(\"common.tpsl\")} ${\n (props.tpSlOrderCount ?? 0) > 0 ? `(${props.tpSlOrderCount})` : \"\"\n }`}\n value={DataListTabType.tp_sl}\n >\n <OrdersView\n type={TabType.tp_sl}\n ordersStatus={OrderStatus.INCOMPLETE}\n {...props}\n />\n </TabPanel>\n <TabPanel title={t(\"trading.history\")} value={DataListTabType.history}>\n <HistoryTab {...props} />\n </TabPanel>\n <TabPanel\n title={t(\"positions.liquidation\")}\n value={DataListTabType.liquidation}\n >\n <MobileLiquidationWidget\n enableLoadMore={true}\n symbol={props.showAllSymbol ? undefined : props.symbol}\n classNames={{ cell: \"oui-p-2 oui-bg-base-9 oui-rounded-xl\" }}\n />\n </TabPanel>\n </Tabs>\n );\n};\n\nconst PositionsView: React.FC<DataListState> = (props) => {\n return (\n <Flex direction={\"column\"} gap={2}>\n <React.Suspense fallback={null}>\n <LazyPositionHeaderWidget\n pnlNotionalDecimalPrecision={props.pnlNotionalDecimalPrecision}\n symbol={props.showAllSymbol ? undefined : props.symbol}\n unPnlPriceBasis={props.unPnlPriceBasis}\n />\n </React.Suspense>\n <MobilePositionsWidget\n symbol={props.showAllSymbol ? undefined : props.symbol}\n onSymbolChange={props.onSymbolChange}\n sharePnLConfig={props.sharePnLConfig}\n pnlNotionalDecimalPrecision={props.pnlNotionalDecimalPrecision}\n />\n </Flex>\n );\n};\n\nconst OrdersView: React.FC<\n DataListState & { type: TabType; ordersStatus?: OrderStatus }\n> = (props) => {\n return (\n <Flex direction={\"column\"} pb={2} width={\"100%\"}>\n <Divider className=\"oui-w-full\" />\n {props.type !== TabType.orderHistory && (\n <SymbolControlHeader {...props} />\n )}\n <MobileOrderListWidget\n symbol={props.showAllSymbol ? undefined : props.symbol}\n onSymbolChange={props.onSymbolChange}\n type={props.type}\n ordersStatus={props.ordersStatus}\n classNames={{\n root: \"oui-w-full oui-hide-scrollbar oui-overflow-y-hidden\",\n content: \"!oui-space-y-1\",\n cell: \"oui-py-2 oui-bg-base-9 oui-p-2 oui-rounded-xl\",\n }}\n sharePnLConfig={props.sharePnLConfig}\n showFilter={props.type === TabType.orderHistory}\n filterConfig={{ range: { from: undefined, to: undefined } }}\n />\n </Flex>\n );\n};\n\nconst SymbolControlHeader: React.FC<\n DataListState & { type: TabType; ordersStatus?: OrderStatus }\n> = (props) => {\n const { t } = useTranslation();\n\n return (\n <Flex\n px={2}\n py={2}\n width={\"100%\"}\n justify={\"between\"}\n gap={2}\n className=\"oui-rounded-b-xl oui-bg-base-9\"\n >\n <Flex className=\"oui-cursor-pointer oui-gap-[2px]\">\n <Checkbox\n color=\"white\"\n checked={!props.showAllSymbol}\n onCheckedChange={(checked: boolean) => {\n props.setShowAllSymbol(!checked);\n }}\n />\n <Text\n size=\"2xs\"\n intensity={54}\n onClick={() => {\n props.setShowAllSymbol(!props.showAllSymbol);\n }}\n >\n {t(\"trading.hideOtherSymbols\")}\n </Text>\n </Flex>\n <Button\n variant=\"outlined\"\n size=\"xs\"\n color=\"secondary\"\n onClick={(e) => {\n props.onCloseAll(props.type);\n }}\n >\n {t(\"trading.orders.closeAll\")}\n </Button>\n </Flex>\n );\n};\n\nconst HistoryTab: React.FC<DataListState> = (props) => {\n const { t } = useTranslation();\n\n return (\n <div className=\"oui-min-h-[300px]\">\n <Tabs\n value={props.subTab}\n onValueChange={(e: any) => props.setSubTab(e)}\n size=\"md\"\n classNames={{\n tabsList: \"oui-bg-base-9 oui-rounded-t-xl oui-p-2\",\n }}\n >\n <TabPanel\n title={t(\"positions.positionHistory\")}\n value={DataListTabSubType.positionHistory}\n >\n <MobilePositionHistoryWidget\n symbol={props.showAllSymbol ? undefined : props.symbol}\n onSymbolChange={props.onSymbolChange}\n classNames={{ cell: \"oui-p-2 oui-bg-base-9 oui-rounded-xl\" }}\n sharePnLConfig={props.sharePnLConfig}\n />\n </TabPanel>\n <TabPanel\n title={t(\"orders.orderHistory\")}\n value={DataListTabSubType.orderHistory}\n >\n <OrdersView type={TabType.orderHistory} {...props} />\n </TabPanel>\n </Tabs>\n </div>\n );\n};\n","import React from \"react\";\nimport type { SharePnLConfig } from \"@orderly.network/ui-share\";\nimport { useDataListScript } from \"./dataList.script\";\nimport { DataList } from \"./dataList.ui\";\n\nexport const DataListWidget: React.FC<{\n symbol: string;\n className?: string;\n sharePnLConfig?: SharePnLConfig;\n}> = (props) => {\n const state = useDataListScript(props);\n return <DataList {...state} className={props.className} />;\n};\n","export { DataList } from \"./dataList.ui\";\nexport { DataListWidget } from \"./dataList.widget\";\nexport { useDataListScript } from \"./dataList.script\";\n","export type {\n ShareOptions,\n TradingPageProps,\n ReferralProps,\n TradingRewardsProps,\n} from \"./types/types\";\n\nexport * from \"./components/desktop/dataList\";\nexport * from \"./components/base/lastTrades\";\nexport * from \"./components/desktop/assetView\";\nexport * from \"./components/base/orderBook\";\nexport * from \"./components/desktop/riskRate\";\nexport * from \"./components/desktop/orderBookAndTrades\";\nexport * from \"./components/desktop/layout/splitLayout/splitLayout\";\nexport * from \"./components/mobile/bottomNavBar\";\nexport * from \"./components/mobile/portfolioSheet\";\nexport * from \"./components/mobile/fundingRate\";\nexport * from \"./components/mobile/fundingRateModal\";\nexport * from \"./pages/trading\";\nexport * from \"./provider/tradingPageContext\";\nexport * from \"./provider/tradingPageProvider\";\nexport * from \"./hooks\";\n","import React, { PropsWithChildren, forwardRef } from \"react\";\nimport Split, { SplitProps } from \"@uiw/react-split\";\nimport { SplitLineBar } from \"./splitLineBar\";\n\ntype SplitLayoutProps = PropsWithChildren<SplitProps> & {\n onSizeChange?: (size: string) => void;\n};\n\nexport const SplitLayout = forwardRef<Split, SplitLayoutProps>((props, ref) => {\n const { onSizeChange, ...rest } = props;\n return (\n <Split\n ref={ref}\n {...rest}\n lineBar\n renderBar={(barProps) => <SplitLineBar {...barProps} mode={props.mode} />}\n onDragEnd={(_, width) => onSizeChange?.(`${width}`)}\n />\n );\n});\n","import React, { HTMLAttributes, useMemo } from \"react\";\nimport { SplitProps } from \"@uiw/react-split\";\nimport { cn } from \"@orderly.network/ui\";\n\nexport type SplitLineBarProps = Pick<SplitProps, \"mode\"> &\n HTMLAttributes<HTMLDivElement>;\n\nexport const SplitLineBar: React.FC<SplitLineBarProps> = (props) => {\n const { onMouseDown, mode = \"horizontal\", ...rest } = props;\n\n const disable = useMemo(\n () => props.className?.split(\" \").includes(\"disable\"),\n [props.className],\n );\n\n const filterCls = useMemo(\n () => props.className?.split(\" \").filter((cls) => cls !== \"disable\"),\n [props.className],\n );\n\n return (\n <div\n {...rest}\n className={cn(\n filterCls,\n \"!oui-transition-none\",\n \"!oui-shadow-none !oui-bg-transparent\",\n \"hover:!oui-bg-primary-light hover:!oui-shadow-[0px_0px_4px_0px] hover:!oui-shadow-primary-light/80\",\n \"active:!oui-bg-primary-light active:!oui-shadow-[0px_0px_4px_0px] active:!oui-shadow-primary-light/80\",\n \"focus:!oui-bg-primary-light focus:!oui-shadow-[0px_0px_4px_0px] focus:!oui-shadow-primary-light/80\",\n mode === \"horizontal\"\n ? \"!oui-w-[2px] !oui-min-w-[2px] !oui-mx-[3px]\"\n : \"!oui-h-[2px] !oui-min-h-[2px] !oui-my-[3px]\",\n disable && \"oui-pointer-events-none\",\n )}\n >\n <div\n onMouseDown={onMouseDown}\n className={cn(\n \"!oui-transition-none\",\n mode === \"horizontal\" ? \"after:!oui-w-[2px]\" : \"after:!oui-h-[2px]\",\n \"after:!oui-bg-transparent after:!oui-shadow-transparent\",\n )}\n />\n </div>\n );\n};\n","import { FC, SVGProps, useState } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { AccountStatusEnum } from \"@orderly.network/types\";\nimport { Flex, SimpleDialog, Text } from \"@orderly.network/ui\";\nimport { ScanQRCodeWidget } from \"@orderly.network/ui-scaffold\";\nimport { MobileAccountMenuExtension } from \"./account/account.widget\";\nimport { BalanceWidget } from \"./balance\";\nimport { BottomNavBarState } from \"./bottomNavBar.script\";\nimport { ChainWidget } from \"./chain\";\n\nexport const BottomNavBar: FC<BottomNavBarState> = (props) => {\n const renderContent = () => {\n if (props.wrongNetwork) {\n return null;\n }\n\n if (\n !props.disabledConnect &&\n props.status === AccountStatusEnum.EnableTradingWithoutConnected\n ) {\n return <LinkDevice onDisconnect={props.onDisconnect} />;\n }\n\n return <ChainWidget />;\n };\n\n const showScanQRCode =\n !props.disabledConnect &&\n props.status !== AccountStatusEnum.EnableTradingWithoutConnected &&\n props.status < AccountStatusEnum.EnableTrading;\n\n return (\n <div className=\"oui-bg-base-9 oui-border-t oui-border-line-4\">\n <Flex\n height={64}\n gap={1}\n justify={\"end\"}\n itemAlign={\"center\"}\n className=\"oui-px-[14px]\"\n // style={{\n // height: \"calc(64px + env(safe-area-inset-bottom))\"\n // }}\n >\n <BalanceWidget />\n <Flex gap={2}>\n {showScanQRCode && <ScanQRCodeWidget />}\n {renderContent()}\n <MobileAccountMenuExtension />\n </Flex>\n </Flex>\n <div className=\"oui-h-[env(safe-area-inset-bottom)]\" />\n </div>\n );\n};\n\ntype LinkDeviceProps = {\n onDisconnect: () => void;\n};\n\nconst LinkDevice: FC<LinkDeviceProps> = (props) => {\n const [open, setOpen] = useState(false);\n const { t } = useTranslation();\n\n const showDialog = () => {\n setOpen(true);\n };\n\n const hideDialog = () => {\n setOpen(false);\n };\n\n return (\n <>\n <SimpleDialog\n open={open}\n onOpenChange={setOpen}\n title={t(\"common.tips\")}\n size=\"xs\"\n actions={{\n secondary: {\n label: t(\"common.cancel\"),\n onClick: hideDialog,\n size: \"md\",\n fullWidth: true,\n },\n primary: {\n label: t(\"connector.disconnect\"),\n onClick: async () => {\n await props.onDisconnect();\n hideDialog();\n },\n size: \"md\",\n variant: \"outlined\",\n color: \"danger\",\n },\n }}\n >\n <Text intensity={54} size=\"sm\">\n {t(\"linkDevice.scanQRCode.connected.description\")}\n </Text>\n </SimpleDialog>\n <Flex\n className=\"oui-text-base-contrast oui-px-[6px]\"\n intensity={500}\n height={28}\n r=\"md\"\n onClick={showDialog}\n >\n <DesktopIcon />\n <Dot />\n <LinkIcon />\n <Dot />\n <MobileIcon />\n </Flex>\n </>\n );\n};\n\nconst Dot = () => {\n return (\n <Flex className=\"oui-gap-x-[1px] oui-px-[1px]\">\n <DotIcon />\n <DotIcon />\n <DotIcon />\n </Flex>\n );\n};\n\nconst DesktopIcon: FC<SVGProps<SVGSVGElement>> = (props) => (\n <svg\n width=\"18\"\n height=\"18\"\n viewBox=\"0 0 18 18\"\n fill=\"currentColor\"\n xmlns=\"http://www.w3.org/2000/svg\"\n {...props}\n >\n <path d=\"M4.5 2.93a2.25 2.25 0 0 0-2.25 2.25v5.25a.75.75 0 0 0-.75.75v1.5c0 1.272.93 2.25 2.25 2.25h10.5c1.318 0 2.25-.978 2.25-2.25v-1.5a.75.75 0 0 0-.75-.75V5.18a2.25 2.25 0 0 0-2.25-2.25zm0 1.5h9a.75.75 0 0 1 .75.75v5.25H3.75V5.18a.75.75 0 0 1 .75-.75M3 11.93h12v.75c0 .46-.277.75-.75.75H3.75c-.474 0-.75-.29-.75-.75z\" />\n </svg>\n);\n\nconst MobileIcon: FC<SVGProps<SVGSVGElement>> = (props) => (\n <svg\n width=\"18\"\n height=\"18\"\n viewBox=\"0 0 18 18\"\n fill=\"currentColor\"\n xmlns=\"http://www.w3.org/2000/svg\"\n {...props}\n >\n <path d=\"M13.498 3.715a2.25 2.25 0 0 0-2.25-2.25h-4.5a2.25 2.25 0 0 0-2.25 2.25v10.5a2.25 2.25 0 0 0 2.25 2.25h4.5a2.25 2.25 0 0 0 2.25-2.25zm-1.5 0v9.75h-6v-9.75a.75.75 0 0 1 .75-.75h4.5a.75.75 0 0 1 .75.75m-2.25 11.25a.75.75 0 1 1-1.5 0 .75.75 0 0 1 1.5 0\" />\n </svg>\n);\n\nconst LinkIcon: FC<SVGProps<SVGSVGElement>> = (props) => (\n <svg\n width=\"12\"\n height=\"12\"\n viewBox=\"0 0 12 12\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M1.007 6a5 5 0 1 1 10 0 5 5 0 0 1-10 0m7.486-2.344A.6.6 0 0 1 8.91 3.5c.15 0 .305.048.418.156a.55.55 0 0 1 0 .798L5.254 8.337a.62.62 0 0 1-.837 0L2.67 6.673a.55.55 0 0 1 0-.798.62.62 0 0 1 .837 0l1.329 1.266z\"\n fill=\"url(#a)\"\n />\n <defs>\n <linearGradient\n id=\"a\"\n x1=\"11.007\"\n y1=\"5.999\"\n x2=\"1.007\"\n y2=\"5.999\"\n gradientUnits=\"userSpaceOnUse\"\n >\n <stop stopColor=\"rgb(var(--oui-gradient-brand-end))\" />\n <stop offset=\"1\" stopColor=\"rgb(var(--oui-gradient-brand-start))\" />\n </linearGradient>\n </defs>\n </svg>\n);\n\nconst DotIcon: FC<SVGProps<SVGSVGElement>> = (props) => (\n <svg\n width=\"2\"\n height=\"2\"\n viewBox=\"0 0 2 2\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M.667.334a.667.667 0 1 1 0 1.333.667.667 0 0 1 0-1.333\"\n fill=\"url(#a)\"\n />\n <defs>\n <linearGradient\n id=\"a\"\n x1=\"1.333\"\n y1=\"1.001\"\n x2=\"0\"\n y2=\"1.001\"\n gradientUnits=\"userSpaceOnUse\"\n >\n <stop stopColor=\"rgb(var(--oui-gradient-brand-end))\" />\n <stop offset=\"1\" stopColor=\"rgb(var(--oui-gradient-brand-start))\" />\n </linearGradient>\n </defs>\n </svg>\n);\n","import { ExtensionPositionEnum, ExtensionSlot, installExtension } from \"@orderly.network/ui\";\nimport { useAccountScript } from \"./account.script\";\nimport { Account } from \"./account.ui\";\n\nexport const AccountWidget = () => {\n const state = useAccountScript();\n return (<Account {...state} />);\n};\ninstallExtension<any>({\n name: \"mobile-account-menu\",\n scope: [\"*\"],\n positions: [ExtensionPositionEnum.MobileAccountMenu],\n builder: useAccountScript,\n __isInternal: true,\n })((props:any) => {\n return <Account {...props} />;\n });\n \n export const MobileAccountMenuExtension = () => {\n return <ExtensionSlot position={ExtensionPositionEnum.MobileAccountMenu} />;\n };\n ","import { AccountState as AccountStateType } from \"@orderly.network/core\";\nimport { useAccount } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { modal } from \"@orderly.network/ui\";\nimport { useTradingPageContext } from \"../../../../provider/tradingPageContext\";\nimport { AccountSheetWidget } from \"../../accountSheet\";\n\nexport const useAccountScript = () => {\n const { t } = useTranslation();\n const { referral, tradingRewards, bottomSheetLeading } =\n useTradingPageContext();\n const { account, state } = useAccount();\n\n const onShowAccountSheet = () => {\n modal.sheet({\n title: t(\"common.account\"),\n leading: bottomSheetLeading,\n content: <AccountSheetWidget {...referral} {...tradingRewards} />,\n });\n };\n\n return {\n onShowAccountSheet,\n address: account.address,\n state: state as AccountStateType,\n };\n};\n\nexport type AccountState = ReturnType<typeof useAccountScript>;\n","import { FC } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { ArrowRightShortIcon, Button, Flex, Text } from \"@orderly.network/ui\";\nimport { Decimal } from \"@orderly.network/utils\";\nimport { AccountSheetState } from \"./accountSheet.script\";\nimport { CopyIcon, HeadIcon, OrderlyIcon, USDCIcon } from \"./icons\";\n\nexport const AccountSheet: FC<AccountSheetState> = (props) => {\n const { t } = useTranslation();\n\n return (\n <Flex direction={\"column\"} gap={4}>\n <AccountInfo {...props} />\n <ReferralInfo {...props} />\n <TradingRewardsInfo {...props} />\n <Flex gap={3} width={\"100%\"} justify={\"center\"}>\n {props.showGetTestUSDC && (\n <Button\n variant=\"outlined\"\n // color=\"primary\"\n size=\"md\"\n onClick={props.onGetTestUSDC}\n fullWidth\n loading={props.gettingTestUSDC}\n className=\"oui-border-primary-light oui-text-primary-light\"\n >\n {t(\"trading.faucet.getTestUSDC\")}\n </Button>\n )}\n <Button\n variant=\"outlined\"\n color=\"danger\"\n size=\"md\"\n onClick={props.onDisconnect}\n className={props.showGetTestUSDC ? \"oui-w-full\" : \"oui-w-[50%]\"}\n >\n {t(\"connector.disconnect\")}\n </Button>\n </Flex>\n </Flex>\n );\n};\nexport const AccountInfo: FC<AccountSheetState> = (props) => {\n return (\n <Flex width={\"100%\"} justify={\"between\"}>\n <Flex gap={3}>\n <HeadIcon />\n <Flex\n direction={\"column\"}\n justify={\"start\"}\n itemAlign={\"start\"}\n className=\"oui-gap-[2px]\"\n >\n <Text.formatted rule={\"address\"}>{props.address}</Text.formatted>\n <Text.formatted\n size=\"2xs\"\n intensity={80}\n // @ts-ignore\n prefix={\n <div className=\"oui-h-1 oui-w-1 oui-rounded-full oui-bg-success oui-pr-1\" />\n }\n >\n {props.chainName}\n </Text.formatted>\n </Flex>\n </Flex>\n <button\n className=\"oui-cursor-pointer\"\n onClick={() => {\n props.onCopyAddress();\n }}\n >\n <CopyIcon />\n </button>\n </Flex>\n );\n};\n\nexport const ReferralInfo: FC<AccountSheetState> = (props) => {\n const { t } = useTranslation();\n return (\n <Flex\n direction={\"column\"}\n gap={3}\n r=\"lg\"\n p={3}\n className=\"oui-bg-base-6\"\n width={\"100%\"}\n >\n <button\n onClick={props.onClickReferral}\n className=\"oui-cursor-pointer oui-w-full\"\n >\n <Flex justify={\"between\"} width={\"100%\"}>\n <Text size=\"2xs\">{t(\"affiliate.referral\")}</Text>\n <ArrowRightShortIcon color=\"white\" opacity={0.98} size={16} />\n </Flex>\n </button>\n {props.isAffiliate && (\n <Flex\n gradient=\"primary\"\n p={4}\n r=\"lg\"\n width={\"100%\"}\n angle={180}\n justify={\"between\"}\n >\n <Flex direction={\"column\"} itemAlign={\"start\"}>\n <Text size=\"xs\">{t(\"common.affiliate\")}</Text>\n <Text size=\"2xs\" intensity={54}>\n ({t(\"affiliate.commission.30d\")})\n </Text>\n </Flex>\n <Flex className=\"oui-gap-[6px]\">\n <USDCIcon />\n <Text.numeral\n dp={2}\n padding={false}\n rm={Decimal.ROUND_DOWN}\n rule=\"price\"\n >\n {props.affiliateCommission30D ?? \"--\"}\n </Text.numeral>\n </Flex>\n </Flex>\n )}\n {props.isTrader && (\n <Flex\n gradient=\"success\"\n p={4}\n r=\"lg\"\n width={\"100%\"}\n angle={180}\n justify={\"between\"}\n >\n <Flex direction={\"column\"} itemAlign={\"start\"}>\n <Text size=\"xs\">{t(\"affiliate.trader\")}</Text>\n <Text size=\"2xs\" intensity={54}>\n ({t(\"affiliate.commission.30d\")})\n </Text>\n </Flex>\n <Flex className=\"oui-gap-[6px]\">\n <USDCIcon />\n <Text.numeral\n dp={2}\n padding={false}\n rm={Decimal.ROUND_DOWN}\n rule=\"price\"\n >\n {props.traderCommission30D ?? \"--\"}\n </Text.numeral>\n </Flex>\n </Flex>\n )}\n </Flex>\n );\n};\n\nexport const TradingRewardsInfo: FC<AccountSheetState> = (props) => {\n const { t } = useTranslation();\n\n return (\n <Flex\n direction={\"column\"}\n gap={3}\n r=\"lg\"\n p={3}\n className=\"oui-bg-base-6\"\n width={\"100%\"}\n >\n <button\n onClick={props.onClickTradingRewards}\n className=\"oui-cursor-pointer oui-w-full\"\n >\n <Flex justify={\"between\"} width={\"100%\"}>\n <Flex gap={1} className=\"oui-text-base-contrast oui-text-2xs\">\n <Text>{t(\"common.tradingRewards\")}</Text>\n <Text intensity={54}>\n (\n <Text>{`${(\n t(\"tradingRewards.epoch\") as string\n )?.toLowerCase()} `}</Text>\n <Text intensity={98}>{props.curEpochId}</Text> )\n </Text>\n </Flex>\n <ArrowRightShortIcon color=\"white\" opacity={0.98} size={16} />\n </Flex>\n </button>\n <Flex\n p={4}\n r=\"lg\"\n width={\"100%\"}\n angle={180}\n justify={\"between\"}\n className=\"oui-bg-gradient-to-t oui-from-[#2d0061] oui-to-[#bd6bed]\"\n >\n <Text size=\"2xs\" intensity={80}>\n {t(\"tradingRewards.myEstRewards\")}\n </Text>\n\n <Flex className=\"oui-gap-[6px]\">\n <OrderlyIcon />\n <Text.numeral\n dp={2}\n padding={false}\n rm={Decimal.ROUND_DOWN}\n rule=\"price\"\n >\n {props.estRewards}\n </Text.numeral>\n </Flex>\n </Flex>\n </Flex>\n );\n};\n","export const HeadIcon = () => {\n return (\n <svg\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n className=\"oui-rounded-full\"\n >\n <g clipPath=\"url(#a)\">\n <path\n d=\"m31.002 14.493-8.326-22.51L.166.31l8.327 22.51z\"\n fill=\"#03435D\"\n />\n <path\n d=\"m4.456-8.716-18.03 15.84 15.84 18.03 18.03-15.84z\"\n fill=\"#157CF2\"\n />\n <path\n d=\"m17.548 38.67 22.825-7.416-7.416-22.825-22.826 7.416z\"\n fill=\"#F3E200\"\n />\n </g>\n <defs>\n <clipPath id=\"a\">\n <rect width=\"24\" height=\"24\" rx=\"12\" fill=\"#fff\" />\n </clipPath>\n </defs>\n </svg>\n );\n};\n\nexport const CopyIcon = () => {\n return (\n <svg\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M5.832 2.492A3.333 3.333 0 0 0 2.5 5.826v5a3.333 3.333 0 0 0 3.333 3.333 3.333 3.333 0 0 0 3.334 3.333h5a3.333 3.333 0 0 0 3.333-3.333v-5a3.333 3.333 0 0 0-3.333-3.333 3.333 3.333 0 0 0-3.334-3.334zm8.334 5c.92 0 1.666.746 1.666 1.667v5c0 .92-.746 1.666-1.666 1.666h-5c-.92 0-1.667-.745-1.667-1.666h3.333a3.333 3.333 0 0 0 3.334-3.334z\"\n fill=\"rgb(var(--oui-color-primary))\"\n />\n </svg>\n );\n};\n\nexport const USDCIcon = (props: { size?: number }) => {\n const { size = 20 } = props;\n return (\n <svg\n width={size}\n height={size}\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <g clipPath=\"url(#a)\">\n <path\n d=\"M10 20c5.542 0 10-4.458 10-10S15.542 0 10 0 0 4.458 0 10s4.458 10 10 10\"\n fill=\"#2775CA\"\n />\n <path\n d=\"M13 11.473c0-1.452-.94-1.95-2.82-2.158-1.344-.166-1.613-.498-1.613-1.078s.448-.955 1.343-.955c.806 0 1.254.25 1.478.872.045.124.18.207.313.207h.717c.179 0 .313-.125.313-.29v-.042c-.179-.913-.985-1.618-2.015-1.701v-.996c0-.166-.134-.29-.358-.332h-.671c-.18 0-.314.124-.359.332v.954c-1.343.166-2.194.996-2.194 2.034 0 1.369.896 1.908 2.776 2.116 1.254.207 1.657.456 1.657 1.12s-.627 1.12-1.477 1.12c-1.165 0-1.568-.456-1.702-1.078a.32.32 0 0 0-.313-.25h-.762c-.179 0-.313.125-.313.291v.042c.179 1.037.895 1.784 2.373 1.991v.996c0 .166.134.29.358.332h.672c.18 0 .313-.124.358-.332v-.996C12.105 13.465 13 12.593 13 11.473\"\n fill=\"#fff\"\n fillOpacity=\".98\"\n />\n <path\n d=\"M7.74 16.57c-3.458-1.215-5.23-4.986-3.945-8.324.665-1.821 2.127-3.208 3.944-3.859.178-.086.266-.216.266-.433v-.607c0-.174-.088-.304-.266-.347-.044 0-.133 0-.177.043-4.21 1.3-6.516 5.68-5.186 9.798.798 2.428 2.704 4.292 5.186 5.072.177.087.355 0 .399-.173.044-.043.044-.087.044-.173v-.608c0-.13-.133-.303-.266-.39m4.698-13.527c-.178-.086-.355 0-.4.174-.043.043-.043.086-.043.173v.607c0 .174.133.347.266.434 3.457 1.213 5.23 4.985 3.944 8.323-.664 1.821-2.127 3.209-3.944 3.859-.178.086-.266.216-.266.433v.607c0 .174.088.304.266.347.044 0 .133 0 .177-.043 4.21-1.3 6.515-5.68 5.186-9.798-.798-2.471-2.748-4.335-5.186-5.116\"\n fill=\"#fff\"\n />\n </g>\n <defs>\n <clipPath id=\"a\">\n <path fill=\"#fff\" d=\"M0 0h20v20H0z\" />\n </clipPath>\n </defs>\n </svg>\n );\n};\n\nexport const OrderlyIcon = (props: { size?: number }) => {\n const { size = 20 } = props;\n return (\n <svg\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <g clipPath=\"url(#clip0_6403_64483)\">\n <path\n d=\"M10.0245 19.9493C15.5198 19.9493 19.9747 15.4944 19.9747 9.99908C19.9747 4.50371 15.5198 0.0488281 10.0245 0.0488281C4.5291 0.0488281 0.0742188 4.50371 0.0742188 9.99908C0.0742188 15.4944 4.5291 19.9493 10.0245 19.9493Z\"\n fill=\"url(#paint0_linear_6403_64483)\"\n />\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M14.1553 4.89304C14.2199 4.94541 14.1821 5.04758 14.0989 5.04758H5.95035C5.86716 5.04758 5.82936 4.94541 5.894 4.89304C7.0223 3.97912 8.45953 3.43164 10.0246 3.43164C11.5898 3.43164 13.0269 3.97912 14.1553 4.89304Z\"\n fill=\"white\"\n />\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M7.47013 11.7869C7.42315 11.7199 7.34748 11.6777 7.26565 11.6777H3.82985C3.75113 11.6777 3.69375 11.7525 3.71563 11.8281C4.5078 14.565 7.0326 16.566 10.0247 16.566C13.017 16.566 15.5417 14.565 16.3339 11.8281C16.3558 11.7525 16.2984 11.6777 16.2197 11.6777H12.7839C12.702 11.6777 12.6264 11.7199 12.5795 11.7869C12.0155 12.5911 11.0815 13.1167 10.0248 13.1167C8.96803 13.1167 8.03406 12.5911 7.47013 11.7869Z\"\n fill=\"white\"\n />\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M12.3347 7.90519C12.3822 7.95756 12.449 7.9891 12.5196 7.9891H16.1137C16.1952 7.9891 16.253 7.90983 16.2261 7.83301C15.9724 7.10689 15.5948 6.43893 15.1187 5.85447C15.074 5.79961 15.0067 5.76855 14.9358 5.76855H5.11323C5.04247 5.76855 4.97512 5.79961 4.93044 5.85447C4.45429 6.43893 4.0767 7.10689 3.82306 7.83301C3.79622 7.90983 3.85398 7.9891 3.93536 7.9891H7.52952C7.60022 7.9891 7.66694 7.95756 7.71445 7.90519C8.28491 7.2763 9.10861 6.88136 10.0246 6.88136C10.9405 6.88136 11.7643 7.2763 12.3347 7.90519Z\"\n fill=\"white\"\n />\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M13.1164 10.9586C13.0553 10.9586 13.0118 10.899 13.0284 10.8401C13.1033 10.5722 13.1433 10.2898 13.1433 9.9981C13.1433 9.58758 13.064 9.19556 12.9199 8.83657C12.8954 8.77581 12.9392 8.70801 13.0046 8.70801H16.392C16.4349 8.70801 16.472 8.73831 16.4799 8.78052C16.5538 9.17511 16.5925 9.58216 16.5925 9.9982C16.5925 10.2978 16.5724 10.5926 16.5337 10.8815C16.5277 10.9258 16.4897 10.9586 16.4451 10.9586H13.1164ZM7.02223 10.8401C7.03868 10.899 6.99532 10.9586 6.93421 10.9586H3.60551C3.56084 10.9586 3.52285 10.9258 3.5169 10.8815C3.47807 10.5926 3.45801 10.2978 3.45801 9.9982C3.45801 9.58216 3.4967 9.17511 3.57069 8.78052C3.57859 8.73831 3.61563 8.70801 3.65856 8.70801H7.04593C7.11141 8.70801 7.15516 8.77581 7.13076 8.83657C6.98657 9.19556 6.90722 9.58758 6.90722 9.9981C6.90722 10.2898 6.94728 10.5722 7.02223 10.8401Z\"\n fill=\"white\"\n />\n </g>\n <defs>\n <linearGradient\n id=\"paint0_linear_6403_64483\"\n x1=\"10.0245\"\n y1=\"0.0488561\"\n x2=\"10.0245\"\n y2=\"19.9493\"\n gradientUnits=\"userSpaceOnUse\"\n >\n <stop stopColor=\"#C750FF\" />\n <stop offset=\"1\" stopColor=\"#5800E8\" />\n </linearGradient>\n <clipPath id=\"clip0_6403_64483\">\n <rect width=\"20\" height=\"20\" fill=\"white\" />\n </clipPath>\n </defs>\n </svg>\n );\n};\n","import { useMemo } from \"react\";\nimport {\n TWType,\n useAccount,\n useChains,\n useConfig,\n useCurEpochEstimate,\n useEpochInfo,\n useLocalStorage,\n useMutation,\n useReferralInfo,\n useWalletConnector,\n} from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { AccountStatusEnum, ChainNamespace } from \"@orderly.network/types\";\nimport { modal, toast, useModal } from \"@orderly.network/ui\";\nimport { isTestnet } from \"@orderly.network/utils\";\nimport { ReferralProps, TradingRewardsProps } from \"../../../types/types\";\n\nexport const useAccountSheetScript = (\n props: ReferralProps & TradingRewardsProps,\n) => {\n const { t } = useTranslation();\n const [linkDeviceStorage] = useLocalStorage(\"orderly_link_device\", {});\n const { account, state } = useAccount();\n const accountId = account.accountId;\n const address = account.address;\n const { hide } = useModal();\n\n const config = useConfig();\n\n const { connectedChain, disconnect, namespace } = useWalletConnector();\n\n const chainId =\n account.chainId || connectedChain?.id || linkDeviceStorage?.chainId;\n\n const showGetTestUSDC = useMemo(() => {\n if (chainId) {\n return (\n (state.status === AccountStatusEnum.EnableTrading ||\n state.status === AccountStatusEnum.EnableTradingWithoutConnected) &&\n // @ts-ignore\n isTestnet(parseInt(chainId))\n );\n }\n\n return false;\n }, [state.status, chainId]);\n\n const chainName = useGetChains(chainId);\n\n const operatorUrl = config.get<string>(\"operatorUrl\");\n\n const onCopyAddress = () => {\n navigator.clipboard.writeText(address ?? \"\");\n toast.success(t(\"common.copy.copied\"));\n };\n\n const {\n affiliateCommission30D,\n traderCommission30D,\n isAffiliate,\n isTrader,\n onClickReferral,\n } = useReferral(props.onClickReferral);\n\n const { curEpochId, estRewards, onClickTradingRewards } = useTradingRewards(\n props.onClickTradingRewards,\n );\n\n const onDisconnect = async () => {\n // The cache must be cleared first, otherwise it will be possible entered link device mode\n localStorage.removeItem(\"orderly_link_device\");\n await disconnect({\n label: state.connectWallet?.name,\n });\n await account.disconnect();\n hide();\n };\n\n const [getTestUSDC, { isMutating: gettingTestUSDC }] = useMutation(\n `${operatorUrl}/v1/faucet/usdc`,\n );\n\n const onGetTestUSDC = () => {\n if (\n state.status < AccountStatusEnum.EnableTrading &&\n state.status !== AccountStatusEnum.EnableTradingWithoutConnected\n ) {\n // return modal.show(WalletConnectSheet, {\n // status: state.status,\n // });\n return;\n }\n\n const message = t(\"trading.faucet.getTestUSDC.success\", {\n quantity: namespace === ChainNamespace.solana ? \"100\" : \"1,000\",\n });\n\n return getTestUSDC({\n chain_id: chainId?.toString(),\n user_address: state.address,\n broker_id: config.get(\"brokerId\"),\n }).then(\n (res: any) => {\n if (res.success) {\n return modal.alert({\n title: t(\"trading.faucet.getTestUSDC\"),\n message,\n onOk: () => {\n return Promise.resolve(true);\n },\n });\n }\n res.message && toast.error(res.message);\n // return Promise.reject(res);\n },\n (error: Error) => {\n toast.error(error.message);\n },\n );\n };\n return {\n accountId,\n address,\n chainId,\n chainName,\n onCopyAddress,\n\n affiliateCommission30D,\n onClickReferral,\n isAffiliate,\n isTrader,\n traderCommission30D,\n\n curEpochId,\n onClickTradingRewards,\n estRewards,\n\n onDisconnect,\n showGetTestUSDC,\n onGetTestUSDC,\n gettingTestUSDC,\n };\n};\n\nconst useReferral = (_onClickReferral?: () => void) => {\n const { data, isLoading, isAffiliate, isTrader } = useReferralInfo();\n\n const affiliateCommission30D = useMemo(() => {\n if (isAffiliate) {\n return data?.referrer_info?.[\"30d_referrer_rebate\"];\n }\n return undefined;\n }, [data, isAffiliate]);\n\n const traderCommission30D = useMemo(() => {\n if (isTrader) {\n return data?.referee_info?.[\"30d_referee_rebate\"];\n }\n return undefined;\n }, [data, isTrader]);\n\n const onClickReferral = () => {\n _onClickReferral?.();\n };\n\n return {\n onClickReferral,\n affiliateCommission30D,\n traderCommission30D,\n isAffiliate,\n isTrader,\n\n // WARNING: test data\n // affiliateCommission30D: 1234.43,\n // traderCommission30D:44343.33,\n // isAffiliate: true,\n // isTrader: true,\n };\n};\n\nconst useTradingRewards = (_onClick?: () => void) => {\n const [curEpochEstimate] = useCurEpochEstimate(TWType.normal);\n const [list, curEpoch] = useEpochInfo(TWType.normal);\n const curEpochId = useMemo(() => {\n return curEpoch.curEpochInfo?.epoch_id ?? \"--\";\n }, [curEpoch]);\n\n const estRewards = useMemo(() => {\n if (typeof curEpochEstimate?.est_r_wallet === \"undefined\") {\n return \"--\";\n }\n return curEpochEstimate?.est_r_wallet;\n }, [curEpochEstimate]);\n\n const onClickTradingRewards = () => {\n _onClick?.();\n };\n\n return {\n curEpochId,\n estRewards,\n onClickTradingRewards,\n };\n};\n\nfunction useGetChains(chainId: number) {\n const [mainChains, { findByChainId }] = useChains(\"mainnet\", {\n pick: \"network_infos\",\n filter: (chain: any) =>\n chain.network_infos?.bridge_enable || chain.network_infos?.bridgeless,\n });\n\n const chainName = useMemo(() => {\n // @ts-ignore\n const chain = findByChainId(parseInt(chainId), \"network_infos\");\n\n if (!chain) {\n return \"Unknown\";\n }\n // // @ts-ignore\n // if (isTestnet(chain.chain_id)) {\n // return \"Testnet\";\n // }\n // @ts-ignore\n return chain.name;\n }, [chainId, findByChainId]);\n\n return chainName;\n}\n\nexport type AccountSheetState = ReturnType<typeof useAccountSheetScript>;\n","import { ReferralProps, TradingRewardsProps } from \"../../../types/types\";\nimport { useAccountSheetScript } from \"./accountSheet.script\";\nimport { AccountSheet } from \"./accountSheet.ui\";\n\nexport const AccountSheetWidget = (\n props: ReferralProps & TradingRewardsProps\n) => {\n const state = useAccountSheetScript(props);\n return <AccountSheet {...state} />;\n};\n","import { FC } from \"react\";\nimport { Button, formatAddress } from \"@orderly.network/ui\";\nimport { AccountState } from \"./account.script\";\nimport { AuthGuard } from \"@orderly.network/ui-connector\";\n\nexport const Account: FC<AccountState> = (props) => {\n return (\n <AuthGuard\n buttonProps={{\n size: \"sm\",\n }}\n >\n <Button\n variant=\"gradient\"\n size={\"sm\"}\n className=\"oui-max-w-[83px]\"\n onClick={(e) => {\n props.onShowAccountSheet();\n }}\n >\n {formatAddress(props.address!, [4, 4])}\n </Button>\n </AuthGuard>\n );\n};\n","import { FC } from \"react\";\nimport { BalanceState } from \"./balance.script\";\n\nexport const Balance: FC<BalanceState> = () => {\n return null;\n};\n","export const useBalanceScript = () => {\n return {};\n};\n\nexport type BalanceState = ReturnType<typeof useBalanceScript>;\n","import { useBalanceScript } from \"./balance.script\";\nimport { Balance } from \"./balance.ui\";\n\nexport const BalanceWidget = () => {\n const state = useBalanceScript();\n return <Balance {...state} />;\n};\n","import { FC } from \"react\";\nimport { Box, ChainIcon, modal, toast } from \"@orderly.network/ui\";\nimport { ChainState } from \"./chain.script\";\nimport { ChainSelectorSheetId } from \"@orderly.network/ui-chain-selector\";\nimport { useTranslation } from \"@orderly.network/i18n\";\n\nexport const Chain: FC<ChainState> = (props) => {\n const { t } = useTranslation();\n\n return (\n <button\n onClick={(e) => {\n modal\n .show<{\n wrongNetwork: boolean;\n }>(ChainSelectorSheetId, {\n // networkId: props.networkId,\n bridgeLessOnly: false,\n isWrongNetwork: props.wrongNetwork,\n })\n .then(\n (r: any) => {\n if (r?.chainId) {\n props.setCurrentChainId(r?.chainId);\n }\n toast.success(t(\"connector.networkSwitched\"));\n },\n (error) => console.log(\"[switchChain error]\", error)\n );\n }}\n >\n <Box className=\"oui-relative oui-rounded-t-[6px] oui-rounded-bl-[6px] oui-rounded-br-[3px] oui-bg-base-5 oui-px-2 oui-h-7 oui-flex oui-items-center\">\n <ChainIcon chainId={props.currentChainId!} size=\"2xs\" />\n <div className=\"oui-absolute oui-right-0 oui-bottom-0\">\n <svg\n width=\"9\"\n height=\"9\"\n viewBox=\"0 0 9 9\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path d=\"M9 6V0L0 9h6a3 3 0 0 0 3-3\" fill=\"url(#a)\" />\n <defs>\n <linearGradient\n id=\"a\"\n x1=\"9\"\n y1=\"4.5\"\n x2=\"0\"\n y2=\"4.5\"\n gradientUnits=\"userSpaceOnUse\"\n >\n <stop stopColor=\"rgb(var(--oui-gradient-brand-end))\" />\n <stop\n offset=\"1\"\n stopColor=\"rgb(var(--oui-gradient-brand-start))\"\n />\n </linearGradient>\n </defs>\n </svg>\n </div>\n </Box>\n </button>\n );\n};\n","import { useConfig } from \"@orderly.network/hooks\";\nimport { useAppContext } from \"@orderly.network/react-app\";\n\nexport const useChainScript = () => {\n const config = useConfig();\n const { wrongNetwork, currentChainId, setCurrentChainId } = useAppContext();\n\n const networkId = config.get(\"networkId\");\n\n return {\n currentChainId,\n setCurrentChainId,\n networkId,\n wrongNetwork,\n };\n};\n\nexport type ChainState = ReturnType<typeof useChainScript>;\n","import React from \"react\";\nimport { useChainScript } from \"./chain.script\";\nimport { Chain } from \"./chain.ui\";\n\nexport const ChainWidget: React.FC = () => {\n const state = useChainScript();\n return <Chain {...state} />;\n};\n","import { useAccount } from \"@orderly.network/hooks\";\nimport { useAppContext } from \"@orderly.network/react-app\";\n\nexport const useBottomNavBarScript = () => {\n const { wrongNetwork, disabledConnect } = useAppContext();\n const { account, state } = useAccount();\n\n /** link device, acally wallet not connect */\n const onDisconnect = async () => {\n localStorage.removeItem(\"orderly_link_device\");\n await account.disconnect();\n };\n\n return {\n wrongNetwork,\n disabledConnect,\n status: state.status,\n onDisconnect,\n };\n};\n\nexport type BottomNavBarState = ReturnType<typeof useBottomNavBarScript>;\n","import { useBottomNavBarScript } from \"./bottomNavBar.script\";\nimport { BottomNavBar } from \"./bottomNavBar.ui\";\n\nexport const BottomNavBarWidget = () => {\n const state = useBottomNavBarScript();\n return (<BottomNavBar {...state} />);\n};\n","import { FC, useCallback, useId } from \"react\";\nimport React from \"react\";\nimport { Trans, useTranslation } from \"@orderly.network/i18n\";\nimport {\n ArrowDownShortIcon,\n ArrowLeftRightIcon,\n ArrowUpShortIcon,\n Button,\n cn,\n Divider,\n EyeCloseIcon,\n EyeIcon,\n Flex,\n Grid,\n Input,\n inputFormatter,\n InputFormatter,\n modal,\n PlusIcon,\n ReduceIcon,\n RefreshIcon,\n Statistic,\n Text,\n} from \"@orderly.network/ui\";\nimport { LeverageProps, LeverageSlider } from \"@orderly.network/ui-leverage\";\nimport { USDCIcon } from \"../accountSheet/icons\";\nimport {\n getMarginRatioColor,\n PortfolioSheetState,\n} from \"./portfolioSheet.script\";\nimport { RiskIndicator } from \"./riskIndicator\";\n\nexport const PortfolioSheet: FC<PortfolioSheetState> = (props) => {\n return (\n <Flex direction={\"column\"} gap={4} width={\"100%\"}>\n <Asset {...props} />\n <Divider className=\"oui-w-full\" />\n <MarginRatio {...props} />\n {/* <Leverage {...props} /> */}\n {/* <Divider className=\"oui-w-full\" /> */}\n {/* <AvailableBalance {...props} /> */}\n <Buttons {...props} />\n </Flex>\n );\n};\n\nconst Asset: FC<PortfolioSheetState> = (props) => {\n const { t } = useTranslation();\n\n const onUnsettleClick = useCallback(() => {\n return modal.confirm({\n title: t(\"settle.settlePnl\"),\n // maxWidth: \"xs\",\n content: (\n <Text intensity={54} size=\"xs\">\n {/* @ts-ignore */}\n <Trans i18nKey=\"settle.settlePnl.description\" />\n </Text>\n ),\n onCancel: () => {\n return Promise.reject();\n },\n onOk: () => {\n if (typeof props.onSettlePnL !== \"function\") {\n return Promise.resolve();\n }\n return props.onSettlePnL().catch((e) => {});\n },\n });\n }, [t]);\n\n const clsName =\n props.totalUnrealizedROI > 0\n ? \"oui-text-success-darken\"\n : \"oui-text-danger-darken\";\n\n return (\n <Flex direction={\"column\"} gap={3} width={\"100%\"}>\n <Flex direction={\"column\"} itemAlign={\"start\"} width={\"100%\"}>\n <Text.formatted\n size=\"2xs\"\n intensity={36}\n suffix={\n props.hideAssets ? (\n <EyeIcon\n opacity={1}\n size={16}\n className=\"oui-text-primary-light\"\n />\n ) : (\n <EyeCloseIcon\n opacity={1}\n size={16}\n className=\"oui-text-primary-light\"\n />\n )\n }\n onClick={() => {\n props.toggleHideAssets();\n }}\n className=\"oui-cursor-pointer\"\n >\n {`${t(\"common.totalValue\")} (USDC)`}\n </Text.formatted>\n <Text.numeral\n size=\"base\"\n // coloring\n dp={2}\n padding={false}\n visible={!props.hideAssets}\n >\n {props.totalValue ?? \"--\"}\n </Text.numeral>\n </Flex>\n <Grid cols={2} rows={1} width={\"100%\"}>\n <Statistic\n label={`${t(\"common.unrealizedPnl\")} (USDC)`}\n classNames={{\n label: \"oui-text-2xs oui-text-base-contrast-36\",\n }}\n >\n <Flex gap={1}>\n <Text.numeral\n size=\"xs\"\n coloring\n dp={2}\n padding={false}\n visible={!props.hideAssets}\n >\n {props.aggregated.unrealPnL}\n </Text.numeral>\n {!props.hideAssets && (\n <Text.numeral\n size=\"xs\"\n dp={2}\n padding={false}\n rule=\"percentages\"\n prefix={\"(\"}\n suffix={\")\"}\n className={clsName}\n >\n {props.totalUnrealizedROI}\n </Text.numeral>\n )}\n </Flex>\n </Statistic>\n <Statistic\n label={`${t(\"trading.asset.unsettledPnl\")} (USDC)`}\n classNames={{\n label: \"oui-text-2xs oui-text-base-contrast-36\",\n }}\n >\n <Flex justify={\"between\"} width={\"100%\"}>\n <Text.numeral\n size=\"xs\"\n coloring\n dp={2}\n padding={false}\n visible={!props.hideAssets}\n >\n {props.aggregated.unsettledPnL}\n </Text.numeral>\n <button\n className=\"oui-flex oui-gap-1 oui-items-center\"\n onClick={onUnsettleClick}\n >\n <RefreshIcon\n opacity={1}\n size={12}\n className=\"oui-text-primary-light\"\n />\n <Text size=\"2xs\" color=\"primary\">\n {t(\"settle.settlePnl\")}\n </Text>\n </button>\n </Flex>\n </Statistic>\n </Grid>\n </Flex>\n );\n};\nconst MarginRatio: FC<PortfolioSheetState> = (props) => {\n const { t } = useTranslation();\n\n const { high, mid, low } = getMarginRatioColor(\n props.marginRatioVal,\n props.mmr,\n );\n\n return (\n <Grid cols={2} rows={1} width={\"100%\"}>\n <Statistic\n label={t(\"trading.asset.marginRatio\")}\n classNames={{\n label: \"oui-text-2xs oui-text-base-contrast-36\",\n }}\n >\n <Flex gap={2}>\n <Text.numeral\n size=\"xs\"\n rule=\"percentages\"\n color=\"primary\"\n dp={2}\n padding={false}\n visible={!props.hideAssets}\n >\n {props.marginRatioVal}\n </Text.numeral>\n {!props.hideAssets && (\n <RiskIndicator\n className={\n low\n ? \"oui-rotate-0\"\n : mid\n ? \"oui-rotate-90\"\n : high\n ? \"oui-rotate-180\"\n : \"\"\n }\n />\n )}\n </Flex>\n </Statistic>\n <Statistic\n label={`${t(\"trading.asset.free&TotalCollateral\")} (USDC)`}\n classNames={{\n label: \"oui-text-2xs oui-text-base-contrast-36\",\n }}\n >\n <Flex justify={\"start\"} width={\"100%\"} gap={1}>\n <Text.numeral\n size=\"xs\"\n dp={2}\n padding={false}\n visible={!props.hideAssets}\n >\n {props.freeCollateral}\n </Text.numeral>\n <Text size=\"xs\">/</Text>\n <Text.numeral\n size=\"xs\"\n dp={2}\n padding={false}\n visible={!props.hideAssets}\n >\n {props.totalCollateral}\n </Text.numeral>\n </Flex>\n </Statistic>\n </Grid>\n );\n};\n\nconst IconButton: React.FC<{\n Icon: React.ComponentType<any>;\n onClick: React.MouseEventHandler<SVGSVGElement>;\n disabled: boolean;\n}> = (props) => {\n const { Icon, onClick, disabled } = props;\n return (\n <Icon\n onClick={disabled ? undefined : onClick}\n className={cn(\n \"oui-text-white oui-m-2 oui-transition-all\",\n disabled\n ? \"oui-cursor-not-allowed oui-opacity-20\"\n : \"oui-cursor-pointer oui-opacity-100\",\n )}\n />\n );\n};\n\nconst LeverageInput: React.FC<PortfolioSheetState> = (props) => {\n const formatters = React.useMemo<InputFormatter[]>(\n () => [\n inputFormatter.numberFormatter,\n inputFormatter.currencyFormatter,\n inputFormatter.decimalPointFormatter,\n ],\n [],\n );\n const id = useId();\n return (\n <label\n htmlFor={id}\n className={cn(\n \"oui-w-full\",\n \"oui-rounded\",\n \"oui-bg-base-6\",\n \"oui-flex\",\n \"oui-items-center\",\n \"oui-justify-between\",\n \"oui-outline\",\n \"oui-outline-offset-0\",\n \"oui-outline-1\",\n \"oui-outline-transparent\",\n \"focus-within:oui-outline-primary-light\",\n \"oui-input-root\",\n )}\n >\n <IconButton\n Icon={ReduceIcon}\n onClick={props.onLeverageReduce}\n disabled={props.isReduceDisabled}\n />\n <Flex itemAlign=\"center\" justify=\"center\">\n <Input\n // {...props}\n value={props.value}\n id={id}\n autoComplete=\"off\"\n classNames={{\n input: cn(\"oui-text-center\"),\n root: cn(\n \"oui-text-center\",\n \"oui-w-6\",\n \"oui-px-0\",\n \"oui-outline\",\n \"oui-outline-offset-0\",\n \"oui-outline-1\",\n \"oui-outline-transparent\",\n \"focus-within:oui-outline-primary-none\",\n ),\n }}\n formatters={formatters}\n onChange={props.onInputChange}\n />\n <div className=\"oui-select-none\">x</div>\n </Flex>\n <IconButton\n Icon={PlusIcon}\n onClick={props.onLeverageIncrease}\n disabled={props.isIncreaseDisabled}\n />\n </label>\n );\n};\n\nexport const LeverageSelector: React.FC<PortfolioSheetState> = (props) => {\n const { value, onLeverageChange, onValueCommit } = props;\n return (\n <Flex itemAlign=\"center\" justify=\"between\" width={\"100%\"} mt={2}>\n {[1, 5, 10, 20, 50].map((option) => (\n <Flex\n key={option}\n itemAlign=\"center\"\n justify=\"center\"\n className={cn(\n `oui-transition-all oui-cursor-pointer oui-box-border oui-bg-clip-padding oui-px-3 oui-py-2.5 oui-rounded-md oui-border oui-border-solid`,\n value === option\n ? \"oui-border-primary oui-bg-base-6\"\n : \"oui-border-line-12\",\n )}\n onClick={() => {\n onLeverageChange(option);\n onValueCommit(option);\n }}\n >\n <Flex\n itemAlign=\"center\"\n justify=\"center\"\n className={cn(`oui-h-3 oui-w-9 oui-select-none`)}\n >\n {option}x\n </Flex>\n </Flex>\n ))}\n </Flex>\n );\n};\n\nconst Buttons: FC<PortfolioSheetState> = (props) => {\n const { t } = useTranslation();\n\n if (props.isMainAccount) {\n return (\n <Grid\n cols={props.hasSubAccount ? 3 : 2}\n rows={1}\n gap={3}\n className=\"oui-grid-row-[1fr,1fr]\"\n width={\"100%\"}\n pt={2}\n pb={4}\n >\n <Button\n icon={<ArrowDownShortIcon color=\"white\" opacity={0.8} />}\n size=\"md\"\n fullWidth\n onClick={props.onDeposit}\n >\n {t(\"common.deposit\")}\n </Button>\n {props.hasSubAccount && (\n <Button\n icon={<ArrowLeftRightIcon color=\"white\" opacity={0.8} />}\n color=\"gray\"\n size=\"md\"\n onClick={props.onTransfer}\n data-testid=\"oui-testid-assetView-transfer-button\"\n >\n <Text>{t(\"common.transfer\")}</Text>\n </Button>\n )}\n <Button\n icon={<ArrowUpShortIcon color=\"white\" opacity={0.8} />}\n size=\"md\"\n fullWidth\n className=\"oui-bg-base-2 hover:oui-bg-base-2/50\"\n onClick={props.onWithdraw}\n >\n {t(\"common.withdraw\")}\n </Button>\n </Grid>\n );\n }\n\n return (\n <Button\n fullWidth\n color=\"secondary\"\n size=\"md\"\n onClick={props.onTransfer}\n data-testid=\"oui-testid-assetView-transfer-button\"\n >\n <Text>{t(\"common.transfer\")}</Text>\n </Button>\n );\n};\n","import { useCallback, useMemo, useState } from \"react\";\nimport {\n useAccount,\n useCollateral,\n useDebouncedCallback,\n useEventEmitter,\n useLeverage,\n useMarginRatio,\n usePositionStream,\n} from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { modal, SliderMarks, toast } from \"@orderly.network/ui\";\nimport {\n DepositAndWithdrawWithSheetId,\n TransferSheetId,\n} from \"@orderly.network/ui-transfer\";\nimport { useTradingLocalStorage } from \"../../../hooks\";\n\nexport const usePortfolioSheetScript = () => {\n const { state, account, isMainAccount } = useAccount();\n const assets = useAssets();\n const marginRatio = useMarginRatioAndLeverage();\n const ee = useEventEmitter();\n const { t } = useTranslation();\n const subAccounts = state.subAccounts ?? [];\n\n const [showSliderTip, setShowSliderTip] = useState(false);\n\n const onSettlePnL = useCallback(async () => {\n return account\n .settle()\n .catch((e) => {\n if (e.code == -1104) {\n toast.error(t(\"settle.settlement.error\"));\n return Promise.reject(e);\n }\n if (\n e.message.indexOf(\n \"Signing off chain messages with Ledger is not yet supported\",\n ) !== -1\n ) {\n ee.emit(\"wallet:sign-message-with-ledger-error\", {\n message: e.message,\n userAddress: account.address,\n });\n return Promise.reject(e);\n }\n\n if (e?.code === \"ACTION_REJECTED\") {\n toast.error(t(\"connector.userRejected\"));\n return Promise.reject(e);\n }\n })\n .then((res) => {\n toast.success(t(\"settle.settlement.requested\"));\n return Promise.resolve(res);\n });\n }, [account, t]);\n\n const onDeposit = useCallback(() => {\n modal.show(DepositAndWithdrawWithSheetId, {\n activeTab: \"deposit\",\n });\n }, []);\n\n const onWithdraw = useCallback(() => {\n modal.show(DepositAndWithdrawWithSheetId, {\n activeTab: \"withdraw\",\n });\n }, []);\n\n const onTransfer = useCallback(() => {\n modal.show(TransferSheetId);\n }, []);\n\n return {\n ...assets,\n ...marginRatio,\n onSettlePnL,\n onDeposit,\n onWithdraw,\n showSliderTip,\n setShowSliderTip,\n isMainAccount,\n onTransfer,\n hasSubAccount: subAccounts?.length > 0,\n };\n};\n\nconst useAssets = () => {\n const { hideAssets, setHideAssets } = useTradingLocalStorage();\n const toggleHideAssets = () => {\n setHideAssets(!hideAssets);\n };\n const { totalCollateral, freeCollateral, totalValue, availableBalance } =\n useCollateral({\n dp: 2,\n });\n return {\n hideAssets,\n toggleHideAssets,\n totalCollateral,\n freeCollateral,\n totalValue,\n availableBalance,\n };\n};\n\nconst useMarginRatioAndLeverage = () => {\n const { t } = useTranslation();\n const [{ aggregated, totalUnrealizedROI }, positionsInfo] =\n usePositionStream();\n const { marginRatio, currentLeverage, mmr } = useMarginRatio();\n\n const marginRatioVal = useMemo(() => {\n return Math.min(\n 10,\n aggregated.notional === 0\n ? positionsInfo[\"margin_ratio\"](10)!\n : marginRatio,\n );\n }, [marginRatio, aggregated]);\n\n const { update, curLeverage, maxLeverage, leverageLevers } = useLeverage();\n\n const marks = useMemo<SliderMarks>(() => {\n return leverageLevers?.map((e) => ({\n label: `${e}x`,\n value: e,\n }));\n }, [leverageLevers]);\n\n const [leverage, setLeverage] = useState<number>(curLeverage ?? 0);\n\n const step = 100 / ((marks?.length || 0) - 1);\n\n // const leverageValue = useMemo(() => {\n // const index = leverageLevers.findIndex((item: any) => item === leverage);\n\n // return index * step;\n // }, [leverageLevers, leverage, step]);\n\n const onLeverageChange = (leverage: number) => {\n // maxLeverage / 100 * leverage;\n setLeverage(leverage);\n // updateLeverage(leverage);\n };\n\n const onSave = async (leverage: number) => {\n try {\n update({ leverage }).then(\n () => {\n toast.success(t(\"leverage.updated\"));\n },\n (err: Error) => {\n toast.error(err.message);\n },\n );\n } catch {\n //\n }\n };\n\n const onValueCommit = useCallback((value: number | number[]) => {\n onSave(Array.isArray(value) ? value[0] : value);\n }, []);\n\n const debouncedCommit = useDebouncedCallback(onValueCommit, 500);\n\n const onInputChange = useCallback<React.ChangeEventHandler<HTMLInputElement>>(\n (e) => {\n const parsed = Number.parseInt(e.target.value, 10);\n const raw = Number.isNaN(parsed) ? 0 : parsed;\n const clamped = Math.min(Math.max(raw, 1), maxLeverage);\n setLeverage(clamped);\n debouncedCommit(clamped);\n },\n [debouncedCommit, maxLeverage],\n );\n\n const onLeverageIncrease: React.MouseEventHandler<SVGSVGElement> = () => {\n setLeverage((prev) => {\n onSave(prev + 1);\n return prev + 1;\n });\n };\n\n const onLeverageReduce: React.MouseEventHandler<SVGSVGElement> = () => {\n setLeverage((prev) => {\n onSave(prev - 1);\n return prev - 1;\n });\n };\n\n return {\n aggregated,\n totalUnrealizedROI,\n positionsInfo,\n marginRatio,\n marginRatioVal,\n mmr,\n currentLeverage,\n step,\n marks,\n onLeverageChange,\n onLeverageIncrease,\n onLeverageReduce,\n onInputChange,\n isReduceDisabled: leverage <= 1,\n isIncreaseDisabled: leverage >= maxLeverage,\n onValueCommit,\n value: leverage,\n maxLeverage,\n onSaveLeverage: onSave,\n };\n};\n\nexport function getMarginRatioColor(marginRatio: number, mmr: number | null) {\n if (mmr === null) {\n return { isRed: false, isYellow: false, isGreen: true };\n }\n const imr = mmr * 2;\n\n const high = marginRatio <= imr;\n const mid = marginRatio > imr && marginRatio < 1;\n const low = marginRatio >= 1;\n return { high, mid, low };\n}\n\nexport type PortfolioSheetState = ReturnType<typeof usePortfolioSheetScript>;\n","import { FC } from \"react\";\nimport { cn } from \"@orderly.network/ui\";\n\ninterface RiskIndicatorProps {\n size?: number;\n className?: string;\n}\n\nexport const RiskIndicator: FC<RiskIndicatorProps> = (props) => {\n const { size = 20, className } = props;\n\n return (\n <div\n className=\"oui-flex oui-justify-center oui-items-end\"\n style={{\n background: \"url(/images/riskLevelBg.png)\",\n backgroundSize: \"contain\",\n backgroundRepeat: \"no-repeat\",\n backgroundPosition: \"center bottom\",\n width: `${size}px`,\n height: `14px`,\n }}\n >\n <div\n className={cn(\n \"oui-relative oui-w-[2px] oui-h-[2px] oui-rounded-full oui-bg-white after:oui-block after:oui-content-[''] after:oui-absolute after:oui-right-0 after:oui-w-[10px] after:oui-h-[2px] after:oui-bg-white/50\",\n className\n // {\n // \"oui-rotate-0\": value > 1,\n // \"oui-rotate-90\": value >= 0.05 && value <= 1,\n // \"oui-rotate-180\": value < 0.05,\n // }\n )}\n ></div>\n </div>\n );\n};\n","import { usePortfolioSheetScript } from \"./portfolioSheet.script\";\nimport { PortfolioSheet } from \"./portfolioSheet.ui\";\n\nexport const PortfolioSheetWidget = () => {\n const state = usePortfolioSheetScript();\n return <PortfolioSheet {...state} />;\n};\n","export {\n useFundingRateModalScript,\n type FundingRateModalState,\n} from \"./fundingRateModal.script\";\nexport { FundingRateModal } from \"./fundingRateModal.ui\";\nexport {\n FundingRateModalWidget,\n FundingRateDialogId,\n FundingRateSheetId,\n} from \"./fundingRateModal.widget\";\n","import { FC } from \"react\";\nimport { useScreen } from \"@orderly.network/ui\";\nimport type { TradingState } from \"./trading.script\";\nimport { DesktopLayout } from \"./trading.ui.desktop\";\nimport { MobileLayout } from \"./trading.ui.mobile\";\n\nexport const Trading: FC<TradingState> = (props) => {\n const { isMobile } = useScreen();\n\n if (isMobile) {\n return <MobileLayout {...props} />;\n }\n\n return (\n <DesktopLayout\n className=\"oui-h-[calc(100vh_-_48px_-_29px)] oui-bg-base-10\"\n {...props}\n />\n );\n};\n","import React, { useMemo } from \"react\";\nimport { useLocalStorage } from \"@orderly.network/hooks\";\nimport {\n SideMarketsWidget,\n SymbolInfoBarFullWidget,\n} from \"@orderly.network/markets\";\nimport { TradingviewFullscreenKey } from \"@orderly.network/types\";\nimport { Box, cn, Flex } from \"@orderly.network/ui\";\nimport { OrderEntryWidget } from \"@orderly.network/ui-order-entry\";\nimport { TradingviewWidget } from \"@orderly.network/ui-tradingview\";\nimport { DepositStatusWidget } from \"@orderly.network/ui-transfer\";\nimport { RemovablePanel } from \"../../components/desktop/layout/removablePanel\";\nimport { SplitLayout } from \"../../components/desktop/layout/splitLayout\";\nimport {\n dataListInitialHeight,\n getOffsetSizeNum,\n TradingState,\n} from \"./trading.script\";\nimport {\n scrollBarWidth,\n topBarHeight,\n bottomBarHeight,\n space,\n symbolInfoBarHeight,\n orderEntryMinWidth,\n orderEntryMaxWidth,\n orderbookMinWidth,\n orderbookMaxWidth,\n orderbookMinHeight,\n orderbookMaxHeight,\n tradindviewMinHeight,\n tradingViewMinWidth,\n dataListMaxHeight,\n} from \"./trading.script\";\n\nconst LazyRiskRateWidget = React.lazy(() =>\n import(\"../../components/desktop/riskRate\").then((mod) => {\n return {\n default: mod.RiskRateWidget,\n };\n }),\n);\n\nconst LazyAssetViewWidget = React.lazy(() =>\n import(\"../../components/desktop/assetView\").then((mod) => {\n return {\n default: mod.AssetViewWidget,\n };\n }),\n);\n\nconst LazyDataListWidget = React.lazy(() =>\n import(\"../../components/desktop/dataList\").then((mod) => {\n return {\n default: mod.DataListWidget,\n };\n }),\n);\n\nconst LazySwitchLayout = React.lazy(() =>\n import(\"../../components/desktop/layout/switchLayout\").then((mod) => {\n return {\n default: mod.SwitchLayout,\n };\n }),\n);\n\nconst LazyOrderBookAndTradesWidget = React.lazy(() =>\n import(\"../../components/desktop/orderBookAndTrades\").then((mod) => {\n return {\n default: mod.OrderBookAndTradesWidget,\n };\n }),\n);\n\nexport type DesktopLayoutProps = TradingState & {\n className?: string;\n};\n\nexport const DesktopLayout: React.FC<DesktopLayoutProps> = (props) => {\n const {\n resizeable,\n panelSize,\n onPanelSizeChange,\n layout,\n onLayout,\n orderBookSplitSize,\n setOrderbookSplitSize,\n dataListSplitSize,\n setDataListSplitSize,\n mainSplitSize,\n setMainSplitSize,\n dataListSplitHeightSM,\n setDataListSplitHeightSM,\n orderBookSplitHeightSM,\n setOrderbookSplitHeightSM,\n max2XL,\n max4XL,\n animating,\n setAnimating,\n positions,\n updatePositions,\n showPositionIcon,\n horizontalDraggable,\n marketsWidth,\n tradindviewMaxHeight,\n dataListMinHeight,\n } = props;\n\n const [tradingViewFullScreen] = useLocalStorage(\n TradingviewFullscreenKey,\n false,\n );\n\n const minScreenHeight = useMemo(() => {\n return tradingViewFullScreen\n ? 0\n : symbolInfoBarHeight +\n orderbookMaxHeight +\n dataListInitialHeight +\n space * 4;\n }, [tradingViewFullScreen]);\n\n const minScreenHeightSM =\n topBarHeight +\n bottomBarHeight +\n symbolInfoBarHeight +\n tradindviewMinHeight +\n orderbookMinHeight +\n dataListMinHeight +\n space * 4;\n\n const marketsWidget = (\n <SideMarketsWidget\n resizeable={resizeable}\n panelSize={panelSize}\n onPanelSizeChange={onPanelSizeChange as any}\n symbol={props.symbol}\n onSymbolChange={props.onSymbolChange}\n />\n );\n\n const marketsView = (\n <Box\n intensity={900}\n pt={3}\n r=\"2xl\"\n height=\"100%\"\n width={marketsWidth}\n style={{ minWidth: marketsWidth }}\n className=\"oui-transition-all oui-duration-150\"\n onTransitionEnd={() => setAnimating(false)}\n >\n {!animating && marketsWidget}\n </Box>\n );\n\n const symbolInfoBarView = (\n <Box\n intensity={900}\n r=\"2xl\"\n px={3}\n width=\"100%\"\n style={{\n minHeight: symbolInfoBarHeight,\n height: symbolInfoBarHeight,\n }}\n >\n <SymbolInfoBarFullWidget\n symbol={props.symbol}\n onSymbolChange={props.onSymbolChange}\n trailing={\n <React.Suspense fallback={null}>\n <LazySwitchLayout layout={layout} onLayout={onLayout} />\n </React.Suspense>\n }\n />\n </Box>\n );\n\n const { library_path, ...restTradingViewConfig } = props.tradingViewConfig;\n\n const tradingviewWidget = (\n <TradingviewWidget\n classNames={{\n root: cn(\n tradingViewFullScreen\n ? \"!oui-absolute oui-top-0 oui-left-0 oui-right-0 oui-bottom-0 oui-z-[40] oui-bg-base-10\"\n : \"oui-z-1\",\n ),\n content: cn(\n tradingViewFullScreen\n ? \"oui-top-3 oui-bottom-3 oui-left-3 oui-right-3 oui-bg-base-9 oui-rounded-[16px] oui-overflow-hidden\"\n : \"\",\n ),\n }}\n symbol={props.symbol}\n {...restTradingViewConfig}\n libraryPath={library_path}\n />\n );\n\n const tradingView = (\n <Box\n width=\"100%\"\n height=\"100%\"\n intensity={900}\n r=\"2xl\"\n style={{ flex: 1, minWidth: tradingViewMinWidth }}\n className=\"oui-overflow-hidden\"\n >\n {tradingviewWidget}\n </Box>\n );\n\n const orderbookWidget = (\n <React.Suspense fallback={null}>\n <LazyOrderBookAndTradesWidget symbol={props.symbol} />\n </React.Suspense>\n );\n\n const orderbookView = (\n <Box\n r=\"2xl\"\n height=\"100%\"\n style={{\n minWidth: orderbookMinWidth,\n maxWidth: horizontalDraggable ? orderbookMaxWidth : orderbookMinWidth,\n width: orderBookSplitSize,\n }}\n className=\"oui-overflow-hidden\"\n >\n {orderbookWidget}\n </Box>\n );\n\n const dataListWidget = (\n <React.Suspense fallback={null}>\n <LazyDataListWidget\n current={undefined}\n symbol={props.symbol}\n sharePnLConfig={props.sharePnLConfig}\n />\n </React.Suspense>\n );\n\n const dataListView = (\n <Box\n intensity={900}\n r=\"2xl\"\n p={2}\n style={{\n height: dataListSplitSize,\n // height: `calc(100% - ${symbolInfoBarHeight}px - ${orderbookMaxHeight}px - ${space}px)`,\n minHeight: dataListInitialHeight,\n // minHeight: `max(${dataListMinHeight}px, calc(100vh - ${symbolInfoBarHeight}px - ${orderbookMaxHeight}px - ${space}px))`,\n }}\n className=\"oui-overflow-hidden\"\n >\n {dataListWidget}\n </Box>\n );\n\n const assetsOrderEntryMargin = [\n <RemovablePanel\n key=\"margin\"\n index={positions.findIndex((item) => item === 0)}\n onLayout={updatePositions}\n showIndicator={showPositionIcon}\n >\n <React.Suspense fallback={null}>\n <LazyRiskRateWidget />\n </React.Suspense>\n </RemovablePanel>,\n <RemovablePanel\n key=\"assets\"\n className=\"oui-border oui-border-line-12\"\n index={positions.findIndex((item) => item === 1)}\n onLayout={updatePositions}\n showIndicator={showPositionIcon}\n >\n <>\n <React.Suspense fallback={null}>\n <LazyAssetViewWidget isFirstTimeDeposit={props.isFirstTimeDeposit} />\n </React.Suspense>\n <DepositStatusWidget\n className=\"oui-mt-3 oui-gap-y-2\"\n onClick={props.navigateToPortfolio}\n />\n </>\n </RemovablePanel>,\n <RemovablePanel\n key=\"orderEntry\"\n index={positions.findIndex((item) => item === 2)}\n onLayout={updatePositions}\n showIndicator={showPositionIcon}\n >\n <OrderEntryWidget\n symbol={props.symbol}\n disableFeatures={\n props.disableFeatures as unknown as (\"slippageSetting\" | \"feesInfo\")[]\n }\n />\n </RemovablePanel>,\n ];\n\n const orderEntryWidget = positions.map(\n (index) => assetsOrderEntryMargin[index],\n );\n\n const orderEntryView = (\n <Flex\n gapY={2}\n direction=\"column\"\n height=\"100%\"\n style={{\n minWidth: orderEntryMinWidth,\n maxWidth: horizontalDraggable ? orderEntryMaxWidth : orderEntryMinWidth,\n width: mainSplitSize,\n }}\n >\n {orderEntryWidget}\n </Flex>\n );\n\n const renderTradingView = () => {\n if (max4XL && layout === \"right\") {\n return (\n <Flex\n gap={2}\n className=\"oui-flex-1 oui-overflow-hidden\"\n style={{ minWidth: marketsWidth + tradingViewMinWidth + space }}\n >\n {marketsView}\n {tradingView}\n </Flex>\n );\n }\n\n return tradingView;\n };\n\n const tradingViewAndOrderbookView = (\n <SplitLayout\n style={{\n // the style width is not set, and a child node style needs to be set to flex: 1 to adapt\n flex: 1,\n minHeight: orderbookMinHeight,\n // maxHeight: orderbookMaxHeight,\n }}\n onSizeChange={setOrderbookSplitSize}\n disable={!horizontalDraggable}\n >\n {renderTradingView()}\n {orderbookView}\n </SplitLayout>\n );\n\n const renderTradingViewAndOrderbookView = () => {\n if (max4XL && layout === \"left\") {\n return (\n <Flex gapX={2} style={{ minHeight: orderbookMinHeight }} height=\"100%\">\n {tradingViewAndOrderbookView}\n {marketsView}\n </Flex>\n );\n }\n return tradingViewAndOrderbookView;\n };\n\n const mainView = (\n <Flex\n direction=\"column\"\n className=\"oui-flex-1 oui-overflow-hidden\"\n gap={2}\n style={{\n minWidth: max4XL\n ? marketsWidth + tradingViewMinWidth + orderbookMinWidth + space * 2\n : tradingViewMinWidth + orderbookMinWidth + space,\n }}\n >\n {symbolInfoBarView}\n <SplitLayout\n style={{\n // height: orderbookMaxHeight + dataListInitialHeight + space,\n maxHeight: `calc(100% - ${symbolInfoBarHeight}px - ${space}px)`,\n }}\n className=\"oui-w-full\"\n mode=\"vertical\"\n onSizeChange={setDataListSplitSize}\n >\n {renderTradingViewAndOrderbookView()}\n {dataListView}\n </SplitLayout>\n </Flex>\n );\n\n const onSizeChange = (width: string) =>\n layout === \"left\"\n ? setMainSplitSize(getOffsetSizeNum(width))\n : setMainSplitSize(width);\n\n if (max2XL) {\n return (\n <SplitLayout\n ref={props.max2XLSplitRef}\n style={{\n minHeight: minScreenHeightSM,\n minWidth: 1024 - scrollBarWidth,\n // height: props.extraHeight ? props.extraHeight : undefined,\n }}\n className={cn(\n \"oui-flex oui-flex-1\",\n \"oui-size-full oui-min-w-[1018px]\",\n \"oui-px-3 oui-py-2\",\n props.className,\n )}\n onSizeChange={setDataListSplitHeightSM}\n onDragging={props.onDataListSplitHeightDragging}\n mode=\"vertical\"\n >\n <Flex\n gapX={2}\n itemAlign=\"stretch\"\n className={cn(\n \"oui-flex-1\",\n layout === \"left\" && \"oui-flex-row-reverse\",\n )}\n style={{\n minHeight: Math.max(\n symbolInfoBarHeight +\n tradindviewMinHeight +\n orderbookMinHeight +\n space * 2,\n props.orderEntryHeight,\n ),\n maxHeight:\n symbolInfoBarHeight +\n tradindviewMaxHeight +\n orderbookMaxHeight +\n space * 2,\n }}\n >\n <Flex\n height=\"100%\"\n className=\"oui-w-[calc(100%_-_280px_-_12px)] oui-flex-1\"\n direction=\"column\"\n gapY={2}\n >\n {symbolInfoBarView}\n <Flex\n width=\"100%\"\n height=\"100%\"\n gapX={2}\n itemAlign=\"stretch\"\n style={{\n minHeight: tradindviewMinHeight + orderbookMinHeight + space,\n maxHeight: tradindviewMaxHeight + orderbookMaxHeight + space,\n }}\n className={cn(\n \"oui-flex-1\",\n layout === \"left\" && \"oui-flex-row-reverse\",\n )}\n >\n <Box\n intensity={900}\n pt={3}\n r=\"2xl\"\n width={marketsWidth}\n style={{\n minHeight: tradindviewMinHeight + orderbookMinHeight + space,\n maxHeight: tradindviewMaxHeight + orderbookMaxHeight + space,\n }}\n >\n {marketsWidget}\n </Box>\n <SplitLayout\n ref={props.tradingviewAndOrderbookSplitRef}\n mode=\"vertical\"\n style={{ width: `calc(100% - ${marketsWidth}px)` }}\n className=\"oui-flex-1\"\n onSizeChange={setOrderbookSplitHeightSM}\n onDragging={props.onTradingviewAndOrderbookDragging}\n >\n <Box\n width=\"100%\"\n intensity={900}\n r=\"2xl\"\n style={{\n minHeight: tradindviewMinHeight,\n maxHeight: tradindviewMaxHeight,\n height: 1200,\n }}\n >\n {tradingviewWidget}\n </Box>\n\n <Box\n r=\"2xl\"\n height=\"100%\"\n width=\"100%\"\n style={{\n minHeight: orderbookMinHeight,\n maxHeight: orderbookMaxHeight,\n height: orderBookSplitHeightSM,\n }}\n className=\"oui-flex-1\"\n >\n {orderbookWidget}\n </Box>\n </SplitLayout>\n </Flex>\n </Flex>\n <Flex\n ref={props.orderEntryViewRef}\n id=\"orderEntryView\"\n gapY={3}\n direction=\"column\"\n className=\"oui-relative\"\n style={{\n width: orderEntryMinWidth,\n // force order entry render actual content height\n height: \"max-content\",\n // height:\n // props.extraHeight && props.extraHeight > 100\n // ? undefined\n // : \"max-content\",\n }}\n >\n {orderEntryWidget}\n <Box height={props.extraHeight} />\n </Flex>\n </Flex>\n\n <Box\n intensity={900}\n r=\"2xl\"\n p={2}\n style={{\n height: dataListSplitHeightSM,\n minHeight: Math.max(dataListMinHeight, props.dataListHeight),\n maxHeight: dataListMaxHeight,\n }}\n className=\"oui-overflow-hidden\"\n >\n {dataListWidget}\n </Box>\n </SplitLayout>\n );\n }\n\n return (\n <Flex\n style={{\n minHeight: minScreenHeight,\n minWidth: 1440 - scrollBarWidth,\n }}\n className={cn(\n props.className,\n layout === \"left\" && \"oui-flex-row-reverse\",\n tradingViewFullScreen &&\n \"oui-relative oui-w-screen oui-h-[calc(100vh-80px)] !oui-p-0 oui-overflow-hidden\",\n )}\n width=\"100%\"\n p={2}\n gap={2}\n >\n {!max4XL && marketsView}\n <SplitLayout\n className={cn(\n \"oui-flex oui-flex-1 oui-overflow-hidden\",\n // layout === \"left\" ? \"oui-flex-row-reverse\" : \"oui-flex-row\",\n )}\n onSizeChange={onSizeChange}\n disable={!horizontalDraggable}\n >\n {layout === \"left\" && orderEntryView}\n {mainView}\n {layout === \"right\" && orderEntryView}\n </SplitLayout>\n </Flex>\n );\n};\n","import React, { FC, PropsWithChildren, SVGProps, useState } from \"react\";\nimport { Box, cn, Flex, Tooltip } from \"@orderly.network/ui\";\n\nexport type RemovablePanelProps = {\n className?: string;\n index: number;\n onLayout: (currentIdx: number, targetIdx: number) => void;\n showIndicator?: boolean;\n};\n\nexport const RemovablePanel: React.FC<\n PropsWithChildren<RemovablePanelProps>\n> = (props) => {\n const { showIndicator = true } = props;\n const [open, setOpen] = useState(false);\n return (\n <Box\n intensity={900}\n r=\"2xl\"\n p={3}\n width=\"100%\"\n className={cn(\"oui-relative\", props.className)}\n >\n {props.children}\n <Tooltip\n open={open}\n onOpenChange={setOpen}\n side=\"left\"\n align=\"start\"\n sideOffset={-4}\n alignOffset={-4}\n content={\n <Flex direction=\"column\" gapY={2}>\n {[TopIcon, MiddleIcon, BottomIcon].map((Icon, idx) => (\n <Icon\n key={idx}\n className={cn(\n \"oui-rounded oui-cursor-pointer hover:oui-bg-base-5\",\n props.index === idx && \"oui-bg-base-5\",\n )}\n onClick={() => {\n props.onLayout?.(props.index, idx);\n setOpen(false);\n }}\n />\n ))}\n </Flex>\n }\n delayDuration={0}\n className={cn(\n \"oui-bg-base-9 oui-rounded\",\n \"oui-border oui-border-line-12\",\n \"oui-p-1\",\n )}\n arrow={{ className: \"oui-fill-transparent\" }}\n >\n {showIndicator && (\n <div className=\"oui-absolute oui-right-[1px] oui-top-[18px]\">\n <IndicatorIcon\n className={cn(\n \"oui-text-base-contrast-20 hover:oui-text-base-contrast-80\",\n \"oui-cursor-pointer\",\n )}\n />\n </div>\n )}\n </Tooltip>\n </Box>\n );\n};\n\nexport const IndicatorIcon: FC<SVGProps<SVGSVGElement>> = (props) => (\n <svg\n width=\"10\"\n height=\"16\"\n viewBox=\"0 0 10 16\"\n fill=\"currentColor\"\n xmlns=\"http://www.w3.org/2000/svg\"\n {...props}\n >\n <rect x=\"2\" y=\"2\" width=\"6\" height=\"2\" rx=\"1\" />\n <rect x=\"2\" y=\"7\" width=\"6\" height=\"2\" rx=\"1\" />\n <rect x=\"2\" y=\"12\" width=\"6\" height=\"2\" rx=\"1\" />\n </svg>\n);\n\nexport const TopIcon: FC<SVGProps<SVGSVGElement>> = (props) => (\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 {...props}\n >\n <rect\n x=\"1.333\"\n y=\"2.667\"\n width=\"13.333\"\n height=\"4\"\n rx=\"2\"\n fill=\"rgb(var(--oui-color-primary))\"\n />\n <rect\n x=\"2.667\"\n y=\"12\"\n width=\"10.667\"\n height=\"1.333\"\n rx=\".667\"\n fill=\"#fff\"\n fillOpacity=\".2\"\n />\n <rect\n x=\"2.667\"\n y=\"8.667\"\n width=\"10.667\"\n height=\"1.333\"\n rx=\".667\"\n fill=\"#fff\"\n fillOpacity=\".2\"\n />\n </svg>\n);\n\nexport const MiddleIcon: FC<SVGProps<SVGSVGElement>> = (props) => (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n {...props}\n >\n <rect\n x=\"1.333\"\n y=\"6\"\n width=\"13.333\"\n height=\"4\"\n rx=\"2\"\n fill=\"rgb(var(--oui-color-primary))\"\n />\n <rect\n x=\"2.667\"\n y=\"12\"\n width=\"10.667\"\n height=\"1.333\"\n rx=\".667\"\n fill=\"#fff\"\n fillOpacity=\".2\"\n />\n <rect\n x=\"2.667\"\n y=\"2.667\"\n width=\"10.667\"\n height=\"1.333\"\n rx=\".667\"\n fill=\"#fff\"\n fillOpacity=\".2\"\n />\n </svg>\n);\n\nexport const BottomIcon: FC<SVGProps<SVGSVGElement>> = (props) => (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n {...props}\n >\n <rect\n x=\"1.333\"\n y=\"9.333\"\n width=\"13.333\"\n height=\"4\"\n rx=\"2\"\n fill=\"rgb(var(--oui-color-primary))\"\n />\n <rect\n x=\"2.667\"\n y=\"6\"\n width=\"10.667\"\n height=\"1.333\"\n rx=\".667\"\n fill=\"#fff\"\n fillOpacity=\".2\"\n />\n <rect\n x=\"2.667\"\n y=\"2.667\"\n width=\"10.667\"\n height=\"1.333\"\n rx=\".667\"\n fill=\"#fff\"\n fillOpacity=\".2\"\n />\n </svg>\n);\n","import { RefObject, useEffect, useMemo, useRef, useState } from \"react\";\nimport Split from \"@uiw/react-split\";\nimport {\n useAccount,\n useCollateral,\n useLocalStorage,\n useMediaQuery,\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 { modal } from \"@orderly.network/ui\";\nimport type { LayoutPosition } from \"../../components/desktop/layout/switchLayout\";\nimport { useSplitPersistent } from \"../../components/desktop/layout/useSplitPersistent\";\nimport { PortfolioSheetWidget } from \"../../components/mobile/portfolioSheet\";\nimport { useTradingLocalStorage } from \"../../hooks/\";\nimport { useTradingPageContext } from \"../../provider/tradingPageContext\";\nimport { TradingPageState } from \"../../types/types\";\nimport { useFirstTimeDeposit } from \"./hooks/useFirstTimeDeposit\";\n\nexport type TradingState = ReturnType<typeof useTradingScript>;\n\nexport const scrollBarWidth = 6;\nexport const topBarHeight = 48;\nexport const bottomBarHeight = 29;\nexport const space = 8;\nexport const symbolInfoBarHeight = 54;\n\nexport const orderEntryMinWidth = 280;\nexport const orderEntryMaxWidth = 360;\n\nexport const orderbookMinWidth = 280;\nexport const orderbookMaxWidth = 732;\n\nexport const orderbookMinHeight = 464;\nexport const orderbookMaxHeight = 728;\n\nexport const tradindviewMinHeight = 320;\n\nexport const tradingViewMinWidth = 540;\n\nexport const dataListMaxHeight = 800;\nexport const dataListInitialHeight = 350;\n\nconst ORDERLY_ORDER_ENTRY_SIDE_MARKETS_LAYOUT =\n \"orderly_order_entry_side_markets_layout\";\n\nconst ORDERLY_SIDE_MARKETS_MODE_KEY = \"orderly_side_markets_mode\";\n\nexport const useTradingScript = () => {\n const [openMarketsSheet, setOpenMarketsSheet] = useState(false);\n const props = useTradingPageContext();\n const { state } = useAccount();\n const { t } = useTranslation();\n const { wrongNetwork, disabledConnect, restrictedInfo, onRouteChange } =\n useAppContext();\n const { hideAssets, setHideAssets } = useTradingLocalStorage();\n\n const isFirstTimeDeposit = useFirstTimeDeposit();\n\n const { totalValue } = useCollateral();\n\n const total = useDataTap(totalValue);\n\n /** max-width: 1279px */\n const max2XL = useMediaQuery(\"(max-width: 1279px)\");\n\n /** min-width: 1440px */\n const min3XL = useMediaQuery(\"(min-width: 1440px)\");\n\n /** max-width: 1680px */\n const max4XL = useMediaQuery(\"(max-width: 1680px)\");\n\n // Order entry and side market list position, default Order entry in right\n const [layout, setLayout] = useLocalStorage<LayoutPosition>(\n ORDERLY_ORDER_ENTRY_SIDE_MARKETS_LAYOUT,\n \"right\",\n );\n\n const canTrade = useMemo<boolean>(() => {\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 onShowPortfolioSheet = () => {\n if (canTrade) {\n modal.sheet({\n title: t(\"trading.asset&Margin\"),\n leading: props.bottomSheetLeading,\n content: <PortfolioSheetWidget />,\n });\n }\n };\n\n const horizontalDraggable = useMemo(() => min3XL, [min3XL]);\n\n const positionsState = useOrderEntryPositions({\n canTrade,\n isFirstTimeDeposit,\n });\n\n const marketsCollapseState = useMarketsCollapse({ resizeable: min3XL });\n\n const observerState = useObserverOrderEntry({ max2XL });\n\n const marketsWidth = useMemo(() => {\n switch (marketsCollapseState.panelSize) {\n case \"small\":\n return 0;\n case \"middle\":\n return 70;\n case \"large\":\n return 280;\n default:\n return 0;\n }\n }, [marketsCollapseState.panelSize]);\n\n const tradindviewMaxHeight = max2XL ? 1200 : 600;\n\n const dataListMinHeight = canTrade ? 379 : 277;\n\n const splitSizeState = useSplitSize({ dep: layout });\n\n const tradingViewHeightState = useExtraHeight({\n orderEntryViewRef: observerState.orderEntryViewRef,\n tradindviewMaxHeight,\n dataListMinHeight,\n });\n\n const navigateToPortfolio =\n typeof onRouteChange === \"function\"\n ? () => onRouteChange({ href: \"/portfolio\", name: t(\"common.portfolio\") })\n : undefined;\n\n const map = {\n layout,\n onLayout: setLayout,\n max2XL,\n min3XL,\n max4XL,\n canTrade,\n openMarketsSheet,\n onOpenMarketsSheetChange: setOpenMarketsSheet,\n horizontalDraggable,\n ...marketsCollapseState,\n ...positionsState,\n ...splitSizeState,\n ...observerState,\n restrictedInfo,\n ...tradingViewHeightState,\n marketsWidth,\n tradindviewMaxHeight,\n dataListMinHeight,\n total,\n hideAssets,\n setHideAssets,\n onShowPortfolioSheet,\n navigateToPortfolio,\n isFirstTimeDeposit,\n };\n\n return { ...props, ...map } as TradingPageState & typeof map;\n};\n\nconst useMarketsCollapse = (options: { resizeable: boolean }) => {\n const { resizeable } = options;\n const [animating, setAnimating] = useState(false);\n\n const [panelSize, setPanelSize] = useLocalStorage<\n \"small\" | \"middle\" | \"large\"\n >(ORDERLY_SIDE_MARKETS_MODE_KEY, \"large\");\n\n const onPanelSizeChange = (collapsed: \"small\" | \"middle\" | \"large\") => {\n setPanelSize(collapsed);\n setAnimating(true);\n };\n\n const memoizedPanelSize = useMemo<\"small\" | \"middle\" | \"large\">(() => {\n // under 1440px markets force collapsed\n return resizeable ? panelSize : \"middle\";\n }, [resizeable, panelSize]);\n\n return {\n resizeable: resizeable,\n panelSize: memoizedPanelSize,\n onPanelSizeChange: onPanelSizeChange,\n animating: animating,\n setAnimating: setAnimating,\n } as const;\n};\n\nconst useOrderEntryPositions = (options: {\n canTrade: boolean;\n isFirstTimeDeposit: boolean;\n}) => {\n const { canTrade, isFirstTimeDeposit } = options;\n\n const [positions, setPositions] = useLocalStorage(\n \"orderly_assets_orderEntry_margin_positions\",\n [0, 1, 2],\n );\n\n const updatePositions = (currentIdx: number, targetIdx: number) => {\n const pos = [...positions];\n // [0,1,2] => [1,2,0]\n if (currentIdx === 0 && targetIdx === pos.length - 1) {\n pos[targetIdx] = positions[currentIdx];\n for (let i = 0; i < pos.length - 1; i++) {\n pos[i] = positions[i + 1];\n }\n\n // [0,1,2] => [2,0,1]\n } else if (currentIdx === pos.length - 1 && targetIdx === 0) {\n pos[targetIdx] = positions[currentIdx];\n for (let i = 1; i < pos.length; i++) {\n pos[i] = positions[i - 1];\n }\n } else {\n // [0,1,2] => [1,0,2], [0,1,2] => [0,2,1]\n [pos[currentIdx], pos[targetIdx]] = [pos[targetIdx], pos[currentIdx]];\n }\n setPositions(pos);\n };\n\n const showPositionIcon = useMemo(\n () => canTrade && !isFirstTimeDeposit,\n [canTrade, isFirstTimeDeposit],\n );\n\n const pos = useMemo(() => {\n return showPositionIcon ? (positions as number[]) : [0, 1, 2];\n }, [showPositionIcon, positions]);\n\n return {\n positions: pos,\n showPositionIcon,\n updatePositions,\n };\n};\n\nconst useSplitSize = (options: { dep: any }) => {\n const { dep } = options;\n const [mainSplitSize, setMainSplitSize] = useSplitPersistent(\n \"orderly_main_split_size\",\n `${orderEntryMinWidth}px`,\n dep,\n );\n const [dataListSplitSize, setDataListSplitSize] = useSplitPersistent(\n \"orderly_datalist_split_size\",\n `${dataListInitialHeight}px`,\n // undefined,\n );\n const [orderBookSplitSize, setOrderbookSplitSize] = useSplitPersistent(\n \"orderly_orderbook_split_size\",\n \"280px\",\n dep,\n );\n\n const [dataListSplitHeightSM, setDataListSplitHeightSM] = useSplitPersistent(\n \"orderly_datalist_split_height_sm\",\n \"350px\",\n );\n\n const [orderBookSplitHeightSM, setOrderbookSplitHeightSM] =\n useSplitPersistent(\"orderly_orderbook_split_height_sm\", \"280px\");\n\n return {\n orderBookSplitSize,\n setOrderbookSplitSize,\n dataListSplitSize,\n setDataListSplitSize,\n mainSplitSize,\n setMainSplitSize,\n dataListSplitHeightSM,\n setDataListSplitHeightSM,\n orderBookSplitHeightSM,\n setOrderbookSplitHeightSM,\n };\n};\n\nconst useObserverOrderEntry = (options: { max2XL: boolean }) => {\n const { max2XL } = options;\n const [orderEntryHeight, setOrderEntryHeight] = useState(0);\n const orderEntryViewRef = useRef<HTMLDivElement>(null);\n\n useEffect(() => {\n const element = orderEntryViewRef.current;\n\n if (!element || !max2XL) {\n return;\n }\n\n const resizeObserver = new ResizeObserver((entries) => {\n for (const entry of entries) {\n const height = entry.contentRect.height;\n if (height) {\n setOrderEntryHeight(height);\n }\n }\n });\n\n resizeObserver.observe(element);\n\n return () => {\n resizeObserver.unobserve(element);\n };\n }, [orderEntryViewRef, max2XL]);\n\n return {\n orderEntryViewRef,\n orderEntryHeight,\n };\n};\n\nexport function getOffsetSizeNum(size: string | null) {\n if (size) {\n return `${100 - Math.min(Number(size), 100)}`;\n }\n return \"\";\n}\n\nfunction useExtraHeight(options: {\n orderEntryViewRef: RefObject<HTMLDivElement>;\n tradindviewMaxHeight: number;\n dataListMinHeight: number;\n}) {\n const { tradindviewMaxHeight, dataListMinHeight } = options;\n const tradingviewAndOrderbookSplitRef = useRef<Split>(null);\n const max2XLSplitRef = useRef<Split>(null);\n\n const [extraHeight, setExtraHeight] = useLocalStorage(\n \"orderly_order_entry_extra_height\",\n 0,\n );\n\n const space = 10 + 12;\n\n const [dataListHeight, setDataListHeight] = useLocalStorage(\n \"orderly_trading_data_list_height\",\n dataListMinHeight,\n );\n\n const onTradingviewAndOrderbookDragging = (\n preSize: number,\n nextSize: number,\n ) => {\n const boxHeight = tradingviewAndOrderbookSplitRef?.current?.boxHeight;\n if (!boxHeight) {\n return;\n }\n\n const splitTradingviewHeight = (boxHeight * preSize) / 100;\n const splitOrderbookHeight = (boxHeight * nextSize) / 100;\n\n const tradingviewHeight = Math.min(\n Math.max(splitTradingviewHeight, tradindviewMinHeight),\n tradindviewMaxHeight,\n );\n\n const orderbookHeight = Math.min(\n Math.max(splitOrderbookHeight, orderbookMinHeight),\n orderbookMaxHeight,\n );\n\n const orderEntryHeight =\n options.orderEntryViewRef.current?.clientHeight || 0;\n\n // console.log(\"tradingviewHeight\", splitTradingviewHeight, tradingviewHeight);\n // console.log(\"orderbookHeight\", splitOrderbookHeight, orderbookHeight);\n\n if (splitOrderbookHeight >= orderbookHeight) {\n const offset = splitOrderbookHeight - orderbookHeight;\n // console.log(\"offset ---\", offset);\n setExtraHeight(Math.max(0, extraHeight - offset));\n } else if (\n tradingviewHeight + orderbookHeight <\n tradindviewMaxHeight + orderbookMaxHeight\n ) {\n const height =\n tradingviewHeight + orderbookHeight + space + symbolInfoBarHeight;\n\n const offset = Math.max(0, height - orderEntryHeight);\n // console.log(\"offset ++++\", height, offset);\n setExtraHeight(extraHeight + offset);\n }\n };\n\n const onDataListSplitHeightDragging = (preSize: number, nextSize: number) => {\n const boxHeight = max2XLSplitRef?.current?.boxHeight;\n if (!boxHeight) {\n return;\n }\n\n // const splitTradingAndOrderbookHeight = (boxHeight * preSize) / 100;\n const splitDataListHeight = (boxHeight * nextSize) / 100;\n\n if (\n splitDataListHeight >= dataListMinHeight &&\n splitDataListHeight <= dataListMaxHeight\n ) {\n setDataListHeight(splitDataListHeight);\n const offset = splitDataListHeight - dataListHeight;\n if (offset > 0) {\n setExtraHeight(Math.max(0, extraHeight - offset));\n }\n }\n };\n\n return {\n max2XLSplitRef,\n tradingviewAndOrderbookSplitRef,\n onTradingviewAndOrderbookDragging,\n onDataListSplitHeightDragging,\n extraHeight,\n dataListHeight,\n };\n}\n","import { useMemo } from \"react\";\n\nexport const useSplitPersistent = (\n key: string,\n defaulValue?: string,\n dep?: any\n): [string | undefined, (size: string) => void] => {\n const size = useMemo(() => {\n const size = localStorage.getItem(key);\n\n if (size) {\n return `${size}%`;\n }\n return defaulValue;\n }, [key, defaulValue, dep]);\n\n const setSize = (size: string) => {\n localStorage.setItem(key, size);\n };\n\n return [size, setSize];\n};\n","import { useMemo } from \"react\";\nimport {\n useAccount,\n useAssetsHistory,\n useCollateral,\n} from \"@orderly.network/hooks\";\nimport { useAppContext } from \"@orderly.network/react-app\";\nimport {\n AccountStatusEnum,\n AssetHistorySideEnum,\n AssetHistoryStatusEnum,\n} from \"@orderly.network/types\";\n\nexport const useFirstTimeDeposit = () => {\n const { state } = useAccount();\n const { wrongNetwork, disabledConnect } = useAppContext();\n const { totalValue } = useCollateral({\n dp: 2,\n });\n\n const unavailable =\n wrongNetwork ||\n disabledConnect ||\n (state.status < AccountStatusEnum.EnableTrading &&\n state.status !== AccountStatusEnum.EnableTradingWithoutConnected);\n\n const { startTime, endTime } = useMemo(() => {\n const d = new Date();\n // must set last second of today, when wallet ws changed, it will get latest data from api\n const today = new Date(\n d.getFullYear(),\n d.getMonth(),\n d.getDate(),\n 23,\n 59,\n 59,\n );\n\n const endTime = today.getTime();\n // 90 days ago timestamp\n const startTime = endTime - 90 * 24 * 60 * 60 * 1000;\n\n return {\n startTime,\n endTime,\n };\n }, []);\n\n const [_, { meta }] = useAssetsHistory(\n {\n startTime,\n endTime,\n page: 1,\n pageSize: 5,\n side: AssetHistorySideEnum.DEPOSIT,\n status: AssetHistoryStatusEnum.COMPLETED,\n },\n {\n shouldUpdateOnWalletChanged: (data) =>\n data.side === AssetHistorySideEnum.DEPOSIT &&\n data.transStatus === AssetHistoryStatusEnum.COMPLETED,\n },\n );\n\n return !unavailable && totalValue === 0 && meta?.total === 0;\n};\n","import React from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n MarketsSheetWidget,\n SymbolInfoBarWidget,\n} from \"@orderly.network/markets\";\nimport {\n Box,\n SimpleSheet,\n EyeCloseIcon,\n EyeIcon,\n Flex,\n Text,\n} from \"@orderly.network/ui\";\nimport type { TradingState } from \"./trading.script\";\n\nconst LazyTopTabWidget = React.lazy(() =>\n import(\"../../components/mobile/topTab\").then((mod) => {\n return { default: mod.TopTabWidget };\n }),\n);\n\nconst LazyOrderBookAndEntryWidget = React.lazy(() =>\n import(\"../../components/mobile/orderBookAndEntry\").then((mod) => {\n return { default: mod.OrderBookAndEntryWidget };\n }),\n);\n\nconst LazyDataListWidget = React.lazy(() =>\n import(\"../../components/mobile/dataList\").then((mod) => {\n return { default: mod.DataListWidget };\n }),\n);\n\nconst MaybeEqual: React.FC = () => {\n return (\n <svg\n width=\"8\"\n height=\"8\"\n viewBox=\"0 0 8 8\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M6.456 3.48a3.5 3.5 0 0 0 .431-.567 9 9 0 0 0 .361-.654l-.648-.66-.107.185q-.071.12-.142.244a3 3 0 0 1-.27.396 1.4 1.4 0 0 1-.318.29.67.67 0 0 1-.38.114q-.307 0-.666-.194t-.742-.42q-.383-.227-.777-.42a1.7 1.7 0 0 0-.771-.194q-.401.001-.72.154a2.1 2.1 0 0 0-.57.404 2.6 2.6 0 0 0-.43.574 5 5 0 0 0-.307.646l.649.66q.165-.437.464-.833.298-.395.742-.396.347 0 .7.194.354.193.721.42.37.227.763.42.396.195.826.195.374.001.665-.155.29-.151.526-.404m.352 2.941a3.5 3.5 0 0 0 .431-.566q.196-.315.361-.654l-.648-.66-.107.184-.142.244a3 3 0 0 1-.27.396 1.4 1.4 0 0 1-.318.29.67.67 0 0 1-.38.115q-.307 0-.666-.195-.36-.193-.742-.42-.383-.226-.778-.42a1.7 1.7 0 0 0-.77-.194q-.401.001-.72.154a2.1 2.1 0 0 0-.57.405 2.6 2.6 0 0 0-.43.574 5 5 0 0 0-.307.646l.649.66q.165-.437.464-.833.297-.395.742-.396.347 0 .7.194.354.193.721.42.369.226.763.42.396.194.826.194.374.001.665-.154.29-.152.526-.404\"\n fill=\"#fff\"\n fillOpacity=\".54\"\n />\n </svg>\n );\n};\n\nexport const MobileLayout: React.FC<TradingState> = (props) => {\n const { t } = useTranslation();\n const topBar = (\n <Box intensity={900} className=\"oui-rounded-xl\" mx={1} px={3} height={54}>\n <SymbolInfoBarWidget\n symbol={props.symbol}\n onSymbol={() => props.onOpenMarketsSheetChange(true)}\n trailing={\n <Flex\n direction={\"column\"}\n itemAlign={\"end\"}\n className=\"oui-cursor-pointer oui-text-[11px]\"\n onClick={props.onShowPortfolioSheet}\n >\n <Flex>\n <Text intensity={54}>{t(\"common.totalValue\")}</Text>\n <button\n onClick={(e) => {\n e.stopPropagation();\n e.preventDefault();\n props.setHideAssets(!props.hideAssets);\n }}\n className=\"oui-px-1\"\n >\n {props.hideAssets ? (\n <EyeIcon\n color=\"primary\"\n opacity={1}\n size={16}\n className=\"oui-text-primary-light\"\n />\n ) : (\n <EyeCloseIcon\n color=\"primary\"\n opacity={1}\n size={16}\n className=\"oui-text-primary-light\"\n />\n )}\n </button>\n <MaybeEqual />\n </Flex>\n <Text.numeral\n suffix={<Text intensity={20}>&nbsp;USDC</Text>}\n dp={2}\n visible={!props.hideAssets}\n >\n {props.canTrade ? (props.total ?? \"--\") : \"--\"}\n </Text.numeral>\n </Flex>\n }\n />\n <SimpleSheet\n open={props.openMarketsSheet}\n onOpenChange={props.onOpenMarketsSheetChange}\n classNames={{\n body: \"oui-h-full oui-pb-0\",\n content: \"oui-w-[280px] !oui-p-0\",\n }}\n contentProps={{ side: \"left\", closeable: false }}\n >\n <MarketsSheetWidget\n symbol={props.symbol}\n onSymbolChange={(symbol) => {\n props.onOpenMarketsSheetChange(false);\n props.onSymbolChange?.(symbol);\n }}\n />\n </SimpleSheet>\n </Box>\n );\n\n return (\n <div className=\"oui-relative oui-grid oui-gap-1 oui-bg-base-10\">\n <main className=\"oui-hide-scrollbar oui-space-y-1 oui-overflow-y-auto\">\n {topBar}\n <React.Suspense fallback={null}>\n <LazyTopTabWidget className=\"oui-mx-1 oui-rounded-xl oui-bg-base-9\" />\n </React.Suspense>\n <React.Suspense fallback={null}>\n <LazyOrderBookAndEntryWidget />\n </React.Suspense>\n <React.Suspense fallback={null}>\n <LazyDataListWidget\n symbol={props.symbol}\n className=\"oui-mx-1 oui-rounded-xl\"\n sharePnLConfig={props.sharePnLConfig}\n />\n </React.Suspense>\n </main>\n </div>\n );\n};\n","import React from \"react\";\nimport { useTradingScript } from \"./trading.script\";\nimport { Trading } from \"./trading.ui\";\n\nexport const TradingWidget: React.FC = () => {\n const state = useTradingScript();\n return <Trading {...state} />;\n};\n","import { FC, PropsWithChildren, useMemo } from \"react\";\nimport { useSymbolsInfo } from \"@orderly.network/hooks\";\nimport { TradingPageState, TradingPageProps } from \"../types/types\";\nimport { getBasicSymbolInfo } from \"../utils/utils\";\nimport { TradingPageContext } from \"./tradingPageContext\";\n\nexport const TradingPageProvider: FC<PropsWithChildren<TradingPageProps>> = (\n props,\n) => {\n const { symbol, children } = props;\n const symbolInfo = useSymbolsInfo()[symbol];\n const memoizedValue = useMemo<TradingPageState>(() => {\n const basicSymbol = getBasicSymbolInfo(symbolInfo);\n return {\n ...props,\n symbolInfo: {\n ...basicSymbol,\n symbol: symbol,\n },\n };\n }, [props, symbol, symbolInfo]);\n return (\n <TradingPageContext.Provider value={memoizedValue}>\n {children}\n </TradingPageContext.Provider>\n );\n};\n","import React from \"react\";\nimport { TradingPageProvider } from \"../../provider/tradingPageProvider\";\nimport { TradingPageProps } from \"../../types/types\";\nimport { TradingWidget } from \"./trading.widget\";\n\nexport const TradingPage: React.FC<TradingPageProps> = (props) => {\n return (\n <TradingPageProvider\n symbol={props.symbol}\n tradingViewConfig={props.tradingViewConfig}\n onSymbolChange={props.onSymbolChange}\n disableFeatures={props.disableFeatures}\n overrideFeatures={props.overrideFeatures}\n referral={props.referral}\n tradingRewards={props.tradingRewards}\n bottomSheetLeading={props.bottomSheetLeading}\n sharePnLConfig={props.sharePnLConfig}\n >\n <TradingWidget />\n </TradingPageProvider>\n );\n};\n"]}
1
+ {"version":3,"sources":["../src/hooks/useTradingLocalStorage.ts","../src/hooks/usePositionsCount.ts","../src/hooks/usePendingOrderCount.ts","../src/hooks/index.ts","../src/provider/tradingPageContext.tsx","../src/components/desktop/dataList/dataList.script.tsx","../src/components/desktop/dataList/setting/setting.ui.tsx","../src/components/desktop/dataList/setting/setting.script.tsx","../src/components/desktop/dataList/setting/setting.widget.tsx","../src/components/desktop/dataList/setting/index.ts","../src/components/base/positionHeader/positionHeader.ui.tsx","../src/components/base/positionHeader/positionHeader.script.tsx","../src/components/base/positionHeader/positionHeader.widget.tsx","../src/components/base/positionHeader/index.ts","../src/components/desktop/dataList/dataList.ui.tsx","../src/components/desktop/dataList/dataList.widget.tsx","../src/components/desktop/dataList/index.ts","../src/components/base/lastTrades/lastTrades.ui.tsx","../src/components/base/lastTrades/lastTrades.script.tsx","../src/components/base/lastTrades/lastTrades.widget.tsx","../src/components/base/lastTrades/index.ts","../src/components/desktop/assetView/faucet/faucet.ui.tsx","../src/components/desktop/assetView/faucet/faucet.script.tsx","../src/components/desktop/assetView/faucet/faucet.widget.tsx","../src/components/desktop/assetView/assetView.ui.tsx","../src/components/desktop/assetView/assetView.script.tsx","../src/components/desktop/assetView/assetView.widget.tsx","../src/components/desktop/assetView/index.ts","../src/components/base/orderBook/orderContext.tsx","../src/components/base/orderBook/types.ts","../src/components/base/orderBook/cellBar.tsx","../src/components/desktop/orderBook/cell.desktop.tsx","../src/components/desktop/orderBook/listBox.desktop.tsx","../src/components/desktop/orderBook/asks.desktop.tsx","../src/components/desktop/orderBook/bids.desktop.tsx","../src/components/desktop/orderBook/depthSelect.desktop.tsx","../src/components/desktop/orderBook/header.desktop.tsx","../src/components/base/orderBook/midPriceView.tsx","../src/components/base/orderBook/markPrice.tsx","../src/components/desktop/orderBook/markPrice.desktop.tsx","../src/components/desktop/orderBook/index.desktop.tsx","../src/components/mobile/fundingRate/fundingRate.ui.tsx","../src/components/mobile/fundingRateModal/fundingRateModal.script.tsx","../src/components/mobile/fundingRateModal/fundingRateModal.ui.tsx","../src/components/mobile/fundingRateModal/fundingRateModal.widget.tsx","../src/components/mobile/fundingRate/fundingRate.script.tsx","../src/components/mobile/fundingRate/fundingRate.widget.tsx","../src/components/mobile/fundingRate/index.ts","../src/components/mobile/orderBook/cell.tsx","../src/components/mobile/orderBook/listBox.tsx","../src/components/mobile/orderBook/asks.tsx","../src/components/mobile/orderBook/bids.tsx","../src/components/mobile/orderBook/depthSelect.tsx","../src/components/mobile/orderBook/header.tsx","../src/components/mobile/orderBook/markPrice.tsx","../src/components/mobile/orderBook/index.tsx","../src/components/base/orderBook/orderBook.ui.tsx","../src/utils/utils.ts","../src/components/base/orderBook/orderBook.script.tsx","../src/components/base/orderBook/orderBook.widget.tsx","../src/components/base/orderBook/index.ts","../src/components/desktop/riskRate/riskRate.ui.tsx","../src/components/desktop/riskRate/riskRate.script.tsx","../src/components/desktop/riskRate/riskRate.widget.tsx","../src/components/desktop/riskRate/index.ts","../src/components/desktop/orderBookAndTrades/orderBookAndTrades.ui.tsx","../src/components/desktop/orderBookAndTrades/orderBookAndTrades.script.tsx","../src/components/desktop/orderBookAndTrades/orderBookAndTrades.widget.tsx","../src/components/desktop/orderBookAndTrades/index.ts","../src/components/desktop/layout/switchLayout.tsx","../src/components/mobile/topTab/topTab.script.tsx","../src/components/mobile/tradingview/tradingview.script.tsx","../src/components/base/icons.tsx","../src/components/mobile/tradingview/tradingview.ui.tsx","../src/components/mobile/tradingview/tradingview.widget.tsx","../src/components/mobile/lastTrades/lastTrades.widget.tsx","../src/components/mobile/tradeData/tradeData.ui.tsx","../src/components/mobile/tradeData/tradeData.script.tsx","../src/components/mobile/tradeData/tradeData.widget.tsx","../src/components/mobile/tradeData/index.ts","../src/components/mobile/topTab/topTab.ui.tsx","../src/components/mobile/topTab/topTab.widget.tsx","../src/components/mobile/topTab/index.ts","../src/components/mobile/orderBookAndEntry/orderBookAndEntry.ui.tsx","../src/components/mobile/orderBookAndEntry/orderBookAndEntry.script.tsx","../src/components/mobile/orderBookAndEntry/orderBookAndEntry.widget.tsx","../src/components/mobile/orderBookAndEntry/index.ts","../src/components/mobile/dataList/dataList.script.tsx","../src/components/mobile/dataList/dataList.ui.tsx","../src/components/mobile/dataList/dataList.widget.tsx","../src/components/mobile/dataList/index.ts","../src/index.ts","../src/components/desktop/layout/splitLayout/splitLayout.tsx","../src/components/desktop/layout/splitLayout/splitLineBar.tsx","../src/components/mobile/bottomNavBar/bottomNavBar.ui.tsx","../src/components/mobile/bottomNavBar/account/account.widget.tsx","../src/components/mobile/bottomNavBar/account/account.script.tsx","../src/components/mobile/accountSheet/accountSheet.ui.tsx","../src/components/mobile/accountSheet/icons.tsx","../src/components/mobile/accountSheet/accountSheet.script.tsx","../src/components/mobile/accountSheet/accountSheet.widget.tsx","../src/components/mobile/bottomNavBar/account/account.ui.tsx","../src/components/mobile/bottomNavBar/balance/balance.ui.tsx","../src/components/mobile/bottomNavBar/balance/balance.script.tsx","../src/components/mobile/bottomNavBar/balance/balance.widget.tsx","../src/components/mobile/bottomNavBar/chain/chain.ui.tsx","../src/components/mobile/bottomNavBar/chain/chain.script.tsx","../src/components/mobile/bottomNavBar/chain/chain.widget.tsx","../src/components/mobile/bottomNavBar/bottomNavBar.script.tsx","../src/components/mobile/bottomNavBar/bottomNavBar.widget.tsx","../src/components/mobile/portfolioSheet/portfolioSheet.ui.tsx","../src/components/mobile/portfolioSheet/portfolioSheet.script.tsx","../src/components/mobile/portfolioSheet/riskIndicator.tsx","../src/components/mobile/portfolioSheet/portfolioSheet.widget.tsx","../src/components/mobile/fundingRateModal/index.ts","../src/pages/trading/trading.ui.tsx","../src/pages/trading/trading.ui.desktop.tsx","../src/components/desktop/layout/removablePanel.tsx","../src/pages/trading/trading.script.tsx","../src/components/desktop/layout/useSplitPersistent.ts","../src/pages/trading/hooks/useFirstTimeDeposit.ts","../src/pages/trading/trading.ui.mobile.tsx","../src/pages/trading/trading.widget.tsx","../src/provider/tradingPageProvider.tsx","../src/pages/trading/trading.page.tsx"],"names":["useLocalStorage","useTradingLocalStorage","init_useTradingLocalStorage","__esmMin","props","unPnlPriceBasis","setUnPnlPriceBasic","pnlNotionalDecimalPrecision","setPnlNotionalDecimalPrecision","showAllSymbol","setShowAllSymbol","hideAssets","setHideAssets","useMemo","usePositionStream","useDataTap","usePositionsCount","init_usePositionsCount","symbol","data","count","useOrderStream","AlgoOrderRootType","OrderStatus","TabType","usePendingOrderCount","init_usePendingOrderCount","pendingOrdersPageSizeKey","tpslOrdersPageSizeKey","pendingOrders","pendingCount","tpslOrders","tpslCount","pendingOrderCount","tpSlOrderCount","init_hooks","createContext","useContext","TradingPageContext","useTradingPageContext","init_tradingPageContext","useDataListScript","init_dataList_script","current","sharePnLConfig","includedPendingOrder","localStorage","onSymbolChange","positionCount","useState","Button","Checkbox","Divider","DropdownMenuContent","DropdownMenuRoot","DropdownMenuTrigger","Flex","SettingFillIcon","Text","useTranslation","jsx","jsxs","Setting","UnPnlPriceBasisCheckBox","DecimalPrecisionCheckbox","RadioButton","SelIcon","UnselIcon","init_setting_ui","open","setOpen","t","checked","e","value","onValueChange","sel","label","onCheckChange","useSettingScript","init_setting_script","SettingWidget","init_setting_widget","state","setting_exports","__export","init_setting","Statistic","useScreen","Decimal","PositionHeader","MobileLayout","DesktopLayout","UnrealPnL","Notional","init_positionHeader_ui","isMobile","unrealPnLClsName","unrealPnLROIClsName","usePositionHeaderScript","init_positionHeader_script","inputs","calcMode","aggregated","unrealPnL","unrealPnlROI","notional","PositionHeaderWidget","init_positionHeader_widget","positionHeader_exports","init_positionHeader","React","Box","InfoCircleIcon","TabPanel","Tabs","Tooltip","DesktopOrderListWidget","LiquidationWidget","PositionHistoryWidget","PositionsWidget","LazySettingWidget","LazyPositionHeaderWidget","DataList","LiquidationTab","PositionsView","init_dataList_ui","mod","DataListWidget","init_dataList_widget","dataList_exports","init_dataList","cn","Grid","ListView","OrderSide","commifyOptional","LastTrades","Row","Header","List","init_lastTrades_ui","left","mid","right","classNames","item","index","useMarketTradeStream","useSymbolsInfo","useLastTradesScript","init_lastTrades_script","isLoading","config","base","quote","baseDp","quoteDp","LastTradesWidget","init_lastTrades_widget","lastTrades_exports","init_lastTrades","FaucetUi","init_faucet_ui","useAccount","useConfig","useMutation","useWalletConnector","AccountStatusEnum","ChainNamespace","isTestnet","modal","toast","useFaucetScript","connectedChain","namespace","account","operatorUrl","getTestUSDC","isMutating","loading","setLoading","showFaucet","message","res","resolve","error","init_faucet_script","FaucetWidget","init_faucet_widget","useCallback","useAppContext","ArrowDownShortIcon","EyeIcon","EyeCloseIcon","ChevronDownIcon","gradientTextVariants","AuthGuard","LTVRiskTooltipWidget","Fragment","calculateTextColor","useCurrentStatusText","TooltipContent","TotalValue","AssetDetail","LTVDetail","AssetValueList","AssetView","init_assetView_ui","val","wrongNetwork","disabledConnect","statusText","description","formula","totalValue","visible","onToggleVisibility","unit","rule","placeholder","freeCollateral","marginRatioVal","renderMMR","isConnected","currentLtv","optionsOpen","setOptionsOpen","toggleOpen","prevOpen","showLTV","networkId","isFirstTimeDeposit","onDeposit","onWithdraw","onTransfer","toggleVisible","isMainAccount","hasSubAccount","title","titleColor","titleClsName","transferButton","depositButton","withdrawButton","useAccountInstance","useEventEmitter","useCollateral","useMarginRatio","useComputedLTV","DepositAndWithdrawWithDialogId","TransferDialogId","useAssetViewScript","init_assetView_script","ee","marginRatio","mmr","positionsInfo","openDepositAndWithdraw","viewName","onSettle","setVisible","_freeCollateral","_marginRatioVal","_mmr","_totalValue","AssetViewWidget","init_assetView_widget","assetView_exports","init_assetView","OrderBookContext","useOrderBookContext","ORDERBOOK_COIN_TYPE_KEY","ORDERBOOK_MOBILE_COIN_TYPE_KEY","OrderBookProvider","init_orderContext","mode","setMode","totalMode","setTotalMode","memoizedValue","init_types","CellBar","init_cellBar","direction","transform","x","parseNumber","getPrecisionByNumber","DesktopOrderBookCell","init_cell_desktop","cellHeight","showTotal","onItemClick","depth","symbolInfo","currentHover","accumulated","accumulatedAmount","price","quantity","base_dp","quote_dp","coinType","width","dp","totalAmount","isPendingOrder","priceStr","TooltipTrigger","TooltipRoot","TooltipArrow","calcHintInfo","DesktopListBox","Tip","init_listBox_desktop","qty","amount","sumQty","sumQtyAmount","type","countQty","findMaxItem","len","priceDp","maxQty","a","b","hoverIndex","setHoverIndex","isHover","hintInfo","info","content","contentDp","DesktopAsks","init_asks_desktop","max","DesktopBids","init_bids_desktop","Select","DesktopDepthSelect","init_depthSelect_desktop","options","d","CaretDownIcon","CaretUpIcon","Popover","Option","DesktopHeader","Title","init_header_desktop","onClick","setCoinType","popoverOpen","TriggerIcon","children","className","justifyEnd","ArrowUpShortIcon","MiddlePriceView","init_midPriceView","markPrice","lastPrice","iconSize","prevLastPrice","middlePrice","down","up","SimpleDialog","MarkPriceView","FlagIcon","init_markPrice","DesktopMarkPrice","Spread","init_markPrice_desktop","asks","bids","spread","bid1","ask1","dValue","useEffect","useRef","EMPTY_LIST","Spinner","DesktopOrderBook","init_index_desktop","onDepthChange","divRef","setShowTotal","resizeObserver","entries","entry","targetDiv","FundingRate","init_fundingRate_ui","predFundingRate","countDown","useFundingDetails","useFundingRateModalScript","init_fundingRateModal_script","fundingPeriod","capFunding","floorFunding","FundingRateModal","init_fundingRateModal_ui","i18n","registerSimpleDialog","registerSimpleSheet","FundingRateModalWidget","FundingRateDialogId","FundingRateSheetId","init_fundingRateModal_widget","useFundingRate","useFundingRateScript","init_fundingRate_script","FundingRateWidget","init_fundingRate_widget","init_fundingRate","OrderBookCell","init_cell","coinUnit","setCoinUnit","renderCell","ListBox","init_listBox","Asks","init_asks","Bids","init_bids","Picker","DepthSelect","init_depthSelect","init_header","_","MarkPrice","OrderBook","init_orderBook","init_orderBook_ui","getBasicSymbolInfo","init_utils","useOrderbookStream","removeTrailingZeros","DEFAULT_CELL_HEIGHT","SPACE","useOrderBookScript","usePendingOrderStream","init_orderBook_script","height","setCellHeight","level","setLevel","allDepths","cellsHeight","restSpace","selDepth","depths","OrderBookWidget","init_orderBook_widget","orderBook_exports","EditIcon","LeverageWidgetWithDialogId","RiskRate","init_riskRate_ui","riskRate","riskRateColor","currentLeverage","maxLeverage","isHigh","isMedium","isLow","textColor","useLeverage","getRiskRateColor","useRiskRateScript","init_riskRate_script","curLeverage","riskRateNumber","_curLeverage","_maxLeverage","RiskRateWidget","init_riskRate_widget","riskRate_exports","init_riskRate","LazyLastTradesWidget","LazyOrderBookWidget","TwoColLayout","TabLayout","OrderBookAndTrades","init_orderBookAndTrades_ui","tab","containerRef","containerSize","useOrderBookAndTradesScript","init_orderBookAndTrades_script","setContainerSize","setTab","OrderBookAndTradesWidget","init_orderBookAndTrades_widget","orderBookAndTrades_exports","init_orderBookAndTrades","switchLayout_exports","LayoutIcon","MarketBottomIcon","MarketHideIcon","MarketLeftIcon","MarketTopIcon","OrderEntryIcon","SwitchLayout","SwitchLayoutDropDown","CloseIcon","DropdownMenuPortal","init_switchLayout","hoveredMarket","setHoveredMarket","renderItem","position","renderMarketItem","getIcon","isHovered","isSelected","getLabel","useTopTabScript","init_topTab_script","useTradingviewScript","setHeight","Key","MaxHeight","dragging","setDragging","dragRef","boxRef","offsetY","setOffsetY","topRef","handleTouchStart","event","rect","handleTouchMove","newHeight","MinHeight","handleTouchEnd","drag","init_tradingview_script","KlineDragIcon","init_icons","TradingviewWidget","TradingviewUI","init_tradingview_ui","tradingview_widget_exports","init_tradingview_widget","lastTrades_widget_exports","MWebLastTrades","TradeData","init_tradeData_ui","showUSDC","useTickerStream","useTradeDataScript","init_tradeData_script","ticker","vol_24h","close","volume","openInterest","TradeDataWidget","init_tradeData_widget","tradeData_exports","init_tradeData","LazyTradingviewWidget","LazyMWebLastTrades","LazyTradeDataWidget","TopTab","ChevronIcon","init_topTab_ui","tradingViewConfig","TopTabWidget","init_topTab_widget","topTab_exports","init_topTab","OrderEntryWidget","OrderBookAndEntry","init_orderBookAndEntry_ui","div","useOrderBookAndEntryScript","init_orderBookAndEntry_script","OrderBookAndEntryWidget","init_orderBookAndEntry_widget","orderBookAndEntry_exports","init_orderBookAndEntry","subTab","setSubTab","cancelAllOrders","cancelAllTPSLOrders","MobileOrderListWidget","MobileLiquidationWidget","MobilePositionHistoryWidget","MobilePositionsWidget","OrdersView","SymbolControlHeader","HistoryTab","module","forwardRef","Split","SplitLineBar","onMouseDown","rest","disable","filterCls","cls","SplitLayout","ref","onSizeChange","barProps","ScanQRCodeWidget","ExtensionPositionEnum","ExtensionSlot","installExtension","ArrowRightShortIcon","HeadIcon","CopyIcon","USDCIcon","size","OrderlyIcon","AccountSheet","AccountInfo","ReferralInfo","TradingRewardsInfo","TWType","useChains","useCurEpochEstimate","useEpochInfo","useReferralInfo","useModal","useAccountSheetScript","linkDeviceStorage","accountId","address","hide","disconnect","chainId","showGetTestUSDC","chainName","useGetChains","onCopyAddress","affiliateCommission30D","traderCommission30D","isAffiliate","isTrader","onClickReferral","useReferral","curEpochId","estRewards","onClickTradingRewards","useTradingRewards","onDisconnect","gettingTestUSDC","_onClickReferral","_onClick","curEpochEstimate","list","curEpoch","mainChains","findByChainId","chain","AccountSheetWidget","useAccountScript","referral","tradingRewards","bottomSheetLeading","formatAddress","Account","MobileAccountMenuExtension","Balance","useBalanceScript","BalanceWidget","ChainIcon","ChainSelectorSheetId","Chain","r","useChainScript","currentChainId","setCurrentChainId","ChainWidget","BottomNavBar","renderContent","LinkDevice","showScanQRCode","showDialog","hideDialog","DesktopIcon","Dot","LinkIcon","MobileIcon","DotIcon","useBottomNavBarScript","BottomNavBarWidget","useId","Trans","ArrowLeftRightIcon","Input","inputFormatter","PlusIcon","ReduceIcon","RefreshIcon","useDebouncedCallback","DepositAndWithdrawWithSheetId","TransferSheetId","usePortfolioSheetScript","assets","useAssets","useMarginRatioAndLeverage","subAccounts","showSliderTip","setShowSliderTip","onSettlePnL","toggleHideAssets","totalCollateral","availableBalance","totalUnrealizedROI","update","leverageLevers","marks","leverage","setLeverage","step","onLeverageChange","onSave","err","onValueCommit","debouncedCommit","onInputChange","parsed","raw","clamped","prev","getMarginRatioColor","imr","high","low","RiskIndicator","PortfolioSheet","Asset","MarginRatio","Buttons","onUnsettleClick","clsName","PortfolioSheetWidget","SideMarketsWidget","SymbolInfoBarFullWidget","HorizontalMarketsWidget","TradingviewFullscreenKey","DepositStatusWidget","RemovablePanel","showIndicator","next","TopIcon","MiddleIcon","BottomIcon","Icon","idx","v","IndicatorIcon","useMediaQuery","useSplitPersistent","key","defaulValue","dep","useAssetsHistory","AssetHistorySideEnum","AssetHistoryStatusEnum","useFirstTimeDeposit","unavailable","startTime","endTime","meta","scrollBarWidth","topBarHeight","bottomBarHeight","space","symbolInfoBarHeight","orderEntryMinWidth","orderEntryMaxWidth","orderbookMinWidth","orderbookMaxWidth","orderbookMinHeight","orderbookMaxHeight","tradindviewMinHeight","tradingViewMinWidth","dataListMaxHeight","dataListInitialHeight","ORDERLY_ORDER_ENTRY_SIDE_MARKETS_LAYOUT","ORDERLY_SIDE_MARKETS_MODE_KEY","ORDERLY_HORIZONTAL_MARKETS_LAYOUT","useTradingScript","openMarketsSheet","setOpenMarketsSheet","restrictedInfo","onRouteChange","total","max2XL","min3XL","max4XL","layout","setLayout","marketLayout","setMarketLayout","canTrade","onShowPortfolioSheet","horizontalDraggable","positionsState","useOrderEntryPositions","marketsCollapseState","useMarketsCollapse","observerState","useObserverOrderEntry","marketsWidth","tradindviewMaxHeight","dataListMinHeight","splitSizeState","useSplitSize","tradingViewHeightState","useExtraHeight","map","resizeable","animating","setAnimating","panelSize","setPanelSize","onPanelSizeChange","collapsed","memoizedPanelSize","positions","setPositions","updatePositions","currentIdx","targetIdx","pos","i","showPositionIcon","mainSplitSize","setMainSplitSize","dataListSplitSize","setDataListSplitSize","orderBookSplitSize","setOrderbookSplitSize","dataListSplitHeightSM","setDataListSplitHeightSM","orderBookSplitHeightSM","setOrderbookSplitHeightSM","orderEntryHeight","setOrderEntryHeight","orderEntryViewRef","element","getOffsetSizeNum","tradingviewAndOrderbookSplitRef","max2XLSplitRef","extraHeight","setExtraHeight","dataListHeight","setDataListHeight","preSize","nextSize","boxHeight","splitTradingviewHeight","splitOrderbookHeight","tradingviewHeight","orderbookHeight","offset","splitDataListHeight","LazyRiskRateWidget","LazyAssetViewWidget","LazyDataListWidget","LazySwitchLayout","LazyOrderBookAndTradesWidget","onLayout","onMarketLayout","tradingViewFullScreen","minScreenHeight","minScreenHeightSM","horizontalMarketsView","marketsWidget","marketsView","symbolInfoBarView","library_path","restTradingViewConfig","tradingviewWidget","tradingView","orderbookWidget","orderbookView","dataListWidget","dataListView","assetsOrderEntryMargin","orderEntryWidget","orderEntryView","tradingViewAndOrderbookView","renderTradingViewAndOrderbookView","mainView","MarketsSheetWidget","SymbolInfoBarWidget","SimpleSheet","LazyTopTabWidget","LazyOrderBookAndEntryWidget","MaybeEqual","topBar","Trading","TradingWidget","TradingPageProvider","basicSymbol","TradingPage"],"mappings":"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CN,OAAO,MACP,QAAQ,cACR,KAAK,OACL,MAAM,6BACL,GAAGzD,EAEJ,UAAAwD,EAAC,QACC,EAAE,IACF,EAAE,IACF,MAAM,MACN,OAAO,KACP,GAAG,KACH,KAAK,UACL,OArBA6c,GACAD,EAAkB,UACf,UAoBH,YAAY,IACd,EACA3c,EAAC,KAAE,SAAS,0BACV,UAAAD,EAAC,QAAK,EAAE,IAAI,EAAE,IAAI,MAAM,MAAM,OAAO,KAAK,GAAG,IAAI,KAAK,UAAU,EAChEA,EAAC,QACC,EAAE,UACF,EAAE,MACF,MAAM,IACN,OAAO,MACP,GAAG,IACH,UAAU,yBACV,KAAK,UACP,EACAA,EAAC,QACC,EAAE,UACF,EAAE,UACF,MAAM,IACN,OAAO,MACP,GAAG,IACH,UAAU,6BACV,KAAK,UACP,EACAA,EAAC,QACC,EAAE,UACF,EAAE,WACF,MAAM,IACN,OAAO,MACP,GAAG,IACH,UAAU,8BACV,KAAK,UACP,EACAA,EAAC,QACC,EAAE,UACF,EAAE,WACF,MAAM,IACN,OAAO,MACP,GAAG,IACH,UAAU,8BACV,KAAK,UACP,EACAA,EAAC,QACC,EAAE,UACF,EAAE,WACF,MAAM,IACN,OAAO,MACP,GAAG,IACH,UAAU,8BACV,KAAK,UACP,EACAA,EAAC,QACC,EAAE,UACF,EAAE,WACF,MAAM,IACN,OAAO,MACP,GAAG,IACH,UAAU,8BACV,KAAK,UACP,EACAA,EAAC,QACC,EAAE,UACF,EAAE,WACF,MAAM,IACN,OAAO,MACP,GAAG,IACH,UAAU,8BACV,KAAK,UACP,EACAA,EAAC,QACC,EAAE,UACF,EAAE,WACF,MAAM,IACN,OAAO,MACP,GAAG,IACH,UAAU,8BACV,KAAK,UACP,EACAA,EAAC,QACC,EAAE,UACF,EAAE,WACF,MAAM,IACN,OAAO,MACP,GAAG,IACH,UAAU,8BACV,KAAK,UACP,EACAA,EAAC,QACC,EAAE,SACF,EAAE,WACF,MAAM,IACN,OAAO,MACP,GAAG,IACH,UAAU,6BACV,KAAK,UACP,EACAA,EAAC,QACC,EAAE,SACF,EAAE,WACF,MAAM,IACN,OAAO,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","sourcesContent":["import { useLocalStorage } from \"@orderly.network/hooks\";\n\nexport const useTradingLocalStorage = (props?: {\n pnlNotionalDecimalPrecision?: number;\n}) => {\n const [unPnlPriceBasis, setUnPnlPriceBasic] = useLocalStorage(\n \"unPnlPriceBasis\",\n \"markPrice\",\n );\n const [pnlNotionalDecimalPrecision, setPnlNotionalDecimalPrecision] =\n useLocalStorage(\n \"pnlNotionalDecimalPrecision\",\n props?.pnlNotionalDecimalPrecision ?? 2,\n );\n const [showAllSymbol, setShowAllSymbol] = useLocalStorage(\n \"showAllSymbol\",\n true,\n );\n\n const [hideAssets, setHideAssets] = useLocalStorage(\"hideAssets\", false);\n\n return {\n unPnlPriceBasis,\n setUnPnlPriceBasic,\n pnlNotionalDecimalPrecision,\n setPnlNotionalDecimalPrecision,\n showAllSymbol,\n setShowAllSymbol,\n hideAssets,\n setHideAssets,\n };\n};\n","import { useMemo } from \"react\";\nimport { usePositionStream } from \"@orderly.network/hooks\";\nimport { useDataTap } from \"@orderly.network/react-app\";\nimport { useTradingLocalStorage } from \"./useTradingLocalStorage\";\n\nexport const usePositionsCount = (symbol?: string) => {\n const { showAllSymbol } = useTradingLocalStorage();\n const [data] = usePositionStream(showAllSymbol ? undefined : symbol);\n\n const count = useMemo(() => {\n return data.rows?.length;\n }, [data.rows?.length]);\n\n const positionCount = useDataTap(count) ?? 0;\n\n return {\n positionCount,\n };\n};\n","import { useOrderStream } from \"@orderly.network/hooks\";\nimport { useDataTap } from \"@orderly.network/react-app\";\nimport { AlgoOrderRootType, OrderStatus } from \"@orderly.network/types\";\nimport { TabType } from \"@orderly.network/ui-orders\";\nimport { useTradingLocalStorage } from \"./useTradingLocalStorage\";\n\nexport const usePendingOrderCount = (symbol?: string) => {\n const { showAllSymbol } = useTradingLocalStorage();\n\n const pendingOrdersPageSizeKey = `orderly_${TabType.pending}_pageSize`;\n const tpslOrdersPageSizeKey = `orderly_${TabType.tp_sl}_pageSize`;\n //\n // const [pendingOrderPageSize] = useLocalStorage(pendingOrdersPageSizeKey, 500);\n // const [tpslOrderPageSize] = useLocalStorage(tpslOrdersPageSizeKey, 500);\n\n const [pendingOrders, { total: pendingCount }] = useOrderStream(\n {\n symbol: showAllSymbol ? undefined : symbol,\n status: OrderStatus.INCOMPLETE,\n excludes: [AlgoOrderRootType.POSITIONAL_TP_SL, AlgoOrderRootType.TP_SL],\n // size: pendingOrderPageSize,\n size: 500,\n // sourceTypeAll: true,\n },\n {\n keeplive: true,\n },\n );\n\n const [tpslOrders, { total: tpslCount }] = useOrderStream(\n {\n symbol: showAllSymbol ? undefined : symbol,\n status: OrderStatus.INCOMPLETE,\n includes: [AlgoOrderRootType.POSITIONAL_TP_SL, AlgoOrderRootType.TP_SL],\n // size: tpslOrderPageSize,\n size: 500,\n // sourceTypeAll: true,\n },\n {\n keeplive: true,\n },\n );\n\n const pendingOrderCount = useDataTap(pendingCount) ?? 0;\n const tpSlOrderCount = useDataTap(tpslCount) ?? 0;\n\n return {\n pendingOrderCount,\n tpSlOrderCount,\n };\n};\n","export { useTradingLocalStorage } from \"./useTradingLocalStorage\";\nexport { usePositionsCount } from \"./usePositionsCount\";\nexport { usePendingOrderCount } from \"./usePendingOrderCount\";\n","import { createContext, useContext } from \"react\";\nimport { TradingPageState } from \"../types/types\";\n\nexport const TradingPageContext = createContext({} as TradingPageState);\n\nexport const useTradingPageContext = () => {\n return useContext(TradingPageContext);\n};\n","import { PositionsProps } from \"@orderly.network/ui-positions\";\nimport {\n usePendingOrderCount,\n usePositionsCount,\n useTradingLocalStorage,\n} from \"../../../hooks\";\nimport { useTradingPageContext } from \"../../../provider/tradingPageContext\";\n\nexport enum DataListTabType {\n positions = \"Positions\",\n pending = \"Pending\",\n tp_sl = \"TP/SL\",\n filled = \"Filled\",\n positionHistory = \"Position history\",\n orderHistory = \"Order history\",\n liquidation = \"Liquidation\",\n}\n\nexport const useDataListScript = (\n props: { current?: DataListTabType } & PositionsProps,\n) => {\n const {\n current,\n pnlNotionalDecimalPrecision,\n sharePnLConfig,\n symbol,\n includedPendingOrder,\n } = props;\n const localStorage = useTradingLocalStorage({\n pnlNotionalDecimalPrecision,\n });\n const { onSymbolChange } = useTradingPageContext();\n\n const { positionCount } = usePositionsCount(props.symbol);\n const { pendingOrderCount, tpSlOrderCount } = usePendingOrderCount(\n props.symbol,\n );\n\n return {\n current,\n sharePnLConfig,\n symbol,\n calcMode: localStorage.unPnlPriceBasis,\n includedPendingOrder,\n ...localStorage,\n positionCount,\n pendingOrderCount,\n tpSlOrderCount,\n onSymbolChange,\n };\n};\n\nexport type DataListState = ReturnType<typeof useDataListScript>;\n","import { FC, useCallback, useState } from \"react\";\nimport {\n Button,\n Checkbox,\n Divider,\n DropdownMenuContent,\n DropdownMenuRoot,\n DropdownMenuTrigger,\n Flex,\n SettingFillIcon,\n Text,\n} from \"@orderly.network/ui\";\nimport { SettingState } from \"./setting.script\";\nimport { useTranslation } from \"@orderly.network/i18n\";\n\nexport const Setting: FC<SettingState> = (props) => {\n const [open, setOpen] = useState(false);\n const { t } = useTranslation();\n\n return (\n <Flex gap={0}>\n <Flex gap={1}>\n <Checkbox\n id=\"oui-checkbox-hideOtherSymbols\"\n color=\"white\"\n checked={props.hideOtherSymbols}\n onCheckedChange={(checked: boolean) => {\n props.setHideOtherSymbols(checked);\n }}\n />\n <label\n className=\"oui-text-xs oui-text-base-contrast-54 oui-cursor-pointer\"\n htmlFor=\"oui-checkbox-hideOtherSymbols\"\n >\n {t(\"trading.hideOtherSymbols\")}\n </label>\n </Flex>\n\n <DropdownMenuRoot open={open} onOpenChange={setOpen}>\n <DropdownMenuTrigger asChild>\n <Button\n size=\"xs\"\n type=\"button\"\n variant=\"contained\"\n className=\"oui-bg-transparent hover:oui-bg-transparent\"\n >\n <SettingFillIcon\n size={16}\n color=\"white\"\n opacity={1}\n className=\"oui-text-white/[.36] hover:oui-text-white/80\"\n />\n </Button>\n </DropdownMenuTrigger>\n <DropdownMenuContent\n className=\"oui-px-5 oui-py-3 oui-w-[360px]\"\n alignOffset={2}\n align=\"end\"\n >\n <div className=\"oui-flex oui-flex-col oui-text-sm\">\n <Text className=\"oui-text-base oui-pb-3\">\n {t(\"trading.portfolioSettings\")}\n </Text>\n <Divider />\n <Text className=\"oui-pb-3 oui-text-base-contrast-54 oui-mt-2\">\n {t(\"trading.portfolioSettings.decimalPrecision\")}\n </Text>\n <DecimalPrecisionCheckbox\n value={props.pnlNotionalDecimalPrecision}\n onValueChange={(e) => {\n props.setPnlNotionalDecimalPrecision(e);\n setOpen(false);\n }}\n />\n <Divider className=\"oui-my-3\" />\n <Text className=\"oui-pb-3 oui-text-base-contrast-54 oui-mt-2\">\n {t(\"trading.portfolioSettings.unrealPnlPriceBasis\")}\n </Text>\n <UnPnlPriceBasisCheckBox\n value={props.unPnlPriceBasis}\n onValueChange={(e) => {\n props.setUnPnlPriceBasic(e);\n setOpen(false);\n }}\n />\n </div>\n </DropdownMenuContent>\n </DropdownMenuRoot>\n </Flex>\n );\n};\n\nconst UnPnlPriceBasisCheckBox = (props: {\n value: string;\n onValueChange: (value: string) => void;\n}) => {\n const { value, onValueChange } = props;\n const { t } = useTranslation();\n\n // \"markPrice\" | \"lastPrice\"\n return (\n <Flex gap={2}>\n <RadioButton\n sel={value === \"markPrice\"}\n label={t(\"common.markPrice\")}\n value={\"markPrice\"}\n onCheckChange={onValueChange}\n />\n <RadioButton\n sel={value === \"lastPrice\"}\n label={t(\"common.lastPrice\")}\n value={\"lastPrice\"}\n onCheckChange={onValueChange}\n />\n </Flex>\n );\n};\n\nconst DecimalPrecisionCheckbox = (props: {\n value: number;\n onValueChange: (value: number) => void;\n}) => {\n const { value, onValueChange } = props;\n return (\n <Flex gap={2}>\n <RadioButton\n sel={value === 0}\n label={1}\n value={0}\n onCheckChange={onValueChange}\n />\n <RadioButton\n sel={value === 1}\n label={0.1}\n value={1}\n onCheckChange={onValueChange}\n />\n <RadioButton\n sel={value === 2}\n label={0.01}\n value={2}\n onCheckChange={onValueChange}\n />\n </Flex>\n );\n};\n\n// const InnerCheckbox = (props: {\n// sel: boolean;\n// label: any;\n// value: any;\n// onCheckChange: (value: any) => void;\n// }) => {\n// const { sel, label, value, onCheckChange } = props;\n// return (\n// <Flex\n// onClick={(e) => {\n// onCheckChange(value);\n// e.stopPropagation();\n// }}\n// gap={1}\n// >\n// <Checkbox color=\"white\" checked={sel} />\n// <Text size=\"xs\" intensity={sel ? 98 : 54}>\n// {`${label}`}\n// </Text>\n// </Flex>\n// );\n// };\n\nconst RadioButton = (props: {\n sel: boolean;\n label: any;\n value: any;\n onCheckChange: (value: any) => void;\n}) => {\n const { sel, label, value, onCheckChange } = props;\n return (\n <Flex\n onClick={(e) => {\n onCheckChange(value);\n e.stopPropagation();\n }}\n gap={1}\n className=\"oui-cursor-pointer\"\n >\n {sel ? <SelIcon /> : <UnselIcon />}\n <Text size=\"2xs\" intensity={sel ? 98 : 54}>\n {label}\n </Text>\n </Flex>\n );\n};\n\nconst SelIcon = () => {\n return (\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 className=\"oui-fill-white\"\n >\n <path\n d=\"M8.01 1.333a6.667 6.667 0 1 0 0 13.333 6.667 6.667 0 0 0 0-13.333m0 1.333a5.334 5.334 0 1 1-.001 10.667 5.334 5.334 0 0 1 0-10.667\"\n fill=\"#fff\"\n fillOpacity=\".36\"\n />\n <circle cx=\"8\" cy=\"8\" r=\"3.333\" />\n </svg>\n );\n};\n\nconst UnselIcon = () => {\n return (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M8.01 1.333a6.667 6.667 0 1 0 0 13.333 6.667 6.667 0 0 0 0-13.333m0 1.333a5.334 5.334 0 1 1-.001 10.667 5.334 5.334 0 0 1 0-10.667\"\n fill=\"#fff\"\n fillOpacity=\".54\"\n />\n </svg>\n );\n};\n","import { SettingWidgetProps } from \"./setting.widget\";\n\nexport const useSettingScript = (props: SettingWidgetProps) => {\n return {\n ...props,\n };\n};\n\nexport type SettingState = ReturnType<typeof useSettingScript>;\n","import React from \"react\";\nimport { useSettingScript } from \"./setting.script\";\nimport { Setting } from \"./setting.ui\";\n\nexport type SettingWidgetProps = {\n pnlNotionalDecimalPrecision: any;\n setPnlNotionalDecimalPrecision: (value: number) => void;\n unPnlPriceBasis: any;\n setUnPnlPriceBasic: (value: string) => void;\n hideOtherSymbols: any;\n setHideOtherSymbols: (value: boolean) => void;\n};\n\nexport const SettingWidget: React.FC<SettingWidgetProps> = (props) => {\n const state = useSettingScript(props);\n return <Setting {...state} />;\n};\n","export { Setting } from \"./setting.ui\";\nexport { SettingWidget } from \"./setting.widget\";\n","import React from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n Checkbox,\n Divider,\n Flex,\n Statistic,\n Text,\n useScreen,\n} from \"@orderly.network/ui\";\nimport { Decimal } from \"@orderly.network/utils\";\nimport type { PositionHeaderState } from \"./positionHeader.script\";\n\nexport const PositionHeader: React.FC<PositionHeaderState> = (props) => {\n const { isMobile } = useScreen();\n return isMobile ? <MobileLayout {...props} /> : <DesktopLayout {...props} />;\n};\n\nconst MobileLayout: React.FC<PositionHeaderState> = (props) => {\n const { t } = useTranslation();\n\n return (\n <Flex\n direction={\"column\"}\n gap={2}\n width={\"100%\"}\n itemAlign={\"start\"}\n p={2}\n className=\"oui-rounded-b-xl oui-bg-base-9\"\n >\n <Flex width={\"100%\"} justify={\"between\"}>\n <UnrealPnL\n classNames={{\n label: \"oui-text-2xs oui-text-base-contrast-54\",\n root: \"oui-text-sm\",\n }}\n {...props}\n />\n <Notional\n classNames={{\n label: \"oui-text-2xs oui-text-base-contrast-54\",\n root: \"oui-text-sm\",\n }}\n {...props}\n />\n </Flex>\n <Divider className=\"oui-w-full\" />\n <Flex className=\"oui-cursor-pointer oui-gap-[2px]\">\n <Checkbox\n id=\"oui-checkbox-hideOtherSymbols\"\n color=\"white\"\n checked={!props.showAllSymbol}\n onCheckedChange={(checked: boolean) => {\n props.setShowAllSymbol(!checked);\n }}\n />\n\n <label\n className=\"oui-text-2xs oui-text-base-contrast-54 oui-cursor-pointer\"\n htmlFor=\"oui-checkbox-hideOtherSymbols\"\n >\n {t(\"trading.hideOtherSymbols\")}\n </label>\n </Flex>\n </Flex>\n );\n};\n\nconst DesktopLayout: React.FC<PositionHeaderState> = (props) => {\n return (\n <Flex py={2} px={3} gap={6} width={\"100%\"} justify={\"start\"}>\n <UnrealPnL\n {...props}\n classNames={{ label: \"oui-text-base-contrast-54\" }}\n />\n <Notional\n {...props}\n classNames={{ label: \"oui-text-base-contrast-54\" }}\n />\n </Flex>\n );\n};\n\nconst UnrealPnL: React.FC<\n PositionHeaderState & {\n classNames?: { root?: string; label?: string; value?: string };\n }\n> = (props) => {\n const { t } = useTranslation();\n\n const unrealPnLClsName =\n typeof props.unrealPnL === \"number\"\n ? props.unrealPnL >= 0\n ? \"oui-text-trade-profit\"\n : \"oui-text-trade-loss\"\n : \"oui-text-base-contrast-80\";\n\n const unrealPnLROIClsName =\n typeof props.unrealPnL === \"number\" && props.unrealPnlROI\n ? props.unrealPnlROI >= 0\n ? \"oui-text-success-darken\"\n : \"oui-text-danger-darken\"\n : \"oui-text-base-contrast-80\";\n\n return (\n <Statistic label={t(\"common.unrealizedPnl\")} classNames={props.classNames}>\n <Flex gap={1}>\n <Text.numeral\n dp={props.pnlNotionalDecimalPrecision}\n rm={Decimal.ROUND_DOWN}\n intensity={80}\n className={unrealPnLClsName}\n >\n {props.unrealPnL ?? \"--\"}\n </Text.numeral>\n {typeof props.unrealPnlROI !== \"undefined\" && (\n <Text.numeral\n prefix=\"(\"\n suffix=\")\"\n rule=\"percentages\"\n size=\"2xs\"\n dp={props.pnlNotionalDecimalPrecision}\n rm={Decimal.ROUND_DOWN}\n className={unrealPnLROIClsName}\n >\n {props.unrealPnlROI}\n </Text.numeral>\n )}\n </Flex>\n </Statistic>\n );\n};\n\nconst Notional: React.FC<\n PositionHeaderState & {\n classNames?: { root?: string; label?: string; value?: string };\n }\n> = (props) => {\n const { t } = useTranslation();\n return (\n <Statistic label={t(\"common.notional\")} classNames={props.classNames}>\n <Text.numeral\n dp={props.pnlNotionalDecimalPrecision}\n rm={Decimal.ROUND_DOWN}\n intensity={80}\n >\n {props.notional ?? \"--\"}\n </Text.numeral>\n </Statistic>\n );\n};\n","import { usePositionStream } from \"@orderly.network/hooks\";\nimport { useDataTap } from \"@orderly.network/react-app\";\nimport { useTradingLocalStorage } from \"../../../hooks\";\n\nexport const usePositionHeaderScript = (inputs: {\n pnlNotionalDecimalPrecision?: number;\n unPnlPriceBasis: \"markPrice\" | \"lastPrice\";\n symbol?: string;\n}) => {\n const { pnlNotionalDecimalPrecision, unPnlPriceBasis, symbol } = inputs;\n const calcMode = unPnlPriceBasis;\n\n const [data] = usePositionStream(symbol, {\n calcMode,\n });\n const aggregated = useDataTap(data.aggregated);\n\n const unrealPnL = aggregated?.total_unreal_pnl;\n const unrealPnlROI = aggregated?.unrealPnlROI;\n const notional = aggregated?.notional;\n const { showAllSymbol, setShowAllSymbol } = useTradingLocalStorage();\n\n return {\n pnlNotionalDecimalPrecision,\n unrealPnL,\n unrealPnlROI,\n notional,\n showAllSymbol,\n setShowAllSymbol,\n };\n};\n\nexport type PositionHeaderState = ReturnType<typeof usePositionHeaderScript>;\n","import React from \"react\";\nimport { usePositionHeaderScript } from \"./positionHeader.script\";\nimport { PositionHeader } from \"./positionHeader.ui\";\n\nexport const PositionHeaderWidget: React.FC<{\n pnlNotionalDecimalPrecision?: number;\n unPnlPriceBasis: \"markPrice\" | \"lastPrice\";\n symbol?: string;\n}> = (props) => {\n const state = usePositionHeaderScript(props);\n return <PositionHeader {...state} />;\n};\n","export { PositionHeader } from \"./positionHeader.ui\";\nexport { PositionHeaderWidget } from \"./positionHeader.widget\";\n","import { FC, SVGProps } from \"react\";\nimport React from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { OrderStatus } from \"@orderly.network/types\";\nimport {\n Box,\n Divider,\n Flex,\n InfoCircleIcon,\n TabPanel,\n Tabs,\n Tooltip,\n} from \"@orderly.network/ui\";\nimport { DesktopOrderListWidget, TabType } from \"@orderly.network/ui-orders\";\nimport {\n LiquidationWidget,\n PositionHistoryWidget,\n PositionsWidget,\n} from \"@orderly.network/ui-positions\";\nimport { DataListState, DataListTabType } from \"./dataList.script\";\n\nconst LazySettingWidget = React.lazy(() =>\n import(\"./setting\").then((mod) => {\n return { default: mod.SettingWidget };\n }),\n);\n\nconst LazyPositionHeaderWidget = React.lazy(() =>\n import(\"../../base/positionHeader\").then((mod) => {\n return { default: mod.PositionHeaderWidget };\n }),\n);\n\nexport const DataList: FC<DataListState> = (props) => {\n const { t } = useTranslation();\n return (\n <Tabs\n defaultValue={props.current || DataListTabType.positions}\n variant=\"contained\"\n trailing={\n <React.Suspense fallback={null}>\n <LazySettingWidget\n pnlNotionalDecimalPrecision={props.pnlNotionalDecimalPrecision}\n setPnlNotionalDecimalPrecision={\n props.setPnlNotionalDecimalPrecision\n }\n unPnlPriceBasis={props.unPnlPriceBasis}\n setUnPnlPriceBasic={props.setUnPnlPriceBasic}\n hideOtherSymbols={!props.showAllSymbol}\n setHideOtherSymbols={(value: boolean) =>\n props.setShowAllSymbol(!value)\n }\n />\n </React.Suspense>\n }\n size=\"lg\"\n className=\"oui-h-full\"\n classNames={{\n // tabsList: \"oui-px-3\",\n tabsContent: \"oui-h-[calc(100%_-_32px)]\",\n trigger: \"oui-group\",\n }}\n >\n <TabPanel\n testid=\"oui-testid-dataList-position-tab\"\n value={DataListTabType.positions}\n title={`${t(\"common.positions\")} ${\n (props.positionCount ?? 0) > 0 ? `(${props.positionCount})` : \"\"\n }`}\n >\n <PositionsView {...props} />\n </TabPanel>\n <TabPanel\n testid=\"oui-testid-dataList-pending-tab\"\n value={DataListTabType.pending}\n title={`${t(\"orders.status.pending\")} ${\n (props.pendingOrderCount ?? 0) > 0\n ? `(${props.pendingOrderCount})`\n : \"\"\n }`}\n >\n <DesktopOrderListWidget\n type={TabType.pending}\n ordersStatus={OrderStatus.INCOMPLETE}\n symbol={!!props.showAllSymbol ? undefined : props.symbol}\n onSymbolChange={props.onSymbolChange}\n testIds={{\n tableBody: \"oui-testid-dataList-pending-table-body\",\n }}\n />\n </TabPanel>\n <TabPanel\n testid=\"oui-testid-dataList-tpsl-tab\"\n value={DataListTabType.tp_sl}\n title={`${t(\"common.tpsl\")} ${\n (props.tpSlOrderCount ?? 0) > 0 ? `(${props.tpSlOrderCount})` : \"\"\n }`}\n >\n <DesktopOrderListWidget\n type={TabType.tp_sl}\n ordersStatus={OrderStatus.INCOMPLETE}\n symbol={!!props.showAllSymbol ? undefined : props.symbol}\n onSymbolChange={props.onSymbolChange}\n testIds={{\n tableBody: \"oui-testid-dataList-tpsl-table-body\",\n }}\n />\n </TabPanel>\n <TabPanel\n testid=\"oui-testid-dataList-filled-tab\"\n value={DataListTabType.filled}\n title={t(\"orders.status.filled\")}\n >\n <DesktopOrderListWidget\n type={TabType.filled}\n symbol={!!props.showAllSymbol ? undefined : props.symbol}\n pnlNotionalDecimalPrecision={props.pnlNotionalDecimalPrecision}\n ordersStatus={OrderStatus.FILLED}\n onSymbolChange={props.onSymbolChange}\n testIds={{\n tableBody: \"oui-testid-dataList-filled-table-body\",\n }}\n sharePnLConfig={props.sharePnLConfig}\n />\n </TabPanel>\n <TabPanel\n testid=\"oui-testid-dataList-positionHistory-tab\"\n value={DataListTabType.positionHistory}\n title={t(\"positions.positionHistory\")}\n >\n <PositionHistoryWidget\n pnlNotionalDecimalPrecision={props.pnlNotionalDecimalPrecision}\n symbol={!!props.showAllSymbol ? undefined : props.symbol}\n onSymbolChange={props.onSymbolChange}\n sharePnLConfig={props.sharePnLConfig}\n />\n </TabPanel>\n <TabPanel\n testid=\"oui-testid-dataList-orderHistory-tab\"\n value={DataListTabType.orderHistory}\n title={t(\"orders.orderHistory\")}\n >\n <DesktopOrderListWidget\n type={TabType.orderHistory}\n pnlNotionalDecimalPrecision={props.pnlNotionalDecimalPrecision}\n symbol={!!props.showAllSymbol ? undefined : props.symbol}\n onSymbolChange={props.onSymbolChange}\n testIds={{\n tableBody: \"oui-testid-dataList-orderHistory-table-body\",\n }}\n sharePnLConfig={props.sharePnLConfig}\n />\n </TabPanel>\n <TabPanel\n testid=\"oui-testid-dataList-liquidation-tab\"\n value={DataListTabType.liquidation}\n title={<LiquidationTab />}\n >\n <LiquidationWidget\n symbol={!!props.showAllSymbol ? undefined : props.symbol}\n />\n </TabPanel>\n </Tabs>\n );\n};\n\nexport const LiquidationTab = () => {\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\nconst PositionsView: FC<DataListState> = (props) => {\n return (\n <Flex direction=\"column\" width=\"100%\" height=\"100%\">\n <React.Suspense fallback={null}>\n <LazyPositionHeaderWidget\n pnlNotionalDecimalPrecision={props.pnlNotionalDecimalPrecision}\n symbol={!!props.showAllSymbol ? undefined : props.symbol}\n unPnlPriceBasis={props.unPnlPriceBasis}\n />\n </React.Suspense>\n <Divider className=\"oui-w-full\" />\n <Box className=\"oui-h-[calc(100%_-_60px)]\" width=\"100%\">\n <PositionsWidget\n symbol={!!props.showAllSymbol ? undefined : props.symbol}\n pnlNotionalDecimalPrecision={props.pnlNotionalDecimalPrecision}\n sharePnLConfig={props.sharePnLConfig}\n calcMode={props.calcMode}\n includedPendingOrder={props.includedPendingOrder}\n onSymbolChange={props.onSymbolChange}\n />\n </Box>\n </Flex>\n );\n};\n","import React from \"react\";\nimport type { PositionsProps } from \"@orderly.network/ui-positions\";\nimport { DataListTabType, useDataListScript } from \"./dataList.script\";\nimport { DataList } from \"./dataList.ui\";\n\nexport const DataListWidget: React.FC<\n { current?: DataListTabType } & PositionsProps\n> = (props) => {\n const state = useDataListScript(props);\n return <DataList {...state} />;\n};\n","export { DataList } from \"./dataList.ui\";\nexport { DataListWidget } from \"./dataList.widget\";\n","import React, { FC, ReactNode } from \"react\";\nimport { Box, cn, Grid, ListView, Text } from \"@orderly.network/ui\";\nimport { LastTradesState } from \"./lastTrades.script\";\nimport { OrderSide } from \"@orderly.network/types\";\nimport { commifyOptional } from \"@orderly.network/utils\";\nimport { useTranslation } from \"@orderly.network/i18n\";\n\nexport const LastTrades: FC<\n LastTradesState & {\n classNames?: {\n root?: string;\n list?: string;\n listHeader?: string;\n listItem?: {\n left?: string;\n mid?: string;\n right?: string;\n };\n };\n style?: React.CSSProperties;\n }\n> = (props) => {\n return (\n <Box\n className={cn(\n \"oui-grid oui-grid-rows=[auto,1fr] oui-h-full oui-w-full\",\n props.classNames?.root\n )}\n style={props.style}\n >\n <Box className=\"oui-pr-1\">\n <Header\n base={props.base}\n quote={props.quote}\n className={props.classNames?.listHeader}\n />\n </Box>\n <List\n data={props.data}\n isLoading={props.isLoading}\n baseDp={props.baseDp}\n quoteDp={props.quoteDp}\n classNames={props.classNames?.listItem}\n className={props.classNames?.list}\n />\n </Box>\n );\n};\n\nconst Row = (props: {\n key?: React.Key | null;\n classNames?: {\n root?: string;\n left?: string;\n mid?: string;\n right?: string;\n };\n left: ReactNode | string;\n mid: ReactNode | string;\n right: ReactNode | string;\n}) => {\n const { left, mid, right, classNames } = props;\n return (\n // <Flex\n // key={key}\n // height={20}\n // gap={2}\n // width={\"100%\"}\n // className={cn(\"oui-text-xs oui-tabular-nums\", classNames?.root)}\n // >\n // <Box className={cn(\"oui-flex-1\", classNames?.left)}>{left}</Box>\n // <Box className={cn(\"oui-flex-1\", classNames?.mid)}>{mid}</Box>\n // <Box className={cn(\"oui-flex-1 oui-text-right\", classNames?.right)}>\n // {right}\n // </Box>\n // </Flex>\n\n <Grid\n cols={3}\n gapX={2}\n width=\"100%\"\n className={cn(\"oui-text-xs oui-tabular-nums\", classNames?.root)}\n >\n <div className={cn(\"oui-flex-1\", classNames?.left)}>{left}</div>\n <div className={cn(\"oui-flex-1\", classNames?.mid)}>{mid}</div>\n <div className={cn(\"oui-flex-1 oui-text-right\", classNames?.right)}>\n {right}\n </div>\n </Grid>\n );\n};\n\nconst Header = (props: { base: string; quote: string; className?: string }) => {\n const { t } = useTranslation();\n return (\n <Row\n left={t(\"common.time\")}\n mid={`${t(\"common.price\")}(${props.quote})`}\n right={`${t(\"common.qty\")}(${props.base})`}\n classNames={{\n root: cn(\n \"oui-text-base-contrast-54 oui-h-[32px] oui-sticky\",\n props.className\n ),\n }}\n />\n );\n};\n\nconst List = (props: {\n data?: any[];\n isLoading?: boolean;\n baseDp: number;\n quoteDp: number;\n classNames?: {\n left?: string;\n mid?: string;\n right?: string;\n };\n className?: string;\n}) => {\n return (\n <ListView\n dataSource={props.data}\n className={cn(\n \"oui-last-trades-list\",\n \"oui-w-full oui-h-full\",\n props.className,\n \"oui-overflow-auto\"\n )}\n contentClassName=\"!oui-space-y-0 oui-pr-[-4px]\"\n renderItem={(item, index) => {\n return (\n <Row\n key={index}\n left={\n <Text.formatted rule={\"date\"} formatString=\"HH:mm:ss\">\n {item?.ts}\n </Text.formatted>\n }\n mid={commifyOptional(item?.price, { fix: props.quoteDp })}\n right={commifyOptional(item?.size, { fix: props.baseDp })}\n classNames={{\n left: cn(\"oui-text-base-contrast-80\", props.classNames?.left),\n right: cn(\n item.side === OrderSide.BUY\n ? \"oui-text-trade-profit\"\n : \"oui-text-trade-loss\",\n props.classNames?.mid\n ),\n mid: cn(\n item.side === OrderSide.BUY\n ? \"oui-text-trade-profit\"\n : \"oui-text-trade-loss\",\n props.classNames?.right\n ),\n }}\n />\n );\n }}\n />\n );\n};\n","import { useMarketTradeStream, useSymbolsInfo } from \"@orderly.network/hooks\";\n\nexport const useLastTradesScript = (symbol: string) => {\n const { data, isLoading } = useMarketTradeStream(symbol);\n // const { quote, quote_dp, base, base_dp } = useContext(SymbolContext);\n const config = useSymbolsInfo()?.[symbol];\n const base = config?.(\"base\");\n const quote = config?.(\"quote\");\n const baseDp = config?.(\"base_dp\");\n const quoteDp = config?.(\"quote_dp\");\n// console.log(\"base, quote\", base, quote, \"baseDp, quoteDp\", baseDp, quoteDp);\n\n return {\n base,\n quote,\n data,\n isLoading,\n baseDp,\n quoteDp,\n };\n};\n\nexport type LastTradesState = ReturnType<typeof useLastTradesScript>;\n","import React from \"react\";\nimport { useLastTradesScript } from \"./lastTrades.script\";\nimport { LastTrades } from \"./lastTrades.ui\";\n\nexport const LastTradesWidget: React.FC<{\n symbol: string;\n classNames?: {\n root?: string;\n list?: string;\n listHeader?: string;\n listItem?: { left?: string; mid?: string; right?: string };\n };\n style?: React.CSSProperties;\n}> = (props) => {\n const state = useLastTradesScript(props.symbol);\n return (\n <LastTrades {...state} classNames={props.classNames} style={props.style} />\n );\n};\n","export { LastTrades } from \"./lastTrades.ui\";\nexport { LastTradesWidget } from \"./lastTrades.widget\";\n","import { useTranslation } from \"@orderly.network/i18n\";\nimport { Button } from \"@orderly.network/ui\";\nimport { FaucetState } from \"./faucet.script\";\n\nexport function FaucetUi(props: FaucetState) {\n const { t } = useTranslation();\n\n if (!props.showFaucet) {\n return null;\n }\n\n return (\n <Button\n variant=\"outlined\"\n fullWidth\n size=\"md\"\n onClick={props.getFaucet}\n loading={props.loading}\n className=\"oui-text-primary-light oui-border-primary-light oui-rounded\"\n data-testid=\"oui-testid-assetView-getFaucet-button\"\n >\n {t(\"trading.faucet.getTestUSDC\")}\n </Button>\n );\n}\n","import { useMemo, useState } from \"react\";\nimport {\n useAccount,\n useConfig,\n useMutation,\n useWalletConnector,\n} from \"@orderly.network/hooks\";\nimport { AccountStatusEnum, ChainNamespace } from \"@orderly.network/types\";\nimport { isTestnet } from \"@orderly.network/utils\";\nimport { modal, toast } from \"@orderly.network/ui\";\nimport { useTranslation } from \"@orderly.network/i18n\";\n\nexport function useFaucetScript() {\n const { t } = useTranslation();\n const { connectedChain, namespace } = useWalletConnector();\n const { state, account } = useAccount();\n const config = useConfig();\n const operatorUrl = config.get<string>(\"operatorUrl\");\n\n const [getTestUSDC, { isMutating }] = useMutation(\n `${operatorUrl}/v1/faucet/usdc`\n );\n const [loading, setLoading] = useState<boolean>(false);\n\n const showFaucet = useMemo(() => {\n if (!connectedChain || !connectedChain.id) {\n return false;\n }\n return (\n (state.status === AccountStatusEnum.EnableTrading ||\n state.status === AccountStatusEnum.EnableTradingWithoutConnected) &&\n isTestnet(parseInt(connectedChain.id as string))\n );\n }, [state, connectedChain]);\n\n const getFaucet = () => {\n if (loading) {\n return;\n }\n setLoading(true);\n const message = t(\"trading.faucet.getTestUSDC.success\", {\n quantity: namespace === ChainNamespace.solana ? \"100\" : \"1,000\",\n });\n\n return getTestUSDC({\n chain_id: account.walletAdapter?.chainId.toString(),\n user_address: state.address,\n broker_id: config.get(\"brokerId\"),\n }).then(\n (res) => {\n setLoading(false);\n if (res.success) {\n return modal.alert({\n title: t(\"trading.faucet.getTestUSDC\"),\n message,\n onOk: () => {\n return new Promise((resolve) => resolve(true));\n },\n });\n }\n res.message && toast.error(res.message);\n },\n (error: Error) => {\n toast.error(error.message);\n }\n );\n };\n return { getFaucet, showFaucet, loading };\n}\n\nexport type FaucetState = ReturnType<typeof useFaucetScript>;\n","import { FaucetUi } from \"./faucet.ui\";\nimport { useFaucetScript } from \"./faucet.script\";\n\nexport function FaucetWidget() {\n const state = useFaucetScript();\n return (\n <FaucetUi {...state}/>\n )\n}","import { FC, useMemo, useState, useCallback, ReactNode } from \"react\";\nimport { useAccount, useLocalStorage } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { useAppContext } from \"@orderly.network/react-app\";\nimport { AccountStatusEnum } from \"@orderly.network/types\";\nimport {\n Flex,\n Text,\n Box,\n Button,\n ArrowDownShortIcon,\n EyeIcon,\n EyeCloseIcon,\n ChevronDownIcon,\n Tooltip,\n Divider,\n gradientTextVariants,\n cn,\n} from \"@orderly.network/ui\";\nimport { AuthGuard } from \"@orderly.network/ui-connector\";\nimport { LTVRiskTooltipWidget } from \"@orderly.network/ui-order-entry\";\nimport { AssetViewState } from \"./assetView.script\";\nimport { FaucetWidget } from \"./faucet/faucet.widget\";\n\ninterface StatusInfo {\n title: string;\n description: string;\n titleColor?: any;\n titleClsName?: string;\n}\n\ninterface TooltipContentProps {\n description: ReactNode;\n formula: ReactNode;\n}\n\ninterface TotalValueProps {\n totalValue?: number;\n visible?: boolean;\n onToggleVisibility?: () => void;\n}\n\ninterface AssetDetailProps {\n label: string;\n description?: ReactNode;\n formula?: ReactNode;\n visible: boolean;\n value?: number | string;\n unit?: string;\n rule?: \"percentages\";\n isConnected?: boolean;\n showPercentage?: boolean;\n placeholder?: string;\n}\n\ninterface AssetValueListProps {\n visible?: boolean;\n freeCollateral?: number | null;\n marginRatioVal?: number;\n renderMMR?: string | number;\n isConnected: boolean;\n currentLtv?: string | number;\n}\n\nconst calculateTextColor = (val: number): string => {\n if (val >= 0 && val < 50) {\n return \"oui-text-success\";\n } else if (val >= 50 && val < 80) {\n return \"oui-text-warning\";\n } else if (val >= 80) {\n return \"oui-text-danger\";\n } else {\n return \"\";\n }\n};\n\nconst useCurrentStatusText = (): StatusInfo => {\n const { state } = useAccount();\n const { wrongNetwork, disabledConnect } = useAppContext();\n const { t } = useTranslation();\n\n return useMemo(() => {\n const statusText = {\n wrongNetwork: {\n title: t(\"connector.wrongNetwork\"),\n description: t(\"connector.wrongNetwork.tooltip\"),\n titleColor: \"warning\",\n },\n connectWallet: {\n title: t(\"connector.connectWallet\"),\n description: t(\"connector.trade.connectWallet.tooltip\"),\n titleClsName:\n \"oui-text-transparent oui-bg-clip-text oui-gradient-brand\",\n },\n createAccount: {\n title: t(\"connector.createAccount\"),\n description: t(\"connector.trade.createAccount.tooltip\"),\n titleColor: \"primary\",\n },\n enableTrading: {\n title: t(\"connector.enableTrading\"),\n description: t(\"connector.trade.enableTrading.tooltip\"),\n titleColor: \"primary\",\n },\n empty: {\n title: \"\",\n description: \"\",\n },\n };\n\n if (disabledConnect) {\n return statusText.connectWallet;\n }\n\n if (wrongNetwork) {\n return statusText.wrongNetwork;\n }\n\n // EnableTradingWithoutConnected is enabled trading status, so we don't need to show anything\n if (state.status === AccountStatusEnum.EnableTradingWithoutConnected) {\n return statusText.empty;\n }\n\n if (state.status <= AccountStatusEnum.NotConnected) {\n return statusText.connectWallet;\n }\n\n if (state.status <= AccountStatusEnum.NotSignedIn) {\n return statusText.createAccount;\n }\n\n if (state.status < AccountStatusEnum.EnableTrading) {\n return statusText.enableTrading;\n }\n\n return statusText.empty;\n }, [t, state.status, wrongNetwork, disabledConnect]);\n};\n\nexport const TooltipContent: FC<TooltipContentProps> = (props) => {\n const { description, formula } = props;\n return (\n <div className=\"oui-min-w-[204px] oui-max-w-[240px] oui-text-2xs oui-leading-normal oui-text-base-contrast-80\">\n {typeof description !== \"undefined\" && description !== null && (\n <span>{description}</span>\n )}\n <Divider className=\"oui-border-white/10\" my={2} />\n {typeof formula !== \"undefined\" && formula !== null && (\n <span>{formula}</span>\n )}\n </div>\n );\n};\n\nconst TotalValue: FC<TotalValueProps> = (props) => {\n const { t } = useTranslation();\n const { totalValue, visible = true, onToggleVisibility } = props;\n return (\n <Flex\n direction=\"column\"\n gap={1}\n className=\"oui-text-2xs\"\n itemAlign=\"center\"\n >\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 <Flex gap={1} itemAlign=\"center\">\n <Text size=\"2xs\" color=\"neutral\" weight=\"semibold\">\n {`${t(\"trading.asset.myAssets\")} (USDC)`}\n </Text>\n <button onClick={onToggleVisibility}>\n {visible ? (\n <EyeIcon size={18} className=\"oui-text-base-contrast-54\" />\n ) : (\n <EyeCloseIcon size={18} className=\"oui-text-base-contrast-54\" />\n )}\n </button>\n </Flex>\n </Flex>\n );\n};\n\nconst AssetDetail: FC<AssetDetailProps> = (props) => {\n const {\n label,\n description,\n formula,\n visible,\n value,\n unit,\n rule,\n placeholder,\n } = props;\n return (\n <Flex justify=\"between\">\n <Tooltip\n className={\"\"}\n content={<TooltipContent description={description} formula={formula} />}\n >\n <Text\n size=\"2xs\"\n color=\"neutral\"\n weight=\"semibold\"\n className=\"oui-cursor-pointer oui-border-b oui-border-dashed oui-border-line-12\"\n >\n {label}\n </Text>\n </Tooltip>\n <Text.numeral\n visible={visible}\n size=\"2xs\"\n unit={unit}\n unitClassName=\"oui-text-base-contrast-36 oui-ml-0.5\"\n as=\"div\"\n rule={rule}\n padding={false}\n dp={2}\n // suffix={value && unit}\n placeholder={placeholder}\n >\n {value || \"--\"}\n </Text.numeral>\n </Flex>\n );\n};\n\nconst LTVDetail: FC<Pick<AssetDetailProps, \"value\" | \"visible\">> = (props) => {\n const { visible, value } = props;\n const { t } = useTranslation();\n return (\n <Flex justify=\"between\">\n <Tooltip\n className={cn(\"oui-bg-base-6 oui-p-2\")}\n content={<LTVRiskTooltipWidget />}\n >\n <Text\n size=\"2xs\"\n color=\"neutral\"\n weight=\"semibold\"\n className=\"oui-cursor-pointer oui-border-b oui-border-dashed oui-border-line-12\"\n >\n {t(\"transfer.LTV\")}\n </Text>\n </Tooltip>\n <Text\n size=\"2xs\"\n className={cn(\n \"select-none\",\n visible && calculateTextColor(Number(value)),\n )}\n >\n {visible ? `${value}%` : \"*****\"}\n </Text>\n </Flex>\n );\n};\n\nconst AssetValueList: FC<AssetValueListProps> = (props) => {\n const {\n visible = true,\n freeCollateral,\n marginRatioVal,\n renderMMR,\n isConnected,\n currentLtv,\n } = props;\n\n const [optionsOpen, setOptionsOpen] = useLocalStorage(\n \"orderly_entry_asset_list_open\",\n false,\n );\n const [open, setOpen] = useState<boolean>(optionsOpen);\n\n const { t } = useTranslation();\n\n const toggleOpen = useCallback(() => {\n setOpen((prevOpen) => !prevOpen);\n setTimeout(() => {\n setOptionsOpen(!open);\n }, 0);\n }, []);\n\n const showLTV =\n typeof currentLtv === \"number\" &&\n !Number.isNaN(currentLtv) &&\n currentLtv > 0;\n\n return (\n <Box className=\"oui-group\">\n <Flex\n justify=\"center\"\n gap={1}\n itemAlign=\"center\"\n className=\"oui-cursor-pointer\"\n onClick={toggleOpen}\n >\n <Divider className=\"oui-flex-1\" />\n <ChevronDownIcon\n size={12}\n color=\"white\"\n className={cn(\"oui-transition-transform\", open && \"oui-rotate-180\")}\n />\n <Divider className=\"oui-flex-1\" />\n </Flex>\n <Box\n style={{ transform: \"translateZ(0)\" }}\n className={cn(\n \"oui-select-none oui-space-y-1.5 oui-overflow-hidden\",\n \"oui-transition-[max-height] oui-duration-150\",\n \"group-hover:oui-will-change-[max-height]\",\n open\n ? showLTV\n ? \"oui-max-h-[94px]\"\n : \"oui-max-h-[69px]\"\n : \"oui-max-h-0\",\n )}\n >\n <AssetDetail\n label={t(\"trading.asset.freeCollateral\")}\n description={t(\"trading.asset.freeCollateral.tooltip\")}\n formula={t(\"trading.asset.freeCollateral.formula\")}\n visible={visible}\n // TODO: change AssetDetail value\n value={freeCollateral! === 0 ? (\"0\" as any) : freeCollateral}\n unit=\"USDC\"\n />\n <AssetDetail\n label={t(\"trading.asset.marginRatio\")}\n description={t(\"trading.asset.marginRatio.tooltip\")}\n formula={t(\"trading.asset.marginRatio.formula\")}\n visible={visible}\n value={marginRatioVal}\n isConnected={isConnected}\n rule=\"percentages\"\n showPercentage={true}\n placeholder=\"--%\"\n />\n <AssetDetail\n label={t(\"trading.asset.maintenanceMarginRatio\")}\n description={t(\"trading.asset.maintenanceMarginRatio.tooltip\")}\n formula={t(\"trading.asset.maintenanceMarginRatio.formula\")}\n visible={visible}\n value={renderMMR}\n rule=\"percentages\"\n showPercentage={true}\n placeholder=\"--%\"\n />\n {showLTV && <LTVDetail visible={visible} value={currentLtv} />}\n </Box>\n </Box>\n );\n};\n\nexport const AssetView: FC<\n AssetViewState & { isFirstTimeDeposit?: boolean }\n> = ({\n networkId,\n isFirstTimeDeposit,\n totalValue,\n onDeposit,\n onWithdraw,\n onTransfer,\n toggleVisible,\n visible,\n freeCollateral,\n marginRatioVal,\n renderMMR,\n isConnected,\n isMainAccount,\n hasSubAccount,\n currentLtv,\n}) => {\n const { title, description, titleColor, titleClsName } =\n useCurrentStatusText();\n\n const { t } = useTranslation();\n\n const transferButton = hasSubAccount && (\n <Button\n fullWidth\n color=\"secondary\"\n size=\"md\"\n onClick={onTransfer}\n data-testid=\"oui-testid-assetView-transfer-button\"\n >\n <Text>{t(\"common.transfer\")}</Text>\n </Button>\n );\n\n const depositButton = isMainAccount && (\n <Button\n data-testid=\"oui-testid-assetView-deposit-button\"\n fullWidth\n size=\"md\"\n onClick={onDeposit}\n >\n {!hasSubAccount && <ArrowDownShortIcon color=\"white\" opacity={1} />}\n <Text>{t(\"common.deposit\")}</Text>\n </Button>\n );\n\n const withdrawButton = isMainAccount && (\n <Button\n fullWidth\n color=\"secondary\"\n size=\"md\"\n onClick={onWithdraw}\n data-testid=\"oui-testid-assetView-withdraw-button\"\n >\n {!hasSubAccount && (\n <ArrowDownShortIcon\n color=\"white\"\n opacity={1}\n className=\"oui-rotate-180\"\n />\n )}\n <Text>{t(\"common.withdraw\")}</Text>\n </Button>\n );\n\n return (\n <Box className=\"oui-relative\">\n {title && description && (\n <Flex direction=\"column\" gap={1} className=\"oui-mb-[32px]\">\n <Text\n size=\"lg\"\n weight=\"bold\"\n color={titleColor || \"inherit\"}\n className={titleClsName}\n >\n {title}\n </Text>\n <Text\n size=\"2xs\"\n color=\"neutral\"\n weight=\"semibold\"\n className=\"oui-text-center\"\n >\n {description}\n </Text>\n </Flex>\n )}\n <AuthGuard\n networkId={networkId}\n buttonProps={{ size: \"md\", fullWidth: true }}\n >\n {isFirstTimeDeposit && isMainAccount ? (\n <>\n <Box>\n <Flex direction=\"column\" gap={1} className=\"oui-mb-[32px]\">\n <Text.gradient size=\"lg\" weight=\"bold\" color=\"brand\">\n {t(\"trading.asset.startTrading\")}\n </Text.gradient>\n <Text size=\"2xs\" color=\"neutral\" weight=\"semibold\">\n {t(\"trading.asset.startTrading.description\")}\n </Text>\n </Flex>\n </Box>\n <Button\n data-testid=\"oui-testid-assetView-deposit-button\"\n fullWidth\n size=\"md\"\n onClick={onDeposit}\n >\n <ArrowDownShortIcon color=\"white\" opacity={1} />\n <Text>{t(\"common.deposit\")}</Text>\n </Button>\n\n <Box className=\"oui-mt-3\">\n <FaucetWidget />\n </Box>\n </>\n ) : (\n <Box className=\"oui-space-y-4\">\n <TotalValue\n totalValue={totalValue}\n visible={visible}\n onToggleVisibility={toggleVisible}\n />\n <AssetValueList\n visible={visible}\n freeCollateral={freeCollateral}\n marginRatioVal={marginRatioVal}\n renderMMR={renderMMR}\n isConnected={isConnected}\n currentLtv={currentLtv}\n />\n <Flex\n gap={isMainAccount ? (hasSubAccount ? 2 : 3) : 0}\n itemAlign=\"center\"\n >\n {isMainAccount ? (\n <>\n {depositButton}\n {transferButton}\n {withdrawButton}\n </>\n ) : (\n transferButton\n )}\n </Flex>\n {isMainAccount && <FaucetWidget />}\n </Box>\n )}\n </AuthGuard>\n <div\n className={cn(\n \"oui-absolute oui-inset-0 oui-rotate-180\",\n \"oui-pointer-events-none oui-rounded-2xl oui-blur-[200px]\",\n )}\n style={{\n background:\n \"conic-gradient(from -40.91deg at 40.63% 50.41%, rgba(159, 115, 241, 0) -48.92deg, rgba(242, 98, 181, 0) 125.18deg, #5FC5FF 193.41deg, #FFAC89 216.02deg, #8155FF 236.07deg, #789DFF 259.95deg, rgba(159, 115, 241, 0) 311.08deg, rgba(242, 98, 181, 0) 485.18deg)\",\n }}\n />\n </Box>\n );\n};\n","import { useCallback, useMemo } from \"react\";\nimport {\n useAccountInstance,\n useEventEmitter,\n useLocalStorage,\n useAccount,\n useConfig,\n useCollateral,\n useMarginRatio,\n usePositionStream,\n useComputedLTV,\n} from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { useDataTap } from \"@orderly.network/react-app\";\nimport { AccountStatusEnum, NetworkId } from \"@orderly.network/types\";\nimport { modal, toast } from \"@orderly.network/ui\";\nimport {\n DepositAndWithdrawWithDialogId,\n TransferDialogId,\n} from \"@orderly.network/ui-transfer\";\n\nexport const useAssetViewScript = () => {\n const { t } = useTranslation();\n const account = useAccountInstance();\n const ee = useEventEmitter();\n\n const { totalValue } = useCollateral({\n dp: 2,\n });\n\n const networkId = useConfig(\"networkId\") as NetworkId;\n const { state, isMainAccount } = useAccount();\n const { freeCollateral } = useCollateral({\n dp: 2,\n });\n const { marginRatio, mmr } = useMarginRatio();\n const isConnected = state.status >= AccountStatusEnum.Connected;\n const [{ aggregated }, positionsInfo] = usePositionStream();\n const marginRatioVal = useMemo(() => {\n return Math.min(\n 10,\n aggregated.notional === 0\n ? positionsInfo[\"margin_ratio\"](10)!\n : marginRatio,\n );\n }, [marginRatio, aggregated]);\n\n // const renderMMR = useMemo(() => {\n // if (!mmr) {\n // return \"\";\n // }\n // const bigMMR = new Decimal(mmr);\n // return bigMMR.mul(100).todp(2, 0).toFixed(2);\n // }, [mmr]);\n\n const openDepositAndWithdraw = useCallback(\n (viewName: \"deposit\" | \"withdraw\") => {\n // desktop always show dialog\n return modal.show(DepositAndWithdrawWithDialogId, {\n activeTab: viewName,\n });\n },\n [],\n );\n\n const onDeposit = useCallback(async () => {\n return openDepositAndWithdraw(\"deposit\");\n }, []);\n\n const onWithdraw = useCallback(async () => {\n return openDepositAndWithdraw(\"withdraw\");\n }, []);\n\n const onTransfer = useCallback(async () => {\n return modal.show(TransferDialogId);\n }, []);\n\n const onSettle = useCallback(async () => {\n return account\n .settle()\n .catch((e) => {\n if (e.code === -1104) {\n toast.error(t(\"settle.settlement.error\"));\n return Promise.reject(e);\n }\n if (\n e.message.indexOf(\n \"Signing off chain messages with Ledger is not yet supported\",\n ) !== -1\n ) {\n ee.emit(\"wallet:sign-message-with-ledger-error\", {\n message: e.message,\n userAddress: account.address,\n });\n }\n })\n .then((res) => {\n toast.success(t(\"settle.settlement.requested\"));\n return Promise.resolve(res);\n });\n }, [account, t]);\n\n const [visible, setVisible] = useLocalStorage<boolean>(\n \"orderly_assets_visible\",\n true,\n );\n\n const toggleVisible = useCallback(() => {\n // @ts-ignore\n setVisible((visible: boolean) => {\n return !visible;\n });\n }, [visible]);\n\n const currentLtv = useComputedLTV();\n const _freeCollateral = useDataTap(freeCollateral) ?? undefined;\n const _marginRatioVal = useDataTap(marginRatioVal) ?? undefined;\n const _mmr = useDataTap(mmr) ?? undefined;\n const _totalValue = useDataTap(totalValue) ?? undefined;\n\n return {\n onDeposit,\n onWithdraw,\n onTransfer,\n onSettle,\n visible,\n toggleVisible,\n networkId,\n totalValue: _totalValue,\n status: state.status,\n freeCollateral: _freeCollateral,\n marginRatioVal: _marginRatioVal,\n renderMMR: _mmr,\n isConnected,\n isMainAccount,\n hasSubAccount: !!state.subAccounts?.length,\n currentLtv,\n };\n};\n\nexport type AssetViewState = ReturnType<typeof useAssetViewScript>;\n","import React from \"react\";\nimport { useAssetViewScript } from \"./assetView.script\";\nimport { AssetView } from \"./assetView.ui\";\n\ntype AssetViewWidgetProps = {\n isFirstTimeDeposit?: boolean;\n};\n\nexport const AssetViewWidget: React.FC<AssetViewWidgetProps> = (props) => {\n const state = useAssetViewScript();\n return <AssetView {...state} isFirstTimeDeposit={props.isFirstTimeDeposit} />;\n};\n","export { AssetView } from \"./assetView.ui\";\nexport { AssetViewWidget } from \"./assetView.widget\";\n","import React, {\n createContext,\n FC,\n PropsWithChildren,\n useContext,\n useState,\n} from \"react\";\nimport { BasicSymbolInfo } from \"../../../types/types\";\nimport { QtyMode, TotalMode } from \"./types\";\n\nexport interface OrderBookContextValue {\n cellHeight: number;\n mode: QtyMode;\n depth?: string;\n onModeChange?: (mode: QtyMode) => void;\n onItemClick?: (item: number[]) => void;\n showTotal: boolean;\n totalMode: TotalMode;\n pendingOrders: ReadonlyArray<number> | number[];\n onTotalModeChange?: (mode: TotalMode) => void;\n symbolInfo: BasicSymbolInfo;\n}\n\nexport const OrderBookContext = createContext({\n cellHeight: 22,\n} as OrderBookContextValue);\n\nexport const useOrderBookContext = () => useContext(OrderBookContext);\n\nexport const ORDERBOOK_COIN_TYPE_KEY = \"orderbook_coin_type\";\n\nexport const ORDERBOOK_MOBILE_COIN_TYPE_KEY = \"orderbook_mobile_coin_unit\";\n\ninterface OrderBookProviderProps {\n cellHeight: number;\n depth?: string;\n showTotal: boolean;\n pendingOrders: ReadonlyArray<number> | number[];\n onItemClick?: (item: number[]) => void;\n symbolInfo: BasicSymbolInfo;\n}\n\nexport const OrderBookProvider: FC<\n PropsWithChildren<OrderBookProviderProps>\n> = (props) => {\n const [mode, setMode] = useState<QtyMode>(\"quantity\");\n const [totalMode, setTotalMode] = useState<QtyMode>(\"quantity\");\n const memoizedValue = React.useMemo<OrderBookContextValue>(() => {\n return {\n cellHeight: props.cellHeight,\n onItemClick: props.onItemClick,\n mode,\n totalMode: totalMode || \"quantity\",\n depth: props.depth,\n onModeChange: setMode,\n onTotalModeChange: setTotalMode,\n showTotal: props.showTotal || false,\n pendingOrders: props.pendingOrders,\n symbolInfo: props.symbolInfo,\n };\n }, [\n mode,\n props.cellHeight,\n props.depth,\n props.onItemClick,\n props.pendingOrders,\n props.showTotal,\n props.symbolInfo,\n totalMode,\n ]);\n return (\n <OrderBookContext.Provider value={memoizedValue}>\n {props.children}\n </OrderBookContext.Provider>\n );\n};\n","export type QtyMode = \"quantity\" | \"amount\";\nexport type TotalMode = \"quantity\" | \"amount\";\n\nexport enum OrderBookCellType {\n BID = \"bid\",\n ASK = \"ask\",\n}\n","import { cn } from \"@orderly.network/ui\";\nimport { FC, useMemo } from \"react\";\n\nexport enum CellBarDirection {\n LEFT_TO_RIGHT,\n RIGHT_TO_LEFT,\n}\n\ninterface CellBarProps {\n width: number;\n className?: string;\n direction?: CellBarDirection\n}\n\nexport const CellBar: FC<CellBarProps> = (props) => {\n const { direction = CellBarDirection.RIGHT_TO_LEFT } = props;\n const transform = useMemo(() => {\n const x = Math.max(props.width, 0);\n if (direction === CellBarDirection.LEFT_TO_RIGHT) {\n return { transform: `translateX(${x}%)` };\n }\n return { transform: `translateX(-${x}%)` };\n \n }, [props.width]);\n\n return (\n <div\n className={cn(\n \"oui-absolute oui-right-[-100%] oui-top-0 oui-h-full oui-w-full oui-transition-transform oui-pointer-events-none\",\n direction === CellBarDirection.LEFT_TO_RIGHT && \"oui-left-[-100%]\",\n props.className\n )}\n style={transform}\n />\n );\n};\n","import { FC, useMemo } from \"react\";\nimport { useLocalStorage } from \"@orderly.network/hooks\";\nimport { cn, Divider, parseNumber, Text } from \"@orderly.network/ui\";\nimport { getPrecisionByNumber } from \"@orderly.network/utils\";\nimport { BasicSymbolInfo } from \"../../../types/types\";\nimport { CellBar, CellBarDirection } from \"../../base/orderBook/cellBar\";\nimport {\n ORDERBOOK_COIN_TYPE_KEY,\n useOrderBookContext,\n} from \"../../base/orderBook/orderContext\";\nimport { OrderBookCellType } from \"../../base/orderBook/types\";\n\nexport interface DesktopOrderBookCellProps {\n background: string;\n maxQty: number;\n price: number;\n quantity: number;\n // size: number;\n count: number;\n accumulated: number;\n accumulatedAmount: number;\n type: OrderBookCellType;\n symbolInfo: BasicSymbolInfo;\n base: string;\n quote: string;\n isHover: boolean;\n currentHover: boolean;\n onMouseEnter: () => void;\n onMouseLeave: () => void;\n}\n\nexport const DesktopOrderBookCell: FC<DesktopOrderBookCellProps> = (props) => {\n const { cellHeight, showTotal, onItemClick, depth, pendingOrders } =\n useOrderBookContext();\n const {\n symbolInfo,\n currentHover,\n accumulated,\n accumulatedAmount,\n count,\n price,\n quantity,\n base,\n quote,\n } = props;\n\n const { base_dp, quote_dp } = symbolInfo;\n\n const [coinType] = useLocalStorage<string>(ORDERBOOK_COIN_TYPE_KEY, base);\n\n const width = Number.isNaN(price) ? 0 : (accumulated / count) * 100;\n\n const dp = useMemo(() => {\n return getPrecisionByNumber(depth || `${quote_dp}`);\n }, [depth, quote_dp]);\n\n const totalAmount = Number.isNaN(accumulated)\n ? \"-\"\n : accumulatedAmount?.toString();\n\n const isPendingOrder = useMemo(() => {\n const priceStr = parseNumber(price, { dp: dp, padding: true });\n return pendingOrders.some(\n (item) => priceStr === parseNumber(item, { dp: dp, padding: true }),\n );\n }, [pendingOrders, price, dp]);\n\n return (\n <div\n className=\"oui-relative oui-flex oui-cursor-pointer oui-flex-row oui-justify-between oui-pl-3 oui-text-xs oui-tabular-nums oui-text-base-contrast-80\"\n style={{ height: `${cellHeight}px` }}\n onClick={() => {\n if (Number.isNaN(price) || Number.isNaN(quantity)) {\n return;\n }\n onItemClick?.([price, quantity]);\n }}\n onMouseEnter={props.onMouseEnter}\n onMouseLeave={props.onMouseLeave}\n >\n <div\n className={cn(\n \"oui-mr-2 oui-flex oui-basis-7/12 oui-flex-row oui-items-center\",\n showTotal && \"oui-basis-5/12\",\n )}\n >\n <div\n className={cn(\n \"oui-flex-1 oui-text-left\",\n props.type === OrderBookCellType.ASK\n ? \"oui-text-trade-loss\"\n : \"oui-text-trade-profit\",\n )}\n >\n <Text.numeral dp={dp}>{price}</Text.numeral>\n </div>\n <div className=\"oui-flex-1 oui-text-right oui-text-base-contrast-80\">\n <Text.numeral dp={base_dp}>{quantity}</Text.numeral>\n </div>\n </div>\n <div\n className={cn(\n \"oui-fex-row oui-relative oui-flex oui-basis-5/12 oui-items-center oui-justify-end oui-overflow-hidden\",\n showTotal && \"oui-basis-7/12\",\n )}\n >\n {showTotal ? (\n <>\n <div className={cn(\"oui-flex-1 oui-pr-3 oui-text-right\")}>\n <Text.numeral dp={base_dp} className=\"oui-z-10\">\n {accumulated}\n </Text.numeral>\n </div>\n <div className={cn(\"oui-flex-1 oui-pr-3 oui-text-right\")}>\n <Text.numeral dp={0} className=\"oui-z-10\">\n {totalAmount}\n </Text.numeral>\n </div>\n </>\n ) : (\n <div className={cn(\"oui-flex-1 oui-pr-3 oui-text-right\")}>\n {coinType === base && (\n <Text.numeral dp={base_dp} className=\"oui-z-10\">\n {accumulated}\n </Text.numeral>\n )}\n {coinType === quote && (\n <Text.numeral dp={0} className=\"oui-z-10\">\n {totalAmount}\n </Text.numeral>\n )}\n </div>\n )}\n <CellBar\n width={width}\n direction={CellBarDirection.LEFT_TO_RIGHT}\n className={\n props.type === OrderBookCellType.ASK\n ? \"oui-bg-trade-loss/10\"\n : \"oui-bg-trade-profit/10\"\n }\n />\n </div>\n\n {isPendingOrder && (\n <div\n className={cn(\n \"oui-pointer-events-none oui-absolute oui-left-[4px] oui-size-[4px] oui-rounded-full\",\n props.type === OrderBookCellType.ASK && \"oui-bg-trade-loss\",\n props.type === OrderBookCellType.BID && \"oui-bg-trade-profit\",\n )}\n style={{ top: `${cellHeight / 2 - 2}px` }}\n />\n )}\n\n {props.isHover && (\n <div className=\"oui-absolute oui-inset-0 oui-bg-white oui-opacity-[.12]\" />\n )}\n {currentHover && (\n <div\n className={cn(\n \"oui-absolute oui-inset-x-0\",\n props.type === OrderBookCellType.ASK && \"oui-top-0\",\n props.type === OrderBookCellType.BID && \"oui-bottom-0\",\n )}\n >\n <Divider\n lineStyle=\"dashed\"\n className={cn(\n \"oui-w-full\",\n props.type === OrderBookCellType.BID && \"oui-border-trade-profit\",\n props.type === OrderBookCellType.ASK && \"oui-border-trade-loss\",\n )}\n />\n </div>\n )}\n </div>\n );\n};\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport React, { useCallback, useMemo, useState } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n TooltipContent,\n TooltipTrigger,\n Text,\n TooltipRoot,\n TooltipArrow,\n cn,\n} from \"@orderly.network/ui\";\nimport { Decimal } from \"@orderly.network/utils\";\nimport { BasicSymbolInfo } from \"../../../types/types\";\nimport { useOrderBookContext } from \"../../base/orderBook/orderContext\";\nimport { OrderBookCellType } from \"../../base/orderBook/types\";\nimport { DesktopOrderBookCell } from \"./cell.desktop\";\n\ninterface DesktopListBoxProps {\n type: OrderBookCellType;\n data: number[][];\n countQty: number;\n}\n\nconst calcHintInfo = (item: number[] | null) => {\n if (!item) {\n return { sumQty: 0, sumQtyAmount: 0, avgPrice: 0 };\n }\n const [, , qty, amount] = item;\n const sumQty = !Number.isNaN(qty) ? qty : 0;\n const sumQtyAmount = !Number.isNaN(amount) ? amount : 0;\n return {\n sumQty: sumQty,\n sumQtyAmount: sumQtyAmount,\n avgPrice:\n sumQtyAmount === 0 || sumQty === 0\n ? 0\n : new Decimal(sumQtyAmount).div(sumQty).toNumber(),\n };\n};\n\nexport const DesktopListBox: React.FC<DesktopListBoxProps> = (props) => {\n const { data, type, countQty } = props;\n const { symbolInfo, depth } = useOrderBookContext();\n\n const findMaxItem = useCallback(() => {\n if (!data?.length) {\n return null;\n }\n if (type === OrderBookCellType.ASK) {\n const index = data.findIndex((item) => !Number.isNaN(item[0]));\n if (index !== -1) {\n return data[index];\n }\n return null;\n } else {\n const len = data.length;\n for (let index = len - 1; index >= 0; index--) {\n const item = data[index];\n if (!Number.isNaN(item[0])) {\n return item;\n }\n }\n return null;\n }\n }, [data, type]);\n\n const priceDp = useMemo(() => {\n if (depth?.toString().includes(\".\")) {\n return depth.toString().split(\".\")[1].length;\n }\n return 0;\n }, [depth]);\n\n const maxQty = useMemo(() => {\n return data.reduce((a, b) => Math.max(a, b[1]), 0);\n }, [data]);\n\n const [hoverIndex, setHoverIndex] = useState<number>(-1);\n\n return (\n <div className=\"oui-order-book-list oui-flex oui-flex-col oui-gap-px\">\n {data.map((item, index) => {\n return (\n <Tip\n key={index}\n index={index}\n item={item}\n countQty={countQty}\n setHoverIndex={setHoverIndex}\n hoverIndex={hoverIndex}\n type={type}\n maxQty={maxQty}\n priceDp={priceDp}\n symbolInfo={symbolInfo}\n findMaxItem={findMaxItem}\n />\n );\n })}\n </div>\n );\n};\n\nconst Tip: React.FC<{\n index: number;\n item: any;\n countQty: number;\n setHoverIndex: any;\n type: OrderBookCellType;\n maxQty: number;\n hoverIndex: number;\n priceDp: number;\n // base: any;\n // quote: any;\n // baseDp: number;\n // quoteDp: number;\n findMaxItem: () => number[] | null;\n symbolInfo: BasicSymbolInfo;\n}> = (props) => {\n const {\n index,\n item,\n setHoverIndex,\n type,\n maxQty,\n hoverIndex,\n priceDp,\n countQty,\n symbolInfo,\n findMaxItem,\n } = props;\n\n const { base, quote, base_dp: baseDp, quote_dp: quoteDp } = symbolInfo;\n const { t } = useTranslation();\n\n const isHover =\n hoverIndex !== -1\n ? type === OrderBookCellType.ASK\n ? index >= hoverIndex\n : index <= hoverIndex\n : false;\n\n const [open, setOpen] = useState(false);\n\n const hintInfo = useMemo(() => {\n const info = calcHintInfo(item);\n return info.avgPrice === 0 ? calcHintInfo(findMaxItem()) : info;\n }, [item, findMaxItem]);\n\n return (\n <TooltipRoot open={open} onOpenChange={setOpen}>\n <TooltipTrigger>\n <DesktopOrderBookCell\n background={\"\"}\n price={item[0]}\n quantity={item[1]}\n accumulated={item[2]}\n count={countQty}\n type={type}\n accumulatedAmount={item[3]}\n maxQty={maxQty}\n isHover={isHover}\n currentHover={hoverIndex === index}\n symbolInfo={symbolInfo}\n base={base}\n quote={quote}\n onMouseEnter={() => {\n setHoverIndex(index);\n setOpen(true);\n }}\n onMouseLeave={() => {\n setHoverIndex(-1);\n setOpen(false);\n }}\n />\n </TooltipTrigger>\n <TooltipContent\n className={cn(\n \"oui-rounded-base oui-flex oui-w-full oui-max-w-[400px] oui-flex-col oui-gap-2 oui-bg-base-6 oui-p-3 oui-text-2xs oui-shadow-md\",\n // type === OrderBookCellType.ASK ? `oui-mb-${30}` : \"oui-mt-0\"\n )}\n align={type === OrderBookCellType.ASK ? \"end\" : \"start\"}\n alignOffset={-25.4}\n side=\"left\"\n sideOffset={2}\n onPointerEnter={(e) => e.preventDefault()}\n >\n <Row\n title={`${t(\"common.avgPrice\")}≈`}\n content={hintInfo.avgPrice}\n // contentDp={priceDp}\n contentDp={quoteDp}\n />\n <Row\n title={`${t(\"trading.orderBook.sum\")} (${base})`}\n content={hintInfo.sumQty}\n contentDp={baseDp}\n />\n <Row\n title={`${t(\"trading.orderBook.sum\")} (${quote})`}\n content={hintInfo.sumQtyAmount}\n contentDp={quoteDp}\n />\n <TooltipArrow\n className=\"oui-fill-base-6\"\n style={{\n transform:\n type === OrderBookCellType.ASK\n ? \"translateX(80%)\"\n : \"translateX(-80%)\",\n }}\n />\n </TooltipContent>\n </TooltipRoot>\n );\n};\n\nconst Row: React.FC<{ title: string; content: number; contentDp: number }> = (\n props,\n) => {\n const { title, content, contentDp } = props;\n return (\n <div className=\"oui-flex oui-flex-row oui-justify-between oui-gap-4\">\n <div className=\"oui-select-none oui-text-base-contrast-36\">{title}</div>\n <div className=\"oui-text-end\">\n <Text.numeral dp={contentDp}>{content}</Text.numeral>\n </div>\n </div>\n );\n};\n","import { FC, useMemo } from \"react\";\nimport { OrderBookCellType } from \"../../base/orderBook/types\";\nimport { DesktopListBox } from \"./listBox.desktop\";\n\nexport interface Props {\n data: number[][];\n}\n\nexport const DesktopAsks: FC<Props> = (props) => {\n const { data } = props;\n const countQty = useMemo(() => {\n let max = Number.NaN;\n const len = data.length;\n let index = 0;\n\n while (Number.isNaN(max) && index < len) {\n max = data[index][2];\n index++;\n }\n\n return max;\n }, [data]);\n\n return (\n <DesktopListBox\n type={OrderBookCellType.ASK}\n data={data}\n countQty={countQty}\n />\n );\n};\n","import { FC, useMemo } from \"react\";\nimport { OrderBookCellType } from \"../../base/orderBook/types\";\nimport { DesktopListBox } from \"./listBox.desktop\";\n\nexport interface Props {\n data: any[];\n}\n\nexport const DesktopBids: FC<Props> = (props) => {\n const { data } = props;\n const countQty = useMemo(() => {\n let max = Number.NaN;\n // let len = data.length;\n let index = data.length - 1;\n\n while (Number.isNaN(max) && index > 0) {\n max = data[index][2];\n index--;\n }\n\n return max;\n // return data.length > 0 ? data[data.length - 1][2] : 0;\n }, [data]);\n return (\n <DesktopListBox\n type={OrderBookCellType.BID}\n data={data}\n countQty={countQty}\n />\n );\n};\n","import { Box, Select } from \"@orderly.network/ui\";\nimport { FC, useMemo } from \"react\";\n\ninterface DesktopDepthSelectProps {\n depths: string[];\n value?: string;\n onChange?: (depth: number) => void;\n}\n\nexport const DesktopDepthSelect: FC<DesktopDepthSelectProps> = (props) => {\n const options = useMemo(() => {\n return props.depths.map((d) => ({\n value: d,\n label: `${d}`,\n }));\n }, [props.depths]);\n\n return (\n <Box pl={3} width={97} className=\"oui-py-[10px]\">\n <Select.options\n options={options}\n size={\"xs\"}\n value={props.value}\n onValueChange={(value: any) => {\n props.onChange?.(value);\n }}\n />\n </Box>\n );\n};\n","import React, { FC, ReactNode } from \"react\";\nimport { useLocalStorage } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n Box,\n CaretDownIcon,\n CaretUpIcon,\n cn,\n Flex,\n Popover,\n} from \"@orderly.network/ui\";\nimport {\n ORDERBOOK_COIN_TYPE_KEY,\n useOrderBookContext,\n} from \"../../base/orderBook/orderContext\";\n\ninterface DesktopHeaderProps {\n quote: string;\n base: string;\n}\n\nconst Option: React.FC<{\n item: string;\n base: string;\n onClick: React.MouseEventHandler<HTMLElement>;\n}> = (props) => {\n const { item, base, onClick } = props;\n const { t } = useTranslation();\n const [coinType, setCoinType] = useLocalStorage(\n ORDERBOOK_COIN_TYPE_KEY,\n base,\n );\n return (\n <Flex\n justify=\"between\"\n itemAlign=\"center\"\n className={cn(\n \"oui-w-full oui-px-2 oui-py-[3px]\",\n \"oui-cursor-pointer\",\n \"oui-text-xs\",\n \"oui-text-base-contrast-54\",\n \"hover:oui-bg-base-6\",\n \"oui-rounded-[3px]\",\n \"oui-transition-all\",\n coinType === item && \"oui-bg-base-5\",\n )}\n onClick={(e) => {\n setCoinType(item);\n onClick(e);\n }}\n >\n {t(\"common.total\")}({item})\n <div\n className={cn(\n \"oui-transition-all\",\n \"oui-w-1\",\n \"oui-h-1\",\n \"oui-rounded-full\",\n \"oui-bg-gradient-to-r\",\n coinType === item &&\n \"oui-from-[rgb(var(--oui-gradient-brand-start))] oui-to-[rgb(var(--oui-gradient-brand-end))]\",\n )}\n />\n </Flex>\n );\n};\n\nexport const DesktopHeader: FC<DesktopHeaderProps> = (props) => {\n const { base, quote = \"USDC\" } = props;\n const { showTotal } = useOrderBookContext();\n const { t } = useTranslation();\n const [popoverOpen, setOpen] = React.useState<boolean>(false);\n const [coinType] = useLocalStorage(ORDERBOOK_COIN_TYPE_KEY, base);\n const TriggerIcon = popoverOpen ? CaretUpIcon : CaretDownIcon;\n return (\n <Flex pl={3} justify={\"between\"} className=\"oui-py-[6px]\">\n <Flex\n gap={1}\n className={cn(\"oui-basis-7/12\", showTotal && \"oui-basis-1/2\")}\n >\n <Box width={\"100%\"}>\n <Title\n id=\"oui-order-book-header-price\"\n className=\"oui-text-base-contrast-36\"\n >\n {`${t(\"common.price\")}(${quote})`}\n </Title>\n </Box>\n <Box width={\"100%\"}>\n <Title\n justifyEnd\n id=\"oui-order-book-header-qty\"\n className=\"oui-text-base-contrast-36\"\n >\n {`${t(\"common.qty\")}(${base})`}\n </Title>\n </Box>\n </Flex>\n <Flex\n gap={1}\n pr={3}\n className={cn(\"oui-basis-5/12\", showTotal && \"oui-basis-1/2\")}\n >\n {showTotal ? (\n <>\n <Box className=\"oui-text-base-contrast-36\" width={\"100%\"}>\n <Title id=\"oui-order-book-header-total-quote\" justifyEnd>\n {`${t(\"common.total\")}(${base})`}\n </Title>\n </Box>\n <Box className=\"oui-text-base-contrast-36\" width={\"100%\"}>\n <Title justifyEnd id=\"oui-order-book-header-total-base\">\n {`${t(\"common.total\")}(${quote})`}\n </Title>\n </Box>\n </>\n ) : (\n <Box width={\"100%\"}>\n <Popover\n open={popoverOpen}\n onOpenChange={setOpen}\n contentProps={{ className: cn(\"oui-w-28 oui-p-1\") }}\n content={\n <Flex\n direction=\"column\"\n itemAlign=\"start\"\n className={cn(\"oui-w-full oui-gap-0.5\")}\n >\n {[base, quote].map((item) => {\n return (\n <Option\n key={`type-${item}`}\n item={item}\n base={base}\n onClick={() => setOpen(false)}\n />\n );\n })}\n </Flex>\n }\n >\n <Flex\n justify=\"end\"\n itemAlign=\"center\"\n className=\"oui-cursor-pointer oui-select-none oui-text-base-contrast-36 oui-transition-all hover:oui-text-base-contrast\"\n >\n <Title justifyEnd id=\"oui-order-book-header-total-base\">\n {`${t(\"common.total\")}(${coinType})`}\n </Title>\n <TriggerIcon\n color=\"inherit\"\n className=\"oui-size-4 oui-text-3xs\"\n />\n </Flex>\n </Popover>\n </Box>\n )}\n </Flex>\n </Flex>\n );\n};\n\nconst Title: FC<{\n justifyEnd?: boolean;\n id?: string;\n children: ReactNode;\n className?: string;\n}> = (props) => {\n const { children, className, justifyEnd = false } = props;\n return (\n <Flex\n id={props.id}\n className={cn(\n className,\n \"oui-items-end oui-text-xs\",\n justifyEnd && \"oui-justify-end\",\n )}\n >\n {children}\n </Flex>\n );\n};\n","import {\n ArrowDownShortIcon,\n ArrowUpShortIcon,\n Box,\n cn,\n Flex,\n Text,\n} from \"@orderly.network/ui\";\nimport { FC } from \"react\";\n\n/**\n * default style is desktop effect\n */\nexport const MiddlePriceView: FC<{\n markPrice: number;\n lastPrice: number[];\n quote_dp: number;\n className?: string;\n iconSize?: number;\n}> = (props) => {\n const {\n markPrice = 0,\n lastPrice,\n quote_dp,\n className,\n iconSize = 18,\n } = props;\n\n const [prevLastPrice, middlePrice] = lastPrice;\n\n const down = middlePrice < prevLastPrice;\n const up = middlePrice > prevLastPrice;\n\n return (\n <Flex\n gap={1}\n className={cn(\n up ? \"oui-text-trade-profit\" : down ? \"oui-text-trade-loss\" : \"\",\n className\n )}\n >\n <Text.numeral dp={quote_dp} intensity={98}>\n {middlePrice}\n </Text.numeral>\n <Box width={19}>\n {down && (\n <ArrowDownShortIcon size={iconSize} color=\"danger\" opacity={1} />\n )}\n {up && <ArrowUpShortIcon size={iconSize} color=\"success\" opacity={1} />}\n </Box>\n </Flex>\n );\n};\n","import { FC, useState } from \"react\";\nimport {\n Tooltip,\n cn,\n Flex,\n Text,\n SimpleDialog,\n useScreen,\n} from \"@orderly.network/ui\";\nimport { useTranslation } from \"@orderly.network/i18n\";\n\n/**\n * default style is desktop effect\n */\nexport const MarkPriceView: FC<{\n markPrice: number;\n quote_dp: number;\n className?: string;\n iconSize?: number;\n}> = (props) => {\n const { isMobile } = useScreen();\n\n return isMobile ? <MobileLayout {...props} /> : <DesktopLayout {...props} />;\n};\n\nconst DesktopLayout: FC<{\n markPrice: number;\n quote_dp: number;\n className?: string;\n iconSize?: number;\n}> = (props) => {\n const { quote_dp, className, iconSize = 18 } = props;\n const { t } = useTranslation();\n return (\n <Tooltip\n content={t(\"trading.orderBook.markPrice.tooltip\")}\n className=\"oui-max-w-[270px]\"\n >\n <Flex\n gap={1}\n className={cn(\"oui-cursor-pointer oui-text-2xs\", className)}\n >\n <FlagIcon size={iconSize} />\n <Text.numeral\n dp={quote_dp}\n color=\"warning\"\n className=\"oui-underline oui-text-base oui-decoration-dashed oui-decoration-1 oui-underline-offset-4 oui-decoration-warning-darken\"\n >\n {props.markPrice}\n </Text.numeral>\n </Flex>\n </Tooltip>\n );\n};\n\nconst MobileLayout: FC<{\n markPrice: number;\n quote_dp: number;\n className?: string;\n iconSize?: number;\n}> = (props) => {\n const { quote_dp, className, iconSize = 18 } = props;\n const [open, setOpen] = useState(false);\n const { t } = useTranslation();\n return (\n <>\n <Flex\n gap={1}\n className={cn(\"oui-cursor-pointer oui-text-2xs\", className)}\n onClick={() => {\n setOpen(true);\n }}\n >\n <FlagIcon size={iconSize} />\n <Text.numeral\n dp={quote_dp}\n color=\"warning\"\n className=\"oui-underline oui-decoration-dashed oui-decoration-1 oui-underline-offset-4 oui-decoration-warning-darken\"\n >\n {props.markPrice}\n </Text.numeral>\n </Flex>\n <SimpleDialog\n size=\"xs\"\n open={open}\n onOpenChange={setOpen}\n title={t(\"common.tips\")}\n actions={{\n primary: {\n label: t(\"common.ok\"),\n onClick: () => setOpen(false),\n },\n }}\n >\n <Text>{t(\"trading.orderBook.markPrice.tooltip\")}</Text>\n </SimpleDialog>\n </>\n );\n};\n\nconst FlagIcon = (props: { size: number }) => {\n return (\n <svg\n width={props.size}\n height={props.size}\n viewBox=\"0 0 18 18\"\n fill=\"currenColor\"\n xmlns=\"http://www.w3.org/2000/svg\"\n className=\"oui-fill-warning-darken\"\n >\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M3.75 1.5a.75.75 0 0 1 .75.75h6a.75.75 0 0 1 .75.75v1.5h3a.75.75 0 0 1 .75.75V12a.75.75 0 0 1-.75.75H7.5a.75.75 0 0 1-.75-.75v-1.5H4.5v5.25a.75.75 0 0 1-1.5 0V2.25a.75.75 0 0 1 .75-.75M4.5 9h5.25V3.75H4.5zm6.75-3v3.75a.75.75 0 0 1-.75.75H8.25v.75h5.25V6z\"\n // fill=\"#FF7D00\"\n />\n </svg>\n );\n};\n","import { FC, useMemo } from \"react\";\nimport { Decimal } from \"@orderly.network/utils\";\nimport { cn, Flex, Text, Tooltip } from \"@orderly.network/ui\";\nimport { BasicSymbolInfo } from \"../../../types/types\";\nimport { useOrderBookContext } from \"../../base/orderBook/orderContext\";\nimport { MiddlePriceView } from \"../../base/orderBook/midPriceView\";\nimport { MarkPriceView } from \"../../base/orderBook/markPrice\";\nimport { useTranslation } from \"@orderly.network/i18n\";\ninterface DesktopMarkPriceProps {\n markPrice: number;\n lastPrice: number[];\n asks: number[][];\n bids: number[][];\n symbolInfo: BasicSymbolInfo;\n}\n\nexport const DesktopMarkPrice: FC<DesktopMarkPriceProps> = (props) => {\n const { markPrice = 0, lastPrice, asks, bids, symbolInfo } = props;\n const { showTotal } = useOrderBookContext();\n\n return (\n <div className=\"oui-flex oui-flex-row oui-pl-3 oui-tabular-nums oui-justify-between oui-text-base-contrast-80 oui-text-xs oui-relative oui-cursor-pointer oui-py-[6px]\">\n <div\n className={cn(\n \"oui-basis-7/12 oui-flex oui-flex-row oui-items-center oui-mr-2 oui-justify-between\",\n showTotal && \"oui-basis-5/12\"\n )}\n >\n <MiddlePriceView\n markPrice={markPrice}\n lastPrice={lastPrice}\n quote_dp={symbolInfo.quote_dp}\n className=\"oui-text-base\"\n />\n <MarkPriceView markPrice={markPrice} quote_dp={symbolInfo.quote_dp} />\n </div>\n <div\n className={cn(\n \"oui-basis-5/12 oui-flex oui-items-center oui-fex-row oui-overflow-hidden oui-relative oui-justify-end\",\n showTotal && \"oui-basis-7/12\",\n \"oui-pr-3\"\n )}\n >\n <Spread asks={asks} bids={bids} />\n </div>\n </div>\n );\n};\n\nconst Spread: FC<{\n asks: number[][];\n bids: number[][];\n}> = (props) => {\n const { asks, bids } = props;\n\n const { t } = useTranslation();\n\n const spread = useMemo(() => {\n if (bids.length === 0 && asks.length === 0) {\n return 0;\n }\n const bid1 = Number.isNaN(bids[0][0]) ? 0 : bids[0][0];\n const index = asks.reverse().findIndex((item) => !Number.isNaN(item[0]));\n\n let ask1 = 0.0;\n if (index !== -1) {\n ask1 = Number.isNaN(asks[index][0]) ? 0 : asks[index][0];\n }\n const dValue = new Decimal(ask1)\n .sub(bid1)\n .div(new Decimal(ask1).add(bid1).div(2));\n // 0.00006416604461251195\n // 0.000065\n // 0.0065\n return Math.ceil(dValue.toNumber() * 1000000 + 0.1) / 10000;\n }, [asks, bids]);\n\n return (\n <div>\n <Tooltip\n content={t(\"trading.orderBook.spreadRatio.tooltip\")}\n className=\"oui-max-w-[240px]\"\n >\n <Text\n size=\"2xs\"\n intensity={36}\n className={\n \"oui-cursor-pointer oui-underline oui-decoration-dashed oui-decoration-1 oui-underline-offset-4 oui-decoration-base-contrast-36\"\n }\n >\n {`${spread}%`}\n </Text>\n </Tooltip>\n </div>\n );\n};\n","import { FC, useEffect, useRef, useState } from \"react\";\nimport { useLocalStorage } from \"@orderly.network/hooks\";\nimport { EMPTY_LIST } from \"@orderly.network/types\";\nimport { cn, Grid, Spinner } from \"@orderly.network/ui\";\nimport { BasicSymbolInfo } from \"../../../types/types\";\nimport {\n ORDERBOOK_COIN_TYPE_KEY,\n OrderBookProvider,\n} from \"../../base/orderBook/orderContext\";\nimport { DesktopAsks } from \"./asks.desktop\";\nimport { DesktopBids } from \"./bids.desktop\";\nimport { DesktopDepthSelect } from \"./depthSelect.desktop\";\nimport { DesktopHeader } from \"./header.desktop\";\nimport { DesktopMarkPrice } from \"./markPrice.desktop\";\n\nexport interface DesktopOrderBookProps {\n asks: any[];\n bids: any[];\n markPrice: number;\n lastPrice: number[];\n onItemClick?: (item: number[]) => void;\n depths: string[];\n activeDepth?: string;\n onDepthChange?: (depth: number) => void;\n //\n autoSize?: boolean;\n level?: number;\n base: string;\n quote: string;\n\n isLoading?: boolean;\n\n cellHeight?: number;\n\n className?: string;\n pendingOrders?: number[];\n symbolInfo: BasicSymbolInfo;\n}\n\nexport const DesktopOrderBook: FC<DesktopOrderBookProps> = (props) => {\n const { lastPrice, markPrice, quote, base, isLoading, onDepthChange } = props;\n\n const divRef = useRef<HTMLDivElement>(null);\n\n const [showTotal, setShowTotal] = useState(false);\n\n const [coinType, setCoinType] = useLocalStorage(\n ORDERBOOK_COIN_TYPE_KEY,\n base,\n );\n\n useEffect(() => {\n if (coinType !== quote && base) {\n setCoinType(base);\n }\n }, [base, quote]);\n\n useEffect(() => {\n const resizeObserver = new ResizeObserver((entries) => {\n for (const entry of entries) {\n const { inlineSize: width } = entry.borderBoxSize[0];\n setShowTotal(width >= 360);\n }\n });\n\n const targetDiv = divRef.current;\n\n if (targetDiv) {\n resizeObserver.observe(targetDiv);\n }\n\n return () => {\n if (targetDiv) {\n resizeObserver.unobserve(targetDiv);\n }\n };\n }, []);\n\n return (\n <OrderBookProvider\n cellHeight={props.cellHeight ?? 20}\n onItemClick={props.onItemClick}\n depth={props.activeDepth}\n showTotal={showTotal}\n pendingOrders={props.pendingOrders || EMPTY_LIST}\n symbolInfo={props.symbolInfo}\n >\n <Grid\n cols={1}\n rows={5}\n id=\"oui-orderbook-desktop\"\n ref={divRef}\n className=\"oui-relative oui-size-full oui-grid-rows-[auto,auto,1fr,auto,1fr]\"\n >\n <DesktopDepthSelect\n depths={props.depths}\n value={props.activeDepth}\n onChange={onDepthChange}\n />\n <DesktopHeader quote={quote} base={base} />\n <DesktopAsks data={[...props.asks]} />\n <DesktopMarkPrice\n lastPrice={lastPrice}\n markPrice={markPrice}\n // ======================================================================\n // == 🔥🔥🔥🔥🔥🔥🔥 DO NOT MODIFY THIS 🔥🔥🔥🔥🔥🔥🔥 ==\n // ======================================================================\n // Use shallow copy here to avoid mutating the original props array when sorting or modifying inside the component.\n // Note: This only clones the array itself, not the element objects.\n asks={[...props.asks]}\n bids={[...props.bids]}\n symbolInfo={props.symbolInfo}\n />\n <DesktopBids data={[...props.bids]} />\n {isLoading && (\n <div className=\"oui-bg-bg-8/70 oui-absolute oui-inset-0 oui-z-10 oui-flex oui-items-center oui-justify-center\">\n <Spinner />\n </div>\n )}\n </Grid>\n </OrderBookProvider>\n );\n};\n","import { FC } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { Flex, Text } from \"@orderly.network/ui\";\nimport { FundingRateState } from \"./fundingRate.script\";\n\nexport const FundingRate: FC<FundingRateState> = (props) => {\n const { data, onClick } = props;\n const predFundingRate = data.est_funding_rate;\n const countDown = data.countDown;\n const { t } = useTranslation();\n return (\n <Flex direction={\"column\"} itemAlign={\"start\"} pb={2}>\n <Text\n size=\"2xs\"\n intensity={36}\n className=\"oui-cursor-pointer oui-underline oui-decoration-line-16 oui-decoration-dashed oui-underline-offset-4\"\n onClick={onClick}\n >\n {t(\"trading.fundingRate.predFundingRate\")}\n </Text>\n {predFundingRate === null ? (\n \"--\"\n ) : (\n <div className=\"orderly-flex orderly-gap-1 oui-text-2xs oui-text-base-contrast-36\">\n {/* <span className=\"orderly-text-warning-darken\">{`${predFundingRate}%`}</span> */}\n <Text.numeral coloring suffix=\"%\" dp={4}>\n {predFundingRate ?? \"--\"}\n </Text.numeral>\n <span>{\" in\"}</span>\n <span>{\" \" + countDown}</span>\n </div>\n )}\n </Flex>\n );\n};\n","import { useMemo } from \"react\";\nimport { useFundingDetails } from \"@orderly.network/hooks\";\nimport { Decimal } from \"@orderly.network/utils\";\n\ninterface FundingRateOptions {\n symbol: string;\n}\n\nexport const useFundingRateModalScript = (options: FundingRateOptions) => {\n const { data, isLoading } = useFundingDetails(options.symbol);\n\n const fundingPeriod = useMemo(() => {\n if (!data || isLoading) {\n return \"-\";\n }\n return `${data.funding_period}h`;\n }, [data, isLoading]);\n\n const capFunding = useMemo(() => {\n if (!data || isLoading) {\n return \"-\";\n }\n return `${new Decimal(data.cap_funding).mul(100).toNumber()}%`;\n }, [data, isLoading]);\n\n const floorFunding = useMemo(() => {\n if (!data || isLoading) {\n return \"-\";\n }\n return `${new Decimal(data.floor_funding).mul(100).toNumber()}%`;\n }, [data, isLoading]);\n\n return { fundingPeriod, capFunding, floorFunding };\n};\n\nexport type FundingRateModalState = ReturnType<\n typeof useFundingRateModalScript\n>;\n","import React from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { Flex, Text, Divider } from \"@orderly.network/ui\";\nimport type { FundingRateModalState } from \"./fundingRateModal.script\";\n\nexport const FundingRateModal: React.FC<FundingRateModalState> = (props) => {\n const { t } = useTranslation();\n const { fundingPeriod, capFunding, floorFunding } = props;\n return (\n <Flex width={\"100%\"} itemAlign={\"center\"} direction=\"column\" gap={1}>\n <Flex justify=\"between\" itemAlign={\"center\"} width={\"100%\"}>\n <Text intensity={54}>\n {t(\"trading.fundingRate.predFundingRate.interval\")}\n </Text>\n <Text intensity={80}>{fundingPeriod}</Text>\n </Flex>\n <Flex justify=\"between\" itemAlign={\"center\"} width={\"100%\"}>\n <Text intensity={54}>\n {t(\"trading.fundingRate.predFundingRate.cap\")} /\n {t(\"trading.fundingRate.predFundingRate.floor\")}\n </Text>\n <Text intensity={80}>\n {capFunding} / {floorFunding}\n </Text>\n </Flex>\n <Divider my={4} className=\"oui-w-full\" intensity={8} />\n {t(\"markets.symbolInfoBar.predFundingRate.tooltip\")}\n </Flex>\n );\n};\n","import React from \"react\";\nimport { i18n } from \"@orderly.network/i18n\";\nimport { registerSimpleDialog, registerSimpleSheet } from \"@orderly.network/ui\";\nimport { useFundingRateModalScript } from \"./fundingRateModal.script\";\nimport { FundingRateModal } from \"./fundingRateModal.ui\";\n\nexport const FundingRateModalWidget: React.FC<{ symbol: string }> = (props) => {\n const state = useFundingRateModalScript(props);\n return <FundingRateModal {...state} />;\n};\n\nexport const FundingRateDialogId = \"FundingRateDialogId\";\nexport const FundingRateSheetId = \"FundingRateSheetId\";\n\nregisterSimpleDialog(FundingRateDialogId, FundingRateModalWidget, {\n size: \"md\",\n classNames: { content: \"oui-border oui-border-line-6\" },\n title: () => i18n.t(\"funding.fundingRate\"),\n});\n\nregisterSimpleSheet(FundingRateSheetId, FundingRateModalWidget, {\n title: () => i18n.t(\"funding.fundingRate\"),\n});\n","import { useCallback } from \"react\";\nimport { useFundingRate } from \"@orderly.network/hooks\";\nimport { modal } from \"@orderly.network/ui\";\nimport { FundingRateDialogId } from \"../fundingRateModal/fundingRateModal.widget\";\n\nexport const useFundingRateScript = (symbol: string) => {\n const data = useFundingRate(symbol);\n const onClick = useCallback<React.MouseEventHandler<HTMLElement>>(() => {\n modal.show(FundingRateDialogId, { symbol });\n }, [symbol]);\n return {\n data,\n onClick,\n };\n};\n\nexport type FundingRateState = ReturnType<typeof useFundingRateScript>;\n","import React from \"react\";\nimport { useFundingRateScript } from \"./fundingRate.script\";\nimport { FundingRate } from \"./fundingRate.ui\";\n\nexport const FundingRateWidget: React.FC<{ symbol: string }> = (props) => {\n const state = useFundingRateScript(props.symbol);\n return <FundingRate {...state} />;\n};\n","export { FundingRate } from \"./fundingRate.ui\";\nexport { FundingRateWidget } from \"./fundingRate.widget\";\nexport { useFundingRateScript } from \"./fundingRate.script\";\n","import { FC, useContext, useMemo } from \"react\";\nimport { useLocalStorage } from \"@orderly.network/hooks\";\nimport { Box, cn, Flex, Text } from \"@orderly.network/ui\";\nimport { getPrecisionByNumber } from \"@orderly.network/utils\";\nimport { CellBar } from \"../../base/orderBook/cellBar\";\nimport {\n ORDERBOOK_MOBILE_COIN_TYPE_KEY,\n OrderBookContext,\n} from \"../../base/orderBook/orderContext\";\nimport { OrderBookCellType, QtyMode } from \"../../base/orderBook/types\";\n\nexport interface OrderBookCellProps {\n background: string;\n price: number;\n quantity: number;\n accumulatedAmount: number;\n // size: number;\n count: number;\n accumulated: number;\n type: OrderBookCellType;\n mode: QtyMode;\n}\n\nexport const OrderBookCell: FC<OrderBookCellProps> = (props) => {\n const { accumulated, count, quantity, price, type, accumulatedAmount } =\n props;\n\n const width = (accumulated / count) * 100;\n\n const { cellHeight, onItemClick, depth, symbolInfo } =\n useContext(OrderBookContext);\n\n const { base_dp, quote_dp, base, quote } = symbolInfo;\n\n const [coinUnit, setCoinUnit] = useLocalStorage<\"qty\" | \"base\" | \"quote\">(\n ORDERBOOK_MOBILE_COIN_TYPE_KEY,\n \"qty\",\n );\n\n const totalAmount = Number.isNaN(accumulated)\n ? \"-\"\n : accumulatedAmount?.toString();\n\n const dp = useMemo(() => {\n return getPrecisionByNumber(depth || `${quote_dp}`);\n }, [depth, quote_dp]);\n\n const renderCell = () => {\n switch (coinUnit) {\n case \"base\":\n return (\n <Text.numeral className=\"oui-text-base-contrast-80\" dp={base_dp}>\n {accumulated}\n </Text.numeral>\n );\n case \"quote\":\n return (\n <Text.numeral className=\"oui-text-base-contrast-80\" dp={0}>\n {totalAmount}\n </Text.numeral>\n );\n default:\n return (\n <Text.numeral className=\"oui-text-base-contrast-80\" dp={base_dp}>\n {Number.isNaN(quantity) ? \"-\" : quantity}\n </Text.numeral>\n );\n }\n };\n\n return (\n <Box\n className={cn(\n \"oui-relative oui-w-full oui-cursor-pointer oui-overflow-hidden oui-text-2xs oui-tabular-nums\",\n )}\n style={{ height: `${cellHeight}px` }}\n onClick={() => {\n if (Number.isNaN(price) || Number.isNaN(quantity)) {\n return;\n }\n onItemClick?.([price, quantity]);\n }}\n >\n <Flex itemAlign=\"center\" justify={\"between\"}>\n <Text.numeral\n color={type === OrderBookCellType.BID ? \"buy\" : \"sell\"}\n dp={dp}\n >\n {price}\n </Text.numeral>\n {renderCell()}\n </Flex>\n {Number.isNaN(width) ? null : (\n <CellBar\n width={width}\n className={cn(\n type === OrderBookCellType.ASK\n ? \"oui-bg-trade-loss/20\"\n : \"oui-bg-trade-profit/20\",\n )}\n />\n )}\n </Box>\n );\n};\n","import { FC } from \"react\";\nimport { Box } from \"@orderly.network/ui\";\nimport { useOrderBookContext } from \"../../base/orderBook/orderContext\";\nimport { OrderBookCellType } from \"../../base/orderBook/types\";\nimport { OrderBookCell } from \"./cell\";\n\ninterface OrderBookListProps {\n type: OrderBookCellType;\n data: number[][];\n countQty: number;\n}\n\nexport const ListBox: FC<OrderBookListProps> = (props) => {\n const { data } = props;\n const { mode } = useOrderBookContext();\n return (\n <Box className=\"oui-order-book-list oui-flex oui-w-full oui-flex-col oui-gap-px\">\n {data.map((item, index) => {\n return (\n <OrderBookCell\n key={`item-${index}`}\n background={\"\"}\n price={item[0]}\n quantity={item[1]}\n accumulated={item[2]}\n accumulatedAmount={item[3]}\n count={props.countQty}\n type={props.type}\n mode={mode}\n />\n );\n })}\n </Box>\n );\n};\n","import { FC, useMemo } from \"react\";\nimport { OrderBookCellType } from \"../../base/orderBook/types\";\nimport { ListBox } from \"./listBox\";\n\nexport interface Props {\n data: number[][];\n}\nexport const Asks: FC<Props> = (props) => {\n const { data } = props;\n const countQty = useMemo(() => {\n const len = data.length;\n let max = Number.NaN;\n\n let index = 0;\n\n while (Number.isNaN(max) && index < len) {\n max = data[index][2];\n index++;\n }\n\n return max;\n }, [data]);\n return (\n <ListBox type={OrderBookCellType.ASK} data={data} countQty={countQty} />\n );\n};\n","import { FC, useMemo } from \"react\";\nimport { OrderBookCellType } from \"../../base/orderBook/types\";\nimport { ListBox } from \"./listBox\";\n\nexport interface Props {\n data: any[];\n}\n\nexport const Bids: FC<Props> = (props) => {\n const { data } = props;\n const countQty = useMemo(() => {\n let max = Number.NaN;\n // let len = data.length;\n let index = data.length - 1;\n\n while (Number.isNaN(max) && index > 0) {\n max = data[index][2];\n index--;\n }\n\n return max;\n // return data.length > 0 ? data[data.length - 1][2] : 0;\n }, [data]);\n\n return (\n <ListBox type={OrderBookCellType.BID} data={data} countQty={countQty} />\n );\n};\n","import { FC, useMemo } from \"react\";\nimport { Box, Picker } from \"@orderly.network/ui\";\n\ninterface DepthSelectProps {\n depth: ReadonlyArray<string> | string[];\n value?: string;\n onChange?: (depth: number) => void;\n}\n\nexport const DepthSelect: FC<DepthSelectProps> = (props) => {\n const options = useMemo(() => {\n return props.depth.map((d) => ({\n value: d,\n label: `${d}`,\n }));\n }, [props.depth]);\n return (\n <Box id=\"oui-order-book-depth\" className=\"oui-w-full oui-pt-2\">\n {/* <Select size={\"small\"} value={\"0.001\"} /> */}\n <Picker\n options={options}\n fullWidth\n size={\"sm\"}\n value={props.value}\n className=\"oui-text-2xs oui-text-base-contrast-54\"\n onValueChange={(value) => {\n //\n props.onChange?.(value);\n }}\n />\n </Box>\n );\n};\n","import React, { FC, useMemo } from \"react\";\nimport { useLocalStorage } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n CaretDownIcon,\n CaretUpIcon,\n Flex,\n Picker,\n Text,\n} from \"@orderly.network/ui\";\nimport { SelectOption } from \"@orderly.network/ui/src/select/withOptions\";\nimport { ORDERBOOK_MOBILE_COIN_TYPE_KEY } from \"../../base/orderBook/orderContext\";\n\ninterface Props {\n quote: string;\n base: string;\n}\n\nexport const Header: FC<Props> = (props) => {\n const { t } = useTranslation();\n\n const { base, quote } = props;\n\n const [coinUnit, setCoinUnit] = useLocalStorage<\"qty\" | \"base\" | \"quote\">(\n ORDERBOOK_MOBILE_COIN_TYPE_KEY,\n \"qty\",\n );\n\n const options = useMemo<SelectOption[]>(() => {\n return [\n {\n value: \"qty\",\n label: `${t(\"common.quantity\")}(${base})`,\n data: [t(\"common.quantity\"), base],\n },\n {\n value: \"base\",\n label: `${t(\"common.total\")}(${base})`,\n data: [t(\"common.total\"), base],\n },\n {\n value: \"quote\",\n label: `${t(\"common.total\")}(${quote})`,\n data: [t(\"common.total\"), quote],\n },\n ];\n }, [t, base, quote]);\n\n return (\n <Flex\n justify={\"between\"}\n width={\"100%\"}\n className=\"oui-py-[5px] oui-text-2xs oui-text-base-contrast-36\"\n >\n <Flex\n direction={\"column\"}\n itemAlign={\"start\"}\n id=\"oui-order-book-header-price\"\n >\n <Text>{t(\"common.price\")}</Text>\n <Text>{`(${quote})`}</Text>\n </Flex>\n <Picker\n size=\"sm\"\n value={coinUnit}\n onValueChange={setCoinUnit}\n options={options}\n valueRenderer={(_, { open, data }) => {\n return (\n <Flex justify=\"between\" itemAlign=\"center\" gap={1}>\n {Array.isArray(data) && (\n <Flex direction={\"column\"} itemAlign={\"end\"}>\n {data[0] && <Text>{data[0]}</Text>}\n {data[1] && <Text>({data[1]})</Text>}\n </Flex>\n )}\n {open ? (\n <CaretUpIcon size={14} color=\"inherit\" />\n ) : (\n <CaretDownIcon size={14} color=\"inherit\" />\n )}\n </Flex>\n );\n }}\n />\n </Flex>\n );\n};\n","import { FC } from \"react\";\nimport { Flex } from \"@orderly.network/ui\";\nimport { MarkPriceView } from \"../../base/orderBook/markPrice\";\nimport { MiddlePriceView } from \"../../base/orderBook/midPriceView\";\nimport { useOrderBookContext } from \"../../base/orderBook/orderContext\";\n\ninterface MarkPriceProps {\n markPrice: number;\n lastPrice: number[];\n}\n\nexport const MarkPrice: FC<MarkPriceProps> = (props) => {\n const { symbolInfo } = useOrderBookContext();\n\n const { quote_dp } = symbolInfo;\n\n return (\n <Flex\n id=\"oui-order-book-mark-price\"\n className=\"oui-py-[6px]\"\n width={\"100%\"}\n justify={\"between\"}\n >\n <MiddlePriceView\n markPrice={props.markPrice}\n lastPrice={props.lastPrice}\n quote_dp={quote_dp}\n className=\"oui-text-sm\"\n iconSize={14}\n />\n <MarkPriceView\n markPrice={props.markPrice}\n quote_dp={quote_dp}\n className=\"oui-text-2xs\"\n iconSize={12}\n />\n </Flex>\n );\n};\n","import { FC, useEffect } from \"react\";\nimport { useLocalStorage } from \"@orderly.network/hooks\";\nimport { EMPTY_LIST } from \"@orderly.network/types\";\nimport { cn, Flex, Spinner } from \"@orderly.network/ui\";\nimport { BasicSymbolInfo } from \"../../../types/types\";\nimport {\n ORDERBOOK_MOBILE_COIN_TYPE_KEY,\n OrderBookProvider,\n} from \"../../base/orderBook/orderContext\";\nimport { FundingRateWidget } from \"../fundingRate\";\nimport { Asks } from \"./asks\";\nimport { Bids } from \"./bids\";\nimport { DepthSelect } from \"./depthSelect\";\nimport { Header } from \"./header\";\nimport { MarkPrice } from \"./markPrice\";\n\nexport interface OrderBookProps {\n asks: any[];\n bids: any[];\n markPrice: number;\n lastPrice: number[];\n onItemClick?: (item: number[]) => void;\n depths?: string[];\n activeDepth?: string;\n onDepthChange?: (depth: number) => void;\n //\n autoSize?: boolean;\n level?: number;\n base: string;\n quote: string;\n\n isLoading?: boolean;\n\n cellHeight?: number;\n\n className?: string;\n symbolInfo: BasicSymbolInfo;\n}\n\nexport const OrderBook: FC<OrderBookProps> = (props) => {\n const { lastPrice, markPrice, quote, base, isLoading, onDepthChange } = props;\n\n const symbol = `PERP_${props.symbolInfo.base}_${props.symbolInfo.quote}`;\n\n const [coinUnit, setCoinUnit] = useLocalStorage<\"qty\" | \"base\" | \"quote\">(\n ORDERBOOK_MOBILE_COIN_TYPE_KEY,\n \"qty\",\n );\n\n return (\n <OrderBookProvider\n cellHeight={props.cellHeight ?? 20}\n onItemClick={props.onItemClick}\n depth={props.activeDepth}\n pendingOrders={EMPTY_LIST}\n showTotal={false}\n symbolInfo={props.symbolInfo}\n >\n <Flex\n direction={\"column\"}\n p={2}\n id=\"oui-orderbook-mobile\"\n className={cn(\"oui-relative oui-size-full\", props.className)}\n justify={\"start\"}\n itemAlign={\"start\"}\n >\n <FundingRateWidget symbol={symbol} />\n <Header quote={quote} base={base} />\n <Asks data={props.asks} />\n <MarkPrice lastPrice={lastPrice} markPrice={markPrice} />\n <Bids data={props.bids} />\n <DepthSelect\n depth={props.depths || EMPTY_LIST}\n value={props.activeDepth}\n onChange={onDepthChange}\n />\n {isLoading && (\n <div className=\"oui-bg-base-800/70 oui-absolute oui-inset-0 oui-z-10 oui-flex oui-h-full oui-min-h-[420px] oui-items-center oui-justify-center\">\n <Spinner />\n </div>\n )}\n </Flex>\n </OrderBookProvider>\n );\n};\n","import React from \"react\";\nimport { Box } from \"@orderly.network/ui\";\nimport { DesktopOrderBook } from \"../../desktop/orderBook/index.desktop\";\nimport { OrderBook as MWebOrderBook } from \"../../mobile/orderBook\";\nimport type { OrderBookState } from \"./orderBook.script\";\n\nexport const OrderBook: React.FC<OrderBookState & { className?: string }> = (\n props,\n) => {\n return (\n <Box className=\"oui-font-semibold\" width={\"100%\"} height={\"100%\"}>\n {props.isMobile ? (\n <MWebOrderBook\n level={props.level}\n asks={props.asks!}\n bids={props.bids!}\n markPrice={props.markPrice!}\n lastPrice={props.lastPrice!}\n depths={props.depths}\n activeDepth={props.selDepth}\n base={props.base}\n quote={props.quote}\n isLoading={props.isLoading}\n onItemClick={props.onItemClick}\n cellHeight={props.cellHeight}\n onDepthChange={props.onDepthChange}\n className={props.className}\n symbolInfo={props.symbolInfo}\n />\n ) : (\n <DesktopOrderBook\n level={props.level}\n asks={props.asks!}\n bids={props.bids!}\n markPrice={props.markPrice!}\n lastPrice={props.lastPrice!}\n depths={props.depths}\n activeDepth={props.selDepth}\n base={props.base}\n quote={props.quote}\n isLoading={props.isLoading}\n onItemClick={props.onItemClick}\n cellHeight={props.cellHeight}\n onDepthChange={props.onDepthChange}\n className={props.className}\n pendingOrders={props.pendingOrders}\n symbolInfo={props.symbolInfo}\n />\n )}\n </Box>\n );\n};\n","import type { API } from \"@orderly.network/types\";\nimport type { BasicSymbolInfo } from \"../types/types\";\n\ntype ValueOf<T> = T[keyof T];\n\nexport const getBasicSymbolInfo = (\n symbolInfo: (\n key?: keyof API.SymbolExt,\n defaultValue?: ValueOf<API.SymbolExt>,\n ) => any,\n): BasicSymbolInfo => {\n return {\n base_dp: symbolInfo(\"base_dp\"),\n quote_dp: symbolInfo(\"quote_dp\"),\n base_tick: symbolInfo(\"base_tick\"),\n base: symbolInfo(\"base\"),\n quote: symbolInfo(\"quote\"),\n };\n};\n","import { useEffect, useMemo, useState } from \"react\";\nimport {\n useOrderbookStream,\n useOrderStream,\n useSymbolsInfo,\n} from \"@orderly.network/hooks\";\nimport { OrderStatus } from \"@orderly.network/types\";\nimport { useScreen } from \"@orderly.network/ui\";\nimport { removeTrailingZeros } from \"@orderly.network/utils\";\nimport { getBasicSymbolInfo } from \"../../../utils/utils\";\n\nconst CELL_MAX = 30;\n\nconst DEFAULT_CELL_HEIGHT = 20;\n\nconst SPACE = 104;\n\nexport const useOrderBookScript = (props: {\n symbol: string;\n height?: number;\n}) => {\n const { symbol, height } = props;\n const symbolInfo = useSymbolsInfo()[symbol];\n\n const [cellHeight, setCellHeight] = useState(DEFAULT_CELL_HEIGHT);\n\n const [level, setLevel] = useState(10);\n const { base, quote, quote_dp } = getBasicSymbolInfo(symbolInfo);\n // const counter = useRef(0);\n\n const [data, { onDepthChange, isLoading, onItemClick, depth, allDepths }] =\n useOrderbookStream(symbol, undefined, { level });\n\n // useEffect(() => {\n // counter.current = 0;\n // }, [symbol]);\n\n const pendingOrders = usePendingOrderStream(symbol);\n useEffect(() => {\n if (height) {\n // setCellHeight(height.content / level);\n const level = Math.floor(\n (height - SPACE) / ((DEFAULT_CELL_HEIGHT + 1) * 2),\n );\n\n const cellsHeight = (DEFAULT_CELL_HEIGHT + 1) * 2 * level;\n\n const restSpace = height - SPACE - cellsHeight;\n\n if (restSpace > 10) {\n setCellHeight(DEFAULT_CELL_HEIGHT + restSpace / level / 2);\n } else {\n setCellHeight(DEFAULT_CELL_HEIGHT);\n }\n\n setLevel(level);\n }\n }, [height]);\n\n const selDepth = useMemo(() => {\n if (typeof depth === \"undefined\" || typeof quote_dp === \"undefined\") {\n return undefined;\n }\n // // FIXME: hardcode for now, need to optimize it\n // counter.current++;\n // if (counter.current === 1 && DEFAULT_DEPTH[symbol]) {\n // return DEFAULT_DEPTH[symbol];\n // }\n\n return removeTrailingZeros(depth);\n }, [depth, quote_dp, symbol]);\n\n const depths = useMemo(() => {\n return allDepths?.map((e) => removeTrailingZeros(e)) || [];\n }, [allDepths, quote_dp]);\n\n const { isMobile } = useScreen();\n\n return {\n level,\n asks: data?.asks,\n bids: data?.bids,\n markPrice: data?.markPrice,\n lastPrice: data?.middlePrice,\n depths,\n selDepth,\n base,\n quote,\n isLoading,\n onItemClick,\n cellHeight,\n onDepthChange,\n pendingOrders,\n symbolInfo: getBasicSymbolInfo(symbolInfo),\n isMobile,\n };\n};\n\nexport const usePendingOrderStream = (symbol: string): number[] => {\n const [data] = useOrderStream({\n status: OrderStatus.INCOMPLETE,\n symbol: symbol,\n });\n\n const pendingOrders = useMemo(() => {\n const info = data\n ?.filter((item) => item.symbol === symbol)\n .reduce((a, b) => {\n // TODO: check if this is the correct price, when the data is from WS, it crashes\n const price = b.price || b.trigger_price || 0;\n return [...a, price];\n }, []);\n\n return info;\n }, [data, symbol]);\n\n return pendingOrders;\n};\n\nexport type OrderBookState = ReturnType<typeof useOrderBookScript>;\n","import React from \"react\";\nimport { useOrderBookScript } from \"./orderBook.script\";\nimport { OrderBook } from \"./orderBook.ui\";\n\ninterface OrderBookWidgetProps {\n className?: string;\n symbol: string;\n height?: number;\n}\n\nexport const OrderBookWidget: React.FC<OrderBookWidgetProps> = (props) => {\n const { className, symbol, height } = props;\n const state = useOrderBookScript({ symbol, height });\n return <OrderBook {...state} className={className} />;\n};\n","export { OrderBook } from \"./orderBook.ui\";\nexport { OrderBookWidget } from \"./orderBook.widget\";\nexport { useOrderBookScript } from \"./orderBook.script\";\n","import React, { FC } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { useAppContext } from \"@orderly.network/react-app\";\nimport {\n Flex,\n Text,\n Box,\n Tooltip,\n modal,\n gradientTextVariants,\n cn,\n EditIcon,\n} from \"@orderly.network/ui\";\nimport { LeverageWidgetWithDialogId } from \"@orderly.network/ui-leverage\";\nimport { TooltipContent } from \"../assetView/assetView.ui\";\nimport { RiskRateState } from \"./riskRate.script\";\n\nexport const RiskRate: FC<RiskRateState> = (props) => {\n const { riskRate, riskRateColor, currentLeverage, maxLeverage } = props;\n const { isHigh, isMedium, isLow } = riskRateColor;\n const { wrongNetwork } = useAppContext();\n const { t } = useTranslation();\n\n const textColor = wrongNetwork\n ? \"\"\n : isHigh\n ? \"oui-text-danger\"\n : isMedium\n ? \"oui-text-warning-darken\"\n : isLow\n ? gradientTextVariants({ color: \"brand\" })\n : \"\";\n\n const boxClsName = wrongNetwork\n ? \"oui-bg-gradient-to-r oui-opacity-20 oui-from-[#26fefe] oui-via-[#ff7d00] oui-to-[#d92d6b] oui-h-1.5 oui-rounded-full\"\n : isHigh\n ? \"oui-bg-gradient-to-tr oui-from-[#791438] oui-to-[#ff447c] oui-h-1.5 oui-rounded-full\"\n : isMedium\n ? \"oui-bg-gradient-to-tr oui-from-[#792e00] oui-to-[#ffb65d] oui-h-1.5 oui-rounded-full\"\n : isLow\n ? \"oui-bg-gradient-to-tr oui-from-[#59b0fe] oui-to-[#26fefe] oui-h-1.5 oui-rounded-full\"\n : \"oui-bg-gradient-to-r oui-opacity-20 oui-from-[#26fefe] oui-via-[#ff7d00] oui-to-[#d92d6b] oui-h-1.5 oui-rounded-full\";\n\n return (\n <Box data-risk={\"\"} className=\"oui-space-y-2\">\n <Flex\n itemAlign=\"center\"\n justify=\"start\"\n className=\"oui-w-full oui-bg-base-6 oui-rounded-full oui-h-2 oui-px-[1px]\"\n >\n <Box\n className={boxClsName}\n style={\n riskRate && riskRate !== \"--\"\n ? { width: riskRate }\n : { width: \"100%\" }\n }\n />\n </Flex>\n\n <Flex className=\"oui-gap-2\" justify=\"between\">\n <Flex direction=\"column\">\n <Tooltip\n content={\n <TooltipContent\n description={t(\"trading.riskRate.tooltip\")}\n formula={t(\"trading.riskRate.formula\")}\n />\n }\n >\n <Text\n size=\"2xs\"\n color=\"neutral\"\n weight=\"semibold\"\n className={cn(\n \"oui-cursor-pointer\",\n \"oui-border-b oui-border-dashed oui-border-b-white/10\",\n )}\n >\n {t(\"trading.riskRate\")}\n </Text>\n </Tooltip>\n <Text\n size=\"xs\"\n color=\"neutral\"\n weight=\"semibold\"\n className={cn(textColor)}\n >\n {riskRate ?? \"--\"}\n </Text>\n </Flex>\n\n <Flex direction=\"column\">\n <Text\n size=\"2xs\"\n color=\"neutral\"\n weight=\"semibold\"\n className={cn(\n \"oui-cursor-pointer\",\n // add extra bottom border to make height same as risk rate text\n \"oui-border-b oui-border-b-transparent\",\n )}\n >\n {t(\"leverage.maxAccountLeverage\")}\n </Text>\n <Flex className=\"oui-gap-1\">\n <Text.numeral\n dp={2}\n padding={false}\n suffix={currentLeverage ? \"x\" : undefined}\n >\n {currentLeverage ?? \"--\"}\n </Text.numeral>\n\n <span className={\"oui-text-base-contrast-54\"}>/</span>\n\n <button\n className=\"oui-flex oui-items-center oui-gap-1\"\n onClick={() => {\n modal.show(LeverageWidgetWithDialogId, { currentLeverage: 5 });\n }}\n data-testid=\"oui-testid-riskRate-leverage-button\"\n >\n <Text.numeral\n dp={2}\n padding={false}\n suffix={maxLeverage ? \"x\" : undefined}\n data-testid=\"oui-testid-riskRate-leverage-value\"\n >\n {maxLeverage ?? \"--\"}\n </Text.numeral>\n\n {typeof maxLeverage !== \"undefined\" && maxLeverage !== null && (\n <EditIcon size={12} color=\"white\" />\n )}\n </button>\n </Flex>\n </Flex>\n </Flex>\n </Box>\n );\n};\n","import { useMemo } from \"react\";\nimport {\n useAccount,\n useLeverage,\n useMarginRatio,\n} from \"@orderly.network/hooks\";\nimport { useDataTap } from \"@orderly.network/react-app\";\nimport { AccountStatusEnum } from \"@orderly.network/types\";\nimport { Decimal } from \"@orderly.network/utils\";\n\nconst getRiskRateColor = (riskRate: null | number) => {\n if (riskRate === null) {\n return { isHigh: false, isMedium: false, isLow: false, isDefault: true };\n }\n\n const isLow = riskRate < 40;\n const isMedium = riskRate >= 40 && riskRate < 80;\n const isHigh = riskRate >= 80;\n const isDefault = !isLow && !isMedium && !isHigh;\n\n return { isHigh, isMedium, isLow, isDefault };\n};\n\nexport const useRiskRateScript = () => {\n const { state } = useAccount();\n\n const isConnected =\n state.status >= AccountStatusEnum.EnableTrading ||\n state.status === AccountStatusEnum.EnableTradingWithoutConnected;\n const { marginRatio, currentLeverage, mmr } = useMarginRatio();\n\n const { curLeverage } = useLeverage();\n\n const riskRate = useMemo(() => {\n if (!isConnected || marginRatio === null || mmr === null) {\n return \"--\";\n }\n\n if (marginRatio === 0 || mmr === 0) {\n return \"0%\";\n }\n\n const calculatedRiskRate = new Decimal(mmr)\n .div(marginRatio)\n .mul(100)\n .todp(2, Decimal.ROUND_UP);\n\n // Remove trailing zeroes and add percentage sign\n return `${calculatedRiskRate.toString().replace(/\\.?0+$/, \"\")}%`;\n }, [isConnected, marginRatio, mmr]);\n\n const riskRateNumber = riskRate === \"--\" ? null : parseFloat(riskRate);\n\n const riskRateColor = useMemo(() => {\n return getRiskRateColor(riskRateNumber);\n }, [riskRateNumber]);\n\n const _curLeverage = useDataTap(currentLeverage);\n const _maxLeverage = useDataTap(curLeverage);\n const _riskRate = useDataTap(riskRate);\n\n return {\n riskRate: _riskRate,\n riskRateColor,\n isConnected,\n currentLeverage: _curLeverage,\n maxLeverage: _maxLeverage,\n };\n};\n\nexport type RiskRateState = ReturnType<typeof useRiskRateScript>;\n","import React from \"react\";\nimport { useRiskRateScript } from \"./riskRate.script\";\nimport { RiskRate } from \"./riskRate.ui\";\n\nexport const RiskRateWidget: React.FC = () => {\n const state = useRiskRateScript();\n return <RiskRate {...state} />;\n};\n","export { RiskRate } from \"./riskRate.ui\";\nexport { RiskRateWidget } from \"./riskRate.widget\";\n","import React from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { Box, cn, Flex, Grid, TabPanel, Tabs, Text } from \"@orderly.network/ui\";\nimport type { OrderBookAndTradesState } from \"./orderBookAndTrades.script\";\n\nconst LazyLastTradesWidget = React.lazy(() =>\n import(\"../../base/lastTrades\").then((mod) => {\n return {\n default: mod.LastTradesWidget,\n };\n }),\n);\n\nconst LazyOrderBookWidget = React.lazy(() =>\n import(\"../../base/orderBook\").then((mod) => {\n return {\n default: mod.OrderBookWidget,\n };\n }),\n);\n\nconst TwoColLayout: React.FC<OrderBookAndTradesState> = (props) => {\n const { t } = useTranslation();\n return (\n <Grid\n cols={2}\n width={\"100%\"}\n gap={3}\n className=\"oui-auto-rows-fr\"\n style={{\n height: props.containerSize?.height,\n }}\n >\n <Flex\n direction={\"column\"}\n itemAlign={\"start\"}\n // pl={3}\n pt={3}\n pb={3}\n r=\"2xl\"\n className=\"oui-bg-base-9\"\n >\n <Title\n title={t(\"trading.orderBook\")}\n className=\"oui-pl-3 oui-text-sm\"\n />\n <React.Suspense fallback={null}>\n <LazyOrderBookWidget\n symbol={props.symbol}\n height={\n props.containerSize\n ? props.containerSize.height - 29 - 24\n : undefined\n }\n />\n </React.Suspense>\n </Flex>\n <Flex\n direction={\"column\"}\n itemAlign={\"start\"}\n py={3}\n r=\"2xl\"\n className=\"oui-bg-base-9 oui-h-full\"\n >\n <Title\n title={t(\"trading.lastTrades\")}\n className=\"oui-text-sm oui-px-3\"\n />\n <React.Suspense fallback={null}>\n <LazyLastTradesWidget\n symbol={props.symbol}\n style={{\n height:\n props.containerSize && props.containerSize.height - 29 - 24,\n }}\n classNames={{ listHeader: \"oui-px-3\", list: \"oui-px-3\" }}\n />\n </React.Suspense>\n </Flex>\n </Grid>\n );\n};\n\nconst TabLayout: React.FC<OrderBookAndTradesState> = (props) => {\n const { t } = useTranslation();\n\n return (\n <Box\n // pl={3}\n pt={3}\n pb={3}\n pr={0}\n r=\"2xl\"\n className=\"oui-bg-base-9\"\n style={{ maxHeight: props.containerSize?.height }}\n >\n <Tabs\n value={props.tab}\n variant=\"contained\"\n onValueChange={(tab) => {\n props.setTab(tab as any);\n }}\n classNames={{\n tabsList: \"oui-pl-3\",\n // tabsContent: props.tab === \"lastTrades\" ? 'oui-pl-3' : ''\n }}\n size=\"lg\"\n >\n <TabPanel value=\"orderBook\" title={t(\"trading.orderBook\")}>\n <React.Suspense fallback={null}>\n <LazyOrderBookWidget\n symbol={props.symbol}\n height={\n props.containerSize\n ? props.containerSize.height - 29 - 18\n : undefined\n }\n />\n </React.Suspense>\n </TabPanel>\n <TabPanel value=\"lastTrades\" title={t(\"trading.lastTrades\")}>\n <React.Suspense fallback={null}>\n <LazyLastTradesWidget\n symbol={props.symbol}\n style={{\n height:\n props.containerSize && props.containerSize.height - 29 - 18,\n }}\n classNames={{\n root: \"oui-pt-[6px]\",\n listHeader: \"oui-px-3\",\n list: \"oui-px-3\",\n }}\n />\n </React.Suspense>\n </TabPanel>\n </Tabs>\n </Box>\n );\n};\n\nconst Title: React.FC<{ title: string; className?: string }> = (props) => {\n return (\n <Text\n size=\"base\"\n intensity={80}\n className={cn(\"oui-pb-[5px]\", props.className)}\n >\n {props.title}\n </Text>\n );\n};\n\nexport const OrderBookAndTrades: React.FC<OrderBookAndTradesState> = (\n props,\n) => {\n const { containerRef, containerSize } = props;\n return (\n <div ref={containerRef} className=\"oui-h-full\">\n {(containerSize?.width ?? 0) >= 572 ? (\n <TwoColLayout {...props} />\n ) : (\n <TabLayout {...props} />\n )}\n </div>\n );\n};\n","import { useEffect, useRef, useState } from \"react\";\n\nexport const useOrderBookAndTradesScript = (symbol: string) => {\n const [containerSize, setContainerSize] = useState<\n | {\n width: number;\n height: number;\n }\n | undefined\n >(undefined);\n\n const [tab, setTab] = useState<\"orderBook\" | \"lastTrades\">(\"orderBook\");\n\n const containerRef = useRef<HTMLDivElement>(null);\n\n useEffect(() => {\n const resizeObserver = new ResizeObserver((entries) => {\n for (const entry of entries) {\n const { width, height } = entry.contentRect;\n setContainerSize({\n width,\n height,\n });\n }\n });\n\n const targetDiv = containerRef.current;\n\n if (targetDiv) {\n resizeObserver.observe(targetDiv);\n }\n\n return () => {\n if (targetDiv) {\n resizeObserver.unobserve(targetDiv);\n }\n };\n }, []);\n\n return {\n symbol,\n containerSize,\n containerRef: containerRef,\n tab,\n setTab,\n };\n};\n\nexport type OrderBookAndTradesState = ReturnType<\n typeof useOrderBookAndTradesScript\n>;\n","import React from \"react\";\nimport { useOrderBookAndTradesScript } from \"./orderBookAndTrades.script\";\nimport { OrderBookAndTrades } from \"./orderBookAndTrades.ui\";\n\nexport const OrderBookAndTradesWidget: React.FC<{ symbol: string }> = (\n props,\n) => {\n const state = useOrderBookAndTradesScript(props.symbol);\n return <OrderBookAndTrades {...state} />;\n};\n","export { OrderBookAndTrades } from \"./orderBookAndTrades.ui\";\nexport { OrderBookAndTradesWidget } from \"./orderBookAndTrades.widget\";\nexport { useOrderBookAndTradesScript } from \"./orderBookAndTrades.script\";\n","import { FC, PropsWithChildren, SVGProps, useState } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n Box,\n CloseIcon,\n cn,\n Divider,\n DropdownMenuContent,\n DropdownMenuPortal,\n DropdownMenuRoot,\n DropdownMenuTrigger,\n Flex,\n Text,\n} from \"@orderly.network/ui\";\nimport type { MarketLayoutPosition } from \"../../../pages/trading/trading.script\";\n\nexport type LayoutPosition = \"left\" | \"right\";\n\nexport type SwitchLayoutProps = {\n layout?: LayoutPosition;\n onLayout?: (layout: LayoutPosition) => void;\n marketLayout?: MarketLayoutPosition;\n onMarketLayout?: (layout: MarketLayoutPosition) => void;\n};\n\nexport const SwitchLayout: FC<SwitchLayoutProps> = (props) => {\n const { t } = useTranslation();\n return (\n <SwitchLayoutDropDown {...props}>\n <Flex\n px={3}\n className={cn(\n \"oui-rounded-md\",\n \"oui-h-[28px]\",\n \"oui-cursor-pointer oui-transition-all\",\n \"oui-bg-base-6 hover:oui-bg-base-4\",\n \"oui-text-base-contrast-54 hover:oui-text-base-contrast-80\",\n )}\n gapX={1}\n ml={3}\n justify=\"center\"\n itemAlign=\"center\"\n >\n <LayoutIcon />\n <Text size=\"2xs\" weight=\"semibold\">\n {t(\"trading.layout\")}\n </Text>\n </Flex>\n </SwitchLayoutDropDown>\n );\n};\n\nexport const SwitchLayoutDropDown: FC<PropsWithChildren<SwitchLayoutProps>> = (\n props,\n) => {\n const [open, setOpen] = useState(false);\n const [hoveredMarket, setHoveredMarket] =\n useState<MarketLayoutPosition | null>(null);\n const { t } = useTranslation();\n const renderItem = (position: LayoutPosition) => {\n return (\n <Flex\n direction=\"column\"\n gapY={2}\n onClick={() => {\n props.onLayout?.(position);\n setOpen(false);\n }}\n className=\"oui-group\"\n >\n <Flex\n justify={position === \"right\" ? \"end\" : \"start\"}\n className={cn(\n \"oui-w-[148px] oui-h-[100px]\",\n \"oui-bg-base-10 oui-rounded-[10px]\",\n \"oui-border-[4px] oui-border-base-5 group-hover:oui-border-primary-light\",\n props.layout === position && \"!oui-border-primary-light\",\n )}\n >\n <Box p={1}>\n <OrderEntryIcon />\n </Box>\n </Flex>\n <Text\n size=\"2xs\"\n intensity={54}\n className={cn(\n \"oui-text-base-contrast-54 group-hover:oui-text-base-contrast-80\",\n props.layout === position && \"oui-text-base-contrast-80\",\n )}\n >\n {String(\n position === \"right\"\n ? t(\"trading.layout.advanced.right\")\n : t(\"trading.layout.advanced.left\"),\n )}\n </Text>\n </Flex>\n );\n };\n\n const renderMarketItem = (position: MarketLayoutPosition) => {\n const getIcon = (isHovered: boolean) => {\n const isSelected = props.marketLayout === position;\n switch (position) {\n case \"left\":\n return (\n <MarketLeftIcon isSelected={isSelected} isHovered={isHovered} />\n );\n case \"top\":\n return (\n <MarketTopIcon isSelected={isSelected} isHovered={isHovered} />\n );\n case \"bottom\":\n return (\n <MarketBottomIcon isSelected={isSelected} isHovered={isHovered} />\n );\n case \"hide\":\n return (\n <MarketHideIcon isSelected={isSelected} isHovered={isHovered} />\n );\n default:\n return (\n <MarketLeftIcon isSelected={isSelected} isHovered={isHovered} />\n );\n }\n };\n\n const getLabel = () => {\n switch (position) {\n case \"left\":\n return t(\"trading.layout.markets.left\");\n case \"top\":\n return t(\"trading.layout.markets.top\");\n case \"bottom\":\n return t(\"trading.layout.markets.bottom\");\n case \"hide\":\n return t(\"trading.layout.markets.hide\");\n default:\n return t(\"trading.layout.markets.left\");\n }\n };\n\n return (\n <Flex\n direction=\"column\"\n gapY={2}\n onClick={() => {\n props.onMarketLayout?.(position);\n setOpen(false);\n }}\n onMouseEnter={() => setHoveredMarket(position)}\n onMouseLeave={() => setHoveredMarket(null)}\n className=\"oui-group\"\n >\n <Flex justify=\"center\" className=\"oui-w-[148px] oui-h-[100px]\">\n {getIcon(hoveredMarket === position)}\n </Flex>\n <Text\n size=\"2xs\"\n intensity={54}\n className={cn(\n \"oui-text-base-contrast-54 group-hover:oui-text-base-contrast-80\",\n props.marketLayout === position && \"oui-text-base-contrast-80\",\n )}\n >\n {String(getLabel())}\n </Text>\n </Flex>\n );\n };\n\n const content = (\n <>\n <Flex\n itemAlign=\"center\"\n justify=\"between\"\n mt={3}\n className=\"oui-mb-[10px] oui-min-w-[500px]\"\n >\n <Text size=\"base\" intensity={98}>\n {t(\"trading.layout\")}\n </Text>\n <CloseIcon\n size={16}\n className=\"oui-text-base-contrast-80 oui-cursor-pointer\"\n opacity={0.98}\n onClick={() => {\n setOpen(false);\n }}\n />\n </Flex>\n <Divider />\n <Flex direction=\"column\" gapY={2} mt={5} itemAlign=\"start\">\n <Text size=\"xs\" intensity={98}>\n {String(t(\"trading.layout.advanced\"))}\n </Text>\n <Flex gapX={6}>\n {renderItem(\"right\")}\n {renderItem(\"left\")}\n </Flex>\n </Flex>\n <Flex direction=\"column\" gapY={2} mt={5} itemAlign=\"start\">\n <Text size=\"xs\" intensity={98}>\n {String(t(\"trading.layout.markets\"))}\n </Text>\n <Flex gapX={6}>\n {renderMarketItem(\"left\")}\n {renderMarketItem(\"top\")}\n {renderMarketItem(\"bottom\")}\n {renderMarketItem(\"hide\")}\n </Flex>\n </Flex>\n </>\n );\n\n return (\n <DropdownMenuRoot open={open} onOpenChange={setOpen}>\n <DropdownMenuTrigger asChild>{props.children}</DropdownMenuTrigger>\n <DropdownMenuPortal>\n <DropdownMenuContent\n onCloseAutoFocus={(e) => e.preventDefault()}\n onClick={(e) => e.stopPropagation()}\n align=\"end\"\n className={cn(\"oui-bg-base-8 oui-p-5 oui-pt-0 oui-font-semibold\")}\n >\n {content}\n </DropdownMenuContent>\n </DropdownMenuPortal>\n </DropdownMenuRoot>\n );\n};\n\nexport const LayoutIcon: FC<SVGProps<SVGSVGElement>> = (props) => (\n <svg\n width=\"17\"\n height=\"16\"\n viewBox=\"0 0 17 16\"\n fill=\"currentColor\"\n xmlns=\"http://www.w3.org/2000/svg\"\n {...props}\n >\n <path d=\"M3.832 1.994c-.736 0-1.333.597-1.333 1.333v9.334c0 .737.597 1.333 1.333 1.333H6.5c.737 0 1.333-.596 1.333-1.333V3.327c0-.736-.596-1.333-1.333-1.333zm6.667 0c-.737 0-1.333.597-1.333 1.333v2.667c0 .737.596 1.333 1.333 1.333h2.667c.736 0 1.333-.596 1.333-1.333V3.327c0-.736-.597-1.333-1.333-1.333zm.437 6.679a2.7 2.7 0 0 0-1.033.607.284.284 0 0 0-.061.339c.222.411-.01.851-.512.876a.29.29 0 0 0-.26.217c-.05.207-.07.38-.07.608 0 .19.02.407.06.599a.28.28 0 0 0 .252.217c.506.044.756.429.53.92a.28.28 0 0 0 .06.321c.296.273.635.466 1.034.59a.285.285 0 0 0 .312-.104c.31-.427.757-.428 1.05 0a.28.28 0 0 0 .313.113 2.8 2.8 0 0 0 1.042-.599.28.28 0 0 0 .06-.33c-.23-.466.035-.894.513-.902a.28.28 0 0 0 .269-.209c.048-.199.06-.372.06-.616q0-.316-.069-.616a.276.276 0 0 0-.27-.217c-.469-.001-.732-.463-.502-.868a.27.27 0 0 0-.053-.339 2.8 2.8 0 0 0-1.059-.607.274.274 0 0 0-.312.112c-.268.417-.77.425-1.033.009a.284.284 0 0 0-.321-.121m.842 1.536a1.111 1.111 0 1 1 0 2.222 1.111 1.111 0 0 1 0-2.222\" />\n </svg>\n);\n\nexport const OrderEntryIcon: FC<SVGProps<SVGSVGElement>> = (props) => (\n <svg\n width=\"36\"\n height=\"84\"\n viewBox=\"0 0 36 84\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <rect width=\"36\" height=\"17\" rx=\"2\" fill=\"#181C23\" />\n <rect y=\"19\" width=\"36\" height=\"54\" rx=\"2\" fill=\"#181C23\" />\n <rect y=\"75\" width=\"36\" height=\"9\" rx=\"2\" fill=\"#181C23\" />\n <rect\n x=\"3\"\n y=\"79\"\n width=\"30\"\n height=\"1\"\n rx=\"0.5\"\n fill=\"url(#paint0_linear_17647_26849)\"\n />\n <rect x=\"3\" y=\"22\" width=\"14\" height=\"6\" rx=\"2\" fill=\"#008676\" />\n <rect x=\"19\" y=\"22\" width=\"14\" height=\"6\" rx=\"2\" fill=\"#D92D6B\" />\n <rect x=\"3\" y=\"11\" width=\"14\" height=\"3\" rx=\"1.5\" fill=\"#333948\" />\n <rect x=\"19\" y=\"11\" width=\"14\" height=\"3\" rx=\"1.5\" fill=\"#335FFC\" />\n <rect x=\"3\" y=\"62\" width=\"30\" height=\"8\" rx=\"2\" fill=\"#008676\" />\n <defs>\n <linearGradient\n id=\"paint0_linear_17647_26849\"\n x1=\"33\"\n y1=\"79.5\"\n x2=\"3\"\n y2=\"79.5\"\n gradientUnits=\"userSpaceOnUse\"\n >\n <stop stopColor=\"#779eff\" />\n <stop offset=\"1\" stopColor=\"#26FEFE\" />\n </linearGradient>\n </defs>\n </svg>\n);\n\nexport const MarketLeftIcon: FC<\n SVGProps<SVGSVGElement> & { isSelected?: boolean; isHovered?: boolean }\n> = ({ isSelected, isHovered, ...props }) => {\n const getStrokeColor = () => {\n if (isSelected) return \"#779eff\"; // primary-light color\n if (isHovered) return \"#779eff\"; // primary-light color\n return \"#333948\"; // base-5 color\n };\n\n return (\n <svg\n width=\"148\"\n height=\"100\"\n viewBox=\"0 0 148 100\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n {...props}\n >\n <rect\n x=\"2\"\n y=\"2\"\n width=\"144\"\n height=\"96\"\n rx=\"10\"\n fill=\"#07080A\"\n stroke={getStrokeColor()}\n strokeWidth=\"4\"\n />\n <rect x=\"8\" y=\"8\" width=\"24\" height=\"84\" rx=\"2\" fill=\"#181C23\" />\n <rect x=\"16\" y=\"10\" width=\"4\" height=\"2\" rx=\"1\" fill=\"#333948\" />\n <rect x=\"21\" y=\"10\" width=\"4\" height=\"2\" rx=\"1\" fill=\"#333948\" />\n <rect x=\"26\" y=\"10\" width=\"4\" height=\"2\" rx=\"1\" fill=\"#333948\" />\n <rect x=\"10\" y=\"10\" width=\"5\" height=\"2\" rx=\"1\" fill=\"#335FFC\" />\n <rect x=\"10\" y=\"14\" width=\"20\" height=\"76\" rx=\"2\" fill=\"#282E3A\" />\n </svg>\n );\n};\n\nexport const MarketTopIcon: FC<\n SVGProps<SVGSVGElement> & { isSelected?: boolean; isHovered?: boolean }\n> = ({ isSelected, isHovered, ...props }) => {\n const getStrokeColor = () => {\n if (isSelected) return \"#779eff\"; // primary-light color\n if (isHovered) return \"#779eff\"; // primary-light color\n return \"#333948\"; // base-5 color\n };\n\n return (\n <svg\n width=\"148\"\n height=\"100\"\n viewBox=\"0 0 148 100\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n {...props}\n >\n <rect\n x=\"2\"\n y=\"2\"\n width=\"144\"\n height=\"96\"\n rx=\"10\"\n fill=\"#07080A\"\n stroke={getStrokeColor()}\n strokeWidth=\"4\"\n />\n <rect x=\"8\" y=\"8\" width=\"132\" height=\"8\" rx=\"2\" fill=\"#181C23\" />\n <g clipPath=\"url(#clip0_31319_74729)\">\n <rect x=\"10\" y=\"10\" width=\"16\" height=\"4\" rx=\"2\" fill=\"#335FFC\" />\n <rect x=\"28\" y=\"10\" width=\"16\" height=\"4\" rx=\"2\" fill=\"#333948\" />\n <rect x=\"46\" y=\"10\" width=\"16\" height=\"4\" rx=\"2\" fill=\"#333948\" />\n <rect x=\"64\" y=\"10\" width=\"16\" height=\"4\" rx=\"2\" fill=\"#333948\" />\n <rect x=\"82\" y=\"10\" width=\"16\" height=\"4\" rx=\"2\" fill=\"#333948\" />\n <rect x=\"100\" y=\"10\" width=\"16\" height=\"4\" rx=\"2\" fill=\"#333948\" />\n <rect x=\"118\" y=\"10\" width=\"16\" height=\"4\" rx=\"2\" fill=\"#333948\" />\n <rect x=\"136\" y=\"10\" width=\"16\" height=\"4\" rx=\"2\" fill=\"#333948\" />\n </g>\n <defs>\n <clipPath id=\"clip0_31319_74729\">\n <rect\n width=\"130\"\n height=\"4\"\n fill=\"white\"\n transform=\"translate(10 10)\"\n />\n </clipPath>\n </defs>\n </svg>\n );\n};\n\nexport const MarketBottomIcon: FC<\n SVGProps<SVGSVGElement> & { isSelected?: boolean; isHovered?: boolean }\n> = ({ isSelected, isHovered, ...props }) => {\n const getStrokeColor = () => {\n if (isSelected) return \"#779eff\"; // primary-light color\n if (isHovered) return \"#779eff\"; // primary-light color\n return \"#333948\"; // base-5 color\n };\n\n return (\n <svg\n width=\"148\"\n height=\"100\"\n viewBox=\"0 0 148 100\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n {...props}\n >\n <rect\n x=\"2\"\n y=\"2\"\n width=\"144\"\n height=\"96\"\n rx=\"10\"\n fill=\"#07080A\"\n stroke={getStrokeColor()}\n strokeWidth=\"4\"\n />\n <rect x=\"8\" y=\"84\" width=\"132\" height=\"8\" rx=\"2\" fill=\"#181C23\" />\n <g clipPath=\"url(#clip0_31319_74743)\">\n <rect x=\"10\" y=\"86\" width=\"16\" height=\"4\" rx=\"2\" fill=\"#335FFC\" />\n <rect x=\"28\" y=\"86\" width=\"16\" height=\"4\" rx=\"2\" fill=\"#333948\" />\n <rect x=\"46\" y=\"86\" width=\"16\" height=\"4\" rx=\"2\" fill=\"#333948\" />\n <rect x=\"64\" y=\"86\" width=\"16\" height=\"4\" rx=\"2\" fill=\"#333948\" />\n <rect x=\"82\" y=\"86\" width=\"16\" height=\"4\" rx=\"2\" fill=\"#333948\" />\n <rect x=\"100\" y=\"86\" width=\"16\" height=\"4\" rx=\"2\" fill=\"#333948\" />\n <rect x=\"118\" y=\"86\" width=\"16\" height=\"4\" rx=\"2\" fill=\"#333948\" />\n <rect x=\"136\" y=\"86\" width=\"16\" height=\"4\" rx=\"2\" fill=\"#333948\" />\n </g>\n <defs>\n <clipPath id=\"clip0_31319_74743\">\n <rect\n width=\"130\"\n height=\"4\"\n fill=\"white\"\n transform=\"translate(10 86)\"\n />\n </clipPath>\n </defs>\n </svg>\n );\n};\n\nexport const MarketHideIcon: FC<\n SVGProps<SVGSVGElement> & { isSelected?: boolean; isHovered?: boolean }\n> = ({ isSelected, isHovered, ...props }) => {\n const getStrokeColor = () => {\n if (isSelected) return \"#779eff\"; // primary-light color\n if (isHovered) return \"#779eff\"; // primary-light color\n return \"#333948\"; // base-5 color\n };\n\n return (\n <svg\n width=\"148\"\n height=\"100\"\n viewBox=\"0 0 148 100\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n {...props}\n >\n <rect\n x=\"2\"\n y=\"2\"\n width=\"144\"\n height=\"96\"\n rx=\"10\"\n fill=\"#07080A\"\n stroke={getStrokeColor()}\n strokeWidth=\"4\"\n />\n <g clipPath=\"url(#clip0_31319_74757)\">\n <rect x=\"8\" y=\"8\" width=\"132\" height=\"84\" rx=\"2\" fill=\"#181C23\" />\n <rect\n x=\"66.8789\"\n y=\"-76\"\n width=\"4\"\n height=\"188\"\n rx=\"2\"\n transform=\"rotate(45 66.8789 -76)\"\n fill=\"#20252F\"\n />\n <rect\n x=\"73.9492\"\n y=\"-68.929\"\n width=\"4\"\n height=\"188\"\n rx=\"2\"\n transform=\"rotate(45 73.9492 -68.929)\"\n fill=\"#20252F\"\n />\n <rect\n x=\"81.0195\"\n y=\"-61.8579\"\n width=\"4\"\n height=\"188\"\n rx=\"2\"\n transform=\"rotate(45 81.0195 -61.8579)\"\n fill=\"#20252F\"\n />\n <rect\n x=\"88.0938\"\n y=\"-54.7867\"\n width=\"4\"\n height=\"188\"\n rx=\"2\"\n transform=\"rotate(45 88.0938 -54.7867)\"\n fill=\"#20252F\"\n />\n <rect\n x=\"95.1641\"\n y=\"-47.7157\"\n width=\"4\"\n height=\"188\"\n rx=\"2\"\n transform=\"rotate(45 95.1641 -47.7157)\"\n fill=\"#20252F\"\n />\n <rect\n x=\"102.234\"\n y=\"-40.6447\"\n width=\"4\"\n height=\"188\"\n rx=\"2\"\n transform=\"rotate(45 102.234 -40.6447)\"\n fill=\"#20252F\"\n />\n <rect\n x=\"109.305\"\n y=\"-33.5736\"\n width=\"4\"\n height=\"188\"\n rx=\"2\"\n transform=\"rotate(45 109.305 -33.5736)\"\n fill=\"#20252F\"\n />\n <rect\n x=\"116.375\"\n y=\"-26.5026\"\n width=\"4\"\n height=\"188\"\n rx=\"2\"\n transform=\"rotate(45 116.375 -26.5026)\"\n fill=\"#20252F\"\n />\n <rect\n x=\"123.449\"\n y=\"-19.4315\"\n width=\"4\"\n height=\"188\"\n rx=\"2\"\n transform=\"rotate(45 123.449 -19.4315)\"\n fill=\"#20252F\"\n />\n <rect\n x=\"130.52\"\n y=\"-12.3604\"\n width=\"4\"\n height=\"188\"\n rx=\"2\"\n transform=\"rotate(45 130.52 -12.3604)\"\n fill=\"#20252F\"\n />\n <rect\n x=\"137.59\"\n y=\"-5.28931\"\n width=\"4\"\n height=\"188\"\n rx=\"2\"\n transform=\"rotate(45 137.59 -5.28931)\"\n fill=\"#20252F\"\n />\n <rect\n x=\"144.66\"\n y=\"1.78174\"\n width=\"4\"\n height=\"188\"\n rx=\"2\"\n transform=\"rotate(45 144.66 1.78174)\"\n fill=\"#20252F\"\n />\n <rect\n x=\"151.73\"\n y=\"8.85278\"\n width=\"4\"\n height=\"188\"\n rx=\"2\"\n transform=\"rotate(45 151.73 8.85278)\"\n fill=\"#20252F\"\n />\n <rect\n x=\"158.805\"\n y=\"15.9238\"\n width=\"4\"\n height=\"188\"\n rx=\"2\"\n transform=\"rotate(45 158.805 15.9238)\"\n fill=\"#20252F\"\n />\n <rect\n x=\"165.875\"\n y=\"22.995\"\n width=\"4\"\n height=\"188\"\n rx=\"2\"\n transform=\"rotate(45 165.875 22.995)\"\n fill=\"#20252F\"\n />\n <rect\n x=\"172.945\"\n y=\"30.066\"\n width=\"4\"\n height=\"188\"\n rx=\"2\"\n transform=\"rotate(45 172.945 30.066)\"\n fill=\"#20252F\"\n />\n <rect\n x=\"180.016\"\n y=\"37.1371\"\n width=\"4\"\n height=\"188\"\n rx=\"2\"\n transform=\"rotate(45 180.016 37.1371)\"\n fill=\"#20252F\"\n />\n <rect\n x=\"187.086\"\n y=\"44.2081\"\n width=\"4\"\n height=\"188\"\n rx=\"2\"\n transform=\"rotate(45 187.086 44.2081)\"\n fill=\"#20252F\"\n />\n <rect\n x=\"194.156\"\n y=\"51.2792\"\n width=\"4\"\n height=\"188\"\n rx=\"2\"\n transform=\"rotate(45 194.156 51.2792)\"\n fill=\"#20252F\"\n />\n <rect\n x=\"201.23\"\n y=\"58.3503\"\n width=\"4\"\n height=\"188\"\n rx=\"2\"\n transform=\"rotate(45 201.23 58.3503)\"\n fill=\"#20252F\"\n />\n </g>\n <defs>\n <clipPath id=\"clip0_31319_74757\">\n <rect\n width=\"132\"\n height=\"84\"\n fill=\"white\"\n transform=\"translate(8 8)\"\n />\n </clipPath>\n </defs>\n </svg>\n );\n};\n","import { useState } from \"react\";\nimport { useTradingPageContext } from \"../../../provider/tradingPageContext\";\n\nexport enum TopTabType {\n chart = \"chart\",\n trades = \"trades\",\n data = \"data\",\n}\n\nexport const useTopTabScript = () => {\n const [tab, setTab] = useState<TopTabType>(TopTabType.chart);\n const { symbol } = useTradingPageContext();\n const [visible, setVisible] = useState(true);\n\n const toggleContentVisible = () => {\n setVisible((e) => !e);\n };\n\n return {\n tab,\n setTab,\n symbol,\n toggleContentVisible,\n setVisible,\n visible,\n };\n};\n\nexport type TopTabState = ReturnType<typeof useTopTabScript>;\n","import React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport { useLocalStorage } from \"@orderly.network/hooks\";\nimport { TradingviewWidgetProps } from \"./tradingview.widget\";\n\nconst MaxHeight = 354;\nconst MinHeight = 234;\nconst Key = \"TRADINGVIEW_MOBILE_HEIGHT\";\n\nexport function useTradingviewScript(props: TradingviewWidgetProps) {\n const [height, setHeight] = useLocalStorage(Key, MaxHeight);\n const [dragging, setDragging] = useState(false);\n const dragRef = useRef<HTMLDivElement>(null);\n const boxRef = useRef<HTMLDivElement>(null);\n const [offsetY, setOffsetY] = useState(0);\n const topRef = useRef<number>(0);\n\n const handleTouchStart = useCallback((e: TouchEvent) => {\n if (!boxRef.current) {\n return;\n }\n setDragging(true);\n const event = e.touches[0];\n const rect = boxRef.current.getBoundingClientRect();\n e.stopPropagation();\n e.preventDefault();\n\n const offsetY = event.clientY - rect.bottom;\n topRef.current = rect.top;\n setOffsetY(offsetY);\n }, []);\n\n const handleTouchMove = useCallback(\n (e: TouchEvent) => {\n if (!boxRef.current) {\n return;\n }\n if (dragging) {\n e.stopPropagation();\n e.preventDefault();\n\n const event = e.touches[0];\n\n const newHeight = event.clientY - topRef.current - offsetY;\n setHeight(\n Math.min(Math.max(Math.round(newHeight), MinHeight), MaxHeight),\n );\n return false;\n }\n },\n [dragging, offsetY],\n );\n\n const handleTouchEnd = useCallback(() => {\n setDragging(false);\n }, []);\n\n useEffect(() => {\n const drag = dragRef.current;\n if (!drag) {\n return;\n }\n\n drag.addEventListener(\"touchstart\", handleTouchStart);\n\n return () => {\n drag.removeEventListener(\"touchstart\", handleTouchStart);\n };\n }, [handleTouchStart]);\n\n useEffect(() => {\n document.addEventListener(\"touchmove\", handleTouchMove, { passive: false });\n document.addEventListener(\"touchend\", handleTouchEnd);\n\n return () => {\n document.removeEventListener(\"touchmove\", handleTouchMove);\n document.removeEventListener(\"touchend\", handleTouchEnd);\n };\n }, [dragging, handleTouchMove, handleTouchEnd]);\n return {\n ...props,\n\n height,\n dragging,\n dragRef,\n boxRef,\n };\n}\n\nexport type TradingviewState = ReturnType<typeof useTradingviewScript>;\n","import React, { FC, SVGProps } from \"react\";\n\nexport const KlineDragIcon: FC<SVGProps<SVGSVGElement>> = (props) => (\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 {...props}\n >\n <g id=\"Arrows-expand\">\n <path\n id=\"Vector\"\n d=\"M5.9989 1.00708C5.8709 1.00708 5.7369 1.05008 5.6394 1.14758L3.7959 3.00708L4.4989 3.71008L5.4989 2.72607V4.50708C5.4989 4.78308 5.7229 5.00708 5.9989 5.00708C6.2749 5.00708 6.4989 4.78308 6.4989 4.50708V2.72607L7.4989 3.71008L8.2019 3.00708L6.3584 1.14758C6.2604 1.05008 6.1269 1.00708 5.9989 1.00708ZM5.9989 7.00707C5.7229 7.00707 5.4989 7.23107 5.4989 7.50707V9.28808L4.4989 8.30407L3.7959 9.00707L5.6394 10.8666C5.8349 11.0616 6.1629 11.0616 6.3584 10.8666L8.2019 9.00707L7.4989 8.30407L6.4989 9.28808V7.50707C6.4989 7.23107 6.2749 7.00707 5.9989 7.00707Z\"\n />\n </g>\n </svg>\n);\n","import React from \"react\";\nimport { cn } from \"@orderly.network/ui\";\nimport { TradingviewWidget } from \"@orderly.network/ui-tradingview\";\nimport { KlineDragIcon } from \"../../base/icons\";\nimport type { TradingviewState } from \"./tradingview.script\";\n\nexport const TradingviewUI: React.FC<TradingviewState> = (props) => {\n return (\n <div\n className=\"oui-pb-1 oui-flex oui-flex-col oui-gap-1\"\n style={{ height: props.height }}\n ref={props.boxRef}\n >\n <div className=\"oui-w-full oui-h-full\">\n <TradingviewWidget\n symbol={props.symbol}\n libraryPath={props.tradingViewConfig?.library_path}\n mode={3}\n scriptSRC={props.tradingViewConfig?.scriptSRC}\n customCssUrl={props.tradingViewConfig?.customCssUrl}\n {...props.tradingViewConfig}\n />\n </div>\n <div className=\"oui-relative oui-w-full\">\n <div\n ref={props.dragRef}\n className={cn(\n \"oui-h-[1px] oui-absolute oui-left-0 oui-right-0 oui-bottom-0 oui-top-0 oui-z-10 oui-mt-[7px] oui-bg-base-contrast-12\",\n props.dragging && \"oui-bg-primary \",\n )}\n >\n <KlineDragIcon\n className={cn(\n \"oui-w-3 oui-h-3 oui-absolute oui-left-1/2 -oui-top-[5px] -oui-translate-y-[0.5px] oui-text-base-contrast-12\",\n props.dragging && \" oui-text-primary\",\n )}\n />\n </div>\n </div>\n </div>\n );\n};\n","import React from \"react\";\nimport { TradingViewConfigInterface } from \"../../../types/types\";\nimport { useTradingviewScript } from \"./tradingview.script\";\nimport { TradingviewUI } from \"./tradingview.ui\";\n\nexport interface TradingviewWidgetProps {\n symbol: string;\n tradingViewConfig: TradingViewConfigInterface;\n}\n\nexport const TradingviewWidget: React.FC<TradingviewWidgetProps> = (props) => {\n const state = useTradingviewScript(props);\n return <TradingviewUI {...state} />;\n};\n","import React from \"react\";\nimport { LastTradesWidget } from \"../../base/lastTrades\";\n\nexport const MWebLastTrades: React.FC<{ symbol: string }> = (props) => {\n return (\n <LastTradesWidget\n symbol={props.symbol}\n classNames={{\n root: \"oui-px-3 \",\n list: \"oui-min-h-[141px] oui-max-h-[202px] oui-w-full\",\n listHeader: \"oui-text-xs oui-text-base-contrast-36\",\n listItem: {\n left: \"oui-text-xs\",\n mid: \"oui-text-xs\",\n right: \"oui-text-xs\",\n },\n }}\n />\n );\n};\n","import { FC } from \"react\";\nimport { Flex, Text } from \"@orderly.network/ui\";\nimport { TradeDataState } from \"./tradeData.script\";\nimport { useTranslation } from \"@orderly.network/i18n\";\n\nexport const TradeData: FC<TradeDataState> = (props) => {\n const { t } = useTranslation();\n\n return (\n <Flex direction={\"column\"} gap={2}>\n <Row\n title={t(\"common.markPrice\")}\n value={props.ticker?.mark_price}\n dp={props.symbolInfo.quote_dp}\n />\n <Row\n title={t(\"common.indexPrice\")}\n value={props.ticker?.index_price}\n dp={props.symbolInfo.quote_dp}\n />\n <Row\n title={t(\"markets.column.24hVolume\")}\n value={props.vol_24h}\n dp={props.symbolInfo.quote_dp}\n rule=\"human\"\n showUSDC\n />\n <Row\n title={t(\"trading.column.24High\")}\n value={props.ticker?.[\"24h_high\"]}\n dp={props.symbolInfo.quote_dp}\n />\n <Row\n title={t(\"trading.column.24Low\")}\n value={props.ticker?.[\"24h_low\"]}\n dp={props.symbolInfo.quote_dp}\n />\n <Row\n title={t(\"markets.openInterest\")}\n value={props.openInterest}\n dp={props.symbolInfo.quote_dp}\n rule=\"human\"\n showUSDC\n />\n </Flex>\n );\n};\n\nconst Row = (props: {\n title: string;\n value: any;\n dp?: number;\n rule?: \"percentages\" | \"price\" | \"human\";\n showUSDC?: boolean;\n}) => {\n const { title, value, showUSDC, dp, rule = \"price\" } = props;\n return (\n <Flex justify={\"between\"} width={\"100%\"} className=\"oui-text-xs\">\n <Text intensity={36}>{title}</Text>\n <Flex gap={1}>\n <Text.numeral rule={rule} dp={dp} intensity={80}>\n {value}\n </Text.numeral>\n {showUSDC && <Text intensity={36}>USDC</Text>}\n </Flex>\n </Flex>\n );\n};\n","import { useMemo } from \"react\";\nimport { useTickerStream } from \"@orderly.network/hooks\";\nimport { Decimal } from \"@orderly.network/utils\";\nimport { useTradingPageContext } from \"../../../provider/tradingPageContext\";\n\nexport const useTradeDataScript = (props: { symbol: string }) => {\n const { symbol } = props;\n const ticker = useTickerStream(symbol);\n const { symbolInfo } = useTradingPageContext();\n const vol_24h = useMemo(() => {\n const close = ticker?.[\"24h_close\"];\n const volume = ticker?.[\"24h_volume\"];\n if (close && volume && !isNaN(close) && !isNaN(volume)) {\n return new Decimal(close)\n .mul(volume)\n .toFixed(symbolInfo.quote_dp, Decimal.ROUND_DOWN);\n }\n return undefined;\n }, [ticker]);\n\n const openInterest = useMemo(() => {\n const markPrice = ticker?.[\"mark_price\"];\n const openInterest = ticker?.[\"open_interest\"];\n if (markPrice && openInterest && !isNaN(markPrice)) {\n return new Decimal(markPrice)\n .mul(Number(openInterest))\n .toFixed(symbolInfo.quote_dp, Decimal.ROUND_DOWN);\n }\n return undefined;\n }, [ticker]);\n return {\n ticker,\n symbolInfo,\n vol_24h,\n openInterest,\n };\n};\n\nexport type TradeDataState = ReturnType<typeof useTradeDataScript>;\n","import React from \"react\";\nimport { useTradeDataScript } from \"./tradeData.script\";\nimport { TradeData } from \"./tradeData.ui\";\n\nexport const TradeDataWidget: React.FC<{ symbol: string }> = (props) => {\n const state = useTradeDataScript(props);\n return <TradeData {...state} />;\n};\n","export { TradeData } from \"./tradeData.ui\";\nexport { TradeDataWidget } from \"./tradeData.widget\";\nexport { useTradeDataScript } from \"./tradeData.script\";\n","import React from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { Box, cn, TabPanel, Tabs } from \"@orderly.network/ui\";\nimport { useTradingPageContext } from \"../../../provider/tradingPageContext\";\nimport { TopTabState, TopTabType } from \"./topTab.script\";\n\nconst LazyTradingviewWidget = React.lazy(() =>\n import(\"../tradingview/tradingview.widget\").then((mod) => {\n return { default: mod.TradingviewWidget };\n }),\n);\n\nconst LazyMWebLastTrades = React.lazy(() =>\n import(\"../lastTrades/lastTrades.widget\").then((mod) => {\n return { default: mod.MWebLastTrades };\n }),\n);\n\nconst LazyTradeDataWidget = React.lazy(() =>\n import(\"../tradeData\").then((mod) => {\n return { default: mod.TradeDataWidget };\n }),\n);\n\nexport const TopTab: React.FC<TopTabState & { className?: string }> = (\n props,\n) => {\n const { t } = useTranslation();\n const { tradingViewConfig } = useTradingPageContext();\n\n return (\n <Tabs\n variant=\"contained\"\n value={props.tab}\n contentVisible={props.visible}\n onValueChange={(e) => {\n props.setTab(e as TopTabType);\n props.setVisible(true);\n }}\n className={props.className}\n classNames={{\n tabsList: \"oui-p-2\",\n tabsContent: \"oui-min-h-[176px] oui-max-h-[396px]\",\n }}\n style={{\n marginBottom: props.tab === TopTabType.chart ? \"8px\" : 0,\n }}\n trailing={\n <button className=\"oui-px-5\" onClick={props.toggleContentVisible}>\n <ChevronIcon\n className={props.visible ? \"oui-rotate-0\" : \"oui-rotate-180\"}\n />\n </button>\n }\n >\n <TabPanel title={t(\"trading.tabs.chart\")} value={TopTabType.chart}>\n <React.Suspense fallback={null}>\n <LazyTradingviewWidget\n symbol={props.symbol}\n tradingViewConfig={tradingViewConfig}\n />\n </React.Suspense>\n </TabPanel>\n <TabPanel title={t(\"trading.tabs.trades\")} value={TopTabType.trades}>\n <React.Suspense fallback={null}>\n <LazyMWebLastTrades symbol={props.symbol} />\n </React.Suspense>\n </TabPanel>\n <TabPanel title={t(\"trading.tabs.data\")} value={TopTabType.data}>\n <Box px={3}>\n <React.Suspense fallback={null}>\n <LazyTradeDataWidget symbol={props.symbol} />\n </React.Suspense>\n </Box>\n </TabPanel>\n </Tabs>\n );\n};\n\nconst ChevronIcon: React.FC<{ className?: string }> = (props) => {\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 className={cn(\n \"oui-fill-base-contrast-54 hover:oui-fill-base-contrast-80\",\n props.className,\n )}\n >\n <path\n d=\"M5.721 4.585 2.726 6.578a.51.51 0 0 0-.14.7.51.51 0 0 0 .702.14l2.714-1.806 2.715 1.806c.23.153.549.089.702-.14a.51.51 0 0 0-.14-.7L6.283 4.585a.51.51 0 0 0-.562 0\"\n // fill=\"url(#a)\"\n />\n <defs>\n {/* <linearGradient\n id=\"a\"\n x1=\"9.502\"\n y1=\"6.001\"\n x2=\"2.502\"\n y2=\"6.001\"\n gradientUnits=\"userSpaceOnUse\"\n >\n <stop stopColor=\"rgb(var(--oui-gradient-brand-end))\" />\n <stop offset=\"1\" stopColor=\"rgb(var(--oui-gradient-brand-start))\" />\n </linearGradient> */}\n </defs>\n </svg>\n );\n};\n","import React from \"react\";\nimport { useTopTabScript } from \"./topTab.script\";\nimport { TopTab } from \"./topTab.ui\";\n\nexport const TopTabWidget: React.FC<{ className?: string }> = (props) => {\n const state = useTopTabScript();\n return <TopTab className={props.className} {...state} />;\n};\n","export { TopTab } from \"./topTab.ui\";\nexport { TopTabWidget } from \"./topTab.widget\";\nexport { useTopTabScript } from \"./topTab.script\";\n","import React, { useEffect, useRef, useState } from \"react\";\nimport { cn } from \"@orderly.network/ui\";\nimport { OrderEntryWidget } from \"@orderly.network/ui-order-entry\";\nimport type { OrderBookAndEntryState } from \"./orderBookAndEntry.script\";\n\nconst LazyOrderBookWidget = React.lazy(() =>\n import(\"../../base/orderBook\").then((mod) => {\n return { default: mod.OrderBookWidget };\n }),\n);\n\nexport const OrderBookAndEntry: React.FC<\n OrderBookAndEntryState & { className?: string }\n> = (props) => {\n const [height, setHeight] = useState(0);\n const divRef = useRef(null);\n\n useEffect(() => {\n const div = divRef.current;\n if (!div) {\n return;\n }\n const resizeObserver = new ResizeObserver((entries) => {\n for (const entry of entries) {\n setHeight(entry.contentRect.height);\n }\n });\n resizeObserver.observe(div);\n return () => {\n resizeObserver.unobserve(div);\n };\n }, []);\n return (\n <div\n className={cn(\n \"oui-mx-1 oui-grid oui-grid-cols-[4fr,6fr] oui-gap-1 \",\n props.className,\n )}\n >\n <div\n className=\"oui-rounded-xl oui-bg-base-9\"\n style={{ height: `${height + 16}px` }}\n >\n <React.Suspense fallback={null}>\n <LazyOrderBookWidget\n symbol={props.symbol}\n height={height ? height - 44 : undefined}\n />\n </React.Suspense>\n </div>\n <div className=\"oui-rounded-xl oui-bg-base-9 oui-p-2\">\n <OrderEntryWidget symbol={props.symbol} containerRef={divRef} />\n </div>\n </div>\n );\n};\n","import { useTradingPageContext } from \"../../../provider/tradingPageContext\";\n\nexport const useOrderBookAndEntryScript = () => {\n const { symbol } = useTradingPageContext();\n return {\n symbol,\n };\n};\n\nexport type OrderBookAndEntryState = ReturnType<\n typeof useOrderBookAndEntryScript\n>;\n","import React from \"react\";\nimport { useOrderBookAndEntryScript } from \"./orderBookAndEntry.script\";\nimport { OrderBookAndEntry } from \"./orderBookAndEntry.ui\";\n\nexport const OrderBookAndEntryWidget: React.FC<{ className?: string }> = (\n props,\n) => {\n const state = useOrderBookAndEntryScript();\n return <OrderBookAndEntry className={props.className} {...state} />;\n};\n","export { OrderBookAndEntry } from \"./orderBookAndEntry.ui\";\nexport { OrderBookAndEntryWidget } from \"./orderBookAndEntry.widget\";\nexport { useOrderBookAndEntryScript } from \"./orderBookAndEntry.script\";\n","import { useState } from \"react\";\nimport { useOrderStream } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { modal, Text } from \"@orderly.network/ui\";\nimport { TabType } from \"@orderly.network/ui-orders\";\nimport { SharePnLConfig } from \"@orderly.network/ui-share\";\nimport {\n usePendingOrderCount,\n usePositionsCount,\n useTradingLocalStorage,\n} from \"../../../hooks\";\nimport { useTradingPageContext } from \"../../../provider/tradingPageContext\";\n\nexport enum DataListTabType {\n position = \"Position\",\n pending = \"Pending\",\n tp_sl = \"TP/SL\",\n history = \"History\",\n liquidation = \"Liquidation\",\n}\n\nexport enum DataListTabSubType {\n positionHistory = \"Position history\",\n orderHistory = \"Order history\",\n}\n\nexport const useDataListScript = (props: {\n symbol: string;\n className?: string;\n sharePnLConfig?: SharePnLConfig;\n}) => {\n const { symbol, sharePnLConfig } = props;\n const [tab, setTab] = useState<DataListTabType>(DataListTabType.position);\n const [subTab, setSubTab] = useState<DataListTabSubType>(\n DataListTabSubType.positionHistory,\n );\n const { t } = useTranslation();\n\n const { onSymbolChange } = useTradingPageContext();\n const localStorage = useTradingLocalStorage();\n\n const [_, { cancelAllOrders, cancelAllTPSLOrders }] = useOrderStream({});\n const { positionCount } = usePositionsCount(symbol);\n const { pendingOrderCount, tpSlOrderCount } = usePendingOrderCount(symbol);\n\n const onCloseAll = (type: TabType) => {\n const title =\n type === TabType.pending\n ? t(\"orders.pending.cancelAll\")\n : type === TabType.tp_sl\n ? t(\"orders.tpsl.cancelAll\")\n : \"\";\n const content =\n type === TabType.pending\n ? t(\"orders.pending.cancelAll.description\")\n : type === TabType.tp_sl\n ? t(\"orders.tpsl.cancelAll.description\")\n : \"\";\n modal.confirm({\n title: title,\n content: <Text size=\"2xs\">{content}</Text>,\n\n onOk: async () => {\n try {\n // await cancelAll(null, { source_type: \"ALL\" });\n if (tab === DataListTabType.tp_sl) {\n await cancelAllTPSLOrders();\n } else {\n await cancelAllOrders();\n }\n return Promise.resolve(true);\n } catch (error) {\n // @ts-ignore\n if (error?.message !== undefined) {\n // @ts-ignore\n toast.error(error.message);\n }\n return Promise.resolve(false);\n } finally {\n Promise.resolve();\n }\n },\n });\n };\n\n return {\n tab,\n setTab,\n subTab,\n setSubTab,\n sharePnLConfig,\n symbol,\n positionCount,\n pendingOrderCount,\n tpSlOrderCount,\n ...localStorage,\n onCloseAll,\n onSymbolChange,\n };\n};\n\nexport type DataListState = ReturnType<typeof useDataListScript>;\n","import React from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { OrderStatus } from \"@orderly.network/types\";\nimport {\n Button,\n Checkbox,\n Divider,\n Flex,\n TabPanel,\n Tabs,\n Text,\n} from \"@orderly.network/ui\";\nimport { MobileOrderListWidget, TabType } from \"@orderly.network/ui-orders\";\nimport {\n MobileLiquidationWidget,\n MobilePositionHistoryWidget,\n MobilePositionsWidget,\n} from \"@orderly.network/ui-positions\";\nimport {\n DataListState,\n DataListTabSubType,\n DataListTabType,\n} from \"./dataList.script\";\n\nconst LazyPositionHeaderWidget = React.lazy(() =>\n import(\"../../base/positionHeader\").then((module) => {\n return { default: module.PositionHeaderWidget };\n }),\n);\n\nexport const DataList: React.FC<DataListState & { className?: string }> = (\n props,\n) => {\n const { t } = useTranslation();\n\n return (\n <Tabs\n value={props.tab}\n onValueChange={(e: any) => props.setTab(e)}\n size=\"lg\"\n className={props.className}\n classNames={{\n tabsList:\n \"oui-bg-base-9 oui-rounded-t-xl oui-p-2 oui-overflow-x-scroll oui-hide-scrollbar\",\n }}\n >\n <TabPanel\n title={`${t(\"common.positions\")} ${\n (props.positionCount ?? 0) > 0 ? `(${props.positionCount})` : \"\"\n }`}\n value={DataListTabType.position}\n >\n <PositionsView {...props} />\n </TabPanel>\n <TabPanel\n title={`${t(\"orders.status.pending\")} ${\n (props.pendingOrderCount ?? 0) > 0\n ? `(${props.pendingOrderCount})`\n : \"\"\n }`}\n value={DataListTabType.pending}\n >\n <OrdersView\n type={TabType.pending}\n ordersStatus={OrderStatus.INCOMPLETE}\n {...props}\n />\n </TabPanel>\n <TabPanel\n title={`${t(\"common.tpsl\")} ${\n (props.tpSlOrderCount ?? 0) > 0 ? `(${props.tpSlOrderCount})` : \"\"\n }`}\n value={DataListTabType.tp_sl}\n >\n <OrdersView\n type={TabType.tp_sl}\n ordersStatus={OrderStatus.INCOMPLETE}\n {...props}\n />\n </TabPanel>\n <TabPanel title={t(\"trading.history\")} value={DataListTabType.history}>\n <HistoryTab {...props} />\n </TabPanel>\n <TabPanel\n title={t(\"positions.liquidation\")}\n value={DataListTabType.liquidation}\n >\n <MobileLiquidationWidget\n enableLoadMore={true}\n symbol={props.showAllSymbol ? undefined : props.symbol}\n classNames={{ cell: \"oui-p-2 oui-bg-base-9 oui-rounded-xl\" }}\n />\n </TabPanel>\n </Tabs>\n );\n};\n\nconst PositionsView: React.FC<DataListState> = (props) => {\n return (\n <Flex direction={\"column\"} gap={2}>\n <React.Suspense fallback={null}>\n <LazyPositionHeaderWidget\n pnlNotionalDecimalPrecision={props.pnlNotionalDecimalPrecision}\n symbol={props.showAllSymbol ? undefined : props.symbol}\n unPnlPriceBasis={props.unPnlPriceBasis}\n />\n </React.Suspense>\n <React.Suspense fallback={null}>\n <MobilePositionsWidget\n symbol={props.showAllSymbol ? undefined : props.symbol}\n onSymbolChange={props.onSymbolChange}\n sharePnLConfig={props.sharePnLConfig}\n pnlNotionalDecimalPrecision={props.pnlNotionalDecimalPrecision}\n />\n </React.Suspense>\n </Flex>\n );\n};\n\nconst OrdersView: React.FC<\n DataListState & { type: TabType; ordersStatus?: OrderStatus }\n> = (props) => {\n return (\n <Flex direction={\"column\"} pb={2} width={\"100%\"}>\n <Divider className=\"oui-w-full\" />\n {props.type !== TabType.orderHistory && (\n <SymbolControlHeader {...props} />\n )}\n <MobileOrderListWidget\n symbol={props.showAllSymbol ? undefined : props.symbol}\n onSymbolChange={props.onSymbolChange}\n type={props.type}\n ordersStatus={props.ordersStatus}\n classNames={{\n root: \"oui-w-full oui-hide-scrollbar oui-overflow-y-hidden\",\n content: \"!oui-space-y-1\",\n cell: \"oui-py-2 oui-bg-base-9 oui-p-2 oui-rounded-xl\",\n }}\n sharePnLConfig={props.sharePnLConfig}\n showFilter={props.type === TabType.orderHistory}\n filterConfig={{ range: { from: undefined, to: undefined } }}\n />\n </Flex>\n );\n};\n\nconst SymbolControlHeader: React.FC<\n DataListState & { type: TabType; ordersStatus?: OrderStatus }\n> = (props) => {\n const { t } = useTranslation();\n\n return (\n <Flex\n px={2}\n py={2}\n width={\"100%\"}\n justify={\"between\"}\n gap={2}\n className=\"oui-rounded-b-xl oui-bg-base-9\"\n >\n <Flex className=\"oui-cursor-pointer oui-gap-[2px]\">\n <Checkbox\n color=\"white\"\n checked={!props.showAllSymbol}\n onCheckedChange={(checked: boolean) => {\n props.setShowAllSymbol(!checked);\n }}\n />\n <Text\n size=\"2xs\"\n intensity={54}\n onClick={() => {\n props.setShowAllSymbol(!props.showAllSymbol);\n }}\n >\n {t(\"trading.hideOtherSymbols\")}\n </Text>\n </Flex>\n <Button\n variant=\"outlined\"\n size=\"xs\"\n color=\"secondary\"\n onClick={(e) => {\n props.onCloseAll(props.type);\n }}\n >\n {t(\"trading.orders.closeAll\")}\n </Button>\n </Flex>\n );\n};\n\nconst HistoryTab: React.FC<DataListState> = (props) => {\n const { t } = useTranslation();\n\n return (\n <div className=\"oui-min-h-[300px]\">\n <Tabs\n value={props.subTab}\n onValueChange={(e: any) => props.setSubTab(e)}\n size=\"md\"\n classNames={{\n tabsList: \"oui-bg-base-9 oui-rounded-t-xl oui-p-2\",\n }}\n >\n <TabPanel\n title={t(\"positions.positionHistory\")}\n value={DataListTabSubType.positionHistory}\n >\n <MobilePositionHistoryWidget\n symbol={props.showAllSymbol ? undefined : props.symbol}\n onSymbolChange={props.onSymbolChange}\n classNames={{ cell: \"oui-p-2 oui-bg-base-9 oui-rounded-xl\" }}\n sharePnLConfig={props.sharePnLConfig}\n />\n </TabPanel>\n <TabPanel\n title={t(\"orders.orderHistory\")}\n value={DataListTabSubType.orderHistory}\n >\n <OrdersView type={TabType.orderHistory} {...props} />\n </TabPanel>\n </Tabs>\n </div>\n );\n};\n","import React from \"react\";\nimport type { SharePnLConfig } from \"@orderly.network/ui-share\";\nimport { useDataListScript } from \"./dataList.script\";\nimport { DataList } from \"./dataList.ui\";\n\nexport const DataListWidget: React.FC<{\n symbol: string;\n className?: string;\n sharePnLConfig?: SharePnLConfig;\n}> = (props) => {\n const state = useDataListScript(props);\n return <DataList {...state} className={props.className} />;\n};\n","export { DataList } from \"./dataList.ui\";\nexport { DataListWidget } from \"./dataList.widget\";\nexport { useDataListScript } from \"./dataList.script\";\n","export type {\n ShareOptions,\n TradingPageProps,\n ReferralProps,\n TradingRewardsProps,\n} from \"./types/types\";\n\nexport * from \"./components/desktop/dataList\";\nexport * from \"./components/base/lastTrades\";\nexport * from \"./components/desktop/assetView\";\nexport * from \"./components/base/orderBook\";\nexport * from \"./components/desktop/riskRate\";\nexport * from \"./components/desktop/orderBookAndTrades\";\nexport * from \"./components/desktop/layout/splitLayout/splitLayout\";\nexport * from \"./components/mobile/bottomNavBar\";\nexport * from \"./components/mobile/portfolioSheet\";\nexport * from \"./components/mobile/fundingRate\";\nexport * from \"./components/mobile/fundingRateModal\";\nexport * from \"./pages/trading\";\nexport * from \"./provider/tradingPageContext\";\nexport * from \"./provider/tradingPageProvider\";\nexport * from \"./hooks\";\n","import React, { PropsWithChildren, forwardRef } from \"react\";\nimport Split, { SplitProps } from \"@uiw/react-split\";\nimport { SplitLineBar } from \"./splitLineBar\";\n\ntype SplitLayoutProps = PropsWithChildren<SplitProps> & {\n onSizeChange?: (size: string) => void;\n};\n\nexport const SplitLayout = forwardRef<Split, SplitLayoutProps>((props, ref) => {\n const { onSizeChange, ...rest } = props;\n return (\n <Split\n ref={ref}\n {...rest}\n lineBar\n renderBar={(barProps) => <SplitLineBar {...barProps} mode={props.mode} />}\n onDragEnd={(_, width) => onSizeChange?.(`${width}`)}\n />\n );\n});\n","import React, { HTMLAttributes, useMemo } from \"react\";\nimport { SplitProps } from \"@uiw/react-split\";\nimport { cn } from \"@orderly.network/ui\";\n\nexport type SplitLineBarProps = Pick<SplitProps, \"mode\"> &\n HTMLAttributes<HTMLDivElement>;\n\nexport const SplitLineBar: React.FC<SplitLineBarProps> = (props) => {\n const { onMouseDown, mode = \"horizontal\", ...rest } = props;\n\n const disable = useMemo(\n () => props.className?.split(\" \").includes(\"disable\"),\n [props.className],\n );\n\n const filterCls = useMemo(\n () => props.className?.split(\" \").filter((cls) => cls !== \"disable\"),\n [props.className],\n );\n\n return (\n <div\n {...rest}\n className={cn(\n filterCls,\n \"!oui-transition-none\",\n \"!oui-shadow-none !oui-bg-transparent\",\n \"hover:!oui-bg-primary-light hover:!oui-shadow-[0px_0px_4px_0px] hover:!oui-shadow-primary-light/80\",\n \"active:!oui-bg-primary-light active:!oui-shadow-[0px_0px_4px_0px] active:!oui-shadow-primary-light/80\",\n \"focus:!oui-bg-primary-light focus:!oui-shadow-[0px_0px_4px_0px] focus:!oui-shadow-primary-light/80\",\n mode === \"horizontal\"\n ? \"!oui-w-[2px] !oui-min-w-[2px] !oui-mx-[3px]\"\n : \"!oui-h-[2px] !oui-min-h-[2px] !oui-my-[3px]\",\n disable && \"oui-pointer-events-none\",\n )}\n >\n <div\n onMouseDown={onMouseDown}\n className={cn(\n \"!oui-transition-none\",\n mode === \"horizontal\" ? \"after:!oui-w-[2px]\" : \"after:!oui-h-[2px]\",\n \"after:!oui-bg-transparent after:!oui-shadow-transparent\",\n )}\n />\n </div>\n );\n};\n","import { FC, SVGProps, useState } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { AccountStatusEnum } from \"@orderly.network/types\";\nimport { Flex, SimpleDialog, Text } from \"@orderly.network/ui\";\nimport { ScanQRCodeWidget } from \"@orderly.network/ui-scaffold\";\nimport { MobileAccountMenuExtension } from \"./account/account.widget\";\nimport { BalanceWidget } from \"./balance\";\nimport { BottomNavBarState } from \"./bottomNavBar.script\";\nimport { ChainWidget } from \"./chain\";\n\nexport const BottomNavBar: FC<BottomNavBarState> = (props) => {\n const renderContent = () => {\n if (props.wrongNetwork) {\n return null;\n }\n\n if (\n !props.disabledConnect &&\n props.status === AccountStatusEnum.EnableTradingWithoutConnected\n ) {\n return <LinkDevice onDisconnect={props.onDisconnect} />;\n }\n\n return <ChainWidget />;\n };\n\n const showScanQRCode =\n !props.disabledConnect &&\n props.status !== AccountStatusEnum.EnableTradingWithoutConnected &&\n props.status < AccountStatusEnum.EnableTrading;\n\n return (\n <div className=\"oui-bg-base-9 oui-border-t oui-border-line-4\">\n <Flex\n height={64}\n gap={1}\n justify={\"end\"}\n itemAlign={\"center\"}\n className=\"oui-px-[14px]\"\n // style={{\n // height: \"calc(64px + env(safe-area-inset-bottom))\"\n // }}\n >\n <BalanceWidget />\n <Flex gap={2}>\n {showScanQRCode && <ScanQRCodeWidget />}\n {renderContent()}\n <MobileAccountMenuExtension />\n </Flex>\n </Flex>\n <div className=\"oui-h-[env(safe-area-inset-bottom)]\" />\n </div>\n );\n};\n\ntype LinkDeviceProps = {\n onDisconnect: () => void;\n};\n\nconst LinkDevice: FC<LinkDeviceProps> = (props) => {\n const [open, setOpen] = useState(false);\n const { t } = useTranslation();\n\n const showDialog = () => {\n setOpen(true);\n };\n\n const hideDialog = () => {\n setOpen(false);\n };\n\n return (\n <>\n <SimpleDialog\n open={open}\n onOpenChange={setOpen}\n title={t(\"common.tips\")}\n size=\"xs\"\n actions={{\n secondary: {\n label: t(\"common.cancel\"),\n onClick: hideDialog,\n size: \"md\",\n fullWidth: true,\n },\n primary: {\n label: t(\"connector.disconnect\"),\n onClick: async () => {\n await props.onDisconnect();\n hideDialog();\n },\n size: \"md\",\n variant: \"outlined\",\n color: \"danger\",\n },\n }}\n >\n <Text intensity={54} size=\"sm\">\n {t(\"linkDevice.scanQRCode.connected.description\")}\n </Text>\n </SimpleDialog>\n <Flex\n className=\"oui-text-base-contrast oui-px-[6px]\"\n intensity={500}\n height={28}\n r=\"md\"\n onClick={showDialog}\n >\n <DesktopIcon />\n <Dot />\n <LinkIcon />\n <Dot />\n <MobileIcon />\n </Flex>\n </>\n );\n};\n\nconst Dot = () => {\n return (\n <Flex className=\"oui-gap-x-[1px] oui-px-[1px]\">\n <DotIcon />\n <DotIcon />\n <DotIcon />\n </Flex>\n );\n};\n\nconst DesktopIcon: FC<SVGProps<SVGSVGElement>> = (props) => (\n <svg\n width=\"18\"\n height=\"18\"\n viewBox=\"0 0 18 18\"\n fill=\"currentColor\"\n xmlns=\"http://www.w3.org/2000/svg\"\n {...props}\n >\n <path d=\"M4.5 2.93a2.25 2.25 0 0 0-2.25 2.25v5.25a.75.75 0 0 0-.75.75v1.5c0 1.272.93 2.25 2.25 2.25h10.5c1.318 0 2.25-.978 2.25-2.25v-1.5a.75.75 0 0 0-.75-.75V5.18a2.25 2.25 0 0 0-2.25-2.25zm0 1.5h9a.75.75 0 0 1 .75.75v5.25H3.75V5.18a.75.75 0 0 1 .75-.75M3 11.93h12v.75c0 .46-.277.75-.75.75H3.75c-.474 0-.75-.29-.75-.75z\" />\n </svg>\n);\n\nconst MobileIcon: FC<SVGProps<SVGSVGElement>> = (props) => (\n <svg\n width=\"18\"\n height=\"18\"\n viewBox=\"0 0 18 18\"\n fill=\"currentColor\"\n xmlns=\"http://www.w3.org/2000/svg\"\n {...props}\n >\n <path d=\"M13.498 3.715a2.25 2.25 0 0 0-2.25-2.25h-4.5a2.25 2.25 0 0 0-2.25 2.25v10.5a2.25 2.25 0 0 0 2.25 2.25h4.5a2.25 2.25 0 0 0 2.25-2.25zm-1.5 0v9.75h-6v-9.75a.75.75 0 0 1 .75-.75h4.5a.75.75 0 0 1 .75.75m-2.25 11.25a.75.75 0 1 1-1.5 0 .75.75 0 0 1 1.5 0\" />\n </svg>\n);\n\nconst LinkIcon: FC<SVGProps<SVGSVGElement>> = (props) => (\n <svg\n width=\"12\"\n height=\"12\"\n viewBox=\"0 0 12 12\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M1.007 6a5 5 0 1 1 10 0 5 5 0 0 1-10 0m7.486-2.344A.6.6 0 0 1 8.91 3.5c.15 0 .305.048.418.156a.55.55 0 0 1 0 .798L5.254 8.337a.62.62 0 0 1-.837 0L2.67 6.673a.55.55 0 0 1 0-.798.62.62 0 0 1 .837 0l1.329 1.266z\"\n fill=\"url(#a)\"\n />\n <defs>\n <linearGradient\n id=\"a\"\n x1=\"11.007\"\n y1=\"5.999\"\n x2=\"1.007\"\n y2=\"5.999\"\n gradientUnits=\"userSpaceOnUse\"\n >\n <stop stopColor=\"rgb(var(--oui-gradient-brand-end))\" />\n <stop offset=\"1\" stopColor=\"rgb(var(--oui-gradient-brand-start))\" />\n </linearGradient>\n </defs>\n </svg>\n);\n\nconst DotIcon: FC<SVGProps<SVGSVGElement>> = (props) => (\n <svg\n width=\"2\"\n height=\"2\"\n viewBox=\"0 0 2 2\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M.667.334a.667.667 0 1 1 0 1.333.667.667 0 0 1 0-1.333\"\n fill=\"url(#a)\"\n />\n <defs>\n <linearGradient\n id=\"a\"\n x1=\"1.333\"\n y1=\"1.001\"\n x2=\"0\"\n y2=\"1.001\"\n gradientUnits=\"userSpaceOnUse\"\n >\n <stop stopColor=\"rgb(var(--oui-gradient-brand-end))\" />\n <stop offset=\"1\" stopColor=\"rgb(var(--oui-gradient-brand-start))\" />\n </linearGradient>\n </defs>\n </svg>\n);\n","import { ExtensionPositionEnum, ExtensionSlot, installExtension } from \"@orderly.network/ui\";\nimport { useAccountScript } from \"./account.script\";\nimport { Account } from \"./account.ui\";\n\nexport const AccountWidget = () => {\n const state = useAccountScript();\n return (<Account {...state} />);\n};\ninstallExtension<any>({\n name: \"mobile-account-menu\",\n scope: [\"*\"],\n positions: [ExtensionPositionEnum.MobileAccountMenu],\n builder: useAccountScript,\n __isInternal: true,\n })((props:any) => {\n return <Account {...props} />;\n });\n \n export const MobileAccountMenuExtension = () => {\n return <ExtensionSlot position={ExtensionPositionEnum.MobileAccountMenu} />;\n };\n ","import { AccountState as AccountStateType } from \"@orderly.network/core\";\nimport { useAccount } from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { modal } from \"@orderly.network/ui\";\nimport { useTradingPageContext } from \"../../../../provider/tradingPageContext\";\nimport { AccountSheetWidget } from \"../../accountSheet\";\n\nexport const useAccountScript = () => {\n const { t } = useTranslation();\n const { referral, tradingRewards, bottomSheetLeading } =\n useTradingPageContext();\n const { account, state } = useAccount();\n\n const onShowAccountSheet = () => {\n modal.sheet({\n title: t(\"common.account\"),\n leading: bottomSheetLeading,\n content: <AccountSheetWidget {...referral} {...tradingRewards} />,\n });\n };\n\n return {\n onShowAccountSheet,\n address: account.address,\n state: state as AccountStateType,\n };\n};\n\nexport type AccountState = ReturnType<typeof useAccountScript>;\n","import { FC } from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { ArrowRightShortIcon, Button, Flex, Text } from \"@orderly.network/ui\";\nimport { Decimal } from \"@orderly.network/utils\";\nimport { AccountSheetState } from \"./accountSheet.script\";\nimport { CopyIcon, HeadIcon, OrderlyIcon, USDCIcon } from \"./icons\";\n\nexport const AccountSheet: FC<AccountSheetState> = (props) => {\n const { t } = useTranslation();\n\n return (\n <Flex direction={\"column\"} gap={4}>\n <AccountInfo {...props} />\n <ReferralInfo {...props} />\n <TradingRewardsInfo {...props} />\n <Flex gap={3} width={\"100%\"} justify={\"center\"}>\n {props.showGetTestUSDC && (\n <Button\n variant=\"outlined\"\n // color=\"primary\"\n size=\"md\"\n onClick={props.onGetTestUSDC}\n fullWidth\n loading={props.gettingTestUSDC}\n className=\"oui-border-primary-light oui-text-primary-light\"\n >\n {t(\"trading.faucet.getTestUSDC\")}\n </Button>\n )}\n <Button\n variant=\"outlined\"\n color=\"danger\"\n size=\"md\"\n onClick={props.onDisconnect}\n className={props.showGetTestUSDC ? \"oui-w-full\" : \"oui-w-[50%]\"}\n >\n {t(\"connector.disconnect\")}\n </Button>\n </Flex>\n </Flex>\n );\n};\nexport const AccountInfo: FC<AccountSheetState> = (props) => {\n return (\n <Flex width={\"100%\"} justify={\"between\"}>\n <Flex gap={3}>\n <HeadIcon />\n <Flex\n direction={\"column\"}\n justify={\"start\"}\n itemAlign={\"start\"}\n className=\"oui-gap-[2px]\"\n >\n <Text.formatted rule={\"address\"}>{props.address}</Text.formatted>\n <Text.formatted\n size=\"2xs\"\n intensity={80}\n // @ts-ignore\n prefix={\n <div className=\"oui-h-1 oui-w-1 oui-rounded-full oui-bg-success oui-pr-1\" />\n }\n >\n {props.chainName}\n </Text.formatted>\n </Flex>\n </Flex>\n <button\n className=\"oui-cursor-pointer\"\n onClick={() => {\n props.onCopyAddress();\n }}\n >\n <CopyIcon />\n </button>\n </Flex>\n );\n};\n\nexport const ReferralInfo: FC<AccountSheetState> = (props) => {\n const { t } = useTranslation();\n return (\n <Flex\n direction={\"column\"}\n gap={3}\n r=\"lg\"\n p={3}\n className=\"oui-bg-base-6\"\n width={\"100%\"}\n >\n <button\n onClick={props.onClickReferral}\n className=\"oui-cursor-pointer oui-w-full\"\n >\n <Flex justify={\"between\"} width={\"100%\"}>\n <Text size=\"2xs\">{t(\"affiliate.referral\")}</Text>\n <ArrowRightShortIcon color=\"white\" opacity={0.98} size={16} />\n </Flex>\n </button>\n {props.isAffiliate && (\n <Flex\n gradient=\"primary\"\n p={4}\n r=\"lg\"\n width={\"100%\"}\n angle={180}\n justify={\"between\"}\n >\n <Flex direction={\"column\"} itemAlign={\"start\"}>\n <Text size=\"xs\">{t(\"common.affiliate\")}</Text>\n <Text size=\"2xs\" intensity={54}>\n ({t(\"affiliate.commission.30d\")})\n </Text>\n </Flex>\n <Flex className=\"oui-gap-[6px]\">\n <USDCIcon />\n <Text.numeral\n dp={2}\n padding={false}\n rm={Decimal.ROUND_DOWN}\n rule=\"price\"\n >\n {props.affiliateCommission30D ?? \"--\"}\n </Text.numeral>\n </Flex>\n </Flex>\n )}\n {props.isTrader && (\n <Flex\n gradient=\"success\"\n p={4}\n r=\"lg\"\n width={\"100%\"}\n angle={180}\n justify={\"between\"}\n >\n <Flex direction={\"column\"} itemAlign={\"start\"}>\n <Text size=\"xs\">{t(\"affiliate.trader\")}</Text>\n <Text size=\"2xs\" intensity={54}>\n ({t(\"affiliate.commission.30d\")})\n </Text>\n </Flex>\n <Flex className=\"oui-gap-[6px]\">\n <USDCIcon />\n <Text.numeral\n dp={2}\n padding={false}\n rm={Decimal.ROUND_DOWN}\n rule=\"price\"\n >\n {props.traderCommission30D ?? \"--\"}\n </Text.numeral>\n </Flex>\n </Flex>\n )}\n </Flex>\n );\n};\n\nexport const TradingRewardsInfo: FC<AccountSheetState> = (props) => {\n const { t } = useTranslation();\n\n return (\n <Flex\n direction={\"column\"}\n gap={3}\n r=\"lg\"\n p={3}\n className=\"oui-bg-base-6\"\n width={\"100%\"}\n >\n <button\n onClick={props.onClickTradingRewards}\n className=\"oui-cursor-pointer oui-w-full\"\n >\n <Flex justify={\"between\"} width={\"100%\"}>\n <Flex gap={1} className=\"oui-text-base-contrast oui-text-2xs\">\n <Text>{t(\"common.tradingRewards\")}</Text>\n <Text intensity={54}>\n (\n <Text>{`${(\n t(\"tradingRewards.epoch\") as string\n )?.toLowerCase()} `}</Text>\n <Text intensity={98}>{props.curEpochId}</Text> )\n </Text>\n </Flex>\n <ArrowRightShortIcon color=\"white\" opacity={0.98} size={16} />\n </Flex>\n </button>\n <Flex\n p={4}\n r=\"lg\"\n width={\"100%\"}\n angle={180}\n justify={\"between\"}\n className=\"oui-bg-gradient-to-t oui-from-[#2d0061] oui-to-[#bd6bed]\"\n >\n <Text size=\"2xs\" intensity={80}>\n {t(\"tradingRewards.myEstRewards\")}\n </Text>\n\n <Flex className=\"oui-gap-[6px]\">\n <OrderlyIcon />\n <Text.numeral\n dp={2}\n padding={false}\n rm={Decimal.ROUND_DOWN}\n rule=\"price\"\n >\n {props.estRewards}\n </Text.numeral>\n </Flex>\n </Flex>\n </Flex>\n );\n};\n","export const HeadIcon = () => {\n return (\n <svg\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n className=\"oui-rounded-full\"\n >\n <g clipPath=\"url(#a)\">\n <path\n d=\"m31.002 14.493-8.326-22.51L.166.31l8.327 22.51z\"\n fill=\"#03435D\"\n />\n <path\n d=\"m4.456-8.716-18.03 15.84 15.84 18.03 18.03-15.84z\"\n fill=\"#157CF2\"\n />\n <path\n d=\"m17.548 38.67 22.825-7.416-7.416-22.825-22.826 7.416z\"\n fill=\"#F3E200\"\n />\n </g>\n <defs>\n <clipPath id=\"a\">\n <rect width=\"24\" height=\"24\" rx=\"12\" fill=\"#fff\" />\n </clipPath>\n </defs>\n </svg>\n );\n};\n\nexport const CopyIcon = () => {\n return (\n <svg\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M5.832 2.492A3.333 3.333 0 0 0 2.5 5.826v5a3.333 3.333 0 0 0 3.333 3.333 3.333 3.333 0 0 0 3.334 3.333h5a3.333 3.333 0 0 0 3.333-3.333v-5a3.333 3.333 0 0 0-3.333-3.333 3.333 3.333 0 0 0-3.334-3.334zm8.334 5c.92 0 1.666.746 1.666 1.667v5c0 .92-.746 1.666-1.666 1.666h-5c-.92 0-1.667-.745-1.667-1.666h3.333a3.333 3.333 0 0 0 3.334-3.334z\"\n fill=\"rgb(var(--oui-color-primary))\"\n />\n </svg>\n );\n};\n\nexport const USDCIcon = (props: { size?: number }) => {\n const { size = 20 } = props;\n return (\n <svg\n width={size}\n height={size}\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <g clipPath=\"url(#a)\">\n <path\n d=\"M10 20c5.542 0 10-4.458 10-10S15.542 0 10 0 0 4.458 0 10s4.458 10 10 10\"\n fill=\"#2775CA\"\n />\n <path\n d=\"M13 11.473c0-1.452-.94-1.95-2.82-2.158-1.344-.166-1.613-.498-1.613-1.078s.448-.955 1.343-.955c.806 0 1.254.25 1.478.872.045.124.18.207.313.207h.717c.179 0 .313-.125.313-.29v-.042c-.179-.913-.985-1.618-2.015-1.701v-.996c0-.166-.134-.29-.358-.332h-.671c-.18 0-.314.124-.359.332v.954c-1.343.166-2.194.996-2.194 2.034 0 1.369.896 1.908 2.776 2.116 1.254.207 1.657.456 1.657 1.12s-.627 1.12-1.477 1.12c-1.165 0-1.568-.456-1.702-1.078a.32.32 0 0 0-.313-.25h-.762c-.179 0-.313.125-.313.291v.042c.179 1.037.895 1.784 2.373 1.991v.996c0 .166.134.29.358.332h.672c.18 0 .313-.124.358-.332v-.996C12.105 13.465 13 12.593 13 11.473\"\n fill=\"#fff\"\n fillOpacity=\".98\"\n />\n <path\n d=\"M7.74 16.57c-3.458-1.215-5.23-4.986-3.945-8.324.665-1.821 2.127-3.208 3.944-3.859.178-.086.266-.216.266-.433v-.607c0-.174-.088-.304-.266-.347-.044 0-.133 0-.177.043-4.21 1.3-6.516 5.68-5.186 9.798.798 2.428 2.704 4.292 5.186 5.072.177.087.355 0 .399-.173.044-.043.044-.087.044-.173v-.608c0-.13-.133-.303-.266-.39m4.698-13.527c-.178-.086-.355 0-.4.174-.043.043-.043.086-.043.173v.607c0 .174.133.347.266.434 3.457 1.213 5.23 4.985 3.944 8.323-.664 1.821-2.127 3.209-3.944 3.859-.178.086-.266.216-.266.433v.607c0 .174.088.304.266.347.044 0 .133 0 .177-.043 4.21-1.3 6.515-5.68 5.186-9.798-.798-2.471-2.748-4.335-5.186-5.116\"\n fill=\"#fff\"\n />\n </g>\n <defs>\n <clipPath id=\"a\">\n <path fill=\"#fff\" d=\"M0 0h20v20H0z\" />\n </clipPath>\n </defs>\n </svg>\n );\n};\n\nexport const OrderlyIcon = (props: { size?: number }) => {\n const { size = 20 } = props;\n return (\n <svg\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <g clipPath=\"url(#clip0_6403_64483)\">\n <path\n d=\"M10.0245 19.9493C15.5198 19.9493 19.9747 15.4944 19.9747 9.99908C19.9747 4.50371 15.5198 0.0488281 10.0245 0.0488281C4.5291 0.0488281 0.0742188 4.50371 0.0742188 9.99908C0.0742188 15.4944 4.5291 19.9493 10.0245 19.9493Z\"\n fill=\"url(#paint0_linear_6403_64483)\"\n />\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M14.1553 4.89304C14.2199 4.94541 14.1821 5.04758 14.0989 5.04758H5.95035C5.86716 5.04758 5.82936 4.94541 5.894 4.89304C7.0223 3.97912 8.45953 3.43164 10.0246 3.43164C11.5898 3.43164 13.0269 3.97912 14.1553 4.89304Z\"\n fill=\"white\"\n />\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M7.47013 11.7869C7.42315 11.7199 7.34748 11.6777 7.26565 11.6777H3.82985C3.75113 11.6777 3.69375 11.7525 3.71563 11.8281C4.5078 14.565 7.0326 16.566 10.0247 16.566C13.017 16.566 15.5417 14.565 16.3339 11.8281C16.3558 11.7525 16.2984 11.6777 16.2197 11.6777H12.7839C12.702 11.6777 12.6264 11.7199 12.5795 11.7869C12.0155 12.5911 11.0815 13.1167 10.0248 13.1167C8.96803 13.1167 8.03406 12.5911 7.47013 11.7869Z\"\n fill=\"white\"\n />\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M12.3347 7.90519C12.3822 7.95756 12.449 7.9891 12.5196 7.9891H16.1137C16.1952 7.9891 16.253 7.90983 16.2261 7.83301C15.9724 7.10689 15.5948 6.43893 15.1187 5.85447C15.074 5.79961 15.0067 5.76855 14.9358 5.76855H5.11323C5.04247 5.76855 4.97512 5.79961 4.93044 5.85447C4.45429 6.43893 4.0767 7.10689 3.82306 7.83301C3.79622 7.90983 3.85398 7.9891 3.93536 7.9891H7.52952C7.60022 7.9891 7.66694 7.95756 7.71445 7.90519C8.28491 7.2763 9.10861 6.88136 10.0246 6.88136C10.9405 6.88136 11.7643 7.2763 12.3347 7.90519Z\"\n fill=\"white\"\n />\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M13.1164 10.9586C13.0553 10.9586 13.0118 10.899 13.0284 10.8401C13.1033 10.5722 13.1433 10.2898 13.1433 9.9981C13.1433 9.58758 13.064 9.19556 12.9199 8.83657C12.8954 8.77581 12.9392 8.70801 13.0046 8.70801H16.392C16.4349 8.70801 16.472 8.73831 16.4799 8.78052C16.5538 9.17511 16.5925 9.58216 16.5925 9.9982C16.5925 10.2978 16.5724 10.5926 16.5337 10.8815C16.5277 10.9258 16.4897 10.9586 16.4451 10.9586H13.1164ZM7.02223 10.8401C7.03868 10.899 6.99532 10.9586 6.93421 10.9586H3.60551C3.56084 10.9586 3.52285 10.9258 3.5169 10.8815C3.47807 10.5926 3.45801 10.2978 3.45801 9.9982C3.45801 9.58216 3.4967 9.17511 3.57069 8.78052C3.57859 8.73831 3.61563 8.70801 3.65856 8.70801H7.04593C7.11141 8.70801 7.15516 8.77581 7.13076 8.83657C6.98657 9.19556 6.90722 9.58758 6.90722 9.9981C6.90722 10.2898 6.94728 10.5722 7.02223 10.8401Z\"\n fill=\"white\"\n />\n </g>\n <defs>\n <linearGradient\n id=\"paint0_linear_6403_64483\"\n x1=\"10.0245\"\n y1=\"0.0488561\"\n x2=\"10.0245\"\n y2=\"19.9493\"\n gradientUnits=\"userSpaceOnUse\"\n >\n <stop stopColor=\"#C750FF\" />\n <stop offset=\"1\" stopColor=\"#5800E8\" />\n </linearGradient>\n <clipPath id=\"clip0_6403_64483\">\n <rect width=\"20\" height=\"20\" fill=\"white\" />\n </clipPath>\n </defs>\n </svg>\n );\n};\n","import { useMemo } from \"react\";\nimport {\n TWType,\n useAccount,\n useChains,\n useConfig,\n useCurEpochEstimate,\n useEpochInfo,\n useLocalStorage,\n useMutation,\n useReferralInfo,\n useWalletConnector,\n} from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { AccountStatusEnum, ChainNamespace } from \"@orderly.network/types\";\nimport { modal, toast, useModal } from \"@orderly.network/ui\";\nimport { isTestnet } from \"@orderly.network/utils\";\nimport { ReferralProps, TradingRewardsProps } from \"../../../types/types\";\n\nexport const useAccountSheetScript = (\n props: ReferralProps & TradingRewardsProps,\n) => {\n const { t } = useTranslation();\n const [linkDeviceStorage] = useLocalStorage(\"orderly_link_device\", {});\n const { account, state } = useAccount();\n const accountId = account.accountId;\n const address = account.address;\n const { hide } = useModal();\n\n const config = useConfig();\n\n const { connectedChain, disconnect, namespace } = useWalletConnector();\n\n const chainId =\n account.chainId || connectedChain?.id || linkDeviceStorage?.chainId;\n\n const showGetTestUSDC = useMemo(() => {\n if (chainId) {\n return (\n (state.status === AccountStatusEnum.EnableTrading ||\n state.status === AccountStatusEnum.EnableTradingWithoutConnected) &&\n // @ts-ignore\n isTestnet(parseInt(chainId))\n );\n }\n\n return false;\n }, [state.status, chainId]);\n\n const chainName = useGetChains(chainId);\n\n const operatorUrl = config.get<string>(\"operatorUrl\");\n\n const onCopyAddress = () => {\n navigator.clipboard.writeText(address ?? \"\");\n toast.success(t(\"common.copy.copied\"));\n };\n\n const {\n affiliateCommission30D,\n traderCommission30D,\n isAffiliate,\n isTrader,\n onClickReferral,\n } = useReferral(props.onClickReferral);\n\n const { curEpochId, estRewards, onClickTradingRewards } = useTradingRewards(\n props.onClickTradingRewards,\n );\n\n const onDisconnect = async () => {\n // The cache must be cleared first, otherwise it will be possible entered link device mode\n localStorage.removeItem(\"orderly_link_device\");\n await disconnect({\n label: state.connectWallet?.name,\n });\n await account.disconnect();\n hide();\n };\n\n const [getTestUSDC, { isMutating: gettingTestUSDC }] = useMutation(\n `${operatorUrl}/v1/faucet/usdc`,\n );\n\n const onGetTestUSDC = () => {\n if (\n state.status < AccountStatusEnum.EnableTrading &&\n state.status !== AccountStatusEnum.EnableTradingWithoutConnected\n ) {\n // return modal.show(WalletConnectSheet, {\n // status: state.status,\n // });\n return;\n }\n\n const message = t(\"trading.faucet.getTestUSDC.success\", {\n quantity: namespace === ChainNamespace.solana ? \"100\" : \"1,000\",\n });\n\n return getTestUSDC({\n chain_id: chainId?.toString(),\n user_address: state.address,\n broker_id: config.get(\"brokerId\"),\n }).then(\n (res: any) => {\n if (res.success) {\n return modal.alert({\n title: t(\"trading.faucet.getTestUSDC\"),\n message,\n onOk: () => {\n return Promise.resolve(true);\n },\n });\n }\n res.message && toast.error(res.message);\n // return Promise.reject(res);\n },\n (error: Error) => {\n toast.error(error.message);\n },\n );\n };\n return {\n accountId,\n address,\n chainId,\n chainName,\n onCopyAddress,\n\n affiliateCommission30D,\n onClickReferral,\n isAffiliate,\n isTrader,\n traderCommission30D,\n\n curEpochId,\n onClickTradingRewards,\n estRewards,\n\n onDisconnect,\n showGetTestUSDC,\n onGetTestUSDC,\n gettingTestUSDC,\n };\n};\n\nconst useReferral = (_onClickReferral?: () => void) => {\n const { data, isLoading, isAffiliate, isTrader } = useReferralInfo();\n\n const affiliateCommission30D = useMemo(() => {\n if (isAffiliate) {\n return data?.referrer_info?.[\"30d_referrer_rebate\"];\n }\n return undefined;\n }, [data, isAffiliate]);\n\n const traderCommission30D = useMemo(() => {\n if (isTrader) {\n return data?.referee_info?.[\"30d_referee_rebate\"];\n }\n return undefined;\n }, [data, isTrader]);\n\n const onClickReferral = () => {\n _onClickReferral?.();\n };\n\n return {\n onClickReferral,\n affiliateCommission30D,\n traderCommission30D,\n isAffiliate,\n isTrader,\n\n // WARNING: test data\n // affiliateCommission30D: 1234.43,\n // traderCommission30D:44343.33,\n // isAffiliate: true,\n // isTrader: true,\n };\n};\n\nconst useTradingRewards = (_onClick?: () => void) => {\n const [curEpochEstimate] = useCurEpochEstimate(TWType.normal);\n const [list, curEpoch] = useEpochInfo(TWType.normal);\n const curEpochId = useMemo(() => {\n return curEpoch.curEpochInfo?.epoch_id ?? \"--\";\n }, [curEpoch]);\n\n const estRewards = useMemo(() => {\n if (typeof curEpochEstimate?.est_r_wallet === \"undefined\") {\n return \"--\";\n }\n return curEpochEstimate?.est_r_wallet;\n }, [curEpochEstimate]);\n\n const onClickTradingRewards = () => {\n _onClick?.();\n };\n\n return {\n curEpochId,\n estRewards,\n onClickTradingRewards,\n };\n};\n\nfunction useGetChains(chainId: number) {\n const [mainChains, { findByChainId }] = useChains(\"mainnet\", {\n pick: \"network_infos\",\n filter: (chain: any) =>\n chain.network_infos?.bridge_enable || chain.network_infos?.bridgeless,\n });\n\n const chainName = useMemo(() => {\n // @ts-ignore\n const chain = findByChainId(parseInt(chainId), \"network_infos\");\n\n if (!chain) {\n return \"Unknown\";\n }\n // // @ts-ignore\n // if (isTestnet(chain.chain_id)) {\n // return \"Testnet\";\n // }\n // @ts-ignore\n return chain.name;\n }, [chainId, findByChainId]);\n\n return chainName;\n}\n\nexport type AccountSheetState = ReturnType<typeof useAccountSheetScript>;\n","import { ReferralProps, TradingRewardsProps } from \"../../../types/types\";\nimport { useAccountSheetScript } from \"./accountSheet.script\";\nimport { AccountSheet } from \"./accountSheet.ui\";\n\nexport const AccountSheetWidget = (\n props: ReferralProps & TradingRewardsProps\n) => {\n const state = useAccountSheetScript(props);\n return <AccountSheet {...state} />;\n};\n","import { FC } from \"react\";\nimport { Button, formatAddress } from \"@orderly.network/ui\";\nimport { AccountState } from \"./account.script\";\nimport { AuthGuard } from \"@orderly.network/ui-connector\";\n\nexport const Account: FC<AccountState> = (props) => {\n return (\n <AuthGuard\n buttonProps={{\n size: \"sm\",\n }}\n >\n <Button\n variant=\"gradient\"\n size={\"sm\"}\n className=\"oui-max-w-[83px]\"\n onClick={(e) => {\n props.onShowAccountSheet();\n }}\n >\n {formatAddress(props.address!, [4, 4])}\n </Button>\n </AuthGuard>\n );\n};\n","import { FC } from \"react\";\nimport { BalanceState } from \"./balance.script\";\n\nexport const Balance: FC<BalanceState> = () => {\n return null;\n};\n","export const useBalanceScript = () => {\n return {};\n};\n\nexport type BalanceState = ReturnType<typeof useBalanceScript>;\n","import { useBalanceScript } from \"./balance.script\";\nimport { Balance } from \"./balance.ui\";\n\nexport const BalanceWidget = () => {\n const state = useBalanceScript();\n return <Balance {...state} />;\n};\n","import { FC } from \"react\";\nimport { Box, ChainIcon, modal, toast } from \"@orderly.network/ui\";\nimport { ChainState } from \"./chain.script\";\nimport { ChainSelectorSheetId } from \"@orderly.network/ui-chain-selector\";\nimport { useTranslation } from \"@orderly.network/i18n\";\n\nexport const Chain: FC<ChainState> = (props) => {\n const { t } = useTranslation();\n\n return (\n <button\n onClick={(e) => {\n modal\n .show<{\n wrongNetwork: boolean;\n }>(ChainSelectorSheetId, {\n // networkId: props.networkId,\n bridgeLessOnly: false,\n isWrongNetwork: props.wrongNetwork,\n })\n .then(\n (r: any) => {\n if (r?.chainId) {\n props.setCurrentChainId(r?.chainId);\n }\n toast.success(t(\"connector.networkSwitched\"));\n },\n (error) => console.log(\"[switchChain error]\", error)\n );\n }}\n >\n <Box className=\"oui-relative oui-rounded-t-[6px] oui-rounded-bl-[6px] oui-rounded-br-[3px] oui-bg-base-5 oui-px-2 oui-h-7 oui-flex oui-items-center\">\n <ChainIcon chainId={props.currentChainId!} size=\"2xs\" />\n <div className=\"oui-absolute oui-right-0 oui-bottom-0\">\n <svg\n width=\"9\"\n height=\"9\"\n viewBox=\"0 0 9 9\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path d=\"M9 6V0L0 9h6a3 3 0 0 0 3-3\" fill=\"url(#a)\" />\n <defs>\n <linearGradient\n id=\"a\"\n x1=\"9\"\n y1=\"4.5\"\n x2=\"0\"\n y2=\"4.5\"\n gradientUnits=\"userSpaceOnUse\"\n >\n <stop stopColor=\"rgb(var(--oui-gradient-brand-end))\" />\n <stop\n offset=\"1\"\n stopColor=\"rgb(var(--oui-gradient-brand-start))\"\n />\n </linearGradient>\n </defs>\n </svg>\n </div>\n </Box>\n </button>\n );\n};\n","import { useConfig } from \"@orderly.network/hooks\";\nimport { useAppContext } from \"@orderly.network/react-app\";\n\nexport const useChainScript = () => {\n const config = useConfig();\n const { wrongNetwork, currentChainId, setCurrentChainId } = useAppContext();\n\n const networkId = config.get(\"networkId\");\n\n return {\n currentChainId,\n setCurrentChainId,\n networkId,\n wrongNetwork,\n };\n};\n\nexport type ChainState = ReturnType<typeof useChainScript>;\n","import React from \"react\";\nimport { useChainScript } from \"./chain.script\";\nimport { Chain } from \"./chain.ui\";\n\nexport const ChainWidget: React.FC = () => {\n const state = useChainScript();\n return <Chain {...state} />;\n};\n","import { useAccount } from \"@orderly.network/hooks\";\nimport { useAppContext } from \"@orderly.network/react-app\";\n\nexport const useBottomNavBarScript = () => {\n const { wrongNetwork, disabledConnect } = useAppContext();\n const { account, state } = useAccount();\n\n /** link device, acally wallet not connect */\n const onDisconnect = async () => {\n localStorage.removeItem(\"orderly_link_device\");\n await account.disconnect();\n };\n\n return {\n wrongNetwork,\n disabledConnect,\n status: state.status,\n onDisconnect,\n };\n};\n\nexport type BottomNavBarState = ReturnType<typeof useBottomNavBarScript>;\n","import React from \"react\";\nimport { useBottomNavBarScript } from \"./bottomNavBar.script\";\nimport { BottomNavBar } from \"./bottomNavBar.ui\";\n\nexport const BottomNavBarWidget: React.FC = () => {\n const state = useBottomNavBarScript();\n return <BottomNavBar {...state} />;\n};\n","import { FC, useCallback, useId } from \"react\";\nimport React from \"react\";\nimport { Trans, useTranslation } from \"@orderly.network/i18n\";\nimport {\n ArrowDownShortIcon,\n ArrowLeftRightIcon,\n ArrowUpShortIcon,\n Button,\n cn,\n Divider,\n EyeCloseIcon,\n EyeIcon,\n Flex,\n Grid,\n Input,\n inputFormatter,\n InputFormatter,\n modal,\n PlusIcon,\n ReduceIcon,\n RefreshIcon,\n Statistic,\n Text,\n} from \"@orderly.network/ui\";\nimport { LeverageProps, LeverageSlider } from \"@orderly.network/ui-leverage\";\nimport { USDCIcon } from \"../accountSheet/icons\";\nimport {\n getMarginRatioColor,\n PortfolioSheetState,\n} from \"./portfolioSheet.script\";\nimport { RiskIndicator } from \"./riskIndicator\";\n\nexport const PortfolioSheet: FC<PortfolioSheetState> = (props) => {\n return (\n <Flex direction={\"column\"} gap={4} width={\"100%\"}>\n <Asset {...props} />\n <Divider className=\"oui-w-full\" />\n <MarginRatio {...props} />\n {/* <Leverage {...props} /> */}\n {/* <Divider className=\"oui-w-full\" /> */}\n {/* <AvailableBalance {...props} /> */}\n <Buttons {...props} />\n </Flex>\n );\n};\n\nconst Asset: FC<PortfolioSheetState> = (props) => {\n const { t } = useTranslation();\n\n const onUnsettleClick = useCallback(() => {\n return modal.confirm({\n title: t(\"settle.settlePnl\"),\n // maxWidth: \"xs\",\n content: (\n <Text intensity={54} size=\"xs\">\n {/* @ts-ignore */}\n <Trans i18nKey=\"settle.settlePnl.description\" />\n </Text>\n ),\n onCancel: () => {\n return Promise.reject();\n },\n onOk: () => {\n if (typeof props.onSettlePnL !== \"function\") {\n return Promise.resolve();\n }\n return props.onSettlePnL().catch((e) => {});\n },\n });\n }, [t]);\n\n const clsName =\n props.totalUnrealizedROI > 0\n ? \"oui-text-success-darken\"\n : \"oui-text-danger-darken\";\n\n return (\n <Flex direction={\"column\"} gap={3} width={\"100%\"}>\n <Flex direction={\"column\"} itemAlign={\"start\"} width={\"100%\"}>\n <Text.formatted\n size=\"2xs\"\n intensity={36}\n suffix={\n props.hideAssets ? (\n <EyeIcon\n opacity={1}\n size={16}\n className=\"oui-text-primary-light\"\n />\n ) : (\n <EyeCloseIcon\n opacity={1}\n size={16}\n className=\"oui-text-primary-light\"\n />\n )\n }\n onClick={() => {\n props.toggleHideAssets();\n }}\n className=\"oui-cursor-pointer\"\n >\n {`${t(\"common.totalValue\")} (USDC)`}\n </Text.formatted>\n <Text.numeral\n size=\"base\"\n // coloring\n dp={2}\n padding={false}\n visible={!props.hideAssets}\n >\n {props.totalValue ?? \"--\"}\n </Text.numeral>\n </Flex>\n <Grid cols={2} rows={1} width={\"100%\"}>\n <Statistic\n label={`${t(\"common.unrealizedPnl\")} (USDC)`}\n classNames={{\n label: \"oui-text-2xs oui-text-base-contrast-36\",\n }}\n >\n <Flex gap={1}>\n <Text.numeral\n size=\"xs\"\n coloring\n dp={2}\n padding={false}\n visible={!props.hideAssets}\n >\n {props.aggregated.unrealPnL}\n </Text.numeral>\n {!props.hideAssets && (\n <Text.numeral\n size=\"xs\"\n dp={2}\n padding={false}\n rule=\"percentages\"\n prefix={\"(\"}\n suffix={\")\"}\n className={clsName}\n >\n {props.totalUnrealizedROI}\n </Text.numeral>\n )}\n </Flex>\n </Statistic>\n <Statistic\n label={`${t(\"trading.asset.unsettledPnl\")} (USDC)`}\n classNames={{\n label: \"oui-text-2xs oui-text-base-contrast-36\",\n }}\n >\n <Flex justify={\"between\"} width={\"100%\"}>\n <Text.numeral\n size=\"xs\"\n coloring\n dp={2}\n padding={false}\n visible={!props.hideAssets}\n >\n {props.aggregated.unsettledPnL}\n </Text.numeral>\n <button\n className=\"oui-flex oui-gap-1 oui-items-center\"\n onClick={onUnsettleClick}\n >\n <RefreshIcon\n opacity={1}\n size={12}\n className=\"oui-text-primary-light\"\n />\n <Text size=\"2xs\" color=\"primary\">\n {t(\"settle.settlePnl\")}\n </Text>\n </button>\n </Flex>\n </Statistic>\n </Grid>\n </Flex>\n );\n};\nconst MarginRatio: FC<PortfolioSheetState> = (props) => {\n const { t } = useTranslation();\n\n const { high, mid, low } = getMarginRatioColor(\n props.marginRatioVal,\n props.mmr,\n );\n\n return (\n <Grid cols={2} rows={1} width={\"100%\"}>\n <Statistic\n label={t(\"trading.asset.marginRatio\")}\n classNames={{\n label: \"oui-text-2xs oui-text-base-contrast-36\",\n }}\n >\n <Flex gap={2}>\n <Text.numeral\n size=\"xs\"\n rule=\"percentages\"\n color=\"primary\"\n dp={2}\n padding={false}\n visible={!props.hideAssets}\n >\n {props.marginRatioVal}\n </Text.numeral>\n {!props.hideAssets && (\n <RiskIndicator\n className={\n low\n ? \"oui-rotate-0\"\n : mid\n ? \"oui-rotate-90\"\n : high\n ? \"oui-rotate-180\"\n : \"\"\n }\n />\n )}\n </Flex>\n </Statistic>\n <Statistic\n label={`${t(\"trading.asset.free&TotalCollateral\")} (USDC)`}\n classNames={{\n label: \"oui-text-2xs oui-text-base-contrast-36\",\n }}\n >\n <Flex justify={\"start\"} width={\"100%\"} gap={1}>\n <Text.numeral\n size=\"xs\"\n dp={2}\n padding={false}\n visible={!props.hideAssets}\n >\n {props.freeCollateral}\n </Text.numeral>\n <Text size=\"xs\">/</Text>\n <Text.numeral\n size=\"xs\"\n dp={2}\n padding={false}\n visible={!props.hideAssets}\n >\n {props.totalCollateral}\n </Text.numeral>\n </Flex>\n </Statistic>\n </Grid>\n );\n};\n\nconst IconButton: React.FC<{\n Icon: React.ComponentType<any>;\n onClick: React.MouseEventHandler<SVGSVGElement>;\n disabled: boolean;\n}> = (props) => {\n const { Icon, onClick, disabled } = props;\n return (\n <Icon\n onClick={disabled ? undefined : onClick}\n className={cn(\n \"oui-text-white oui-m-2 oui-transition-all\",\n disabled\n ? \"oui-cursor-not-allowed oui-opacity-20\"\n : \"oui-cursor-pointer oui-opacity-100\",\n )}\n />\n );\n};\n\nconst LeverageInput: React.FC<PortfolioSheetState> = (props) => {\n const formatters = React.useMemo<InputFormatter[]>(\n () => [\n inputFormatter.numberFormatter,\n inputFormatter.currencyFormatter,\n inputFormatter.decimalPointFormatter,\n ],\n [],\n );\n const id = useId();\n return (\n <label\n htmlFor={id}\n className={cn(\n \"oui-w-full\",\n \"oui-rounded\",\n \"oui-bg-base-6\",\n \"oui-flex\",\n \"oui-items-center\",\n \"oui-justify-between\",\n \"oui-outline\",\n \"oui-outline-offset-0\",\n \"oui-outline-1\",\n \"oui-outline-transparent\",\n \"focus-within:oui-outline-primary-light\",\n \"oui-input-root\",\n )}\n >\n <IconButton\n Icon={ReduceIcon}\n onClick={props.onLeverageReduce}\n disabled={props.isReduceDisabled}\n />\n <Flex itemAlign=\"center\" justify=\"center\">\n <Input\n // {...props}\n value={props.value}\n id={id}\n autoComplete=\"off\"\n classNames={{\n input: cn(\"oui-text-center\"),\n root: cn(\n \"oui-text-center\",\n \"oui-w-6\",\n \"oui-px-0\",\n \"oui-outline\",\n \"oui-outline-offset-0\",\n \"oui-outline-1\",\n \"oui-outline-transparent\",\n \"focus-within:oui-outline-primary-none\",\n ),\n }}\n formatters={formatters}\n onChange={props.onInputChange}\n />\n <div className=\"oui-select-none\">x</div>\n </Flex>\n <IconButton\n Icon={PlusIcon}\n onClick={props.onLeverageIncrease}\n disabled={props.isIncreaseDisabled}\n />\n </label>\n );\n};\n\nexport const LeverageSelector: React.FC<PortfolioSheetState> = (props) => {\n const { value, onLeverageChange, onValueCommit } = props;\n return (\n <Flex itemAlign=\"center\" justify=\"between\" width={\"100%\"} mt={2}>\n {[1, 5, 10, 20, 50].map((option) => (\n <Flex\n key={option}\n itemAlign=\"center\"\n justify=\"center\"\n className={cn(\n `oui-transition-all oui-cursor-pointer oui-box-border oui-bg-clip-padding oui-px-3 oui-py-2.5 oui-rounded-md oui-border oui-border-solid`,\n value === option\n ? \"oui-border-primary oui-bg-base-6\"\n : \"oui-border-line-12\",\n )}\n onClick={() => {\n onLeverageChange(option);\n onValueCommit(option);\n }}\n >\n <Flex\n itemAlign=\"center\"\n justify=\"center\"\n className={cn(`oui-h-3 oui-w-9 oui-select-none`)}\n >\n {option}x\n </Flex>\n </Flex>\n ))}\n </Flex>\n );\n};\n\nconst Buttons: FC<PortfolioSheetState> = (props) => {\n const { t } = useTranslation();\n\n if (props.isMainAccount) {\n return (\n <Grid\n cols={props.hasSubAccount ? 3 : 2}\n rows={1}\n gap={3}\n className=\"oui-grid-row-[1fr,1fr]\"\n width={\"100%\"}\n pt={2}\n pb={4}\n >\n <Button\n icon={<ArrowDownShortIcon color=\"white\" opacity={0.8} />}\n size=\"md\"\n fullWidth\n onClick={props.onDeposit}\n >\n {t(\"common.deposit\")}\n </Button>\n {props.hasSubAccount && (\n <Button\n icon={<ArrowLeftRightIcon color=\"white\" opacity={0.8} />}\n color=\"gray\"\n size=\"md\"\n onClick={props.onTransfer}\n data-testid=\"oui-testid-assetView-transfer-button\"\n >\n <Text>{t(\"common.transfer\")}</Text>\n </Button>\n )}\n <Button\n icon={<ArrowUpShortIcon color=\"white\" opacity={0.8} />}\n size=\"md\"\n fullWidth\n className=\"oui-bg-base-2 hover:oui-bg-base-2/50\"\n onClick={props.onWithdraw}\n >\n {t(\"common.withdraw\")}\n </Button>\n </Grid>\n );\n }\n\n return (\n <Button\n fullWidth\n color=\"secondary\"\n size=\"md\"\n onClick={props.onTransfer}\n data-testid=\"oui-testid-assetView-transfer-button\"\n >\n <Text>{t(\"common.transfer\")}</Text>\n </Button>\n );\n};\n","import { useCallback, useMemo, useState } from \"react\";\nimport {\n useAccount,\n useCollateral,\n useDebouncedCallback,\n useEventEmitter,\n useLeverage,\n useMarginRatio,\n usePositionStream,\n} from \"@orderly.network/hooks\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { modal, SliderMarks, toast } from \"@orderly.network/ui\";\nimport {\n DepositAndWithdrawWithSheetId,\n TransferSheetId,\n} from \"@orderly.network/ui-transfer\";\nimport { useTradingLocalStorage } from \"../../../hooks\";\n\nexport const usePortfolioSheetScript = () => {\n const { state, account, isMainAccount } = useAccount();\n const assets = useAssets();\n const marginRatio = useMarginRatioAndLeverage();\n const ee = useEventEmitter();\n const { t } = useTranslation();\n const subAccounts = state.subAccounts ?? [];\n\n const [showSliderTip, setShowSliderTip] = useState(false);\n\n const onSettlePnL = useCallback(async () => {\n return account\n .settle()\n .catch((e) => {\n if (e.code == -1104) {\n toast.error(t(\"settle.settlement.error\"));\n return Promise.reject(e);\n }\n if (\n e.message.indexOf(\n \"Signing off chain messages with Ledger is not yet supported\",\n ) !== -1\n ) {\n ee.emit(\"wallet:sign-message-with-ledger-error\", {\n message: e.message,\n userAddress: account.address,\n });\n return Promise.reject(e);\n }\n\n if (e?.code === \"ACTION_REJECTED\") {\n toast.error(t(\"connector.userRejected\"));\n return Promise.reject(e);\n }\n })\n .then((res) => {\n toast.success(t(\"settle.settlement.requested\"));\n return Promise.resolve(res);\n });\n }, [account, t]);\n\n const onDeposit = useCallback(() => {\n modal.show(DepositAndWithdrawWithSheetId, {\n activeTab: \"deposit\",\n });\n }, []);\n\n const onWithdraw = useCallback(() => {\n modal.show(DepositAndWithdrawWithSheetId, {\n activeTab: \"withdraw\",\n });\n }, []);\n\n const onTransfer = useCallback(() => {\n modal.show(TransferSheetId);\n }, []);\n\n return {\n ...assets,\n ...marginRatio,\n onSettlePnL,\n onDeposit,\n onWithdraw,\n showSliderTip,\n setShowSliderTip,\n isMainAccount,\n onTransfer,\n hasSubAccount: subAccounts?.length > 0,\n };\n};\n\nconst useAssets = () => {\n const { hideAssets, setHideAssets } = useTradingLocalStorage();\n const toggleHideAssets = () => {\n setHideAssets(!hideAssets);\n };\n const { totalCollateral, freeCollateral, totalValue, availableBalance } =\n useCollateral({\n dp: 2,\n });\n return {\n hideAssets,\n toggleHideAssets,\n totalCollateral,\n freeCollateral,\n totalValue,\n availableBalance,\n };\n};\n\nconst useMarginRatioAndLeverage = () => {\n const { t } = useTranslation();\n const [{ aggregated, totalUnrealizedROI }, positionsInfo] =\n usePositionStream();\n const { marginRatio, currentLeverage, mmr } = useMarginRatio();\n\n const marginRatioVal = useMemo(() => {\n return Math.min(\n 10,\n aggregated.notional === 0\n ? positionsInfo[\"margin_ratio\"](10)!\n : marginRatio,\n );\n }, [marginRatio, aggregated]);\n\n const { update, curLeverage, maxLeverage, leverageLevers } = useLeverage();\n\n const marks = useMemo<SliderMarks>(() => {\n return leverageLevers?.map((e) => ({\n label: `${e}x`,\n value: e,\n }));\n }, [leverageLevers]);\n\n const [leverage, setLeverage] = useState<number>(curLeverage ?? 0);\n\n const step = 100 / ((marks?.length || 0) - 1);\n\n // const leverageValue = useMemo(() => {\n // const index = leverageLevers.findIndex((item: any) => item === leverage);\n\n // return index * step;\n // }, [leverageLevers, leverage, step]);\n\n const onLeverageChange = (leverage: number) => {\n // maxLeverage / 100 * leverage;\n setLeverage(leverage);\n // updateLeverage(leverage);\n };\n\n const onSave = async (leverage: number) => {\n try {\n update({ leverage }).then(\n () => {\n toast.success(t(\"leverage.updated\"));\n },\n (err: Error) => {\n toast.error(err.message);\n },\n );\n } catch {\n //\n }\n };\n\n const onValueCommit = useCallback((value: number | number[]) => {\n onSave(Array.isArray(value) ? value[0] : value);\n }, []);\n\n const debouncedCommit = useDebouncedCallback(onValueCommit, 500);\n\n const onInputChange = useCallback<React.ChangeEventHandler<HTMLInputElement>>(\n (e) => {\n const parsed = Number.parseInt(e.target.value, 10);\n const raw = Number.isNaN(parsed) ? 0 : parsed;\n const clamped = Math.min(Math.max(raw, 1), maxLeverage);\n setLeverage(clamped);\n debouncedCommit(clamped);\n },\n [debouncedCommit, maxLeverage],\n );\n\n const onLeverageIncrease: React.MouseEventHandler<SVGSVGElement> = () => {\n setLeverage((prev) => {\n onSave(prev + 1);\n return prev + 1;\n });\n };\n\n const onLeverageReduce: React.MouseEventHandler<SVGSVGElement> = () => {\n setLeverage((prev) => {\n onSave(prev - 1);\n return prev - 1;\n });\n };\n\n return {\n aggregated,\n totalUnrealizedROI,\n positionsInfo,\n marginRatio,\n marginRatioVal,\n mmr,\n currentLeverage,\n step,\n marks,\n onLeverageChange,\n onLeverageIncrease,\n onLeverageReduce,\n onInputChange,\n isReduceDisabled: leverage <= 1,\n isIncreaseDisabled: leverage >= maxLeverage,\n onValueCommit,\n value: leverage,\n maxLeverage,\n onSaveLeverage: onSave,\n };\n};\n\nexport function getMarginRatioColor(marginRatio: number, mmr: number | null) {\n if (mmr === null) {\n return { isRed: false, isYellow: false, isGreen: true };\n }\n const imr = mmr * 2;\n\n const high = marginRatio <= imr;\n const mid = marginRatio > imr && marginRatio < 1;\n const low = marginRatio >= 1;\n return { high, mid, low };\n}\n\nexport type PortfolioSheetState = ReturnType<typeof usePortfolioSheetScript>;\n","import { FC } from \"react\";\nimport { cn } from \"@orderly.network/ui\";\n\ninterface RiskIndicatorProps {\n size?: number;\n className?: string;\n}\n\nexport const RiskIndicator: FC<RiskIndicatorProps> = (props) => {\n const { size = 20, className } = props;\n\n return (\n <div\n className=\"oui-flex oui-justify-center oui-items-end\"\n style={{\n background: \"url(/images/riskLevelBg.png)\",\n backgroundSize: \"contain\",\n backgroundRepeat: \"no-repeat\",\n backgroundPosition: \"center bottom\",\n width: `${size}px`,\n height: `14px`,\n }}\n >\n <div\n className={cn(\n \"oui-relative oui-w-[2px] oui-h-[2px] oui-rounded-full oui-bg-white after:oui-block after:oui-content-[''] after:oui-absolute after:oui-right-0 after:oui-w-[10px] after:oui-h-[2px] after:oui-bg-white/50\",\n className\n // {\n // \"oui-rotate-0\": value > 1,\n // \"oui-rotate-90\": value >= 0.05 && value <= 1,\n // \"oui-rotate-180\": value < 0.05,\n // }\n )}\n ></div>\n </div>\n );\n};\n","import { usePortfolioSheetScript } from \"./portfolioSheet.script\";\nimport { PortfolioSheet } from \"./portfolioSheet.ui\";\n\nexport const PortfolioSheetWidget = () => {\n const state = usePortfolioSheetScript();\n return <PortfolioSheet {...state} />;\n};\n","export {\n useFundingRateModalScript,\n type FundingRateModalState,\n} from \"./fundingRateModal.script\";\nexport { FundingRateModal } from \"./fundingRateModal.ui\";\nexport {\n FundingRateModalWidget,\n FundingRateDialogId,\n FundingRateSheetId,\n} from \"./fundingRateModal.widget\";\n","import { FC } from \"react\";\nimport { useScreen } from \"@orderly.network/ui\";\nimport type { TradingState } from \"./trading.script\";\nimport { DesktopLayout } from \"./trading.ui.desktop\";\nimport { MobileLayout } from \"./trading.ui.mobile\";\n\nexport const Trading: FC<TradingState> = (props) => {\n const { isMobile } = useScreen();\n\n if (isMobile) {\n return <MobileLayout {...props} />;\n }\n\n return (\n <DesktopLayout\n className=\"oui-h-[calc(100vh_-_48px_-_29px)] oui-bg-base-10\"\n {...props}\n />\n );\n};\n","import React, { useMemo } from \"react\";\nimport { useLocalStorage } from \"@orderly.network/hooks\";\nimport {\n SideMarketsWidget,\n SymbolInfoBarFullWidget,\n HorizontalMarketsWidget,\n} from \"@orderly.network/markets\";\nimport { TradingviewFullscreenKey } from \"@orderly.network/types\";\nimport { Box, cn, Flex } from \"@orderly.network/ui\";\nimport { OrderEntryWidget } from \"@orderly.network/ui-order-entry\";\nimport { TradingviewWidget } from \"@orderly.network/ui-tradingview\";\nimport { DepositStatusWidget } from \"@orderly.network/ui-transfer\";\nimport { RemovablePanel } from \"../../components/desktop/layout/removablePanel\";\nimport { SplitLayout } from \"../../components/desktop/layout/splitLayout\";\nimport {\n dataListInitialHeight,\n getOffsetSizeNum,\n TradingState,\n} from \"./trading.script\";\nimport {\n scrollBarWidth,\n topBarHeight,\n bottomBarHeight,\n space,\n symbolInfoBarHeight,\n orderEntryMinWidth,\n orderEntryMaxWidth,\n orderbookMinWidth,\n orderbookMaxWidth,\n orderbookMinHeight,\n orderbookMaxHeight,\n tradindviewMinHeight,\n tradingViewMinWidth,\n dataListMaxHeight,\n} from \"./trading.script\";\n\nconst LazyRiskRateWidget = React.lazy(() =>\n import(\"../../components/desktop/riskRate\").then((mod) => {\n return {\n default: mod.RiskRateWidget,\n };\n }),\n);\n\nconst LazyAssetViewWidget = React.lazy(() =>\n import(\"../../components/desktop/assetView\").then((mod) => {\n return {\n default: mod.AssetViewWidget,\n };\n }),\n);\n\nconst LazyDataListWidget = React.lazy(() =>\n import(\"../../components/desktop/dataList\").then((mod) => {\n return {\n default: mod.DataListWidget,\n };\n }),\n);\n\nconst LazySwitchLayout = React.lazy(() =>\n import(\"../../components/desktop/layout/switchLayout\").then((mod) => {\n return {\n default: mod.SwitchLayout,\n };\n }),\n);\n\nconst LazyOrderBookAndTradesWidget = React.lazy(() =>\n import(\"../../components/desktop/orderBookAndTrades\").then((mod) => {\n return {\n default: mod.OrderBookAndTradesWidget,\n };\n }),\n);\n\nexport type DesktopLayoutProps = TradingState & {\n className?: string;\n};\n\nexport const DesktopLayout: React.FC<DesktopLayoutProps> = (props) => {\n const {\n resizeable,\n panelSize,\n onPanelSizeChange,\n layout,\n onLayout,\n marketLayout,\n onMarketLayout,\n orderBookSplitSize,\n setOrderbookSplitSize,\n dataListSplitSize,\n setDataListSplitSize,\n mainSplitSize,\n setMainSplitSize,\n dataListSplitHeightSM,\n setDataListSplitHeightSM,\n orderBookSplitHeightSM,\n setOrderbookSplitHeightSM,\n max2XL,\n max4XL,\n animating,\n setAnimating,\n positions,\n updatePositions,\n showPositionIcon,\n horizontalDraggable,\n marketsWidth,\n tradindviewMaxHeight,\n dataListMinHeight,\n } = props;\n\n const [tradingViewFullScreen] = useLocalStorage(\n TradingviewFullscreenKey,\n false,\n );\n\n const minScreenHeight = useMemo(() => {\n return tradingViewFullScreen\n ? 0\n : symbolInfoBarHeight +\n orderbookMaxHeight +\n dataListInitialHeight +\n space * 4;\n }, [tradingViewFullScreen]);\n\n const minScreenHeightSM =\n topBarHeight +\n bottomBarHeight +\n symbolInfoBarHeight +\n tradindviewMinHeight +\n orderbookMinHeight +\n dataListMinHeight +\n space * 4;\n\n const horizontalMarketsView = (\n <HorizontalMarketsWidget\n symbol={props.symbol}\n onSymbolChange={props.onSymbolChange}\n maxItems={-1} // show all markets\n dropdownPos={marketLayout === \"bottom\" ? \"top\" : \"bottom\"}\n />\n );\n\n const marketsWidget = (\n <SideMarketsWidget\n resizeable={resizeable}\n panelSize={panelSize}\n onPanelSizeChange={onPanelSizeChange as any}\n symbol={props.symbol}\n onSymbolChange={props.onSymbolChange}\n />\n );\n\n const marketsView = (\n <Box\n intensity={900}\n pt={3}\n r=\"2xl\"\n height=\"100%\"\n width={marketsWidth}\n style={{ minWidth: marketsWidth }}\n className=\"oui-transition-all oui-duration-150\"\n onTransitionEnd={() => setAnimating(false)}\n >\n {!animating && marketLayout === \"left\" && marketsWidget}\n </Box>\n );\n\n const symbolInfoBarView = (\n <Box\n intensity={900}\n r=\"2xl\"\n px={3}\n width=\"100%\"\n style={{\n minHeight: symbolInfoBarHeight,\n height: symbolInfoBarHeight,\n }}\n >\n <SymbolInfoBarFullWidget\n symbol={props.symbol}\n onSymbolChange={props.onSymbolChange}\n trailing={\n <React.Suspense fallback={null}>\n <LazySwitchLayout\n layout={layout}\n onLayout={onLayout}\n marketLayout={marketLayout}\n onMarketLayout={onMarketLayout}\n />\n </React.Suspense>\n }\n />\n </Box>\n );\n\n const { library_path, ...restTradingViewConfig } = props.tradingViewConfig;\n\n const tradingviewWidget = (\n <TradingviewWidget\n classNames={{\n root: cn(\n tradingViewFullScreen\n ? \"!oui-absolute oui-top-0 oui-left-0 oui-right-0 oui-bottom-0 oui-z-[40] oui-bg-base-10\"\n : \"oui-z-1\",\n ),\n content: cn(\n tradingViewFullScreen\n ? \"oui-top-3 oui-bottom-3 oui-left-3 oui-right-3 oui-bg-base-9 oui-rounded-[16px] oui-overflow-hidden\"\n : \"\",\n ),\n }}\n symbol={props.symbol}\n {...restTradingViewConfig}\n libraryPath={library_path}\n />\n );\n\n const tradingView = (\n <Box\n width=\"100%\"\n height=\"100%\"\n intensity={900}\n r=\"2xl\"\n style={{ flex: 1, minWidth: tradingViewMinWidth }}\n className=\"oui-overflow-hidden\"\n >\n {tradingviewWidget}\n </Box>\n );\n\n const orderbookWidget = (\n <React.Suspense fallback={null}>\n <LazyOrderBookAndTradesWidget symbol={props.symbol} />\n </React.Suspense>\n );\n\n const orderbookView = (\n <Box\n r=\"2xl\"\n height=\"100%\"\n style={{\n minWidth: orderbookMinWidth,\n maxWidth: horizontalDraggable ? orderbookMaxWidth : orderbookMinWidth,\n width: orderBookSplitSize,\n }}\n className=\"oui-overflow-hidden\"\n >\n {orderbookWidget}\n </Box>\n );\n\n const dataListWidget = (\n <React.Suspense fallback={null}>\n <LazyDataListWidget\n current={undefined}\n symbol={props.symbol}\n sharePnLConfig={props.sharePnLConfig}\n />\n </React.Suspense>\n );\n\n const dataListView = (\n <Box\n intensity={900}\n r=\"2xl\"\n p={2}\n style={{\n height: dataListSplitSize,\n // height: `calc(100% - ${symbolInfoBarHeight}px - ${orderbookMaxHeight}px - ${space}px)`,\n minHeight: dataListInitialHeight,\n // minHeight: `max(${dataListMinHeight}px, calc(100vh - ${symbolInfoBarHeight}px - ${orderbookMaxHeight}px - ${space}px))`,\n }}\n className=\"oui-overflow-hidden\"\n >\n {dataListWidget}\n </Box>\n );\n\n const assetsOrderEntryMargin = [\n <RemovablePanel\n key=\"margin\"\n index={positions.findIndex((item) => item === 0)}\n onLayout={updatePositions}\n showIndicator={showPositionIcon}\n >\n <React.Suspense fallback={null}>\n <LazyRiskRateWidget />\n </React.Suspense>\n </RemovablePanel>,\n <RemovablePanel\n key=\"assets\"\n className=\"oui-border oui-border-line-12\"\n index={positions.findIndex((item) => item === 1)}\n onLayout={updatePositions}\n showIndicator={showPositionIcon}\n >\n <>\n <React.Suspense fallback={null}>\n <LazyAssetViewWidget isFirstTimeDeposit={props.isFirstTimeDeposit} />\n </React.Suspense>\n <DepositStatusWidget\n className=\"oui-mt-3 oui-gap-y-2\"\n onClick={props.navigateToPortfolio}\n />\n </>\n </RemovablePanel>,\n <RemovablePanel\n key=\"orderEntry\"\n index={positions.findIndex((item) => item === 2)}\n onLayout={updatePositions}\n showIndicator={showPositionIcon}\n >\n <OrderEntryWidget\n symbol={props.symbol}\n disableFeatures={\n props.disableFeatures as unknown as (\"slippageSetting\" | \"feesInfo\")[]\n }\n />\n </RemovablePanel>,\n ];\n\n const orderEntryWidget = positions.map(\n (index) => assetsOrderEntryMargin[index],\n );\n\n const orderEntryView = (\n <Flex\n gapY={2}\n direction=\"column\"\n height=\"100%\"\n style={{\n minWidth: orderEntryMinWidth,\n maxWidth: horizontalDraggable ? orderEntryMaxWidth : orderEntryMinWidth,\n width: mainSplitSize,\n }}\n >\n {orderEntryWidget}\n </Flex>\n );\n\n const renderTradingView = () => {\n if (max4XL && layout === \"right\") {\n return (\n <Flex\n gap={2}\n className=\"oui-flex-1 oui-overflow-hidden\"\n style={{ minWidth: marketsWidth + tradingViewMinWidth + space }}\n >\n {marketLayout === \"left\" && marketsView}\n {tradingView}\n </Flex>\n );\n }\n\n return tradingView;\n };\n\n const tradingViewAndOrderbookView = (\n <SplitLayout\n style={{\n // the style width is not set, and a child node style needs to be set to flex: 1 to adapt\n flex: 1,\n minHeight: orderbookMinHeight,\n // maxHeight: orderbookMaxHeight,\n }}\n onSizeChange={setOrderbookSplitSize}\n disable={!horizontalDraggable}\n >\n {renderTradingView()}\n {orderbookView}\n </SplitLayout>\n );\n\n const renderTradingViewAndOrderbookView = () => {\n if (max4XL && layout === \"left\") {\n return (\n <Flex gapX={2} style={{ minHeight: orderbookMinHeight }} height=\"100%\">\n {tradingViewAndOrderbookView}\n {marketLayout === \"left\" && marketsView}\n </Flex>\n );\n }\n return tradingViewAndOrderbookView;\n };\n\n const mainView = (\n <Flex\n direction=\"column\"\n className=\"oui-flex-1 oui-overflow-hidden\"\n gap={2}\n style={{\n minWidth: max4XL\n ? marketsWidth + tradingViewMinWidth + orderbookMinWidth + space * 2\n : tradingViewMinWidth + orderbookMinWidth + space,\n }}\n >\n {symbolInfoBarView}\n <SplitLayout\n style={{\n // height: orderbookMaxHeight + dataListInitialHeight + space,\n maxHeight: `calc(100% - ${symbolInfoBarHeight}px - ${space}px)`,\n }}\n className=\"oui-w-full\"\n mode=\"vertical\"\n onSizeChange={setDataListSplitSize}\n >\n {renderTradingViewAndOrderbookView()}\n {dataListView}\n </SplitLayout>\n </Flex>\n );\n\n const onSizeChange = (width: string) =>\n layout === \"left\"\n ? setMainSplitSize(getOffsetSizeNum(width))\n : setMainSplitSize(width);\n\n if (max2XL) {\n return (\n <Box height=\"100%\">\n {marketLayout === \"top\" && (\n <Box className={cn(\"oui-max-h-8 oui-px-3 oui-mt-2\", props.className)}>\n {horizontalMarketsView}\n </Box>\n )}\n\n <SplitLayout\n ref={props.max2XLSplitRef}\n style={{\n minHeight: minScreenHeightSM,\n minWidth: 1024 - scrollBarWidth,\n // height: props.extraHeight ? props.extraHeight : undefined,\n }}\n className={cn(\n \"oui-flex oui-flex-1\",\n \"oui-size-full oui-min-w-[1018px]\",\n \"oui-px-3 oui-py-2\",\n props.className,\n )}\n onSizeChange={setDataListSplitHeightSM}\n onDragging={props.onDataListSplitHeightDragging}\n mode=\"vertical\"\n >\n <Flex\n gapX={2}\n itemAlign=\"stretch\"\n className={cn(\n \"oui-flex-1\",\n layout === \"left\" && \"oui-flex-row-reverse\",\n )}\n style={{\n minHeight: Math.max(\n symbolInfoBarHeight +\n tradindviewMinHeight +\n orderbookMinHeight +\n space * 2,\n props.orderEntryHeight,\n ),\n maxHeight:\n symbolInfoBarHeight +\n tradindviewMaxHeight +\n orderbookMaxHeight +\n space * 2,\n }}\n >\n <Flex\n height=\"100%\"\n className=\"oui-w-[calc(100%_-_280px_-_12px)] oui-flex-1\"\n direction=\"column\"\n gapY={2}\n >\n {symbolInfoBarView}\n <Flex\n width=\"100%\"\n height=\"100%\"\n gapX={2}\n itemAlign=\"stretch\"\n style={{\n minHeight: tradindviewMinHeight + orderbookMinHeight + space,\n maxHeight: tradindviewMaxHeight + orderbookMaxHeight + space,\n }}\n className={cn(\n \"oui-flex-1\",\n layout === \"left\" && \"oui-flex-row-reverse\",\n )}\n >\n {marketLayout === \"left\" && (\n <Box\n intensity={900}\n pt={3}\n r=\"2xl\"\n width={marketsWidth}\n style={{\n minHeight:\n tradindviewMinHeight + orderbookMinHeight + space,\n maxHeight:\n tradindviewMaxHeight + orderbookMaxHeight + space,\n }}\n >\n {marketsWidget}\n </Box>\n )}\n <SplitLayout\n ref={props.tradingviewAndOrderbookSplitRef}\n mode=\"vertical\"\n style={{ width: `calc(100% - ${marketsWidth}px)` }}\n className=\"oui-flex-1\"\n onSizeChange={setOrderbookSplitHeightSM}\n onDragging={props.onTradingviewAndOrderbookDragging}\n >\n <Box\n width=\"100%\"\n intensity={900}\n r=\"2xl\"\n style={{\n minHeight: tradindviewMinHeight,\n maxHeight: tradindviewMaxHeight,\n height: 1200,\n }}\n >\n {tradingviewWidget}\n </Box>\n\n <Box\n r=\"2xl\"\n height=\"100%\"\n width=\"100%\"\n style={{\n minHeight: orderbookMinHeight,\n maxHeight: orderbookMaxHeight,\n height: orderBookSplitHeightSM,\n }}\n className=\"oui-flex-1\"\n >\n {orderbookWidget}\n </Box>\n </SplitLayout>\n </Flex>\n </Flex>\n <Flex\n ref={props.orderEntryViewRef}\n id=\"orderEntryView\"\n gapY={3}\n direction=\"column\"\n className=\"oui-relative\"\n style={{\n width: orderEntryMinWidth,\n // force order entry render actual content height\n height: \"max-content\",\n // height:\n // props.extraHeight && props.extraHeight > 100\n // ? undefined\n // : \"max-content\",\n }}\n >\n {orderEntryWidget}\n <Box height={props.extraHeight} />\n </Flex>\n </Flex>\n\n <Box\n intensity={900}\n r=\"2xl\"\n p={2}\n style={{\n height: dataListSplitHeightSM,\n minHeight: Math.max(dataListMinHeight, props.dataListHeight),\n maxHeight: dataListMaxHeight,\n }}\n className=\"oui-overflow-hidden\"\n >\n {dataListWidget}\n </Box>\n\n {marketLayout === \"bottom\" && (\n <Box className=\"oui-pb-2\">{horizontalMarketsView}</Box>\n )}\n </SplitLayout>\n </Box>\n );\n }\n\n return (\n <Flex\n style={{\n minHeight: minScreenHeight,\n minWidth: 1440 - scrollBarWidth,\n }}\n className={cn(\n props.className,\n \"oui-justify-start\",\n tradingViewFullScreen &&\n \"oui-relative oui-w-screen oui-h-[calc(100vh-80px)] !oui-p-0 oui-overflow-hidden\",\n )}\n width=\"100%\"\n p={2}\n gap={2}\n itemAlign=\"stretch\"\n direction=\"column\"\n >\n {/* Horizontal Markets View on top for !=2xl screens */}\n {marketLayout === \"top\" && horizontalMarketsView}\n\n {/* Main Content Group */}\n <Flex\n className={cn(\n \"oui-flex-1 oui-overflow-hidden\",\n layout === \"left\" && \"oui-flex-row-reverse\",\n )}\n gap={2}\n >\n {!max4XL && marketLayout === \"left\" && marketsView}\n <SplitLayout\n className={cn(\"oui-flex oui-flex-1 oui-overflow-hidden\")}\n onSizeChange={onSizeChange}\n disable={!horizontalDraggable}\n >\n {layout === \"left\" && orderEntryView}\n {mainView}\n {layout === \"right\" && orderEntryView}\n </SplitLayout>\n </Flex>\n\n {/* Horizontal Markets View on bottom for !=2xl screens */}\n {marketLayout === \"bottom\" && horizontalMarketsView}\n </Flex>\n );\n};\n","import React, { FC, PropsWithChildren, SVGProps, useState } from \"react\";\nimport { Box, cn, Flex, Tooltip } from \"@orderly.network/ui\";\n\nexport type RemovablePanelProps = {\n className?: string;\n index: number;\n onLayout: (currentIdx: number, targetIdx: number) => void;\n showIndicator?: boolean;\n};\n\nexport const RemovablePanel: React.FC<\n PropsWithChildren<RemovablePanelProps>\n> = (props) => {\n const { showIndicator = true } = props;\n const [open, setOpen] = useState(false);\n return (\n <Box\n intensity={900}\n r=\"2xl\"\n p={3}\n width=\"100%\"\n className={cn(\"oui-relative\", props.className)}\n >\n {props.children}\n <Tooltip\n open={open}\n onOpenChange={(next) => {\n // controlled by click\n if (!next) setOpen(false);\n }}\n side=\"left\"\n align=\"start\"\n sideOffset={-4}\n alignOffset={-4}\n content={\n <Flex direction=\"column\" gapY={2}>\n {[TopIcon, MiddleIcon, BottomIcon].map((Icon, idx) => (\n <Icon\n key={idx}\n className={cn(\n \"oui-rounded oui-cursor-pointer hover:oui-bg-base-5\",\n props.index === idx && \"oui-bg-base-5\",\n )}\n onClick={() => {\n props.onLayout?.(props.index, idx);\n setOpen(false);\n }}\n />\n ))}\n </Flex>\n }\n delayDuration={0}\n className={cn(\n \"oui-bg-base-9 oui-rounded\",\n \"oui-border oui-border-line-12\",\n \"oui-p-1\",\n )}\n arrow={{ className: \"oui-fill-transparent\" }}\n >\n {showIndicator && (\n <div\n className=\"oui-absolute oui-right-[1px] oui-top-[18px]\"\n onClick={() => setOpen((v) => !v)}\n >\n <IndicatorIcon\n className={cn(\n \"oui-text-base-contrast-20 hover:oui-text-base-contrast-80\",\n \"oui-cursor-pointer\",\n )}\n />\n </div>\n )}\n </Tooltip>\n </Box>\n );\n};\n\nexport const IndicatorIcon: FC<SVGProps<SVGSVGElement>> = (props) => (\n <svg\n width=\"10\"\n height=\"16\"\n viewBox=\"0 0 10 16\"\n fill=\"currentColor\"\n xmlns=\"http://www.w3.org/2000/svg\"\n {...props}\n >\n <rect x=\"2\" y=\"2\" width=\"6\" height=\"2\" rx=\"1\" />\n <rect x=\"2\" y=\"7\" width=\"6\" height=\"2\" rx=\"1\" />\n <rect x=\"2\" y=\"12\" width=\"6\" height=\"2\" rx=\"1\" />\n </svg>\n);\n\nexport const TopIcon: FC<SVGProps<SVGSVGElement>> = (props) => (\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 {...props}\n >\n <rect\n x=\"1.333\"\n y=\"2.667\"\n width=\"13.333\"\n height=\"4\"\n rx=\"2\"\n fill=\"rgb(var(--oui-color-primary))\"\n />\n <rect\n x=\"2.667\"\n y=\"12\"\n width=\"10.667\"\n height=\"1.333\"\n rx=\".667\"\n fill=\"#fff\"\n fillOpacity=\".2\"\n />\n <rect\n x=\"2.667\"\n y=\"8.667\"\n width=\"10.667\"\n height=\"1.333\"\n rx=\".667\"\n fill=\"#fff\"\n fillOpacity=\".2\"\n />\n </svg>\n);\n\nexport const MiddleIcon: FC<SVGProps<SVGSVGElement>> = (props) => (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n {...props}\n >\n <rect\n x=\"1.333\"\n y=\"6\"\n width=\"13.333\"\n height=\"4\"\n rx=\"2\"\n fill=\"rgb(var(--oui-color-primary))\"\n />\n <rect\n x=\"2.667\"\n y=\"12\"\n width=\"10.667\"\n height=\"1.333\"\n rx=\".667\"\n fill=\"#fff\"\n fillOpacity=\".2\"\n />\n <rect\n x=\"2.667\"\n y=\"2.667\"\n width=\"10.667\"\n height=\"1.333\"\n rx=\".667\"\n fill=\"#fff\"\n fillOpacity=\".2\"\n />\n </svg>\n);\n\nexport const BottomIcon: FC<SVGProps<SVGSVGElement>> = (props) => (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n {...props}\n >\n <rect\n x=\"1.333\"\n y=\"9.333\"\n width=\"13.333\"\n height=\"4\"\n rx=\"2\"\n fill=\"rgb(var(--oui-color-primary))\"\n />\n <rect\n x=\"2.667\"\n y=\"6\"\n width=\"10.667\"\n height=\"1.333\"\n rx=\".667\"\n fill=\"#fff\"\n fillOpacity=\".2\"\n />\n <rect\n x=\"2.667\"\n y=\"2.667\"\n width=\"10.667\"\n height=\"1.333\"\n rx=\".667\"\n fill=\"#fff\"\n fillOpacity=\".2\"\n />\n </svg>\n);\n","import { RefObject, useEffect, useMemo, useRef, useState } from \"react\";\nimport Split from \"@uiw/react-split\";\nimport {\n useAccount,\n useCollateral,\n useLocalStorage,\n useMediaQuery,\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 { modal } from \"@orderly.network/ui\";\nimport type { LayoutPosition } from \"../../components/desktop/layout/switchLayout\";\nimport { useSplitPersistent } from \"../../components/desktop/layout/useSplitPersistent\";\nimport { PortfolioSheetWidget } from \"../../components/mobile/portfolioSheet\";\nimport { useTradingLocalStorage } from \"../../hooks/\";\nimport { useTradingPageContext } from \"../../provider/tradingPageContext\";\nimport { TradingPageState } from \"../../types/types\";\nimport { useFirstTimeDeposit } from \"./hooks/useFirstTimeDeposit\";\n\nexport type TradingState = ReturnType<typeof useTradingScript>;\n\nexport const scrollBarWidth = 6;\nexport const topBarHeight = 48;\nexport const bottomBarHeight = 29;\nexport const space = 8;\nexport const symbolInfoBarHeight = 54;\n\nexport const orderEntryMinWidth = 280;\nexport const orderEntryMaxWidth = 360;\n\nexport const orderbookMinWidth = 280;\nexport const orderbookMaxWidth = 732;\n\nexport const orderbookMinHeight = 464;\nexport const orderbookMaxHeight = 728;\n\nexport const tradindviewMinHeight = 320;\n\nexport const tradingViewMinWidth = 540;\n\nexport const dataListMaxHeight = 800;\nexport const dataListInitialHeight = 350;\n\nconst ORDERLY_ORDER_ENTRY_SIDE_MARKETS_LAYOUT =\n \"orderly_order_entry_side_markets_layout\";\n\nconst ORDERLY_SIDE_MARKETS_MODE_KEY = \"orderly_side_markets_mode\";\n\nconst ORDERLY_HORIZONTAL_MARKETS_LAYOUT = \"orderly_horizontal_markets_layout\";\n\nexport type MarketLayoutPosition = \"left\" | \"top\" | \"bottom\" | \"hide\";\n\nexport const useTradingScript = () => {\n const [openMarketsSheet, setOpenMarketsSheet] = useState(false);\n const props = useTradingPageContext();\n const { state } = useAccount();\n const { t } = useTranslation();\n const { wrongNetwork, disabledConnect, restrictedInfo, onRouteChange } =\n useAppContext();\n const { hideAssets, setHideAssets } = useTradingLocalStorage();\n\n const isFirstTimeDeposit = useFirstTimeDeposit();\n\n const { totalValue } = useCollateral();\n\n const total = useDataTap(totalValue);\n\n /** max-width: 1279px */\n const max2XL = useMediaQuery(\"(max-width: 1279px)\");\n\n /** min-width: 1440px */\n const min3XL = useMediaQuery(\"(min-width: 1440px)\");\n\n /** max-width: 1680px */\n const max4XL = useMediaQuery(\"(max-width: 1680px)\");\n\n // Order entry and side market list position, default Order entry in right\n const [layout, setLayout] = useLocalStorage<LayoutPosition>(\n ORDERLY_ORDER_ENTRY_SIDE_MARKETS_LAYOUT,\n \"right\",\n );\n\n // Horizontal markets layout position, default left\n const [marketLayout, setMarketLayout] = useLocalStorage<MarketLayoutPosition>(\n ORDERLY_HORIZONTAL_MARKETS_LAYOUT,\n \"left\",\n );\n\n const canTrade = useMemo<boolean>(() => {\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 onShowPortfolioSheet = () => {\n if (canTrade) {\n modal.sheet({\n title: t(\"trading.asset&Margin\"),\n leading: props.bottomSheetLeading,\n content: <PortfolioSheetWidget />,\n });\n }\n };\n\n const horizontalDraggable = useMemo(() => min3XL, [min3XL]);\n\n const positionsState = useOrderEntryPositions({\n canTrade,\n isFirstTimeDeposit,\n });\n\n const marketsCollapseState = useMarketsCollapse({ resizeable: min3XL });\n\n const observerState = useObserverOrderEntry({ max2XL });\n\n const marketsWidth = useMemo(() => {\n switch (marketsCollapseState.panelSize) {\n case \"small\":\n return 0;\n case \"middle\":\n return 70;\n case \"large\":\n return 280;\n default:\n return 0;\n }\n }, [marketsCollapseState.panelSize]);\n\n const tradindviewMaxHeight = max2XL ? 1200 : 600;\n\n const dataListMinHeight = canTrade ? 379 : 277;\n\n const splitSizeState = useSplitSize({ dep: layout });\n\n const tradingViewHeightState = useExtraHeight({\n orderEntryViewRef: observerState.orderEntryViewRef,\n tradindviewMaxHeight,\n dataListMinHeight,\n });\n\n const navigateToPortfolio =\n typeof onRouteChange === \"function\"\n ? () => onRouteChange({ href: \"/portfolio\", name: t(\"common.portfolio\") })\n : undefined;\n\n const map = {\n layout,\n onLayout: setLayout,\n marketLayout,\n onMarketLayout: setMarketLayout,\n max2XL,\n min3XL,\n max4XL,\n canTrade,\n openMarketsSheet,\n onOpenMarketsSheetChange: setOpenMarketsSheet,\n horizontalDraggable,\n ...marketsCollapseState,\n ...positionsState,\n ...splitSizeState,\n ...observerState,\n restrictedInfo,\n ...tradingViewHeightState,\n marketsWidth,\n tradindviewMaxHeight,\n dataListMinHeight,\n total,\n hideAssets,\n setHideAssets,\n onShowPortfolioSheet,\n navigateToPortfolio,\n isFirstTimeDeposit,\n };\n\n return { ...props, ...map } as TradingPageState & typeof map;\n};\n\nconst useMarketsCollapse = (options: { resizeable: boolean }) => {\n const { resizeable } = options;\n const [animating, setAnimating] = useState(false);\n\n const [panelSize, setPanelSize] = useLocalStorage<\n \"small\" | \"middle\" | \"large\"\n >(ORDERLY_SIDE_MARKETS_MODE_KEY, \"large\");\n\n const onPanelSizeChange = (collapsed: \"small\" | \"middle\" | \"large\") => {\n setPanelSize(collapsed);\n setAnimating(true);\n };\n\n const memoizedPanelSize = useMemo<\"small\" | \"middle\" | \"large\">(() => {\n // Force only two states\n const normalized = panelSize === \"large\" ? \"large\" : \"middle\";\n // under 1440px markets force collapsed\n return resizeable ? normalized : \"middle\";\n }, [resizeable, panelSize]);\n\n return {\n resizeable: resizeable,\n panelSize: memoizedPanelSize,\n onPanelSizeChange: onPanelSizeChange,\n animating: animating,\n setAnimating: setAnimating,\n } as const;\n};\n\nconst useOrderEntryPositions = (options: {\n canTrade: boolean;\n isFirstTimeDeposit: boolean;\n}) => {\n const { canTrade, isFirstTimeDeposit } = options;\n\n const [positions, setPositions] = useLocalStorage(\n \"orderly_assets_orderEntry_margin_positions\",\n [0, 1, 2],\n );\n\n const updatePositions = (currentIdx: number, targetIdx: number) => {\n const pos = [...positions];\n // [0,1,2] => [1,2,0]\n if (currentIdx === 0 && targetIdx === pos.length - 1) {\n pos[targetIdx] = positions[currentIdx];\n for (let i = 0; i < pos.length - 1; i++) {\n pos[i] = positions[i + 1];\n }\n\n // [0,1,2] => [2,0,1]\n } else if (currentIdx === pos.length - 1 && targetIdx === 0) {\n pos[targetIdx] = positions[currentIdx];\n for (let i = 1; i < pos.length; i++) {\n pos[i] = positions[i - 1];\n }\n } else {\n // [0,1,2] => [1,0,2], [0,1,2] => [0,2,1]\n [pos[currentIdx], pos[targetIdx]] = [pos[targetIdx], pos[currentIdx]];\n }\n setPositions(pos);\n };\n\n const showPositionIcon = useMemo(\n () => canTrade && !isFirstTimeDeposit,\n [canTrade, isFirstTimeDeposit],\n );\n\n const pos = useMemo(() => {\n return showPositionIcon ? (positions as number[]) : [0, 1, 2];\n }, [showPositionIcon, positions]);\n\n return {\n positions: pos,\n showPositionIcon,\n updatePositions,\n };\n};\n\nconst useSplitSize = (options: { dep: any }) => {\n const { dep } = options;\n const [mainSplitSize, setMainSplitSize] = useSplitPersistent(\n \"orderly_main_split_size\",\n `${orderEntryMinWidth}px`,\n dep,\n );\n const [dataListSplitSize, setDataListSplitSize] = useSplitPersistent(\n \"orderly_datalist_split_size\",\n `${dataListInitialHeight}px`,\n // undefined,\n );\n const [orderBookSplitSize, setOrderbookSplitSize] = useSplitPersistent(\n \"orderly_orderbook_split_size\",\n \"280px\",\n dep,\n );\n\n const [dataListSplitHeightSM, setDataListSplitHeightSM] = useSplitPersistent(\n \"orderly_datalist_split_height_sm\",\n \"350px\",\n );\n\n const [orderBookSplitHeightSM, setOrderbookSplitHeightSM] =\n useSplitPersistent(\"orderly_orderbook_split_height_sm\", \"280px\");\n\n return {\n orderBookSplitSize,\n setOrderbookSplitSize,\n dataListSplitSize,\n setDataListSplitSize,\n mainSplitSize,\n setMainSplitSize,\n dataListSplitHeightSM,\n setDataListSplitHeightSM,\n orderBookSplitHeightSM,\n setOrderbookSplitHeightSM,\n };\n};\n\nconst useObserverOrderEntry = (options: { max2XL: boolean }) => {\n const { max2XL } = options;\n const [orderEntryHeight, setOrderEntryHeight] = useState(0);\n const orderEntryViewRef = useRef<HTMLDivElement>(null);\n\n useEffect(() => {\n const element = orderEntryViewRef.current;\n\n if (!element || !max2XL) {\n return;\n }\n\n const resizeObserver = new ResizeObserver((entries) => {\n for (const entry of entries) {\n const height = entry.contentRect.height;\n if (height) {\n setOrderEntryHeight(height);\n }\n }\n });\n\n resizeObserver.observe(element);\n\n return () => {\n resizeObserver.unobserve(element);\n };\n }, [orderEntryViewRef, max2XL]);\n\n return {\n orderEntryViewRef,\n orderEntryHeight,\n };\n};\n\nexport function getOffsetSizeNum(size: string | null) {\n if (size) {\n return `${100 - Math.min(Number(size), 100)}`;\n }\n return \"\";\n}\n\nfunction useExtraHeight(options: {\n orderEntryViewRef: RefObject<HTMLDivElement>;\n tradindviewMaxHeight: number;\n dataListMinHeight: number;\n}) {\n const { tradindviewMaxHeight, dataListMinHeight } = options;\n const tradingviewAndOrderbookSplitRef = useRef<Split>(null);\n const max2XLSplitRef = useRef<Split>(null);\n\n const [extraHeight, setExtraHeight] = useLocalStorage(\n \"orderly_order_entry_extra_height\",\n 0,\n );\n\n const space = 10 + 12;\n\n const [dataListHeight, setDataListHeight] = useLocalStorage(\n \"orderly_trading_data_list_height\",\n dataListMinHeight,\n );\n\n const onTradingviewAndOrderbookDragging = (\n preSize: number,\n nextSize: number,\n ) => {\n const boxHeight = tradingviewAndOrderbookSplitRef?.current?.boxHeight;\n if (!boxHeight) {\n return;\n }\n\n const splitTradingviewHeight = (boxHeight * preSize) / 100;\n const splitOrderbookHeight = (boxHeight * nextSize) / 100;\n\n const tradingviewHeight = Math.min(\n Math.max(splitTradingviewHeight, tradindviewMinHeight),\n tradindviewMaxHeight,\n );\n\n const orderbookHeight = Math.min(\n Math.max(splitOrderbookHeight, orderbookMinHeight),\n orderbookMaxHeight,\n );\n\n const orderEntryHeight =\n options.orderEntryViewRef.current?.clientHeight || 0;\n\n // console.log(\"tradingviewHeight\", splitTradingviewHeight, tradingviewHeight);\n // console.log(\"orderbookHeight\", splitOrderbookHeight, orderbookHeight);\n\n if (splitOrderbookHeight >= orderbookHeight) {\n const offset = splitOrderbookHeight - orderbookHeight;\n // console.log(\"offset ---\", offset);\n setExtraHeight(Math.max(0, extraHeight - offset));\n } else if (\n tradingviewHeight + orderbookHeight <\n tradindviewMaxHeight + orderbookMaxHeight\n ) {\n const height =\n tradingviewHeight + orderbookHeight + space + symbolInfoBarHeight;\n\n const offset = Math.max(0, height - orderEntryHeight);\n // console.log(\"offset ++++\", height, offset);\n setExtraHeight(extraHeight + offset);\n }\n };\n\n const onDataListSplitHeightDragging = (preSize: number, nextSize: number) => {\n const boxHeight = max2XLSplitRef?.current?.boxHeight;\n if (!boxHeight) {\n return;\n }\n\n // const splitTradingAndOrderbookHeight = (boxHeight * preSize) / 100;\n const splitDataListHeight = (boxHeight * nextSize) / 100;\n\n if (\n splitDataListHeight >= dataListMinHeight &&\n splitDataListHeight <= dataListMaxHeight\n ) {\n setDataListHeight(splitDataListHeight);\n const offset = splitDataListHeight - dataListHeight;\n if (offset > 0) {\n setExtraHeight(Math.max(0, extraHeight - offset));\n }\n }\n };\n\n return {\n max2XLSplitRef,\n tradingviewAndOrderbookSplitRef,\n onTradingviewAndOrderbookDragging,\n onDataListSplitHeightDragging,\n extraHeight,\n dataListHeight,\n };\n}\n","import { useMemo } from \"react\";\n\nexport const useSplitPersistent = (\n key: string,\n defaulValue?: string,\n dep?: any\n): [string | undefined, (size: string) => void] => {\n const size = useMemo(() => {\n const size = localStorage.getItem(key);\n\n if (size) {\n return `${size}%`;\n }\n return defaulValue;\n }, [key, defaulValue, dep]);\n\n const setSize = (size: string) => {\n localStorage.setItem(key, size);\n };\n\n return [size, setSize];\n};\n","import { useMemo } from \"react\";\nimport {\n useAccount,\n useAssetsHistory,\n useCollateral,\n} from \"@orderly.network/hooks\";\nimport { useAppContext } from \"@orderly.network/react-app\";\nimport {\n AccountStatusEnum,\n AssetHistorySideEnum,\n AssetHistoryStatusEnum,\n} from \"@orderly.network/types\";\n\nexport const useFirstTimeDeposit = () => {\n const { state } = useAccount();\n const { wrongNetwork, disabledConnect } = useAppContext();\n const { totalValue } = useCollateral({\n dp: 2,\n });\n\n const unavailable =\n wrongNetwork ||\n disabledConnect ||\n (state.status < AccountStatusEnum.EnableTrading &&\n state.status !== AccountStatusEnum.EnableTradingWithoutConnected);\n\n const { startTime, endTime } = useMemo(() => {\n const d = new Date();\n // must set last second of today, when wallet ws changed, it will get latest data from api\n const today = new Date(\n d.getFullYear(),\n d.getMonth(),\n d.getDate(),\n 23,\n 59,\n 59,\n );\n\n const endTime = today.getTime();\n // 90 days ago timestamp\n const startTime = endTime - 90 * 24 * 60 * 60 * 1000;\n\n return {\n startTime,\n endTime,\n };\n }, []);\n\n const [_, { meta }] = useAssetsHistory(\n {\n startTime,\n endTime,\n page: 1,\n pageSize: 5,\n side: AssetHistorySideEnum.DEPOSIT,\n status: AssetHistoryStatusEnum.COMPLETED,\n },\n {\n shouldUpdateOnWalletChanged: (data) =>\n data.side === AssetHistorySideEnum.DEPOSIT &&\n data.transStatus === AssetHistoryStatusEnum.COMPLETED,\n },\n );\n\n return !unavailable && totalValue === 0 && meta?.total === 0;\n};\n","import React from \"react\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport {\n MarketsSheetWidget,\n SymbolInfoBarWidget,\n} from \"@orderly.network/markets\";\nimport {\n Box,\n SimpleSheet,\n EyeCloseIcon,\n EyeIcon,\n Flex,\n Text,\n} from \"@orderly.network/ui\";\nimport type { TradingState } from \"./trading.script\";\n\nconst LazyTopTabWidget = React.lazy(() =>\n import(\"../../components/mobile/topTab\").then((mod) => {\n return { default: mod.TopTabWidget };\n }),\n);\n\nconst LazyOrderBookAndEntryWidget = React.lazy(() =>\n import(\"../../components/mobile/orderBookAndEntry\").then((mod) => {\n return { default: mod.OrderBookAndEntryWidget };\n }),\n);\n\nconst LazyDataListWidget = React.lazy(() =>\n import(\"../../components/mobile/dataList\").then((mod) => {\n return { default: mod.DataListWidget };\n }),\n);\n\nconst MaybeEqual: React.FC = () => {\n return (\n <svg\n width=\"8\"\n height=\"8\"\n viewBox=\"0 0 8 8\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M6.456 3.48a3.5 3.5 0 0 0 .431-.567 9 9 0 0 0 .361-.654l-.648-.66-.107.185q-.071.12-.142.244a3 3 0 0 1-.27.396 1.4 1.4 0 0 1-.318.29.67.67 0 0 1-.38.114q-.307 0-.666-.194t-.742-.42q-.383-.227-.777-.42a1.7 1.7 0 0 0-.771-.194q-.401.001-.72.154a2.1 2.1 0 0 0-.57.404 2.6 2.6 0 0 0-.43.574 5 5 0 0 0-.307.646l.649.66q.165-.437.464-.833.298-.395.742-.396.347 0 .7.194.354.193.721.42.37.227.763.42.396.195.826.195.374.001.665-.155.29-.151.526-.404m.352 2.941a3.5 3.5 0 0 0 .431-.566q.196-.315.361-.654l-.648-.66-.107.184-.142.244a3 3 0 0 1-.27.396 1.4 1.4 0 0 1-.318.29.67.67 0 0 1-.38.115q-.307 0-.666-.195-.36-.193-.742-.42-.383-.226-.778-.42a1.7 1.7 0 0 0-.77-.194q-.401.001-.72.154a2.1 2.1 0 0 0-.57.405 2.6 2.6 0 0 0-.43.574 5 5 0 0 0-.307.646l.649.66q.165-.437.464-.833.297-.395.742-.396.347 0 .7.194.354.193.721.42.369.226.763.42.396.194.826.194.374.001.665-.154.29-.152.526-.404\"\n fill=\"#fff\"\n fillOpacity=\".54\"\n />\n </svg>\n );\n};\n\nexport const MobileLayout: React.FC<TradingState> = (props) => {\n const { t } = useTranslation();\n const topBar = (\n <Box intensity={900} className=\"oui-rounded-xl\" mx={1} px={3} height={54}>\n <SymbolInfoBarWidget\n symbol={props.symbol}\n onSymbol={() => props.onOpenMarketsSheetChange(true)}\n trailing={\n <Flex\n direction={\"column\"}\n itemAlign={\"end\"}\n className=\"oui-cursor-pointer oui-text-[11px]\"\n onClick={props.onShowPortfolioSheet}\n >\n <Flex>\n <Text intensity={54}>{t(\"common.totalValue\")}</Text>\n <button\n onClick={(e) => {\n e.stopPropagation();\n e.preventDefault();\n props.setHideAssets(!props.hideAssets);\n }}\n className=\"oui-px-1\"\n >\n {props.hideAssets ? (\n <EyeIcon\n color=\"primary\"\n opacity={1}\n size={16}\n className=\"oui-text-primary-light\"\n />\n ) : (\n <EyeCloseIcon\n color=\"primary\"\n opacity={1}\n size={16}\n className=\"oui-text-primary-light\"\n />\n )}\n </button>\n <MaybeEqual />\n </Flex>\n <Text.numeral\n suffix={<Text intensity={20}>&nbsp;USDC</Text>}\n dp={2}\n visible={!props.hideAssets}\n >\n {props.canTrade ? (props.total ?? \"--\") : \"--\"}\n </Text.numeral>\n </Flex>\n }\n />\n <SimpleSheet\n open={props.openMarketsSheet}\n onOpenChange={props.onOpenMarketsSheetChange}\n classNames={{\n body: \"oui-h-full oui-pb-0\",\n content: \"oui-w-[280px] !oui-p-0\",\n }}\n contentProps={{ side: \"left\", closeable: false }}\n >\n <MarketsSheetWidget\n symbol={props.symbol}\n onSymbolChange={(symbol) => {\n props.onOpenMarketsSheetChange(false);\n props.onSymbolChange?.(symbol);\n }}\n />\n </SimpleSheet>\n </Box>\n );\n\n return (\n <div className=\"oui-relative oui-grid oui-gap-1 oui-bg-base-10\">\n <main className=\"oui-hide-scrollbar oui-space-y-1 oui-overflow-y-auto\">\n {topBar}\n <React.Suspense fallback={null}>\n <LazyTopTabWidget className=\"oui-mx-1 oui-rounded-xl oui-bg-base-9\" />\n </React.Suspense>\n <React.Suspense fallback={null}>\n <LazyOrderBookAndEntryWidget />\n </React.Suspense>\n <React.Suspense fallback={null}>\n <LazyDataListWidget\n symbol={props.symbol}\n className=\"oui-mx-1 oui-rounded-xl\"\n sharePnLConfig={props.sharePnLConfig}\n />\n </React.Suspense>\n </main>\n </div>\n );\n};\n","import React from \"react\";\nimport { useTradingScript } from \"./trading.script\";\nimport { Trading } from \"./trading.ui\";\n\nexport const TradingWidget: React.FC = () => {\n const state = useTradingScript();\n return <Trading {...state} />;\n};\n","import { FC, PropsWithChildren, useMemo } from \"react\";\nimport { useSymbolsInfo } from \"@orderly.network/hooks\";\nimport { TradingPageState, TradingPageProps } from \"../types/types\";\nimport { getBasicSymbolInfo } from \"../utils/utils\";\nimport { TradingPageContext } from \"./tradingPageContext\";\n\nexport const TradingPageProvider: FC<PropsWithChildren<TradingPageProps>> = (\n props,\n) => {\n const { symbol, children } = props;\n const symbolInfo = useSymbolsInfo()[symbol];\n const memoizedValue = useMemo<TradingPageState>(() => {\n const basicSymbol = getBasicSymbolInfo(symbolInfo);\n return {\n ...props,\n symbolInfo: {\n ...basicSymbol,\n symbol: symbol,\n },\n };\n }, [props, symbol, symbolInfo]);\n return (\n <TradingPageContext.Provider value={memoizedValue}>\n {children}\n </TradingPageContext.Provider>\n );\n};\n","import React from \"react\";\nimport { TradingPageProvider } from \"../../provider/tradingPageProvider\";\nimport { TradingPageProps } from \"../../types/types\";\nimport { TradingWidget } from \"./trading.widget\";\n\nexport const TradingPage: React.FC<TradingPageProps> = (props) => {\n return (\n <TradingPageProvider\n symbol={props.symbol}\n tradingViewConfig={props.tradingViewConfig}\n onSymbolChange={props.onSymbolChange}\n disableFeatures={props.disableFeatures}\n overrideFeatures={props.overrideFeatures}\n referral={props.referral}\n tradingRewards={props.tradingRewards}\n bottomSheetLeading={props.bottomSheetLeading}\n sharePnLConfig={props.sharePnLConfig}\n >\n <TradingWidget />\n </TradingPageProvider>\n );\n};\n"]}