@kodiak-finance/orderly-ui-positions 2.8.14-prerelease.0 → 2.8.14
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.d.mts +12 -31
- package/dist/index.d.ts +12 -31
- package/dist/index.js +23 -23
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +7 -7
- package/dist/index.mjs.map +1 -1
- package/package.json +13 -13
package/dist/index.mjs
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import { registerSimpleDialog,
|
|
2
|
-
import
|
|
1
|
+
import { registerSimpleDialog, Flex, Text, CloseIcon, Button, ThrottledButton, useScreen, Grid, Statistic, DataTable, cn, ListView, SimpleSheet, SimpleDialog, usePagination, DataFilter, Badge, formatAddress, Tooltip, Box, HoverCard, Divider, toast, capitalizeFirstLetter, ChevronRightIcon, modal, ShareIcon, EditIcon, Input, inputFormatter, Select, PopoverRoot, PopoverTrigger, PopoverContent, Slider } from '@kodiak-finance/orderly-ui';
|
|
2
|
+
import Dr, { createContext, useContext, useCallback, useMemo, useState, useEffect, useRef } from 'react';
|
|
3
3
|
import { useTranslation, i18n } from '@kodiak-finance/orderly-i18n';
|
|
4
|
-
import { AccountStatusEnum, OrderType, PositionType, AlgoOrderType,
|
|
4
|
+
import { EMPTY_LIST, AccountStatusEnum, OrderType, PositionType, AlgoOrderType, OrderSide } from '@kodiak-finance/orderly-types';
|
|
5
5
|
import { commifyOptional, Decimal, getTimestamp, commify } from '@kodiak-finance/orderly-utils';
|
|
6
|
-
import {
|
|
7
|
-
import {
|
|
6
|
+
import { jsxs, jsx, Fragment } from 'react/jsx-runtime';
|
|
7
|
+
import { usePrivateInfiniteQuery, useBoolean, useSessionStorage, useAccount, usePrivateQuery, usePositionStream, useSymbolsInfo, usePositionClose, useSWR, fetcher, useLocalStorage, useConfig, useReferralInfo, useAccountInfo, useLeverageBySymbol, utils, useMaxLeverage } from '@kodiak-finance/orderly-hooks';
|
|
8
8
|
import { produce } from 'immer';
|
|
9
9
|
import { positions, account } from '@kodiak-finance/orderly-perp';
|
|
10
10
|
import { useDataTap, useOrderEntryFormErrorMsg } from '@kodiak-finance/orderly-react-app';
|
|
@@ -14,8 +14,8 @@ import { SharePnLDialogId, SharePnLBottomSheetId } from '@kodiak-finance/orderly
|
|
|
14
14
|
import { TPSLDetailSheetId, TPSLDetailDialogId, TPSLSheetId, TPSLDialogId } from '@kodiak-finance/orderly-ui-tpsl';
|
|
15
15
|
import { subDays, differenceInDays } from 'date-fns';
|
|
16
16
|
|
|
17
|
-
var Qo=t=>{let{hideCloseIcon:e=false}=t;return jsxs("div",{className:"oui-relative oui-w-full oui-border-b oui-border-line-4 oui-pb-3",children:[jsx(Text,{size:"base",children:t.title}),!e&&jsx("button",{onClick:t.onClose,className:"oui-absolute oui-right-0 oui-top-0 oui-p-2 oui-text-base-contrast-54 hover:oui-text-base-contrast-80",children:jsx(CloseIcon,{size:18,color:"white"})})]})},ce=t=>{let{t:e}=useTranslation();return jsxs(Flex,{id:"oui-positions-confirm-footer",gap:2,width:"100%",className:"oui-mt-3 oui-pb-1",children:[jsx(Button,{id:"oui-positions-confirm-footer-cancel-button",color:"secondary",fullWidth:true,onClick:t.onCancel,size:"md",children:e("common.cancel")}),jsx(ThrottledButton,{id:"oui-positions-confirm-footer-confirm-button",onClick:t.onConfirm,fullWidth:true,loading:t.submitting,disabled:t.disabled,size:"md",children:e("common.confirm")})]})},Xn=t=>{let{quantity:e,price:o,quoteDp:i,side:r}=t,{t:n}=useTranslation(),s=useMemo(()=>o&&e?new Decimal(o).mul(e).toFixed(i,Decimal.ROUND_DOWN):"--",[o,e]);return jsxs(Flex,{direction:"column",gap:1,width:"100%",className:"oui-text-sm oui-text-base-contrast-54",py:5,children:[jsxs(Flex,{justify:"between",width:"100%",gap:1,children:[jsx(Text,{children:n("common.qty")}),jsx(Text,{color:r===OrderSide.BUY?"success":"danger",children:e})]}),jsxs(Flex,{justify:"between",width:"100%",gap:1,children:[jsx(Text,{children:n("common.price")}),jsx(Text.formatted,{intensity:98,suffix:jsx(Text,{intensity:54,children:"USDC"}),children:o})]}),jsxs(Flex,{justify:"between",width:"100%",gap:1,children:[jsx(Text,{children:n("common.notional")}),jsx(Text.formatted,{intensity:98,suffix:jsx(Text,{intensity:54,children:"USDC"}),children:s})]})]})},Mt=t=>{let{t:e}=useTranslation(),o=()=>{(t?.onClose??t.close)?.();};return jsxs(Flex,{direction:"column",className:t.classNames?.root,children:[jsx(Qo,{onClose:o,title:e("positions.marketClose"),hideCloseIcon:t.hideCloseIcon}),jsx(Text,{intensity:54,size:"sm",className:"oui-my-5",children:e("positions.marketClose.description",{quantity:commifyOptional(t.quantity),base:t.base})}),jsx(ce,{onCancel:o,onConfirm:async()=>{await t.onConfirm?.(),o();},submitting:t.submitting})]})},de=t=>{let{order:e,quoteDp:o,quantity:i,price:r}=t,{side:n}=e,{t:s}=useTranslation(),a=()=>{t.onClose?.();};return jsxs(Fragment,{children:[jsx(Qo,{onClose:a,title:s("positions.limitClose"),hideCloseIcon:t.hideCloseIcon}),jsx(Box,{mt:5,children:jsx(Text,{intensity:54,size:"sm",children:s("positions.limitClose.description",{quantity:commify(t.quantity),base:t.base})})}),jsxs(Flex,{gap:2,mb:4,mt:5,justify:"between",children:[jsx(Text.formatted,{rule:"symbol",formatString:"base-type",size:"base",showIcon:true,children:e.symbol}),jsxs(Flex,{gap:1,children:[jsx(Badge,{color:"neutral",size:"xs",children:s("orderEntry.orderType.limit")}),jsx(Badge,{color:n===OrderSide.BUY?"success":"danger",size:"xs",children:n===OrderSide.BUY?s("common.buy"):s("common.sell")})]})]}),jsx(Divider,{className:"oui-w-full"}),jsx(Xn,{className:"oui-text-sm",price:r,quantity:i,side:e.side,quoteDp:o??2}),jsx(ce,{onCancel:a,onConfirm:t.onConfirm,submitting:t.submitting})]})};var $e=createContext({}),et=()=>useContext($e);function Vo(t,e){let o=useRef(),i=useRef(e);i.current=e,useEffect(()=>{let r={root:null,rootMargin:"0px",threshold:0},n=s=>{s.forEach(a=>{a.isIntersecting&&i.current?.();});};return o.current=new IntersectionObserver(n,r),()=>{o.current?.disconnect();}},[]),useEffect(()=>{o.current?.observe(t.current);},[]);}var Ko=t=>{let e=useRef(null),{onEndReached:o}=t;return Vo(e,()=>{o?.();}),jsxs(Fragment,{children:[t.children,jsx("div",{ref:e,className:"oui-relative oui-invisible oui-h-[25px] oui-bg-red-400 oui-top-[-300px]"})]})};var Go=60,pe=({total:t,symbol:e,start_t:o,end_t:i})=>{let{t:r}=useTranslation(),{isMobile:n}=useScreen(),{isLoading:s,data:a,setSize:l}=usePrivateInfiniteQuery((d,f)=>(!f||(f.length??0)<Go)&&d>0?null:`/v1/funding_fee/history?page=${d+1}&size=${Go}&symbol=${e}&start_t=${o}&end_t=${i}`,{revalidateFirstPage:false}),u=useCallback(()=>{l(d=>d+1);},[l]),c=useMemo(()=>Array.isArray(a)?a.flat().map(d=>({...d,funding_fee:-d.funding_fee})):[],[a]),m=useMemo(()=>n?jsx(cr,{data:c??EMPTY_LIST,isLoading:s,loadMore:u}):jsx(mr,{data:c??EMPTY_LIST,isLoading:s,loadMore:u}),[n,c,s]);return jsxs("div",{children:[jsxs(Grid,{cols:2,gapX:3,className:"oui-sticky oui-top-0 oui-z-10 oui-bg-base-8 oui-py-4",children:[jsx("div",{className:"oui-rounded-lg oui-border oui-border-line-6 oui-bg-base-9 oui-p-3",children:jsxs(Flex,{direction:"column",gap:1,itemAlign:"start",children:[jsx("span",{className:"oui-text-2xs oui-text-base-contrast-36",children:r("common.symbol")}),jsx(Text.formatted,{rule:"symbol",className:"oui-font-semibold",intensity:98,children:e})]})}),jsx("div",{className:"oui-rounded-lg oui-border oui-border-line-6 oui-bg-base-9 oui-p-3",children:jsx(Statistic,{label:`${r("funding.fundingFee")} (USDC)`,valueProps:{ignoreDP:true,coloring:true,showIdentifier:true},children:t})})]}),m]})},mr=({isLoading:t,data:e,loadMore:o})=>{let{t:i}=useTranslation(),r=useMemo(()=>[{title:i("common.time"),dataIndex:"created_time",width:120,render:n=>jsx(Text.formatted,{rule:"date",children:n})},{title:i("funding.fundingRate"),dataIndex:"funding_rate",formatter:n=>new Decimal(n).mul(100).toString(),render:n=>jsx("span",{children:`${n}%`})},{title:i("funding.paymentType"),dataIndex:"payment_type",formatter:n=>i(n==="Pay"?"funding.paymentType.paid":"funding.paymentType.received"),render:n=>jsx("span",{children:n})},{title:`${i("funding.fundingFee")} (USDC)`,dataIndex:"funding_fee",render:n=>jsx(Text.numeral,{rule:"price",coloring:true,showIdentifier:true,ignoreDP:true,children:n})}],[i]);return jsx("div",{className:"oui-h-[calc(80vh_-_132px_-_8px)] oui-overflow-y-auto",children:jsx(Ko,{onEndReached:o,children:jsx(DataTable,{classNames:{root:cn$1("oui-h-auto oui-bg-base-8 oui-text-sm")},columns:r,dataSource:e??EMPTY_LIST,loading:t})})})},cr=({data:t,isLoading:e,loadMore:o})=>{let i=useCallback(r=>jsx(dr,{item:r}),[]);return jsx("div",{className:"oui-h-[calc(80vh_-_104px)] oui-overflow-y-auto",children:jsx(ListView,{dataSource:t,renderItem:i,isLoading:e,contentClassName:"oui-space-y-0",loadMore:o})})},dr=({item:t})=>{let{t:e}=useTranslation();return jsxs("div",{className:"oui-flex oui-flex-col oui-space-y-2 oui-border-t oui-border-line-6 oui-py-2",children:[jsxs(Flex,{justify:"between",children:[jsx(Statistic,{label:e("funding.fundingRate"),classNames:{label:"oui-text-2xs"},valueProps:{ignoreDP:true,rule:"percentages",className:"oui-text-xs"},children:t.funding_rate}),jsx(Statistic,{label:e("common.amount"),className:"oui-items-end",classNames:{label:"oui-text-2xs"},valueProps:{ignoreDP:true,coloring:true,as:"div",className:"oui-text-xs",showIdentifier:true},children:t.funding_fee})]}),jsxs(Flex,{justify:"between",children:[jsx(Text.formatted,{rule:"date",className:"oui-text-base-contrast-36",size:"2xs",children:t.created_time}),jsx(Text,{size:"sm",intensity:80,children:t.payment_type==="Pay"?e("funding.paymentType.paid"):e("funding.paymentType.received")})]})]})};var mt=({fee:t,symbol:e,start_t:o,end_t:i})=>{let{t:r}=useTranslation(),[n,{setTrue:s,setFalse:a}]=useBoolean(false),{isMobile:l}=useScreen();return jsxs(Fragment,{children:[jsx("button",{onClick:s,children:jsx(Text.numeral,{rule:"price",coloring:true,showIdentifier:true,ignoreDP:true,className:"oui-border-b oui-border-line-16 oui-border-dashed oui-py-0.5",children:t})}),l?jsx(SimpleSheet,{open:n,onOpenChange:a,title:r("funding.fundingFee"),classNames:{body:"oui-max-h-[80vh] oui-py-0"},children:jsx(pe,{total:t,symbol:e,start_t:o,end_t:i})}):jsx(SimpleDialog,{open:n,onOpenChange:a,title:r("funding.fundingFee"),classNames:{content:"lg:oui-max-w-[640px]",body:"oui-max-h-[80vh] oui-bg-base-8 lg:oui-py-0"},children:jsx(pe,{total:t,symbol:e,start_t:o,end_t:i})})]})};var vr=(t,e)=>{let o=useConfig("apiBaseUrl");return i=>(r,n,s)=>{try{return i(r,async l=>{let u=Array.isArray(l)?l[0]:l,c=`${o}${u}`,m=t.signer,d={method:"GET",url:u},f=await m.sign(d,getTimestamp()),y=Array.isArray(e)?e:[e];return Promise.all(y.map(g=>n(c,{headers:{...f,"orderly-account-id":g}})))},s)}catch(a){throw a}}},Zo=(t,e)=>{let{formatter:o,accountId:i,...r}=e||{},{state:n,account:s}=useAccount(),a=Array.isArray(e?.use)?e?.use??[]:[],l=Array.isArray(i)?i:[i],u=l.filter(Boolean).length&&(n.status>=AccountStatusEnum.EnableTrading||n.status===AccountStatusEnum.EnableTradingWithoutConnected);return useSWR(()=>u?[t,l]:null,(c,m)=>fetcher(c,m,{formatter:o}),{...r,use:[...a,vr(s,l)],onError:()=>{}})};var Jo=t=>{let{symbol:e,calcMode:o,includedPendingOrder:i,pnlNotionalDecimalPrecision:r,sharePnLConfig:n,onSymbolChange:s,selectedAccount:a}=t,{pagination:l,setPage:u}=usePagination({pageSize:50});useEffect(()=>{u(1);},[e]);let c=useSymbolsInfo(),{state:m}=useAccount(),[d,,{isLoading:f}]=usePositionStream(e,{calcMode:o,includedPendingOrder:i}),{data:y=[],isLoading:g,mutate:b}=usePrivateQuery("/v1/client/aggregate/positions",{errorRetryCount:3}),{data:v=[],isLoading:D}=Zo("/v1/client/info",{accountId:y.map(_=>_.account_id),revalidateOnFocus:false}),S=produce(y.filter(_=>_.account_id!==m.mainAccountId),_=>{for(let p of _){let $=c[p.symbol],X=positions.notional(p.position_qty,p.mark_price),h=v.find(We=>We.account_id===p.account_id),z=positions.MMR({baseMMR:$?.("base_mmr"),baseIMR:$?.("base_imr"),IMRFactor:h?.imr_factor[p.symbol]??0,positionNotional:X,IMR_factor_power:4/5}),se=positions.maintenanceMargin({positionQty:p.position_qty,markPrice:p.mark_price,MMR:z}),ae=positions.unrealizedPnL({qty:p.position_qty,openPrice:p?.average_open_price,markPrice:p.mark_price}),Be=p.leverage||1,Gt=account.IMR({maxLeverage:Be,baseIMR:$?.("base_imr"),IMR_Factor:h?.imr_factor[p.symbol]??0,positionNotional:X,ordersNotional:0,IMR_factor_power:4/5}),le=positions.unrealizedPnLROI({positionQty:p.position_qty,openPrice:p.average_open_price,IMR:Gt,unrealizedPnL:ae}),ue=0,Rt=0;p.index_price&&(ue=positions.unrealizedPnL({qty:p.position_qty,openPrice:p?.average_open_price,markPrice:p.index_price}),Rt=positions.unrealizedPnLROI({positionQty:p.position_qty,openPrice:p.average_open_price,IMR:Gt,unrealizedPnL:ue})),p.mmr=z,p.mm=se,p.notional=X,p.unrealized_pnl=ae,p.unrealized_pnl_ROI=le,p.unrealized_pnl_ROI_index=Rt;}}),M=useDataTap([...d?.rows,...S].filter(_=>_.position_qty!==0))??[],E=useMemo(()=>!a||a==="All accounts"?M:M.filter(_=>a==="Main accounts"?_.account_id===m.mainAccountId||!_.account_id:_.account_id===a),[M,a,m.mainAccountId]),Q=useMemo(()=>Er(E,{mainAccountId:m.mainAccountId,subAccounts:m.subAccounts}),[E,m.mainAccountId,m.subAccounts]),ut=useMemo(()=>f||g||D,[f,g,D]);return {tableData:Q,isLoading:ut,pnlNotionalDecimalPrecision:r,sharePnLConfig:n,symbol:e,onSymbolChange:s,pagination:l,mutatePositions:b}},Er=(t,e)=>{let{mainAccountId:o="",subAccounts:i=[]}=e,r=new Map;for(let n of t){let s=n.account_id||o,a=i.find(l=>l.id===s);r.has(s)?r.get(s)?.children?.push(n):r.set(s,{id:s,description:s===o?i18n.t("common.mainAccount"):a?.description||formatAddress(a?.id||""),children:[n]});}return {expanded:Array.from(r.keys()),dataSource:Array.from(r.values())}};var fe="orderly_trading_positions_sort";var zr=(t,e)=>{if(t==null&&e==null)return 0;if(t==null)return 1;if(e==null)return -1;let o=String(t).trim(),i=String(e).trim(),r=Number(o),n=Number(i),s=!isNaN(r)&&isFinite(r)&&/^-?\d*\.?\d+([eE][+-]?\d+)?$/.test(o),a=!isNaN(n)&&isFinite(n)&&/^-?\d*\.?\d+([eE][+-]?\d+)?$/.test(i);if(s&&a)return r-n;let l=/^\d{4}-\d{2}-\d{2}/.test(o)||/^\d{13}$/.test(o),u=/^\d{4}-\d{2}-\d{2}/.test(i)||/^\d{13}$/.test(i);if(l&&u){let c=new Date(t),m=new Date(e);if(!isNaN(c.getTime())&&!isNaN(m.getTime()))return c.getTime()-m.getTime()}return o.localeCompare(i,void 0,{sensitivity:"base",numeric:false})};function ti(t,e){let{sortKey:o,sortOrder:i}=e||{},r=[...t||[]];return o&&i&&r.sort((n,s)=>{let a=zr(n[o],s[o]);return i==="desc"?-a:a}),r}function Zt(t,e){let[o,i]=useState(t),r=useCallback(s=>{let a=s?{sortKey:s.sortKey,sortOrder:s.sort}:void 0;i(a),e?.(a);},[]),n=useCallback(s=>ti(s,o),[o]);return {sort:o,onSort:r,getSortedList:n}}var ye=(o=>(o.Positions="positions",o.PositionHistory="positionHistory",o))(ye||{});function Jt(t){let[e,o]=useSessionStorage(t.storageKey,{positions:{sortKey:"unrealized_pnl",sortOrder:"desc"},positionHistory:{sortKey:"close_timestamp",sortOrder:"desc"}}),i=useCallback(r=>n=>{o({...e,[r]:n});},[e,o]);return {tabSort:e,onTabSort:i}}var Je=t=>{let{symbol:e,calcMode:o,includedPendingOrder:i,pnlNotionalDecimalPrecision:r,sharePnLConfig:n,onSymbolChange:s,enableSortingStorage:a=true}=t,{pagination:l,setPage:u}=usePagination({pageSize:50}),{tabSort:c,onTabSort:m}=Jt({storageKey:fe}),{onSort:d,getSortedList:f,sort:y}=Zt(a?c?.positions:void 0,a?m("positions"):void 0);_t.useEffect(()=>{u(1);},[e]);let[g,,{isLoading:b}]=usePositionStream(e,{calcMode:o,includedPendingOrder:i}),v=useDataTap(g?.rows,{fallbackData:[]})??void 0;return {dataSource:f(v||[]),isLoading:b,pnlNotionalDecimalPrecision:r,sharePnLConfig:n,symbol:e,onSymbolChange:s,pagination:l,onSort:d,initialSort:a?c?.positions:void 0}};var je=createContext({}),V=()=>useContext(je);var Nt=t=>{let{symbol:e,children:o}=t,i=useSymbolsInfo()[e],r=useMemo(()=>({symbol:e,base_dp:i("base_dp"),quote_dp:i("quote_dp"),base_tick:i("base_tick"),quote_tick:i("quote_tick"),base:i("base"),quote:i("quote"),origin:i(),quote_max:i("quote_max"),quote_min:i("quote_min")}),[e,i]);return jsx(je.Provider,{value:r,children:o})};var xe=t=>{let{t:e}=useTranslation();return jsxs(Fragment,{children:[jsx(Slider,{showTip:true,markCount:4,value:[t.value],color:"primary",onValueChange:o=>{t.onValueChange(o[0]);}}),jsxs(Flex,{width:"100%",justify:"between",children:[jsx(Text,{color:"primary",size:"2xs",children:`${t.value}%`}),jsxs(Flex,{gap:1,onClick:t.onMax,className:"oui-cursor-pointer",children:[jsx(Text,{size:"2xs",color:"primary",children:e("common.max")}),jsx(Text.numeral,{intensity:54,size:"2xs",dp:t.base_dp,padding:false,children:t.max})]})]})]})};var io=t=>{let{base:e,base_dp:o,quote:i,quote_dp:r,sheetOpen:n,setSheetOpen:s,dialogOpen:a,setDialogOpen:l,quantity:u,price:c,submitting:m,priceErrorMsg:d,quantityErrorMsg:f,disabled:y,isMarketClose:g,position:b,maxQty:v,isBuy:D}=t,{t:S}=useTranslation(),M=S(g?"positions.marketClose":"positions.limitClose"),E=S(g?"orderEntry.orderType.market":"orderEntry.orderType.limit"),Q=D?jsx(Badge,{color:"success",size:"xs",children:S("common.buy")}):jsx(Badge,{color:"danger",size:"xs",children:S("common.sell")}),ut=jsxs(Flex,{width:"100%",justify:"between",children:[jsx(Text.formatted,{rule:"symbol",showIcon:true,children:b.symbol}),jsxs(Flex,{gap:1,children:[jsx(Badge,{color:"neutral",size:"xs",children:E}),Q]})]}),_=jsxs(Flex,{width:"100%",justify:"between",children:[jsx(Text,{intensity:54,children:S("common.lastPrice")}),jsx(Text.numeral,{dp:r,suffix:jsxs(Text,{intensity:36,children:[" ",i]}),children:b.mark_price})]}),p=!g&&jsx(Fragment,{children:jsxs(Flex,{width:"100%",direction:"column",gap:2,children:[jsx(Input.tooltip,{prefix:S("common.price"),suffix:i,align:"right",fullWidth:true,autoComplete:"off",inputMode:"decimal",formatters:[inputFormatter.numberFormatter,inputFormatter.dpFormatter(r)],triggerClassName:"oui-w-full",tooltip:d,color:d?"danger":void 0,value:c,onValueChange:t.updatePriceChange,classNames:{prefix:"oui-text-base-contrast-54",suffix:"oui-text-base-contrast-54",root:cn$1("oui-w-full oui-outline-line-12",d?"oui-outline-danger":void 0)}}),jsx(Input.tooltip,{prefix:S("common.quantity"),suffix:e,align:"right",fullWidth:true,autoComplete:"off",inputMode:"decimal",formatters:[inputFormatter.numberFormatter,inputFormatter.dpFormatter(o)],triggerClassName:"oui-w-full",tooltip:f,color:f?"danger":void 0,value:u,onBlur:()=>t.formatQuantityToBaseTick(u),onValueChange:t.updateQuantity,classNames:{prefix:"oui-text-base-contrast-54",suffix:"oui-text-base-contrast-54",root:cn$1("oui-w-full oui-outline-line-12",f?"oui-outline-danger":void 0)}})]})}),$=jsx(xe,{value:t.sliderValue,onValueChange:t.onSliderValueChange,base_dp:o,max:v,onMax:t.onMax}),X=jsxs(Flex,{width:"100%",gap:3,mt:2,children:[jsx(Button,{fullWidth:true,color:"secondary",onClick:t.onCloseSheet,children:S("common.cancel")}),jsx(ThrottledButton,{fullWidth:true,disabled:m||y,loading:m,onClick:h=>{h.stopPropagation(),h.preventDefault(),t.onDoubleConfirm();},children:S("common.confirm")})]});return jsxs(Fragment,{children:[jsx(Button,{variant:"outlined",color:"secondary",size:"sm",className:"oui-border-base-contrast-36",onClick:h=>{h.stopPropagation(),h.preventDefault(),s(true);},children:M}),jsx(SimpleSheet,{title:M,open:n,onOpenChange:s,children:jsxs(Flex,{direction:"column",gap:3,width:"100%",itemAlign:"start",className:"oui-text-sm",children:[ut,jsx(Divider,{className:"oui-w-full"}),_,p,$,X]})}),jsx(SimpleDialog,{open:a,onOpenChange:l,size:"xs",children:g?jsx(Mt,{base:e,quantity:u,submitting:m,onClose:t.onCloseDialog,onConfirm:t.onConfirm,hideCloseIcon:true}):jsx(de,{base:e,quoteDp:r,quantity:u,price:c,submitting:m,order:t.closeOrderData,onClose:t.onCloseDialog,onConfirm:t.onConfirm,hideCloseIcon:true})})]})};var no=t=>{let{position:e,base:o,base_dp:i,quote_dp:r,price:n,quantity:s,submitting:a,dialogOpen:l,setDialogOpen:u,isMarketClose:c,popoverOpen:m,setPopoverOpen:d,maxQty:f,quantityErrorMsg:y,priceErrorMsg:g,isEntirePosition:b}=t,{t:v}=useTranslation(),D=jsxs(Flex,{width:"100%",gap:2,mb:1,children:[jsx(Input.tooltip,{ref:t.quantityInputRef,prefix:v("common.quantity"),suffix:b?jsx(Text,{size:"2xs",intensity:54,className:"oui-cursor-pointer oui-px-3",onClick:t.onEntirePosition,children:v("tpsl.entirePosition")}):o,align:"right",size:"md",fullWidth:true,autoComplete:"off",inputMode:"decimal",formatters:[inputFormatter.numberFormatter,inputFormatter.dpFormatter(i)],triggerClassName:"oui-w-full",tooltip:y,color:y?"danger":void 0,value:b?"":s,onBlur:()=>t.formatQuantityToBaseTick(s),onValueChange:t.updateQuantity,classNames:{prefix:"oui-text-base-contrast-54",suffix:"oui-text-base-contrast-54",root:cn$1("oui-w-full oui-outline-line-12",y?"oui-outline-danger":void 0)}}),jsx(Button,{onClick:t.onMax,size:"md",variant:"outlined",className:cn$1("oui-text-2xs",b?"oui-border-primary-light oui-text-primary-light hover:oui-bg-primary-light/20":"oui-border-line-12 oui-bg-base-6 oui-text-base-contrast-54 hover:oui-bg-base-5"),children:v("common.position")})]}),S=jsx(Select.options,{variant:"text",size:"md",options:[{label:v("orderEntry.orderType.limit"),value:OrderType.LIMIT},{label:v("orderEntry.orderType.market"),value:OrderType.MARKET}],classNames:{trigger:"oui-w-[--radix-select-content-available-width]"},value:t.type,onValueChange:Q=>{t.updateOrderType(Q);},contentProps:{align:"end",className:"oui-border oui-border-line-6"}}),M=c,E=jsx(Input.tooltip,{suffix:S,size:"md",fullWidth:true,autoComplete:"off",inputMode:"decimal",formatters:[inputFormatter.numberFormatter,inputFormatter.dpFormatter(r)],triggerClassName:"oui-w-full",tooltip:g,color:g?"danger":void 0,value:n,onValueChange:t.updatePriceChange,placeholder:M?"--":"",disabled:M,classNames:{prefix:"oui-text-base-contrast-54",suffix:"oui-text-base-contrast-54",root:cn$1("oui-w-full oui-outline-line-12",g?"oui-outline-danger":void 0,M?"focus-within:oui-outline-line-12":void 0)}});return jsxs(Fragment,{children:[jsxs(PopoverRoot,{open:m,onOpenChange:d,children:[jsx(PopoverTrigger,{asChild:true,onClick:()=>{d(true);},children:jsx(Button,{variant:"outlined",size:"sm",color:"secondary",children:v("positions.column.close")})}),jsx(PopoverContent,{className:cn$1("oui-w-[360px] oui-p-5",m?"oui-visible":"oui-invisible"),align:"end",side:"top",onOpenAutoFocus:Q=>Q.preventDefault(),children:jsxs(Flex,{gapY:2,direction:"column",children:[D,jsx(xe,{value:t.sliderValue,onValueChange:t.onSliderValueChange,base_dp:i,max:f,onMax:t.onMax}),jsx(Divider,{my:2,intensity:8,className:"oui-w-full"}),E,jsx(ce,{onConfirm:t.onDoubleConfirm,onCancel:t.onClosePopover,submitting:a,disabled:t.disabled})]})})]}),jsx(SimpleDialog,{open:l,onOpenChange:u,size:"sm",children:c?jsx(Mt,{base:o,quantity:s,submitting:a,onClose:t.onCloseDialog,onConfirm:t.onConfirm,classNames:{root:"oui-items-start"},hideCloseIcon:true}):jsx(de,{base:o,quoteDp:r,quantity:s,price:n,submitting:a,order:t.closeOrderData,onClose:t.onCloseDialog,onConfirm:t.onConfirm,hideCloseIcon:true})})]})};var ro=t=>{let[e,o]=useState(false),[i,r]=useState(false),[n,s]=useState(false),[a,l]=useState(100),u=useRef(null),[c]=useLocalStorage("orderly_order_confirm",true),{position:m,onSubmit:d,price:f,quantity:y,closeOrderData:g,submitting:b,updatePriceChange:v,updateOrderType:D,updateQuantity:S,errors:M,baseTick:E,type:Q}=et(),{quote_dp:ut,base_dp:_,base:p,quote:$}=V(),{getErrorMsg:X}=useOrderEntryFormErrorMsg(M),h=m.position_qty>0,z=Math.abs(m.position_qty),se=t.type||Q,ae=se===OrderType.MARKET,Be=z?.toString()===y.toString();useEffect(()=>{e&&D(t.type);},[t.type,e]);let{priceErrorMsg:Gt,quantityErrorMsg:le}=useMemo(()=>({priceErrorMsg:X("order_price"),quantityErrorMsg:X("order_quantity")}),[M]),ue=!!(Gt||le),Rt=useCallback(bt=>{if(E&&E>0){let Xt=utils.formatNumber(bt,E)??bt;S(Xt);}},[E,S]),We=useCallback(bt=>{l(bt);let Xt=new Decimal(bt).div(100).mul(z).toFixed(_,Decimal.ROUND_DOWN);Rt(Xt);},[z,_,Rt]);useEffect(()=>{let bt=Math.min(Number(y||0),z),Xt=new Decimal(bt).div(z).mul(100).toDecimalPlaces(2,Decimal.ROUND_DOWN).toNumber();l(Xt);},[y]);let On=useCallback(()=>{S(z?.toString());},[z,S]),Qe=useCallback(()=>d().then(bt=>{o(false),r(false),s(false);}),[d]),An=useCallback(()=>c?(r(true),Promise.resolve()):Qe(),[Qe,c]),kn=useCallback(()=>{o(false);},[]),En=useCallback(()=>{r(false);},[]),Hn=useCallback(()=>{s(false);},[]),zn=useCallback(()=>{S("0"),u.current?.focus(),setTimeout(()=>{u.current?.setSelectionRange(0,1);},0);},[S]);return {position:m,closeOrderData:g,quote_dp:ut,base_dp:_,base:p,quote:$,price:f,quantity:y,submitting:b,onConfirm:Qe,onDoubleConfirm:An,updatePriceChange:v,updateQuantity:S,formatQuantityToBaseTick:Rt,updateOrderType:D,sliderValue:a,onSliderValueChange:We,priceErrorMsg:Gt,quantityErrorMsg:le,disabled:ue,isMarketClose:ae,maxQty:z,onMax:On,isBuy:h,isEntirePosition:Be,type:se,quantityInputRef:u,onEntirePosition:zn,sheetOpen:e,onCloseSheet:kn,setSheetOpen:o,dialogOpen:i,setDialogOpen:r,onCloseDialog:En,popoverOpen:n,setPopoverOpen:s,onClosePopover:Hn}};var Et=t=>{let e=ro(t),{isMobile:o}=useScreen();return o?jsx(io,{...e}):jsx(no,{...e})};var Dt=()=>{let{position:t,baseDp:e,quoteDp:o,tpslOrder:i}=et(),{isMobile:r}=useScreen();return jsx(EditIcon,{onClick:()=>{let s=r?TPSLDetailSheetId:TPSLDetailDialogId;modal.show(s,{order:i,position:t,baseDP:e,quoteDP:o});},opacity:1,className:"oui-cursor-pointer oui-text-base-contrast-54",size:16})},dt=t=>{let{position:e,baseDp:o,quoteDp:i,tpslOrder:r}=et(),[n]=useLocalStorage("orderly_order_confirm",true),{t:s}=useTranslation(),{isMobile:a}=useScreen(),l=()=>{let u=a?TPSLSheetId:TPSLDialogId,c={symbol:e.symbol,baseDP:o,quoteDP:i,isEditing:false,positionType:t.positionType};modal.show(u,c);};return jsx(Text,{className:cn$1("oui-cursor-pointer oui-text-base-contrast",a&&"oui-text-base-contrast-80"),onClick:l,children:s("tpsl.add")})},ve=t=>{let{symbol:e,leverage:o}=t,i=()=>{modal.show(t.modalId,{symbol:e,curLeverage:o});};return jsxs("div",{className:cn$1("oui-flex oui-h-[18px] oui-items-center oui-gap-1","oui-cursor-pointer oui-rounded oui-bg-line-6 oui-pl-2 oui-pr-1","oui-text-2xs oui-font-semibold oui-text-base-contrast-36"),onClick:i,children:[jsx(Text,{children:"Cross"}),o?jsx(Text.numeral,{dp:0,rm:Decimal.ROUND_DOWN,size:"2xs",unit:"X",children:o}):jsx(Ls,{symbol:e}),jsx(ChevronRightIcon,{size:14,opacity:1,className:"oui-text-base-contrast-36"})]})},Ls=({symbol:t})=>{let e=useLeverageBySymbol(t);return jsx(Text.numeral,{dp:0,rm:Decimal.ROUND_DOWN,size:"2xs",unit:"X",children:e||1})};var yi=t=>{let e=V();return jsx(Text.numeral,{dp:e.base_dp,rm:Decimal.ROUND_DOWN,padding:false,coloring:true,children:t})};var Fe=t=>{let{tick:e="quote_dp",children:o,...i}=t,r=V();if(!r)throw new Error("NumeralWithCtx must be used inside SymbolProvider");return jsx(Text.numeral,{as:"span",dp:r[e],...i,children:o})};var xi=t=>{let{orderNum:e,tpTriggerPrice:o,slTriggerPrice:i,direction:r="column"}=t,{partialTPSLOrder:n,quoteDp:s,baseDp:a}=et(),l=useSymbolsInfo(),{t:u}=useTranslation(),c=useMemo(()=>{let d=[];return n?.symbol?(o&&d.push(jsx(Text.formatted,{className:cn$1("oui-text-trade-profit oui-gap-0 oui-decoration-white/20"),rule:"price",dp:l[n.symbol]("quote_dp",2),children:o,prefix:!i||r==="column"?jsx(Text,{intensity:54,children:`${u("tpsl.tp")} - `}):""},"tp")),i&&d.push(jsx(Text.formatted,{className:cn$1("oui-text-trade-loss oui-gap-0 oui-decoration-white/20 "),rule:"price",dp:l[n.symbol]("quote_dp",2),prefix:jsx(Text,{intensity:54,children:`${u("tpsl.sl")} - `}),children:i},"sl")),d.length===0?jsx(dt,{positionType:PositionType.PARTIAL}):(d.length===2&&r==="row"&&d.splice(1,0,jsx(Text,{children:"/"},"split")),d)):jsx(dt,{positionType:PositionType.PARTIAL})},[o,i,n?.symbol,u]),m=Array.isArray(c)?!!c.length:!c;return jsxs(Flex,{className:"oui-gap-[6px]",children:[jsx("div",{className:cn$1("oui-inline-flex oui-text-base-contrast-36",r==="column"?"oui-flex-col":"oui-flex-row oui-gap-1"),children:c}),m&&jsxs(Fragment,{children:[jsxs(Text,{className:"oui-text-base-contrast-54",children:["(",e,")"]}),jsx(Dt,{})]})]})};var uo=t=>t.sharePnLConfig?jsx("button",{type:"button",onClick:e=>{e.stopPropagation(),t.showModal();},children:jsx(ShareIcon,{color:"white",opacity:.54,size:t.iconSize??16})}):null;var Si=t=>{let{position:e,sharePnLConfig:o,iconSize:i}=t,{getFirstRefCode:r}=useReferralInfo(),n=useSymbolsInfo(),{data:s}=useAccountInfo(),a=useMemo(()=>r()?.code,[r]),l=useLeverageBySymbol(e.symbol),u=()=>{let m=e.netPnL||0,d=Math.abs(e.avg_open_price),f=Math.abs(e.closed_position_qty),y,g=n[e.symbol],b=g("base_imr"),v=g("imr_factor");if(m!==0&&f!==0&&d!==0&&s?.max_leverage&&b&&v){let D=positions.notional(f,d),S=e.leverage?e.leverage:s.max_leverage,M=account.IMR({maxLeverage:S,baseIMR:b,IMR_Factor:v,positionNotional:D,ordersNotional:0,IMR_factor_power:4/5}),E=positions.unrealizedPnLROI({positionQty:f,openPrice:d,IMR:M,unrealizedPnL:m});y=new Decimal(E*100).toFixed(2,Decimal.ROUND_DOWN);}return {side:e.side,pnl:m,roi:y,openPrice:d,closePrice:Math.abs(e.avg_close_price),openTime:e.open_timestamp,closeTime:e.close_timestamp,quantity:e.closed_position_qty}};return {iconSize:i,sharePnLConfig:o,showModal:()=>{let m=t.isPositionHistory?u():{side:e.position_qty>0?"LONG":"SHORT",pnl:e.unrealized_pnl,roi:new Decimal(e.unrealized_pnl_ROI*100).toFixed(2,Decimal.ROUND_DOWN),openPrice:Math.abs(e.average_open_price),markPrice:e.mark_price,openTime:e.timestamp,quantity:e.position_qty};modal.show(t.modalId,{pnl:{entity:{symbol:e.symbol,leverage:e.leverage||l,...m},refCode:a,...o}});}}};var ft=t=>{let e=Si(t);return jsx(uo,{...e})};var wi=t=>{let{stopLossPrice:e,takeProfitPrice:o}=t,{tpslOrder:i,position:r}=et();return jsx(oa,{stopLossPrice:e,takeProfitPrice:o,direction:"column",order:i,position:r,tooltip:true})},hi=t=>{let{qty:e,price:o,entryPrice:i,orderSide:r,orderType:n,symbolInfo:s}=t,a=utils.priceToPnl({qty:e,price:o,entryPrice:i,orderSide:r,orderType:n},{symbol:s}),l=n===AlgoOrderType.TAKE_PROFIT?"TP":"SL";return jsxs(Flex,{children:[jsx(Text,{intensity:54,className:"oui-mr-1",children:`${l} PnL:`}),jsx(Text.formatted,{rule:"price",className:a===0?"oui-text-base-contrast-36":a>0?"oui-text-trade-profit oui-gap-0":"oui-text-trade-loss oui-gap-0",prefix:jsx(Text,{children:a===0?"":a>0?"+":"-"}),suffix:jsx(Text,{intensity:36,className:"oui-ml-1",children:"USDC"}),children:`${Math.abs(a)}`})]})},oa=t=>{let{direction:e="row",order:o,position:i}=t,r=useSymbolsInfo(),{t:n}=useTranslation(),s=useMemo(()=>{let c=[];if(!t.tooltip||!o||!i)return;let m=o.quantity;return m===0&&o.child_orders[0].type==="CLOSE_POSITION"&&(m=i.position_qty),t.takeProfitPrice&&c.push(jsx(hi,{qty:m,price:t.takeProfitPrice,entryPrice:i.average_open_price,orderSide:o.side,orderType:AlgoOrderType.TAKE_PROFIT,symbolInfo:r[o.symbol]()},"tp")),t.stopLossPrice&&c.push(jsx(hi,{qty:m,price:t.stopLossPrice,entryPrice:i.average_open_price,orderSide:o.side,orderType:AlgoOrderType.STOP_LOSS,symbolInfo:r[o.symbol]()},"sl")),jsx("div",{children:c})},[t.takeProfitPrice,t.stopLossPrice,i?.average_open_price,o?.side,o?.quantity,o?.algo_type]),a=useMemo(()=>{let c=[];if(!o?.symbol)return jsx(dt,{positionType:PositionType.FULL});return t.takeProfitPrice&&c.push(jsx(Text.formatted,{className:cn$1("oui-text-trade-profit oui-gap-0 oui-decoration-white/20"),rule:"price",dp:r[o.symbol]("quote_dp",2),children:t.takeProfitPrice,prefix:!t.stopLossPrice||e==="column"?jsx(Text,{intensity:54,children:`${n("tpsl.tp")} - `}):""},"tp")),t.stopLossPrice&&c.push(jsx(Text.formatted,{className:cn$1("oui-text-trade-loss oui-gap-0 oui-decoration-white/20 "),rule:"price",dp:r[o.symbol]("quote_dp",2),children:t.stopLossPrice,prefix:!t.takeProfitPrice||e==="column"?jsx(Text,{intensity:54,children:`${n("tpsl.sl")} - `}):""},"sl")),c.length===0?jsx(dt,{positionType:PositionType.FULL}):(c.length===2&&e==="row"&&c.splice(1,0,jsx(Text,{children:"/"},"split")),c)},[t.takeProfitPrice,t.stopLossPrice,o?.symbol,n]),l=jsx("div",{className:cn$1("oui-inline-flex oui-text-base-contrast-36",t.direction==="column"?"oui-flex-col":"oui-flex-row oui-gap-1",t.className),children:a}),u=Array.isArray(a)?!!a.length:!a;return t.tooltip?jsxs(Flex,{gapX:2,children:[jsx(Tooltip,{content:s,children:l}),u&&jsx(Dt,{})]}):l};var Di=t=>{let[e,o]=useLocalStorage("unPnlPriceBasis","markPrice"),{t:i}=useTranslation();return jsxs(Flex,{direction:"column",gap:3,className:"oui-text-base-contrast-54 oui-items-start",children:[jsx(Text,{children:i("positions.column.unrealPnl.tooltip")}),jsx(Divider,{className:"oui-w-full"}),jsx("div",{className:"oui-mb-0",children:i("positions.column.unrealPnl.priceBasis")}),jsx(ra,{value:e,onValueChange:o})]})},ra=t=>{let{value:e,onValueChange:o}=t,{t:i}=useTranslation();return jsxs(Flex,{gap:2,children:[jsx(Fi,{sel:e==="markPrice",label:i("common.markPrice"),value:"markPrice",onCheckChange:o}),jsx(Fi,{sel:e==="lastPrice",label:i("common.lastPrice"),value:"lastPrice",onCheckChange:o})]})},Fi=t=>{let{sel:e,label:o,value:i,onCheckChange:r}=t;return jsxs(Flex,{onClick:n=>{r(i),n.stopPropagation();},gap:1,className:"oui-cursor-pointer",children:[e?jsx(sa,{}):jsx(aa,{}),jsx(Text,{size:"xs",intensity:e?98:54,children:o})]})},sa=()=>jsxs("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"currentColor",xmlns:"http://www.w3.org/2000/svg",className:"oui-fill-white",children:[jsx("path",{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",fill:"#fff",fillOpacity:".36"}),jsx("circle",{cx:"8",cy:"8",r:"3.333"})]}),aa=()=>jsx("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:jsx("path",{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",fill:"#fff",fillOpacity:".54"})});var fo=t=>{let{pnlNotionalDecimalPrecision:e,sharePnLConfig:o,onSymbolChange:i}=t,{t:r}=useTranslation(),n=useRef(Date.now().toString());return useMemo(()=>[{title:r("common.symbol"),dataIndex:"symbol",fixed:"left",width:140,onSort:(a,l)=>a.symbol?.localeCompare(l.symbol||""),render:(a,l)=>jsxs(Flex,{gap:2,children:[jsx(Box,{width:4,height:20,className:cn$1("oui-h-[38px] oui-rounded-[1px]",l.position_qty>0?"oui-bg-trade-profit":"oui-bg-trade-loss")}),jsxs(Flex,{direction:"column",itemAlign:"start",children:[jsx(Text.formatted,{formatString:"base-type",className:"oui-cursor-pointer",onClick:u=>{i?.({symbol:a}),u.stopPropagation(),u.preventDefault();},children:`${a.split("_")[1]}-PERP`}),jsx(ve,{symbol:a,leverage:l.leverage,modalId:SymbolLeverageDialogId})]})]})},{title:r("common.quantity"),dataIndex:"position_qty",onSort:(a,l)=>a.position_qty-l.position_qty,width:120,className:"oui-pl-6",render:yi},{title:r("common.avgOpen"),className:"oui-h-[48px]",width:120,onSort:true,dataIndex:"average_open_price",render:a=>jsx(Fe,{rm:Decimal.ROUND_DOWN,children:a})},{title:r("common.markPrice"),dataIndex:"mark_price",width:120,onSort:true,className:"oui-h-[48px]",render:a=>jsx(Fe,{rm:Decimal.ROUND_DOWN,children:a})},{title:jsx(Tooltip,{className:"oui-max-w-[280px] oui-bg-base-8 oui-p-3 oui-text-2xs oui-text-base-contrast-54",content:r("positions.column.liqPrice.tooltip"),children:jsx(Text,{children:r("positions.column.liqPrice")})}),plantTextTitle:r("positions.column.liqPrice"),width:100,onSort:true,dataIndex:"est_liq_price",render:a=>Number(a)===0?"--":jsx(Fe,{rm:Decimal.ROUND_DOWN,className:Number(a)>0?"oui-text-warning-light":"",children:a??"--"})},{title:jsx(HoverCard,{content:jsx(Di,{}),side:"top",align:"center",className:"oui-max-w-[280px] oui-text-2xs",children:jsx(Text,{children:r("common.unrealizedPnl")})}),plantTextTitle:r("common.unrealizedPnl"),dataIndex:"unrealized_pnl",width:180,onSort:true,rule:"price",numeralProps:{coloring:true},render:(a,l)=>jsxs(Flex,{gap:2,children:[jsxs(Flex,{children:[jsx(Text.numeral,{dp:e,rm:Decimal.ROUND_DOWN,coloring:true,className:"oui-font-semibold",children:a}),jsx(Text.numeral,{rule:"percentages",dp:e,rm:Decimal.ROUND_DOWN,coloring:true,className:"oui-font-semibold",prefix:"(",suffix:")",children:l.unrealized_pnl_ROI})]}),jsx(ft,{position:l,sharePnLConfig:o,modalId:SharePnLDialogId})]})},{title:r("common.fullTPSL"),dataIndex:"full_tpsl",width:150,render:(a,l)=>jsx(wi,{stopLossPrice:l.full_tp_sl?.sl_trigger_price,takeProfitPrice:l.full_tp_sl?.tp_trigger_price})},{title:r("common.partialTPSL"),dataIndex:"partial_tpsl",width:150,render:(a,l)=>jsx(xi,{orderNum:l.partial_tp_sl?.order_num,tpTriggerPrice:l.partial_tp_sl?.tp_trigger_price,slTriggerPrice:l.partial_tp_sl?.sl_trigger_price})},{title:r("common.notional"),dataIndex:"notional",className:"oui-h-[48px]",width:100,onSort:true,render:a=>jsx(Text.numeral,{dp:e,children:a})},{title:jsx(Tooltip,{className:"oui-max-w-[280px] oui-bg-base-8 oui-p-3 oui-text-2xs oui-text-base-contrast-54",content:jsxs(Flex,{direction:"column",gap:3,className:"oui-rounded-sm oui-bg-base-8 oui-text-base-contrast-54",children:[jsx("span",{children:r("positions.column.margin.tooltip")}),jsx(Divider,{className:"oui-w-full"}),jsx("span",{children:r("positions.column.margin.formula")})]}),children:jsx(Text,{children:r("positions.column.margin")})}),plantTextTitle:r("positions.column.margin"),dataIndex:"mm",onSort:true,width:100,rule:"price",render:a=>jsx(Text.numeral,{children:a})},{title:r("funding.fundingFee"),dataIndex:"fundingFee",width:100,render:(a,l)=>jsx(mt,{fee:a,symbol:l.symbol,start_t:l.timestamp.toString(),end_t:n.current})},{title:null,dataIndex:"close_position",align:"right",width:70,fixed:"right",render(){return jsx(Flex,{gapX:2,justify:"end",children:jsx(Et,{})})}}],[e,o,r])};var Mi=t=>{let{item:e}=t,o=e.position_qty>0,{t:i}=useTranslation();return jsx(Text.formatted,{rule:"symbol",formatString:"base-type",size:"2xs",suffix:jsxs("div",{className:"oui-flex oui-items-center oui-gap-1",children:[jsx(Badge,{color:o?"success":"danger",size:"xs",children:i(o?"common.long":"common.short")}),jsx(ve,{symbol:e.symbol,leverage:e.leverage,modalId:SymbolLeverageSheetId})]}),showIcon:true,onClick:()=>{t.onSymbolChange?.({symbol:e.symbol});},children:e.symbol})},Oi=t=>{let{item:e}=t,{t:o}=useTranslation();return jsxs(Flex,{gap:3,children:[jsxs(Flex,{direction:"column",className:"oui-text-2xs",itemAlign:"end",children:[jsxs("div",{children:[jsx(Text,{intensity:36,children:o("common.unrealizedPnl")}),jsx(Text,{intensity:20,children:"(USDC)"})]}),jsx(Text.numeral,{size:"xs",dp:t.pnlNotionalDecimalPrecision,rm:Decimal.ROUND_DOWN,coloring:true,className:"orderly-font-semibold",suffix:jsx(Text.numeral,{rule:"percentages",dp:t.pnlNotionalDecimalPrecision,rm:Decimal.ROUND_DOWN,prefix:"(",suffix:")",className:cn$1("oui-ml-1",e.unrealized_pnl_ROI>0?"oui-text-success-darken":"oui-text-danger-darken"),children:e.unrealized_pnl_ROI}),children:e.unrealized_pnl})]}),jsx(ft,{position:e,sharePnLConfig:t.sharePnLConfig,modalId:SharePnLBottomSheetId,iconSize:12})]})},Ai=t=>{let{item:e}=t,{t:o}=useTranslation();return jsx(Statistic,{label:o("common.qty"),classNames:{root:"oui-text-xs",label:"oui-text-2xs"},children:jsx(Text.numeral,{dp:t.base_dp,padding:false,coloring:true,children:e.position_qty})})},ki=t=>{let{item:e}=t,{t:o}=useTranslation();return jsx(Statistic,{label:jsxs("span",{children:[o("positions.column.margin"),jsx(Text,{intensity:20,children:"(USDC)"})]}),classNames:{root:"oui-text-xs",label:"oui-text-2xs"},children:jsx(Text.numeral,{dp:t.quote_dp,intensity:80,children:e.mm})})},Ei=t=>{let{item:e}=t,{t:o}=useTranslation();return jsx(Statistic,{align:"end",label:jsxs("span",{children:[o("common.notional"),jsx(Text,{intensity:20,children:"(USDC)"})]}),classNames:{root:"oui-text-xs",label:"oui-text-2xs"},children:jsx(Text.numeral,{dp:t.quote_dp,intensity:80,children:e.notional})})},Hi=t=>{let{item:e}=t,{t:o}=useTranslation();return jsx(Statistic,{label:o("common.avgOpen"),classNames:{root:"oui-text-xs",label:"oui-text-2xs"},children:jsx(Text.numeral,{dp:t.quote_dp,rm:Decimal.ROUND_DOWN,intensity:80,children:e.average_open_price})})},zi=t=>{let{item:e}=t,{t:o}=useTranslation();return jsx(Statistic,{label:o("common.markPrice"),classNames:{root:"oui-text-xs",label:"oui-text-2xs"},children:jsx(Text.numeral,{dp:t.quote_dp,rm:Decimal.ROUND_DOWN,intensity:80,children:e.mark_price})})},Bi=t=>{let{item:e}=t,{t:o}=useTranslation(),i=e.est_liq_price&&e.est_liq_price>0?e.est_liq_price:"-";return jsx(Statistic,{label:o("positions.column.liqPrice"),align:"end",classNames:{root:"oui-text-xs",label:"oui-text-2xs"},children:jsx(Text.numeral,{dp:t.quote_dp,rm:Decimal.ROUND_DOWN,color:"warning",children:i})})},Wi=t=>{let{item:e}=t,{t:o}=useTranslation(),i=useMemo(()=>e.full_tp_sl?.tp_trigger_price==null&&e.full_tp_sl?.sl_trigger_price==null?jsx(dt,{positionType:PositionType.FULL}):jsxs(Flex,{className:"oui-gap-[2px]",children:[e.full_tp_sl?.tp_trigger_price&&jsx(Text.numeral,{color:"buy",children:e.full_tp_sl.tp_trigger_price}),e.full_tp_sl?.sl_trigger_price&&"/",e.full_tp_sl?.sl_trigger_price&&jsx(Text.numeral,{color:"sell",children:e.full_tp_sl.sl_trigger_price}),jsx(Dt,{})]}),[e.full_tp_sl]),r=useMemo(()=>e.partial_tp_sl?.tp_trigger_price==null&&e.partial_tp_sl?.sl_trigger_price==null?jsx(dt,{positionType:PositionType.PARTIAL}):jsxs(Flex,{className:"oui-gap-[2px]",itemAlign:"center",children:[e.partial_tp_sl?.tp_trigger_price&&jsx(Text.numeral,{color:"buy",children:e.partial_tp_sl.tp_trigger_price}),e.partial_tp_sl?.sl_trigger_price&&"/",e.partial_tp_sl?.sl_trigger_price&&jsx(Text.numeral,{color:"sell",children:e.partial_tp_sl.sl_trigger_price}),jsx(Text,{children:`(${e.partial_tp_sl?.order_num})`}),jsx(Dt,{})]}),[e.partial_tp_sl]);return jsxs(Grid,{cols:2,rows:1,gap:2,width:"100%",children:[jsxs(Flex,{className:"oui-text-2xs oui-text-base-contrast-36",direction:"column",itemAlign:"start",children:[jsxs(Text,{children:[o("common.fullTPSL"),": "]}),i]}),jsxs(Flex,{className:"oui-text-2xs oui-text-base-contrast-36 oui-grid-cols-end",direction:"column",itemAlign:"end",children:[jsxs(Text,{children:[o("common.partialTPSL"),": "]}),r]})]})},Qi=t=>{let{t:e}=useTranslation(),o=useRef(Date.now().toString());return jsxs(Flex,{justify:"end",className:"oui-w-full oui-text-2xs",children:[jsxs(Text,{intensity:36,children:[e("funding.fundingFee"),": "]}),jsx(mt,{fee:t.item.fundingFee,symbol:t.item.symbol,start_t:t.item.timestamp.toString(),end_t:o.current})]})};var yo=t=>{let{className:e,...o}=t,i=jsxs(Flex,{justify:"between",width:"100%",children:[jsx(Mi,{...t}),jsx(Oi,{...t})]}),r=jsxs(Grid,{cols:3,rows:2,gap:2,width:"100%",children:[jsx(Ai,{...t}),jsx(ki,{...t}),jsx(Ei,{...t}),jsx(Hi,{...t}),jsx(zi,{...t}),jsx(Bi,{...t})]}),n=jsxs(Grid,{width:"100%",gap:2,cols:2,rows:1,children:[jsx(Et,{type:OrderType.LIMIT}),jsx(Et,{type:OrderType.MARKET})]});return jsxs(Flex,{direction:"column",width:"100%",gap:2,p:2,r:"xl",itemAlign:"start",className:cn$1(e,"oui-bg-base-9"),children:[i,jsx(Divider,{intensity:6,className:"oui-w-full"}),r,jsx(Wi,{...o}),jsx(Qi,{...o}),n]})};var go=t=>{let e=V();return {...t,...e}};var xo=t=>{let e=go(t);return jsx(yo,{...e,className:t.className})};var qe=t=>{let{position:e,children:o,mutatePositions:i}=t,{t:r}=useTranslation(),[n,s]=useState(Math.abs(e.position_qty).toString()),[a,l]=useState(""),[u,c]=useState(OrderType.MARKET);useEffect(()=>{s(Math.abs(e.position_qty).toString());},[e.position_qty]);let m=e.symbol,d=useSymbolsInfo(),f=d?.[m],y=f("quote_dp"),g=f("base_dp"),b=f("base_tick"),{side:v,closeOrderData:D,submit:S,isMutating:M,errors:E,calculate:Q}=usePositionClose({position:e,order:{type:u,quantity:n,price:a}}),ut=useCallback(h=>{let z=Q({},"order_quantity",h,e.mark_price,f());s(z.order_quantity);},[Q,d,e.mark_price]),_=useCallback(h=>{let z=Q({},"order_price",h,e.mark_price,f());l(z.order_price);},[Q,d,e.mark_price]),p=useCallback(h=>{c(h),l(h===OrderType.LIMIT?e.mark_price?.toString():"");},[e.mark_price]),$=useCallback(async()=>{if(Number(n)>f("base_max")){toast.error(jsxs("div",{children:[r("positions.limitClose.errors.exceed.title"),jsx("br",{}),jsx("div",{className:"oui-break-normal",children:r("positions.limitClose.errors.exceed.description",{quantity:n,symbol:La(m,"base"),maxQuantity:f("base_max")})})]}));return}return S().then(h=>{if(h.success)return i?.(),h;throw h.message&&toast.error(h.message),true}).catch(h=>(h.message&&toast.error(h.message),false))},[S]),X=useMemo(()=>({quantity:n,price:a,type:u,side:v,position:e,updatePriceChange:_,updateQuantity:ut,updateOrderType:p,tpslOrder:e.full_tp_sl?.algo_order,partialTPSLOrder:e.partial_tp_sl?.algo_order,onSubmit:$,submitting:M,closeOrderData:D,quoteDp:y,baseDp:g,baseTick:b,errors:E}),[n,a,u,v,e,_,ut,p,$,M,D,y,g,b,E]);return jsx($e.Provider,{value:X,children:o})};function La(t,e="base"){let o=t.split("_"),i=o[0],r=o[1],n=o[2];return (e??"base-quote").replace("type",i).replace("base",r).replace("quote",n)}var Zi=t=>{let{pnlNotionalDecimalPrecision:e,sharePnLConfig:o,pagination:i,isLoading:r,dataSource:n,onSymbolChange:s,tableRef:a}=t,l=fo({pnlNotionalDecimalPrecision:e,sharePnLConfig:o,onSymbolChange:s});return jsx(Flex,{direction:"column",width:"100%",height:"100%",gap:3,children:jsx(AuthGuardDataTable,{loading:r,id:"oui-desktop-positions-content",columns:l,bordered:true,dataSource:n,generatedRowKey:u=>u.symbol,renderRowContainer:(u,c,m)=>jsx(Nt,{symbol:u.symbol,children:jsx(qe,{position:u,children:m})}),manualPagination:false,pagination:i,manualSorting:true,onSort:t.onSort,initialSort:t.initialSort?{sortKey:t.initialSort.sortKey,sort:t.initialSort.sortOrder}:void 0,features:[TableFeatures.DownloadFeature],getTableInstance:u=>{a&&(a.current=u);},testIds:{body:"oui-testid-dataList-position-tab-body"}})})},Ji=t=>{let{pnlNotionalDecimalPrecision:e,sharePnLConfig:o,dataSource:i,onSymbolChange:r}=t;return jsx(ListView,{className:"oui-hide-scrollbar oui-w-full oui-space-y-0 oui-overflow-y-hidden",contentClassName:"!oui-space-y-1",dataSource:i,renderItem:(n,s)=>jsx(Nt,{symbol:n.symbol,children:jsx(qe,{position:n,children:jsx(xo,{item:n,index:s,pnlNotionalDecimalPrecision:e,sharePnLConfig:o,onSymbolChange:r})})})})},ji=t=>{let{pnlNotionalDecimalPrecision:e,sharePnLConfig:o,pagination:i,isLoading:r,tableData:n,onSymbolChange:s,mutatePositions:a,tableRef:l}=t,u=fo({pnlNotionalDecimalPrecision:e,sharePnLConfig:o,onSymbolChange:s}),{dataSource:c=[]}=n;return jsx(Flex,{direction:"column",width:"100%",height:"100%",gap:3,children:jsx(AuthGuardDataTable,{bordered:true,loading:r,id:"oui-desktop-positions-content",columns:u,dataSource:c,expanded:true,getSubRows:m=>m.children,generatedRowKey:m=>m.id,onCell:(m,d)=>{if((d.children??[]).length>0)return {children:m.id==="symbol"?jsx(Badge,{color:"neutral",size:"xs",children:d?.description||formatAddress(d?.id)}):null}},renderRowContainer:(m,d,f)=>m.symbol?jsx(Nt,{symbol:m.symbol,children:jsx(qe,{position:m,mutatePositions:a,children:f})}):f,manualPagination:false,pagination:i,features:[TableFeatures.DownloadFeature],getTableInstance:m=>{l&&(l.current=m);},testIds:{body:"oui-testid-dataList-position-tab-body"}})})};var en=forwardRef((t,e)=>{let o=Je(t),i=_t.useRef(null);return _t.useImperativeHandle(e,()=>({download:()=>{let r=`positions_${new Date().getTime()}`;i.current?.download(r);},getRowCount:()=>i.current?.getRowCount?.()??0}),[]),jsx(Zi,{...o,tableRef:i})});en.displayName="PositionsWidget";var on=_t.forwardRef((t,e)=>{let o=Je(t),i=_t.useRef(o.dataSource);return _t.useEffect(()=>{i.current=o.dataSource;},[o.dataSource]),_t.useImperativeHandle(e,()=>({download:()=>{},getRowCount:()=>i.current?.length??0,get dataSource(){return i.current}}),[o.dataSource]),jsx(Ji,{...o})});on.displayName="MobilePositionsWidget";var nn=forwardRef((t,e)=>{let o=Jo(t),i=_t.useRef(null);return _t.useImperativeHandle(e,()=>({download:()=>{let r=`positions_${new Date().getTime()}`;i.current?.download(r);},getRowCount:()=>i.current?.getRowCount?.()??0})),jsx(ji,{...o,tableRef:i})});nn.displayName="CombinePositionsWidget";var an=t=>{let{onSymbolChange:e,pnlNotionalDecimalPrecision:o}=t,{t:i}=useTranslation();return useMemo(()=>[{title:i("common.symbol"),dataIndex:"symbol",fixed:"left",width:200,onSort:(n,s)=>n.symbol?.localeCompare(s.symbol||""),render:(n,s)=>jsx(Ba,{record:s,onSymbolChange:e})},{title:i("positions.history.column.closed&maxClosed"),plantTextTitle:"Closed Position Qty",dataIndex:"close_maxClose",width:200,renderPlantText:(n,s)=>Math.abs(s.closed_position_qty)??"--",render:(n,s)=>jsx(Wa,{record:s})},{title:i("positions.history.column.maxClosed"),plantTextTitle:"Max Position Qty",dataIndex:"max_position_qty",hidden:true,renderPlantText:(n,s)=>Math.abs(s.max_position_qty)??"--",render:()=>null},{title:i("positions.history.column.netPnl"),dataIndex:"netPnL",width:140,onSort:(n,s)=>n.netPnL==null||s.netPnL==null?-1:(n.netPnL??0)-(s.netPnL??0),render:(n,s)=>jsxs(Flex,{gapX:1,children:[jsx(Qa,{record:s,pnlNotionalDecimalPrecision:o}),jsx(ft,{position:s,sharePnLConfig:t.sharePnLConfig,modalId:SharePnLDialogId,isPositionHistory:true})]})},{title:i("common.avgPrice"),dataIndex:"avg_open",width:140,renderPlantText:(n,s)=>s.avg_open_price!=null?Math.abs(s.avg_open_price):"--",render:(n,s)=>{let a=s.avg_open_price!=null?Math.abs(s.avg_open_price):"--",{quote_dp:l}=V();return jsx(Text.numeral,{dp:l,padding:false,children:a})}},{title:i("common.avgClose"),dataIndex:"avg_close",width:175,renderPlantText:(n,s)=>s.avg_close_price!=null?Math.abs(s.avg_close_price):"--",render:(n,s)=>{let a=s.avg_close_price!=null?Math.abs(s.avg_close_price):"--",{quote_dp:l}=V();return jsx(Text.numeral,{dp:l,padding:false,children:a})}},{title:i("funding.fundingFee"),dataIndex:"accumulated_funding_fee",render:(n,s)=>jsx(mt,{fee:-n,symbol:s.symbol,start_t:s.open_timestamp.toString(),end_t:s.close_timestamp?.toString()})},{title:i("positions.history.column.timeOpened"),plantTextTitle:"Time Opened",dataIndex:"open_timestamp",width:175,onSort:true,renderPlantText:n=>{if(!n)return "--";let s=Number(n),a=new Date(s>1e10?s:s*1e3);return a.toISOString().split("T")[0]+" "+a.toTimeString().slice(0,8)},render:(n,s)=>jsx(Text.formatted,{rule:"date",formatString:"yyyy-MM-dd HH:mm:ss",children:s.open_timestamp})},{title:i("positions.history.column.timeClosed"),plantTextTitle:"Time Closed",dataIndex:"close_timestamp",width:175,onSort:true,renderPlantText:n=>{if(!n)return "--";let s=Number(n),a=new Date(s>1e10?s:s*1e3);return a.toISOString().split("T")[0]+" "+a.toTimeString().slice(0,8)},render:(n,s)=>s.position_status=="closed"&&s.close_timestamp?jsx(Text.formatted,{rule:"date",formatString:"yyyy-MM-dd HH:mm:ss",children:s.close_timestamp??"--"}):"--"},{title:i("positions.history.column.updatedTime"),plantTextTitle:"Updated Time",dataIndex:"last_update_time",width:175,onSort:true,renderPlantText:n=>{if(!n)return "--";let s=Number(n),a=new Date(s>1e10?s:s*1e3);return a.toISOString().split("T")[0]+" "+a.toTimeString().slice(0,8)},render:(n,s)=>jsx(Text.formatted,{rule:"date",formatString:"yyyy-MM-dd HH:mm:ss",children:s.last_update_time})}],[o,i])},Ba=t=>{let{record:e,onSymbolChange:o}=t,{t:i}=useTranslation(),r=useMemo(()=>{let n=[],s=e.position_status,a=()=>s==="closed"?i("positions.history.status.closed"):s==="partial_closed"?i("positions.history.status.partialClosed"):capitalizeFirstLetter(s.replace("_"," "));return n.push(jsx(Badge,{color:s!=="closed"?"primaryLight":"neutral",size:"xs",className:"oui-whitespace-nowrap oui-break-normal",children:a()},`status-${s}`)),e.type==="adl"?n.push(jsx(Badge,{color:"danger",size:"xs",children:i("positions.history.type.adl")},`type-${e.type}`)):e.type==="liquidated"&&n.push(jsx(Tooltip,{className:"oui-min-w-[204px] oui-bg-base-5",arrow:{className:"oui-fill-base-5"},content:jsxs(Flex,{direction:"column",itemAlign:"start",className:"oui-text-2xs",children:[e.liquidation_id!=null&&jsxs(Flex,{justify:"between",width:"100%",gap:2,children:[jsx(Text,{intensity:54,children:i("positions.history.liquidated.liquidationId")}),jsx(Text,{intensity:98,children:e.liquidation_id})]}),jsxs(Flex,{justify:"between",width:"100%",gap:2,children:[jsx(Text,{intensity:54,children:i("positions.history.liquidated.liquidatorFee")}),jsxs(Text,{color:"lose",children:[e.liquidator_fee>0&&"-",commifyOptional(e.liquidator_fee)]})]}),jsxs(Flex,{justify:"between",width:"100%",gap:2,children:[jsx(Text,{intensity:54,children:i("positions.history.liquidated.insFundFee")}),jsxs(Text,{color:"lose",children:[e.insurance_fund_fee>0&&"-",commifyOptional(e.insurance_fund_fee)]})]})]}),children:jsx("div",{children:jsx(Badge,{size:"xs",color:"danger",className:"oui-cursor-pointer",children:jsx("span",{className:"oui-underline oui-decoration-dashed oui-decoration-1",children:i("positions.history.type.liquidated")})})})},`type-${e.type}`)),n.push(jsx(Ua,{symbol:e.symbol,leverage:e.leverage},`leverage-${e.symbol}`)),n},[e,i]);return jsxs(Flex,{gap:2,height:48,children:[jsx(Box,{width:4,height:38,className:cn$1("oui-shrink-0 oui-rounded-[1px]",e.side==="LONG"?"oui-bg-trade-profit":"oui-bg-trade-loss")}),jsxs(Flex,{direction:"column",itemAlign:"start",children:[jsx(Text.formatted,{formatString:"base-type",className:"oui-cursor-pointer",onClick:n=>{o?.({symbol:e.symbol}),n.stopPropagation(),n.preventDefault();},children:`${e.symbol.split("_")[1]}-PERP`}),jsx(Flex,{gap:1,children:r})]})]})},Wa=t=>{let{record:e}=t,{base_dp:o}=V();return jsxs(Flex,{gap:1,direction:"column",itemAlign:"start",className:"oui-truncate",children:[jsx(Text.numeral,{dp:o,padding:false,children:Math.abs(e.closed_position_qty)}),jsx(Text.numeral,{dp:o,padding:false,className:"oui-truncate",children:Math.abs(e.max_position_qty)})]})},Qa=t=>{let{record:e,pnlNotionalDecimalPrecision:o}=t,{t:i}=useTranslation(),r=e.netPnL!=null?e.netPnL:void 0,n=()=>jsx(Text.numeral,{dp:o,color:e.netPnL!=null?e.netPnL>0?"profit":"lose":void 0,className:r==null?"":"oui-cursor-pointer oui-border-b oui-border-dashed oui-border-line-12",children:r??"--"});return e.netPnL==null?n():jsx(Tooltip,{delayDuration:200,content:jsxs(Flex,{direction:"column",itemAlign:"start",className:"oui-text-2xs",children:[jsx(Text,{intensity:80,children:i("positions.history.column.netPnl")}),jsxs(Flex,{justify:"between",width:"100%",gap:2,children:[jsx(Text,{intensity:54,children:i("common.realizedPnl")}),jsx(Text,{color:e.realized_pnl>=0?"profit":"lose",className:"oui-cursor-pointer",children:commifyOptional(e.realized_pnl)})]}),jsxs(Flex,{justify:"between",width:"100%",gap:2,children:[jsx(Text,{intensity:54,children:i("funding.fundingFee")}),jsx(Text,{color:e.accumulated_funding_fee>0?"lose":"profit",className:"oui-cursor-pointer",children:commifyOptional(-e.accumulated_funding_fee)})]}),jsxs(Flex,{justify:"between",width:"100%",gap:2,children:[jsx(Text,{intensity:54,children:i("positions.history.netPnl.tradingFee")}),jsx(Text,{color:e.trading_fee>0?"lose":"profit",className:"oui-cursor-pointer",children:commifyOptional(-e.trading_fee)})]})]}),className:"oui-min-w-[204px] oui-bg-base-5",arrow:{className:"oui-fill-base-5"},children:jsx("div",{children:n()})})},Ua=t=>{let{symbol:e,leverage:o}=t;return jsx(Badge,{color:"neutral",size:"xs",children:o?jsx(Text.numeral,{dp:0,size:"2xs",unit:"X",children:o}):jsx($a,{symbol:e})})},$a=({symbol:t})=>{let e=useMaxLeverage(t);return jsx(Text.numeral,{dp:0,size:"2xs",unit:"X",children:e})};function B(t){if(t==null)return t;let e=new Date(t);return e.setHours(0,0,0,0),e}function W(t){if(t==null)return t;let e=new Date(t);return e.setHours(23,59,59,999),e}var Wt=t=>({from:B(t.from),to:W(t.to??t.from)}),Qt=(t,e)=>t.getTime()===e.getTime();var Oe=t=>{let{onSymbolChange:e,symbol:o,pnlNotionalDecimalPrecision:i,enableSortingStorage:r=true}=t,{state:n}=useAccount(),{tabSort:s,onTabSort:a}=Jt({storageKey:fe}),{onSort:l,getSortedList:u}=Zt(r?s?.positionHistory:void 0,r?a("positionHistory"):void 0),{data:c,isLoading:m}=usePrivateQuery(o?`/v1/position_history?symbol=${o}&limit=1000`:"/v1/position_history?limit=1000",{formatter(_){return (_.rows??null)?.map(p=>{if(p.realized_pnl!=null&&p.accumulated_funding_fee!=null&&p.trading_fee!=null){let $=p.realized_pnl-p.accumulated_funding_fee-p.trading_fee;return {...p,netPnL:$}}return p})},revalidateOnFocus:true}),{pagination:d,setPage:f}=usePagination({pageSize:10}),{status:y,side:g,dateRange:b,filterDays:v,updateFilterDays:D,filterItems:S,onFilter:M}=tl();useEffect(()=>{f(1);},[y,g,b,v,o]);let E=useMemo(()=>c==null?c:c.filter(_=>{let p=g==="all"?true:_.side.toLowerCase()===g.toLowerCase(),$=y==="all"?true:_.position_status.toLowerCase()===y.toLowerCase(),X=_?.last_update_time??_.open_timestamp,h=b.from&&b.to?X>=b.from.getTime()&&X<=b.to.getTime():true,z=o?_.symbol==o:true;return p&&$&&h&&z}),[y,g,b,c,o]),Q=useDataTap(E,{accountStatus:n.status===AccountStatusEnum.EnableTradingWithoutConnected?AccountStatusEnum.EnableTradingWithoutConnected:AccountStatusEnum.EnableTrading,fallbackData:[]});return {dataSource:u(Q||[]),isLoading:m,onSymbolChange:e,pagination:d,filterItems:S,onFilter:M,symbol:o,filterDays:v,updateFilterDays:D,pnlNotionalDecimalPrecision:i,onSort:l,initialSort:r?s?.positionHistory:void 0}},tl=()=>{let{t}=useTranslation(),[e,o]=useState("all"),[i,r]=useState("all"),n=Wt({to:W(new Date),from:B(subDays(new Date,89))}),[s,a]=useState(90),[l,u]=useState(n),c=y=>{a(y),u({from:B(subDays(new Date,y-1)),to:W(new Date)});},m=y=>{if(y.name==="side"&&r(y.value),y.name==="status"&&o(y.value),y.name==="dateRange"){let g=Wt(y.value);if(u(g),g.from&&g.to){let b=Math.abs(differenceInDays(g.from,g.to))+1,D={1:{from:B(new Date),to:W(new Date)},7:{from:B(subDays(new Date,6)),to:W(new Date)},30:{from:B(subDays(new Date,29)),to:W(new Date)},90:{from:B(subDays(new Date,89)),to:W(new Date)}}[b];D&&Qt(D.from,g.from)&&Qt(D.to,g.to)?a(b):a(null);}}},{isMobile:d}=useScreen();return {filterItems:useMemo(()=>{let y={type:"select",name:"side",options:[{label:t("common.side.all"),value:"all"},{label:t("common.buy"),value:"LONG"},{label:t("common.sell"),value:"SHORT"}],value:i},g={type:"range",name:"dateRange",value:l,fromDate:B(subDays(new Date,89)),toDate:W(new Date)},b={type:"select",name:"status",options:[{label:t("common.status.all"),value:"all"},{label:t("positions.history.status.closed"),value:"closed"},{label:t("positions.history.status.partialClosed"),value:"partial_closed"}],value:e};return d?[y,b]:[y,b,g]},[i,e,l]),onFilter:m,side:i,dateRange:l,status:e,filterDays:s,updateFilterDays:c}};var mn=t=>{let{side:e,symbol:o}=t.item,{t:i}=useTranslation(),r=e==="LONG";return jsx(Text.formatted,{intensity:80,rule:"symbol",formatString:"base-type",size:"sm",prefix:jsx(Badge,{color:r?"success":"danger",size:"xs",children:i(r?"common.buy":"common.sell")}),onClick:()=>{t.onSymbolChange?.({symbol:o});},children:o})};var cn=t=>{let{item:e}=t,{t:o}=useTranslation(),i=()=>{modal.alert({title:o("positions.liquidation"),message:jsxs(Flex,{direction:"column",width:"100%",gap:2,className:"oui-text-2xs oui-text-base-contrast-54",children:[e.liquidation_id!=null&&jsxs(Flex,{justify:"between",width:"100%",children:[jsx(Text,{children:o("positions.history.liquidated.liquidationId")}),jsx(Text,{intensity:98,children:e.liquidation_id})]}),jsxs(Flex,{justify:"between",width:"100%",children:[jsx(Text,{children:o("positions.history.liquidated.liquidatorFee")}),jsxs(Text,{color:"lose",children:[e.liquidator_fee>0&&"-",commifyOptional(e.liquidator_fee)]})]}),jsxs(Flex,{justify:"between",width:"100%",children:[jsx(Text,{children:o("positions.history.liquidated.insFundFee")}),jsxs(Text,{color:"lose",children:[e.insurance_fund_fee>0&&"-",commifyOptional(e.insurance_fund_fee)]})]})]})});},r=useMemo(()=>{let n=[],s=e.position_status,a=()=>s==="closed"?o("positions.history.status.closed"):s==="partial_closed"?o("positions.history.status.partialClosed"):capitalizeFirstLetter(s.replace("_"," "));return n.push(jsx(Badge,{color:s!=="closed"?"primaryLight":"neutral",size:"xs",children:a()},1)),e.type==="adl"?n.push(jsx(Badge,{color:"danger",size:"xs",children:o("positions.history.type.adl")},2)):e.type==="liquidated"&&n.push(jsx(Badge,{size:"xs",color:"danger",className:"oui-cursor-pointer",onClick:i,children:jsx("span",{className:"oui-underline oui-decoration-dashed oui-decoration-1",children:o("positions.history.type.liquidated")})},3)),n},[e]);return jsx(Flex,{gap:1,children:r})},dn=t=>{let{item:e}=t,{t:o}=useTranslation(),i=e.closed_position_qty!=null?Math.abs(e.closed_position_qty):"--";return jsx(Statistic,{label:jsx(Text,{children:o("positions.history.column.closed")}),classNames:{root:"oui-text-xs",label:"oui-text-2xs"},children:jsx(Text.numeral,{dp:t.base_dp,padding:false,coloring:true,intensity:80,children:i})})},pn=t=>{let{item:e}=t,{t:o}=useTranslation(),i=e.max_position_qty!=null?Math.abs(e.max_position_qty):"--";return jsx(Statistic,{label:jsx(Text,{children:o("positions.history.column.maxClosed")}),classNames:{root:"oui-text-xs",label:"oui-text-2xs"},children:jsx(Text.numeral,{dp:t.base_dp,padding:false,coloring:true,intensity:80,children:i})})},fn=t=>{let{item:e}=t,o=e.avg_open_price!=null?Math.abs(e.avg_open_price):"--",{t:i}=useTranslation();return jsx(Statistic,{label:jsxs(Flex,{gap:1,children:[i("common.avgOpen"),jsx(Text,{intensity:20,children:"(USDC)"})]}),classNames:{root:"oui-text-xs",label:"oui-text-2xs"},children:jsx(Text.numeral,{dp:t.quote_dp,padding:false,coloring:true,intensity:80,children:o})})},yn=t=>{let{item:e}=t,o=e.avg_close_price!=null?Math.abs(e.avg_close_price):"--",{t:i}=useTranslation();return jsx(Statistic,{label:jsxs(Flex,{gap:1,children:[i("common.avgClose"),jsx(Text,{intensity:20,children:"(USDC)"})]}),classNames:{root:"oui-text-xs",label:"oui-text-2xs"},children:jsx(Text.numeral,{dp:t.quote_dp,padding:false,coloring:true,intensity:80,children:o})})},gn=t=>{let{item:e}=t,{t:o}=useTranslation();return jsx(Statistic,{label:jsx(Text,{children:o("positions.history.column.timeOpened")}),classNames:{root:"oui-text-xs",label:"oui-text-2xs"},align:"end",children:jsx(Text.formatted,{intensity:80,formatString:"yyyy-MM-dd HH:mm:ss",rule:"date",children:e.open_timestamp})})},xn=t=>{let{item:e}=t,{t:o}=useTranslation(),i=e.position_status=="closed"&&e.close_timestamp?jsx(Text.formatted,{intensity:80,formatString:"yyyy-MM-dd HH:mm:ss",rule:"date",children:e.close_timestamp}):"--";return jsx(Statistic,{label:jsx(Text,{children:o("positions.history.column.timeClosed")}),classNames:{root:"oui-text-xs",label:"oui-text-2xs"},align:"end",children:i})},bn=t=>{let{t:e}=useTranslation();return jsxs(Flex,{justify:"end",className:"oui-text-2xs oui-w-full oui-py-2 oui-gap-1 oui-gap-1",children:[jsxs(Text,{intensity:36,children:[e("funding.fundingFee"),": "]}),jsx(mt,{fee:-t.item.accumulated_funding_fee,symbol:t.item.symbol,start_t:t.item.open_timestamp.toString(),end_t:t.item.close_timestamp?.toString()})]})};var wo=t=>jsxs(Flex,{direction:"column",width:"100%",gap:2,itemAlign:"start",className:t.classNames?.root,children:[jsx(ul,{...t}),jsx(Divider,{intensity:6,className:"oui-w-full"}),jsx(ml,{...t})]}),ul=t=>{let{t:e}=useTranslation(),o=()=>{let{item:i}=t;modal.alert({title:e("positions.history.column.netPnl"),message:jsxs(Flex,{direction:"column",width:"100%",gap:2,className:"oui-text-2xs oui-text-base-contrast-54",children:[jsxs(Flex,{justify:"between",width:"100%",gap:2,children:[jsx(Text,{intensity:54,children:e("common.realizedPnl")}),jsx(Text,{color:i.realized_pnl>=0?"profit":"lose",children:commifyOptional(i.realized_pnl)})]}),jsxs(Flex,{justify:"between",width:"100%",gap:2,children:[jsx(Text,{intensity:54,children:e("funding.fundingFee")}),jsx(Text,{color:i.accumulated_funding_fee>0?"lose":"profit",children:commifyOptional(-i.accumulated_funding_fee)})]}),jsxs(Flex,{justify:"between",width:"100%",gap:2,children:[jsx(Text,{intensity:54,children:e("positions.history.netPnl.tradingFee")}),jsx(Text,{color:i.trading_fee>0?"lose":"profit",children:commifyOptional(-i.trading_fee)})]})]})});};return jsxs(Flex,{gap:1,width:"100%",children:[jsxs(Flex,{direction:"column",itemAlign:"start",className:"oui-flex-1",gap:1,children:[jsx(mn,{...t}),jsx(cn,{...t})]}),jsxs(Flex,{direction:"column",itemAlign:"end",className:"oui-flex-1",children:[jsx(Text,{size:"2xs",intensity:36,children:e("positions.history.column.netPnl")}),jsxs(Flex,{gapX:1,children:[jsx("button",{onClick:o,children:jsx(Text.numeral,{size:"xs",coloring:true,children:t.item.netPnL??"--"})}),jsx(ft,{position:t.item,sharePnLConfig:t.sharePnLConfig,modalId:SharePnLBottomSheetId,iconSize:12,isPositionHistory:true})]})]})]})},ml=t=>jsxs("div",{className:"oui-w-full",children:[jsxs(Grid,{cols:3,rows:2,width:"100%",gap:0,className:"oui-grid-cols-[1fr,1fr,135px]",children:[jsx(dn,{...t}),jsx(pn,{...t}),jsx(gn,{...t}),jsx(fn,{...t}),jsx(yn,{...t}),jsx(xn,{...t})]}),jsx(bn,{...t})]});var vo=t=>{let e=V();return {...t,...e}};var Fo=t=>{let e=vo(t);return jsx(wo,{...e})};var Do=t=>{let{onSymbolChange:e,pagination:o,pnlNotionalDecimalPrecision:i,tableRef:r}=t,n=an({onSymbolChange:e,pnlNotionalDecimalPrecision:i,sharePnLConfig:t.sharePnLConfig}),{t:s}=useTranslation(),a=useMemo(()=>({1:s("common.select.1d"),7:s("common.select.7d"),30:s("common.select.30d"),90:s("common.select.90d")}),[s]);return jsxs(Flex,{direction:"column",width:"100%",height:"100%",itemAlign:"start",children:[jsxs(Flex,{gap:3,children:[t.filterItems.length>0&&jsx(DataFilter,{items:t.filterItems,onFilter:l=>{t.onFilter(l);}}),[1,7,30,90].map(l=>jsxs("button",{className:"oui-relative oui-px-2 oui-py-[2px] oui-text-sm",children:[jsx("div",{className:"oui-z-10",children:jsx(Text.gradient,{color:t.filterDays===l?"brand":void 0,className:cn$1("oui-whitespace-nowrap oui-break-normal",t.filterDays!==l?"oui-text-base-contrast-54":""),children:a[l]||`${l}D`})}),jsx("div",{className:"oui-absolute oui-inset-0 oui-rounded oui-opacity-[.12] oui-gradient-primary",onClick:()=>{t.updateFilterDays(l);}})]},`item-${l}`))]}),jsx(AuthGuardDataTable,{loading:t.isLoading,id:"oui-desktop-positions-content",columns:n,bordered:true,dataSource:t.dataSource,generatedRowKey:l=>`${l.symbol}_${l.position_id}`,renderRowContainer:(l,u,c)=>jsx(Nt,{symbol:l.symbol,children:c}),manualPagination:false,pagination:o,manualSorting:true,onSort:t.onSort,initialSort:t.initialSort?{sortKey:t.initialSort.sortKey,sort:t.initialSort.sortOrder}:void 0,features:[TableFeatures.DownloadFeature],getTableInstance:l=>{r&&(r.current=l);},testIds:{body:"oui-testid-dataList-positionHistory-tab-body"},classNames:{root:"!oui-h-[calc(100%_-_49px)]"}})]})},Lo=t=>{let{t:e}=useTranslation();return jsxs(Grid,{cols:1,rows:2,className:"oui-w-full oui-grid-rows-[auto,1fr]",gap:1,children:[jsxs(Flex,{gap:2,p:2,justify:"between",itemAlign:"center",className:"oui-rounded-b-xl oui-bg-base-9",children:[jsx(DataFilter,{className:"oui-border-none oui-py-0",items:t.filterItems,onFilter:o=>{t.onFilter(o);}}),t.onExport&&jsx(Button,{variant:"outlined",size:"xs",color:"secondary",onClick:t.onExport,children:e("common.export")||"Export CSV"})]}),jsx(ListView,{className:cn$1("oui-hide-scrollbar oui-w-full oui-space-y-0 oui-overflow-y-hidden",t.classNames?.root),contentClassName:cn$1("!oui-space-y-1",t.classNames?.content),dataSource:t.dataSource,renderItem:(o,i)=>jsx(Nt,{symbol:o.symbol,children:jsx(Fo,{item:o,index:i,onSymbolChange:t.onSymbolChange,classNames:{root:t.classNames?.cell},sharePnLConfig:t.sharePnLConfig})})})]})};var Cn=forwardRef((t,e)=>{let o=Oe(t),i=_t.useRef(null);return _t.useImperativeHandle(e,()=>({download:()=>{let r=`position_history_${new Date().getTime()}`;i.current?.download(r);},getRowCount:()=>i.current?.getRowCount?.()??0})),jsx(Do,{...o,sharePnLConfig:t.sharePnLConfig,tableRef:i})});Cn.displayName="PositionHistoryWidget";var Sl=_t.forwardRef((t,e)=>{let{classNames:o,onExport:i,...r}=t,n=Oe(r),s=_t.useRef(n.dataSource);return _t.useEffect(()=>{s.current=n.dataSource;},[n.dataSource]),_t.useImperativeHandle(e,()=>({download:()=>{},getRowCount:()=>s.current?.length??0,get dataSource(){return s.current}}),[n.dataSource]),jsx(Lo,{...n,classNames:o,sharePnLConfig:t.sharePnLConfig,onExport:i})});var hn=t=>jsx(Tooltip,{className:"oui-w-[275px] oui-bg-base-6",content:t.tooltip,arrow:{className:"oui-fill-base-6"},children:jsx("button",{className:"oui-border-b oui-border-dashed oui-border-line-12",children:t.label})}),Tn=t=>{let{t:e}=useTranslation();return useMemo(()=>[{title:e("common.time"),dataIndex:"timestamp",width:202,render:i=>jsx(Text.formatted,{rule:"date",formatString:"yyyy-MM-dd HH:mm:ss",children:i})},{title:e("positions.Liquidation.column.liquidationId"),dataIndex:"liquidation_id",width:120,render:i=>jsx(Text,{children:i})},{title:e("common.symbol"),dataIndex:"Symbol",render:(i,r)=>jsx(Flex,{direction:"column",itemAlign:"start",children:r.positions_by_perp?.map(n=>jsx(Text.formatted,{rule:"symbol",formatString:"base-quote",children:n.symbol},n.symbol))})},{title:e("positions.Liquidation.column.markPrice"),dataIndex:"Price_(USDC)",render:(i,r)=>jsx(Flex,{direction:"column",itemAlign:"start",children:r.positions_by_perp?.map(n=>jsx(qo,{value:n.mark_price,type:"quote"},n.symbol))})},{title:e("common.quantity"),dataIndex:"Quantity",render:(i,r)=>jsx(Flex,{direction:"column",itemAlign:"start",children:r.positions_by_perp?.map(n=>jsx(qo,{value:n.position_qty,type:"base"},n.symbol))})},{title:jsx(hn,{tooltip:e("positions.Liquidation.col.tooltip.feeRate"),label:e("positions.Liquidation.column.liquidationFeeRate")}),dataIndex:"liquidationFeeRate",render:i=>jsx(Text.numeral,{rule:"percentages",children:i})},{title:jsx(hn,{tooltip:e("positions.Liquidation.col.tooltip.fee"),label:e("positions.Liquidation.column.liquidationFee")}),dataIndex:"abs_liquidation_fee",width:100,render:(i,r)=>jsx(Flex,{direction:"column",itemAlign:"start",children:r.positions_by_perp?.map(n=>jsx(qo,{value:n.abs_liquidation_fee,type:"quote"},n.symbol))})},{title:"",dataIndex:"actions",align:"right",width:40,render:(i,r,n,s)=>{let a=s.row.getIsExpanded();return jsx("button",{className:"oui-p-2",onClick:()=>{s.row.getToggleExpandedHandler()();},children:jsx(wl,{className:a?"oui-rotate-180":""})})}}],[e])},qo=t=>jsx(Text,{children:commifyOptional(t.value)}),wl=t=>jsx("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",xmlns:"http://www.w3.org/2000/svg",className:t.className,children:jsx("path",{d:"M3.884 6.02a.67.67 0 0 0-.436.27.68.68 0 0 0 .187.933L7.63 9.88a.68.68 0 0 0 .749 0l3.994-2.657a.68.68 0 0 0 .187-.934.68.68 0 0 0-.936-.186L8.003 8.51l-3.62-2.407a.65.65 0 0 0-.499-.084",fill:"#fff",fillOpacity:".54"})});var Ro=t=>jsxs(Flex,{direction:"column",width:"100%",gap:2,itemAlign:"start",className:cn$1("oui-rounded-xl oui-bg-base-9 oui-p-2",t.classNames?.root),children:[jsx(Il,{...t}),jsx(Divider,{}),jsx(Dl,{...t})]},t.item.timestamp),Il=t=>{let{t:e}=useTranslation();return jsxs(Flex,{width:"100%",justify:"between",itemAlign:"start",children:[jsx(Flex,{direction:"column",itemAlign:"start",gap:1,children:jsx(Flex,{gap:2,itemAlign:"center",children:jsx(Flex,{direction:"column",gap:1,itemAlign:"start",children:jsx(Text.formatted,{rule:"symbol",formatString:"base-quote",size:"xs",intensity:80,children:t.item.positions_by_perp?.[0]?.symbol||""})})})}),jsxs(Flex,{direction:"column",itemAlign:"end",children:[jsx(Text,{size:"2xs",intensity:36,children:jsx(Text.formatted,{rule:"date",formatString:"yyyy-MM-dd HH:mm:ss",children:t.item.timestamp})}),jsxs(Text,{size:"2xs",intensity:36,children:[`${e("positions.Liquidation.column.liquidationId")}: `,jsx(Text,{as:"span",intensity:80,children:t.item.liquidation_id})]})]})]})},Dl=t=>{let e=t.item.positions_by_perp?.[0],{t:o}=useTranslation(),i=useMemo(()=>isNaN(t.item?.margin_ratio)?"--":`${new Decimal(t.item.margin_ratio).mul(100).todp(2,Decimal.ROUND_DOWN).toNumber()}%`,[t.item?.margin_ratio]);return e?jsxs(Flex,{direction:"column",width:"100%",gap:1,children:[jsxs(Flex,{gap:2,width:"100%",children:[jsx(wt,{label:o("positions.Liquidation.column.markPrice"),value:commifyOptional(e.transfer_price),className:"oui-flex-1"}),jsx(wt,{label:o("common.quantity"),value:commifyOptional(e.position_qty),className:"oui-flex-1"}),jsx(wt,{label:o("positions.Liquidation.column.liquidationFeeRate"),value:t.item.liquidationFeeRate,className:"oui-flex-1",align:"end"})]}),jsxs(Flex,{gap:2,width:"100%",children:[jsx(wt,{label:o("positions.Liquidation.column.liquidationFee"),value:commifyOptional(e.abs_liquidation_fee),className:"oui-flex-1"}),jsx(wt,{label:o("positions.Liquidation.expand.label.mr"),value:i,className:"oui-flex-1"}),jsx(wt,{label:o("positions.Liquidation.expand.label.mmr"),value:t.item.formatted_account_mmr?`${t.item.formatted_account_mmr}%`:"--",className:"oui-flex-1",align:"end"})]}),jsxs(Flex,{gap:2,width:"100%",children:[jsx(wt,{label:o("positions.Liquidation.expand.label.collateral"),value:commifyOptional(t.item.collateral_value),className:"oui-flex-1"}),jsx(wt,{label:o("positions.Liquidation.expand.label.notional"),value:commifyOptional(t.item.position_notional),className:"oui-flex-1"}),jsx("div",{className:"oui-flex-1 oui-opacity-0"})," "]})]}):null},wt=({label:t,value:e,className:o,align:i="start"})=>jsxs(Flex,{direction:"column",itemAlign:i,className:o,children:[jsx(Text,{size:"2xs",intensity:36,children:t}),jsx(Text,{size:"xs",intensity:80,children:e})]});var Mo=t=>({...t});var Oo=t=>{let{classNames:e,...o}=t,i=Mo(o);return jsx(Ro,{classNames:e,...i})};var Eo=t=>{let[e,o]=useState({}),i=Tn();return jsxs(Flex,{direction:"column",width:"100%",height:"100%",itemAlign:"start",children:[jsxs(Flex,{gap:3,children:[t.filterItems.length>0&&jsx(DataFilter,{items:t.filterItems,onFilter:r=>{t.onFilter(r);}}),[1,7,30,90].map(r=>jsxs("button",{className:"oui-relative oui-px-2 oui-py-[2px] oui-text-sm",children:[jsx("div",{className:"oui-z-10",children:jsx(Text.gradient,{color:t.filterDays===r?"brand":void 0,className:t.filterDays!==r?"oui-text-base-contrast-54":"",children:`${r}D`})}),jsx("div",{className:"oui-absolute oui-inset-0 oui-rounded oui-opacity-[.12] oui-gradient-primary",onClick:()=>{t.updateFilterDays(r);}})]},`item-${r}`))]}),jsx(AuthGuardDataTable,{loading:t.isLoading,id:"oui-desktop-liquidation-content",columns:i,bordered:true,dataSource:t.dataSource,generatedRowKey:r=>`${r.liquidation_id}`,pagination:t.pagination,testIds:{body:"oui-testid-dataList-liquidation-tab-body"},classNames:{root:"!oui-h-[calc(100%_-_49px)]"},expanded:e,onExpandedChange:o,getRowCanExpand:()=>true,expandRowRender:r=>jsx(El,{record:r.original})})]})},Ee=t=>jsx("th",{className:"oui-h-10 oui-border-b oui-border-line oui-text-left oui-text-base-contrast-36",children:jsx(Tooltip,{content:t.tooltip,className:"oui-w-[275px] oui-bg-base-6",side:t.side,arrow:{className:"oui-fill-base-6"},children:jsx("button",{className:"oui-border-b oui-border-dashed oui-border-line-12",children:t.label})})}),El=t=>{let{margin_ratio:e,account_mmr:o,collateral_value:i,position_notional:r}=t.record,{t:n}=useTranslation();return jsx("div",{className:"oui-w-full oui-bg-base-8 oui-px-6",children:jsxs("table",{className:"oui-w-full",children:[jsx("thead",{children:jsxs("tr",{children:[jsx(Ee,{tooltip:n("positions.Liquidation.expand.tooltip.mr"),label:n("positions.Liquidation.expand.label.mr"),side:"left"}),jsx(Ee,{tooltip:n("positions.Liquidation.expand.tooltip.mmr"),label:n("positions.Liquidation.expand.label.mmr")}),jsx(Ee,{tooltip:n("positions.Liquidation.expand.tooltip.collateral"),label:n("positions.Liquidation.expand.label.collateral")}),jsx(Ee,{tooltip:n("positions.Liquidation.expand.tooltip.notional"),label:n("positions.Liquidation.expand.label.notional")})]})}),jsx("tbody",{children:jsxs("tr",{children:[jsx("td",{className:"oui-h-10",children:jsx(Text.numeral,{rule:"percentages",children:e})}),jsx("td",{className:"oui-h-10",children:jsx(Text.numeral,{rule:"percentages",children:o})}),jsx("td",{className:"oui-h-10",children:commifyOptional(i)}),jsx("td",{className:"oui-h-10",children:commifyOptional(r)})]})})]})})},Ho=t=>{let{t:e}=useTranslation();return jsxs(Grid,{cols:1,rows:2,className:"oui-w-full oui-grid-rows-[auto,1fr]",gap:1,children:[jsxs(Flex,{gap:2,p:2,justify:"between",itemAlign:"center",className:"oui-rounded-b-xl oui-bg-base-9",children:[jsx(DataFilter,{className:"oui-border-none oui-py-0",items:t.filterItems,onFilter:o=>{t.onFilter(o);}}),t.onExport&&jsx(Button,{variant:"outlined",size:"xs",color:"secondary",onClick:t.onExport,children:e("common.export")||"Export CSV"})]}),jsx(ListView,{className:cn$1("oui-hide-scrollbar oui-w-full oui-space-y-0 oui-overflow-y-hidden",t.classNames?.root),contentClassName:cn$1("!oui-space-y-1",t.classNames?.content),dataSource:t.dataSource,loadMore:t.loadMore,renderItem:(o,i)=>jsx(Oo,{item:o,index:i,classNames:{root:t.classNames?.cell}})})]})};var He=t=>{let{symbol:e,enableLoadMore:o}=t,{page:i,pageSize:r,setPage:n,pagination:s,parsePagination:a}=usePagination({pageSize:10}),{dateRange:l,filterDays:u,updateFilterDays:c,filterItems:m,onFilter:d}=Vl();useEffect(()=>{n(1);},[e,l,u]);let[f,{meta:y,isLoading:g,loadMore:b}]=$l({page:o?void 0:i,size:r,symbol:e,start_t:l.from!=null?l.from.getTime():void 0,end_t:l.to!=null?l.to.getTime():void 0});return {dataSource:useDataTap(f,{fallbackData:[]}),isLoading:g,loadMore:b,pagination:a(y),dateRange:l,filterDays:u,updateFilterDays:c,filterItems:m,onFilter:d}},$l=t=>{let e=usePrivateInfiniteQuery(Kl(t),{initialSize:1,formatter:s=>s,revalidateOnFocus:true}),o=useMemo(()=>e.data?.[0]?.meta,[e.data?.[0]]),i=useMemo(()=>e.data?.map(s=>s.rows?.map(a=>{let l=null,u=a.positions_by_perp[0];return u&&(l=new Decimal(u.liquidator_fee).add(u.insurance_fund_fee).toNumber()),{...a,symbol:u?.symbol,transfer_price:u?.transfer_price,position_qty:u?.position_qty,abs_liquidation_fee:u?.abs_liquidation_fee,formatted_account_mmr:isNaN(a.account_mmr)?null:new Decimal(a.account_mmr).mul(100).toFixed(2).toString(),liquidationFeeRate:l}}))?.flat(),[e.data]),r=e.isLoading;return [i,{meta:o,isLoading:r,loadMore:()=>{e.setSize(e.size+1);}}]},Vl=()=>{let t=Wt({to:W(new Date),from:B(subDays(new Date,89))}),[e,o]=useState(90),[i,r]=useState(t),n=u=>{o(u),r({from:B(subDays(new Date,u-1)),to:W(new Date)});},s=u=>{if(u.name==="dateRange"){let c=Wt(u.value);if(r(c),c.from&&c.to){let m=Math.abs(differenceInDays(c.from,c.to))+1,f={1:{from:B(new Date),to:W(new Date)},7:{from:B(subDays(new Date,6)),to:W(new Date)},30:{from:B(subDays(new Date,29)),to:W(new Date)},90:{from:B(subDays(new Date,89)),to:W(new Date)}}[m];f&&Qt(f.from,c.from)&&Qt(f.to,c.to)?o(m):o(null);}}},{isMobile:a}=useScreen();return {filterItems:useMemo(()=>{let u={type:"range",name:"dateRange",value:i,fromDate:B(subDays(new Date,89)),toDate:W(new Date)};return a?[u]:[u]},[i]),onFilter:s,dateRange:i,filterDays:e,updateFilterDays:n}},Kl=t=>(e,o)=>{if(o&&!o.rows?.length)return null;let{symbol:i,size:r=10,page:n,end_t:s,start_t:a}=t,l=new URLSearchParams([["size",r.toString()],["page",`${e+1}`]]);return n&&l.set("page",`${n}`),i&&l.set("symbol",i),s&&l.set("end_t",`${s}`),a&&l.set("start_t",`${a}`),`/v1/liquidations?${l.toString()}`};var Gl=forwardRef((t,e)=>{let o=He(t);return _t.useImperativeHandle(e,()=>({download:()=>{},getRowCount:()=>o.dataSource?.length??0,get dataSource(){return o.dataSource}})),jsx(Eo,{...o})}),Xl=forwardRef((t,e)=>{let{classNames:o,onExport:i,...r}=t,n=He(r),s=_t.useRef(n.dataSource);return _t.useEffect(()=>{s.current=n.dataSource;},[n.dataSource]),_t.useImperativeHandle(e,()=>({download:()=>{},getRowCount:()=>s.current?.length??0,get dataSource(){return s.current}}),[n.dataSource]),jsx(Ho,{classNames:o,...n,onExport:i})});var Zl="MarketCloseConfirmID";registerSimpleDialog(Zl,Mt,{size:"md",closable:false});
|
|
17
|
+
var zo=t=>{let{hideCloseIcon:e=false}=t;return jsxs("div",{className:"oui-relative oui-w-full oui-border-b oui-border-line-4 oui-pb-3",children:[jsx(Text,{size:"base",children:t.title}),!e&&jsx("button",{onClick:t.onClose,className:"oui-absolute oui-right-0 oui-top-0 oui-p-2 oui-text-base-contrast-54 hover:oui-text-base-contrast-80",children:jsx(CloseIcon,{size:18,color:"white"})})]})},le=t=>{let{t:e}=useTranslation();return jsxs(Flex,{id:"oui-positions-confirm-footer",gap:2,width:"100%",className:"oui-mt-3 oui-pb-1",children:[jsx(Button,{id:"oui-positions-confirm-footer-cancel-button",color:"secondary",fullWidth:true,onClick:t.onCancel,size:"md",children:e("common.cancel")}),jsx(ThrottledButton,{id:"oui-positions-confirm-footer-confirm-button",onClick:t.onConfirm,fullWidth:true,loading:t.submitting,disabled:t.disabled,size:"md",children:e("common.confirm")})]})},An=t=>{let{quantity:e,price:o,quoteDp:i,side:r}=t,{t:n}=useTranslation(),a=useMemo(()=>o&&e?new Decimal(o).mul(e).toFixed(i,Decimal.ROUND_DOWN):"--",[o,e]);return jsxs(Flex,{direction:"column",gap:1,width:"100%",className:"oui-text-sm oui-text-base-contrast-54",py:5,children:[jsxs(Flex,{justify:"between",width:"100%",gap:1,children:[jsx(Text,{children:n("common.qty")}),jsx(Text,{color:r===OrderSide.BUY?"success":"danger",children:e})]}),jsxs(Flex,{justify:"between",width:"100%",gap:1,children:[jsx(Text,{children:n("common.price")}),jsx(Text.formatted,{intensity:98,suffix:jsx(Text,{intensity:54,children:"USDC"}),children:o})]}),jsxs(Flex,{justify:"between",width:"100%",gap:1,children:[jsx(Text,{children:n("common.notional")}),jsx(Text.formatted,{intensity:98,suffix:jsx(Text,{intensity:54,children:"USDC"}),children:a})]})]})},Rt=t=>{let{t:e}=useTranslation(),o=()=>{(t?.onClose??t.close)?.();};return jsxs(Flex,{direction:"column",className:t.classNames?.root,children:[jsx(zo,{onClose:o,title:e("positions.marketClose"),hideCloseIcon:t.hideCloseIcon}),jsx(Text,{intensity:54,size:"sm",className:"oui-my-5",children:e("positions.marketClose.description",{quantity:commifyOptional(t.quantity),base:t.base})}),jsx(le,{onCancel:o,onConfirm:async()=>{await t.onConfirm?.(),o();},submitting:t.submitting})]})},ue=t=>{let{order:e,quoteDp:o,quantity:i,price:r}=t,{side:n}=e,{t:a}=useTranslation(),s=()=>{t.onClose?.();};return jsxs(Fragment,{children:[jsx(zo,{onClose:s,title:a("positions.limitClose"),hideCloseIcon:t.hideCloseIcon}),jsx(Box,{mt:5,children:jsx(Text,{intensity:54,size:"sm",children:a("positions.limitClose.description",{quantity:commify(t.quantity),base:t.base})})}),jsxs(Flex,{gap:2,mb:4,mt:5,justify:"between",children:[jsx(Text.formatted,{rule:"symbol",formatString:"base-type",size:"base",showIcon:true,children:e.symbol}),jsxs(Flex,{gap:1,children:[jsx(Badge,{color:"neutral",size:"xs",children:a("orderEntry.orderType.limit")}),jsx(Badge,{color:n===OrderSide.BUY?"success":"danger",size:"xs",children:n===OrderSide.BUY?a("common.buy"):a("common.sell")})]})]}),jsx(Divider,{className:"oui-w-full"}),jsx(An,{className:"oui-text-sm",price:r,quantity:i,side:e.side,quoteDp:o??2}),jsx(le,{onCancel:s,onConfirm:t.onConfirm,submitting:t.submitting})]})};var We=createContext({}),tt=()=>useContext(We);function Qo(t,e){let o=useRef(),i=useRef(e);i.current=e,useEffect(()=>{let r={root:null,rootMargin:"0px",threshold:0},n=a=>{a.forEach(s=>{s.isIntersecting&&i.current?.();});};return o.current=new IntersectionObserver(n,r),()=>{o.current?.disconnect();}},[]),useEffect(()=>{o.current?.observe(t.current);},[]);}var Uo=t=>{let e=useRef(null),{onEndReached:o}=t;return Qo(e,()=>{o?.();}),jsxs(Fragment,{children:[t.children,jsx("div",{ref:e,className:"oui-relative oui-invisible oui-h-[25px] oui-bg-red-400 oui-top-[-300px]"})]})};var $o=60,me=({total:t,symbol:e,start_t:o,end_t:i})=>{let{t:r}=useTranslation(),{isMobile:n}=useScreen(),{isLoading:a,data:s,setSize:l}=usePrivateInfiniteQuery((d,x)=>(!x||(x.length??0)<$o)&&d>0?null:`/v1/funding_fee/history?page=${d+1}&size=${$o}&symbol=${e}&start_t=${o}&end_t=${i}`,{revalidateFirstPage:false}),m=useCallback(()=>{l(d=>d+1);},[l]),u=useMemo(()=>Array.isArray(s)?s.flat().map(d=>({...d,funding_fee:-d.funding_fee})):[],[s]),c=useMemo(()=>n?jsx(Jn,{data:u??EMPTY_LIST,isLoading:a,loadMore:m}):jsx(Zn,{data:u??EMPTY_LIST,isLoading:a,loadMore:m}),[n,u,a]);return jsxs("div",{children:[jsxs(Grid,{cols:2,gapX:3,className:"oui-sticky oui-top-0 oui-z-10 oui-bg-base-8 oui-py-4",children:[jsx("div",{className:"oui-rounded-lg oui-border oui-border-line-6 oui-bg-base-9 oui-p-3",children:jsxs(Flex,{direction:"column",gap:1,itemAlign:"start",children:[jsx("span",{className:"oui-text-2xs oui-text-base-contrast-36",children:r("common.symbol")}),jsx(Text.formatted,{rule:"symbol",className:"oui-font-semibold",intensity:98,children:e})]})}),jsx("div",{className:"oui-rounded-lg oui-border oui-border-line-6 oui-bg-base-9 oui-p-3",children:jsx(Statistic,{label:`${r("funding.fundingFee")} (USDC)`,valueProps:{ignoreDP:true,coloring:true,showIdentifier:true},children:t})})]}),c]})},Zn=({isLoading:t,data:e,loadMore:o})=>{let{t:i}=useTranslation(),r=useMemo(()=>[{title:i("common.time"),dataIndex:"created_time",width:120,render:n=>jsx(Text.formatted,{rule:"date",children:n})},{title:i("funding.fundingRate"),dataIndex:"funding_rate",formatter:n=>new Decimal(n).mul(100).toString(),render:n=>jsx("span",{children:`${n}%`})},{title:i("funding.paymentType"),dataIndex:"payment_type",formatter:n=>i(n==="Pay"?"funding.paymentType.paid":"funding.paymentType.received"),render:n=>jsx("span",{children:n})},{title:`${i("funding.fundingFee")} (USDC)`,dataIndex:"funding_fee",render:n=>jsx(Text.numeral,{rule:"price",coloring:true,showIdentifier:true,ignoreDP:true,children:n})}],[i]);return jsx("div",{className:"oui-h-[calc(80vh_-_132px_-_8px)] oui-overflow-y-auto",children:jsx(Uo,{onEndReached:o,children:jsx(DataTable,{classNames:{root:cn("oui-h-auto oui-bg-base-8 oui-text-sm")},columns:r,dataSource:e??EMPTY_LIST,loading:t})})})},Jn=({data:t,isLoading:e,loadMore:o})=>{let i=useCallback(r=>jsx(jn,{item:r}),[]);return jsx("div",{className:"oui-h-[calc(80vh_-_104px)] oui-overflow-y-auto",children:jsx(ListView,{dataSource:t,renderItem:i,isLoading:e,contentClassName:"oui-space-y-0",loadMore:o})})},jn=({item:t})=>{let{t:e}=useTranslation();return jsxs("div",{className:"oui-flex oui-flex-col oui-space-y-2 oui-border-t oui-border-line-6 oui-py-2",children:[jsxs(Flex,{justify:"between",children:[jsx(Statistic,{label:e("funding.fundingRate"),classNames:{label:"oui-text-2xs"},valueProps:{ignoreDP:true,rule:"percentages",className:"oui-text-xs"},children:t.funding_rate}),jsx(Statistic,{label:e("common.amount"),className:"oui-items-end",classNames:{label:"oui-text-2xs"},valueProps:{ignoreDP:true,coloring:true,as:"div",className:"oui-text-xs",showIdentifier:true},children:t.funding_fee})]}),jsxs(Flex,{justify:"between",children:[jsx(Text.formatted,{rule:"date",className:"oui-text-base-contrast-36",size:"2xs",children:t.created_time}),jsx(Text,{size:"sm",intensity:80,children:t.payment_type==="Pay"?e("funding.paymentType.paid"):e("funding.paymentType.received")})]})]})};var mt=({fee:t,symbol:e,start_t:o,end_t:i})=>{let{t:r}=useTranslation(),[n,{setTrue:a,setFalse:s}]=useBoolean(false),{isMobile:l}=useScreen();return jsxs(Fragment,{children:[jsx("button",{onClick:a,children:jsx(Text.numeral,{rule:"price",coloring:true,showIdentifier:true,ignoreDP:true,className:"oui-border-b oui-border-line-16 oui-border-dashed oui-py-0.5",children:t})}),l?jsx(SimpleSheet,{open:n,onOpenChange:s,title:r("funding.fundingFee"),classNames:{body:"oui-max-h-[80vh] oui-py-0"},children:jsx(me,{total:t,symbol:e,start_t:o,end_t:i})}):jsx(SimpleDialog,{open:n,onOpenChange:s,title:r("funding.fundingFee"),classNames:{content:"lg:oui-max-w-[640px]",body:"oui-max-h-[80vh] oui-bg-base-8 lg:oui-py-0"},children:jsx(me,{total:t,symbol:e,start_t:o,end_t:i})})]})};var pr=(t,e)=>{let o=useConfig("apiBaseUrl");return i=>(r,n,a)=>{try{return i(r,async l=>{let m=Array.isArray(l)?l[0]:l,u=`${o}${m}`,c=t.signer,d={method:"GET",url:m},x=await c.sign(d,getTimestamp()),f=Array.isArray(e)?e:[e];return Promise.all(f.map(y=>n(u,{headers:{...x,"orderly-account-id":y}})))},a)}catch(s){throw s}}},Vo=(t,e)=>{let{formatter:o,accountId:i,...r}=e||{},{state:n,account:a}=useAccount(),s=Array.isArray(e?.use)?e?.use??[]:[],l=Array.isArray(i)?i:[i],m=l.filter(Boolean).length&&(n.status>=AccountStatusEnum.EnableTrading||n.status===AccountStatusEnum.EnableTradingWithoutConnected);return useSWR(()=>m?[t,l]:null,(u,c)=>fetcher(u,c,{formatter:o}),{...r,use:[...s,pr(a,l)],onError:()=>{}})};var Xo=t=>{let{symbol:e,calcMode:o,includedPendingOrder:i,pnlNotionalDecimalPrecision:r,sharePnLConfig:n,onSymbolChange:a,selectedAccount:s}=t,{pagination:l,setPage:m}=usePagination({pageSize:50});useEffect(()=>{m(1);},[e]);let u=useSymbolsInfo(),{state:c}=useAccount(),[d,,{isLoading:x}]=usePositionStream(e,{calcMode:o,includedPendingOrder:i}),{data:f=[],isLoading:y,mutate:b}=usePrivateQuery("/v1/client/aggregate/positions",{errorRetryCount:3}),{data:N=[],isLoading:D}=Vo("/v1/client/info",{accountId:f.map(_=>_.account_id),revalidateOnFocus:false}),C=produce(f.filter(_=>_.account_id!==c.mainAccountId),_=>{for(let p of _){let $=u[p.symbol],X=positions.notional(p.position_qty,p.mark_price),h=N.find(He=>He.account_id===p.account_id),z=positions.MMR({baseMMR:$?.("base_mmr"),baseIMR:$?.("base_imr"),IMRFactor:h?.imr_factor[p.symbol]??0,positionNotional:X,IMR_factor_power:4/5}),ie=positions.maintenanceMargin({positionQty:p.position_qty,markPrice:p.mark_price,MMR:z}),ne=positions.unrealizedPnL({qty:p.position_qty,openPrice:p?.average_open_price,markPrice:p.mark_price}),Ee=p.leverage||1,Kt=account.IMR({maxLeverage:Ee,baseIMR:$?.("base_imr"),IMR_Factor:h?.imr_factor[p.symbol]??0,positionNotional:X,ordersNotional:0,IMR_factor_power:4/5}),re=positions.unrealizedPnLROI({positionQty:p.position_qty,openPrice:p.average_open_price,IMR:Kt,unrealizedPnL:ne}),se=0,qt=0;p.index_price&&(se=positions.unrealizedPnL({qty:p.position_qty,openPrice:p?.average_open_price,markPrice:p.index_price}),qt=positions.unrealizedPnLROI({positionQty:p.position_qty,openPrice:p.average_open_price,IMR:Kt,unrealizedPnL:se})),p.mmr=z,p.mm=ie,p.notional=X,p.unrealized_pnl=ne,p.unrealized_pnl_ROI=re,p.unrealized_pnl_ROI_index=qt;}}),M=useDataTap([...d?.rows,...C].filter(_=>_.position_qty!==0))??[],E=useMemo(()=>!s||s==="All accounts"?M:M.filter(_=>s==="Main accounts"?_.account_id===c.mainAccountId||!_.account_id:_.account_id===s),[M,s,c.mainAccountId]),Q=useMemo(()=>Fr(E,{mainAccountId:c.mainAccountId,subAccounts:c.subAccounts}),[E,c.mainAccountId,c.subAccounts]),ut=useMemo(()=>x||y||D,[x,y,D]);return {tableData:Q,isLoading:ut,pnlNotionalDecimalPrecision:r,sharePnLConfig:n,symbol:e,onSymbolChange:a,pagination:l,mutatePositions:b}},Fr=(t,e)=>{let{mainAccountId:o="",subAccounts:i=[]}=e,r=new Map;for(let n of t){let a=n.account_id||o,s=i.find(l=>l.id===a);r.has(a)?r.get(a)?.children?.push(n):r.set(a,{id:a,description:a===o?i18n.t("common.mainAccount"):s?.description||formatAddress(s?.id||""),children:[n]});}return {expanded:Array.from(r.keys()),dataSource:Array.from(r.values())}};var ce="orderly_trading_positions_sort";var wr=(t,e)=>{if(t==null&&e==null)return 0;if(t==null)return 1;if(e==null)return -1;let o=String(t).trim(),i=String(e).trim(),r=Number(o),n=Number(i),a=!isNaN(r)&&isFinite(r)&&/^-?\d*\.?\d+([eE][+-]?\d+)?$/.test(o),s=!isNaN(n)&&isFinite(n)&&/^-?\d*\.?\d+([eE][+-]?\d+)?$/.test(i);if(a&&s)return r-n;let l=/^\d{4}-\d{2}-\d{2}/.test(o)||/^\d{13}$/.test(o),m=/^\d{4}-\d{2}-\d{2}/.test(i)||/^\d{13}$/.test(i);if(l&&m){let u=new Date(t),c=new Date(e);if(!isNaN(u.getTime())&&!isNaN(c.getTime()))return u.getTime()-c.getTime()}return o.localeCompare(i,void 0,{sensitivity:"base",numeric:false})};function Zo(t,e){let{sortKey:o,sortOrder:i}=e||{},r=[...t||[]];return o&&i&&r.sort((n,a)=>{let s=wr(n[o],a[o]);return i==="desc"?-s:s}),r}function Xt(t,e){let[o,i]=useState(t),r=useCallback(a=>{let s=a?{sortKey:a.sortKey,sortOrder:a.sort}:void 0;i(s),e?.(s);},[]),n=useCallback(a=>Zo(a,o),[o]);return {sort:o,onSort:r,getSortedList:n}}var de=(o=>(o.Positions="positions",o.PositionHistory="positionHistory",o))(de||{});function Yt(t){let[e,o]=useSessionStorage(t.storageKey,{positions:{sortKey:"unrealized_pnl",sortOrder:"desc"},positionHistory:{sortKey:"close_timestamp",sortOrder:"desc"}}),i=useCallback(r=>n=>{o({...e,[r]:n});},[e,o]);return {tabSort:e,onTabSort:i}}var Xe=t=>{let{symbol:e,calcMode:o,includedPendingOrder:i,pnlNotionalDecimalPrecision:r,sharePnLConfig:n,onSymbolChange:a,enableSortingStorage:s=true}=t,{pagination:l,setPage:m}=usePagination({pageSize:50}),{tabSort:u,onTabSort:c}=Yt({storageKey:ce}),{onSort:d,getSortedList:x,sort:f}=Xt(s?u?.positions:void 0,s?c("positions"):void 0);Dr.useEffect(()=>{m(1);},[e]);let[y,,{isLoading:b}]=usePositionStream(e,{calcMode:o,includedPendingOrder:i}),N=useDataTap(y?.rows,{fallbackData:[]})??void 0;return {dataSource:x(N||[]),isLoading:b,pnlNotionalDecimalPrecision:r,sharePnLConfig:n,symbol:e,onSymbolChange:a,pagination:l,onSort:d,initialSort:s?u?.positions:void 0}};var Ye=createContext({}),K=()=>useContext(Ye);var Nt=t=>{let{symbol:e,children:o}=t,i=useSymbolsInfo()[e],r=useMemo(()=>({symbol:e,base_dp:i("base_dp"),quote_dp:i("quote_dp"),base_tick:i("base_tick"),quote_tick:i("quote_tick"),base:i("base"),quote:i("quote"),origin:i(),quote_max:i("quote_max"),quote_min:i("quote_min")}),[e,i]);return jsx(Ye.Provider,{value:r,children:o})};var fe=t=>{let{t:e}=useTranslation();return jsxs(Fragment,{children:[jsx(Slider,{showTip:true,markCount:4,value:[t.value],color:"primary",onValueChange:o=>{t.onValueChange(o[0]);}}),jsxs(Flex,{width:"100%",justify:"between",children:[jsx(Text,{color:"primary",size:"2xs",children:`${t.value}%`}),jsxs(Flex,{gap:1,onClick:t.onMax,className:"oui-cursor-pointer",children:[jsx(Text,{size:"2xs",color:"primary",children:e("common.max")}),jsx(Text.numeral,{intensity:54,size:"2xs",dp:t.base_dp,padding:false,children:t.max})]})]})]})};var to=t=>{let{base:e,base_dp:o,quote:i,quote_dp:r,sheetOpen:n,setSheetOpen:a,dialogOpen:s,setDialogOpen:l,quantity:m,price:u,submitting:c,priceErrorMsg:d,quantityErrorMsg:x,disabled:f,isMarketClose:y,position:b,maxQty:N,isBuy:D}=t,{t:C}=useTranslation(),M=C(y?"positions.marketClose":"positions.limitClose"),E=C(y?"orderEntry.orderType.market":"orderEntry.orderType.limit"),Q=D?jsx(Badge,{color:"success",size:"xs",children:C("common.buy")}):jsx(Badge,{color:"danger",size:"xs",children:C("common.sell")}),ut=jsxs(Flex,{width:"100%",justify:"between",children:[jsx(Text.formatted,{rule:"symbol",showIcon:true,children:b.symbol}),jsxs(Flex,{gap:1,children:[jsx(Badge,{color:"neutral",size:"xs",children:E}),Q]})]}),_=jsxs(Flex,{width:"100%",justify:"between",children:[jsx(Text,{intensity:54,children:C("common.lastPrice")}),jsx(Text.numeral,{dp:r,suffix:jsxs(Text,{intensity:36,children:[" ",i]}),children:b.mark_price})]}),p=!y&&jsx(Fragment,{children:jsxs(Flex,{width:"100%",direction:"column",gap:2,children:[jsx(Input.tooltip,{prefix:C("common.price"),suffix:i,align:"right",fullWidth:true,autoComplete:"off",inputMode:"decimal",formatters:[inputFormatter.numberFormatter,inputFormatter.dpFormatter(r)],triggerClassName:"oui-w-full",tooltip:d,color:d?"danger":void 0,value:u,onValueChange:t.updatePriceChange,classNames:{prefix:"oui-text-base-contrast-54",suffix:"oui-text-base-contrast-54",root:cn("oui-w-full oui-outline-line-12",d?"oui-outline-danger":void 0)}}),jsx(Input.tooltip,{prefix:C("common.quantity"),suffix:e,align:"right",fullWidth:true,autoComplete:"off",inputMode:"decimal",formatters:[inputFormatter.numberFormatter,inputFormatter.dpFormatter(o)],triggerClassName:"oui-w-full",tooltip:x,color:x?"danger":void 0,value:m,onBlur:()=>t.formatQuantityToBaseTick(m),onValueChange:t.updateQuantity,classNames:{prefix:"oui-text-base-contrast-54",suffix:"oui-text-base-contrast-54",root:cn("oui-w-full oui-outline-line-12",x?"oui-outline-danger":void 0)}})]})}),$=jsx(fe,{value:t.sliderValue,onValueChange:t.onSliderValueChange,base_dp:o,max:N,onMax:t.onMax}),X=jsxs(Flex,{width:"100%",gap:3,mt:2,children:[jsx(Button,{fullWidth:true,color:"secondary",onClick:t.onCloseSheet,children:C("common.cancel")}),jsx(ThrottledButton,{fullWidth:true,disabled:c||f,loading:c,onClick:h=>{h.stopPropagation(),h.preventDefault(),t.onDoubleConfirm();},children:C("common.confirm")})]});return jsxs(Fragment,{children:[jsx(Button,{variant:"outlined",color:"secondary",size:"sm",className:"oui-border-base-contrast-36",onClick:h=>{h.stopPropagation(),h.preventDefault(),a(true);},children:M}),jsx(SimpleSheet,{title:M,open:n,onOpenChange:a,children:jsxs(Flex,{direction:"column",gap:3,width:"100%",itemAlign:"start",className:"oui-text-sm",children:[ut,jsx(Divider,{className:"oui-w-full"}),_,p,$,X]})}),jsx(SimpleDialog,{open:s,onOpenChange:l,size:"xs",children:y?jsx(Rt,{base:e,quantity:m,submitting:c,onClose:t.onCloseDialog,onConfirm:t.onConfirm,hideCloseIcon:true}):jsx(ue,{base:e,quoteDp:r,quantity:m,price:u,submitting:c,order:t.closeOrderData,onClose:t.onCloseDialog,onConfirm:t.onConfirm,hideCloseIcon:true})})]})};var eo=t=>{let{position:e,base:o,base_dp:i,quote_dp:r,price:n,quantity:a,submitting:s,dialogOpen:l,setDialogOpen:m,isMarketClose:u,popoverOpen:c,setPopoverOpen:d,maxQty:x,quantityErrorMsg:f,priceErrorMsg:y,isEntirePosition:b}=t,{t:N}=useTranslation(),D=jsxs(Flex,{width:"100%",gap:2,mb:1,children:[jsx(Input.tooltip,{ref:t.quantityInputRef,prefix:N("common.quantity"),suffix:b?jsx(Text,{size:"2xs",intensity:54,className:"oui-cursor-pointer oui-px-3",onClick:t.onEntirePosition,children:N("tpsl.entirePosition")}):o,align:"right",size:"md",fullWidth:true,autoComplete:"off",inputMode:"decimal",formatters:[inputFormatter.numberFormatter,inputFormatter.dpFormatter(i)],triggerClassName:"oui-w-full",tooltip:f,color:f?"danger":void 0,value:b?"":a,onBlur:()=>t.formatQuantityToBaseTick(a),onValueChange:t.updateQuantity,classNames:{prefix:"oui-text-base-contrast-54",suffix:"oui-text-base-contrast-54",root:cn("oui-w-full oui-outline-line-12",f?"oui-outline-danger":void 0)}}),jsx(Button,{onClick:t.onMax,size:"md",variant:"outlined",className:cn("oui-text-2xs",b?"oui-border-primary-light oui-text-primary-light hover:oui-bg-primary-light/20":"oui-border-line-12 oui-bg-base-6 oui-text-base-contrast-54 hover:oui-bg-base-5"),children:N("common.position")})]}),C=jsx(Select.options,{variant:"text",size:"md",options:[{label:N("orderEntry.orderType.limit"),value:OrderType.LIMIT},{label:N("orderEntry.orderType.market"),value:OrderType.MARKET}],classNames:{trigger:"oui-w-[--radix-select-content-available-width]"},value:t.type,onValueChange:Q=>{t.updateOrderType(Q);},contentProps:{align:"end",className:"oui-border oui-border-line-6"}}),M=u,E=jsx(Input.tooltip,{suffix:C,size:"md",fullWidth:true,autoComplete:"off",inputMode:"decimal",formatters:[inputFormatter.numberFormatter,inputFormatter.dpFormatter(r)],triggerClassName:"oui-w-full",tooltip:y,color:y?"danger":void 0,value:n,onValueChange:t.updatePriceChange,placeholder:M?"--":"",disabled:M,classNames:{prefix:"oui-text-base-contrast-54",suffix:"oui-text-base-contrast-54",root:cn("oui-w-full oui-outline-line-12",y?"oui-outline-danger":void 0,M?"focus-within:oui-outline-line-12":void 0)}});return jsxs(Fragment,{children:[jsxs(PopoverRoot,{open:c,onOpenChange:d,children:[jsx(PopoverTrigger,{asChild:true,onClick:()=>{d(true);},children:jsx(Button,{variant:"outlined",size:"sm",color:"secondary",children:N("positions.column.close")})}),jsx(PopoverContent,{className:cn("oui-w-[360px] oui-p-5",c?"oui-visible":"oui-invisible"),align:"end",side:"top",onOpenAutoFocus:Q=>Q.preventDefault(),children:jsxs(Flex,{gapY:2,direction:"column",children:[D,jsx(fe,{value:t.sliderValue,onValueChange:t.onSliderValueChange,base_dp:i,max:x,onMax:t.onMax}),jsx(Divider,{my:2,intensity:8,className:"oui-w-full"}),E,jsx(le,{onConfirm:t.onDoubleConfirm,onCancel:t.onClosePopover,submitting:s,disabled:t.disabled})]})})]}),jsx(SimpleDialog,{open:l,onOpenChange:m,size:"sm",children:u?jsx(Rt,{base:o,quantity:a,submitting:s,onClose:t.onCloseDialog,onConfirm:t.onConfirm,classNames:{root:"oui-items-start"},hideCloseIcon:true}):jsx(ue,{base:o,quoteDp:r,quantity:a,price:n,submitting:s,order:t.closeOrderData,onClose:t.onCloseDialog,onConfirm:t.onConfirm,hideCloseIcon:true})})]})};var oo=t=>{let[e,o]=useState(false),[i,r]=useState(false),[n,a]=useState(false),[s,l]=useState(100),m=useRef(null),[u]=useLocalStorage("orderly_order_confirm",true),{position:c,onSubmit:d,price:x,quantity:f,closeOrderData:y,submitting:b,updatePriceChange:N,updateOrderType:D,updateQuantity:C,errors:M,baseTick:E,type:Q}=tt(),{quote_dp:ut,base_dp:_,base:p,quote:$}=K(),{getErrorMsg:X}=useOrderEntryFormErrorMsg(M),h=c.position_qty>0,z=Math.abs(c.position_qty),ie=t.type||Q,ne=ie===OrderType.MARKET,Ee=z?.toString()===f.toString();useEffect(()=>{e&&D(t.type);},[t.type,e]);let{priceErrorMsg:Kt,quantityErrorMsg:re}=useMemo(()=>({priceErrorMsg:X("order_price"),quantityErrorMsg:X("order_quantity")}),[M]),se=!!(Kt||re),qt=useCallback(bt=>{if(E&&E>0){let Gt=utils.formatNumber(bt,E)??bt;C(Gt);}},[E,C]),He=useCallback(bt=>{l(bt);let Gt=new Decimal(bt).div(100).mul(z).toFixed(_,Decimal.ROUND_DOWN);qt(Gt);},[z,_,qt]);useEffect(()=>{let bt=Math.min(Number(f||0),z),Gt=new Decimal(bt).div(z).mul(100).toDecimalPlaces(2,Decimal.ROUND_DOWN).toNumber();l(Gt);},[f]);let _n=useCallback(()=>{C(z?.toString());},[z,C]),ze=useCallback(()=>d().then(bt=>{o(false),r(false),a(false);}),[d]),hn=useCallback(()=>u?(r(true),Promise.resolve()):ze(),[ze,u]),Tn=useCallback(()=>{o(false);},[]),Fn=useCallback(()=>{r(false);},[]),Nn=useCallback(()=>{a(false);},[]),wn=useCallback(()=>{C("0"),m.current?.focus(),setTimeout(()=>{m.current?.setSelectionRange(0,1);},0);},[C]);return {position:c,closeOrderData:y,quote_dp:ut,base_dp:_,base:p,quote:$,price:x,quantity:f,submitting:b,onConfirm:ze,onDoubleConfirm:hn,updatePriceChange:N,updateQuantity:C,formatQuantityToBaseTick:qt,updateOrderType:D,sliderValue:s,onSliderValueChange:He,priceErrorMsg:Kt,quantityErrorMsg:re,disabled:se,isMarketClose:ne,maxQty:z,onMax:_n,isBuy:h,isEntirePosition:Ee,type:ie,quantityInputRef:m,onEntirePosition:wn,sheetOpen:e,onCloseSheet:Tn,setSheetOpen:o,dialogOpen:i,setDialogOpen:r,onCloseDialog:Fn,popoverOpen:n,setPopoverOpen:a,onClosePopover:Nn}};var kt=t=>{let e=oo(t),{isMobile:o}=useScreen();return o?jsx(to,{...e}):jsx(eo,{...e})};var vt=()=>{let{position:t,baseDp:e,quoteDp:o,tpslOrder:i}=tt(),{isMobile:r}=useScreen();return jsx(EditIcon,{onClick:()=>{let a=r?TPSLDetailSheetId:TPSLDetailDialogId;modal.show(a,{order:i,position:t,baseDP:e,quoteDP:o});},opacity:1,className:"oui-cursor-pointer oui-text-base-contrast-54",size:16})},dt=t=>{let{position:e,baseDp:o,quoteDp:i,tpslOrder:r}=tt(),[n]=useLocalStorage("orderly_order_confirm",true),{t:a}=useTranslation(),{isMobile:s}=useScreen(),l=()=>{let m=s?TPSLSheetId:TPSLDialogId,u={symbol:e.symbol,baseDP:o,quoteDP:i,isEditing:false,positionType:t.positionType};modal.show(m,u);};return jsx(Text,{className:cn("oui-cursor-pointer oui-text-base-contrast",s&&"oui-text-base-contrast-80"),onClick:l,children:a("tpsl.add")})},he=t=>{let{symbol:e,leverage:o}=t,i=()=>{modal.show(t.modalId,{symbol:e,curLeverage:o});};return jsxs("div",{className:cn("oui-flex oui-h-[18px] oui-items-center oui-gap-1","oui-cursor-pointer oui-rounded oui-bg-line-6 oui-pl-2 oui-pr-1","oui-text-2xs oui-font-semibold oui-text-base-contrast-36"),onClick:i,children:[jsx(Text,{children:"Cross"}),o?jsx(Text.numeral,{dp:0,rm:Decimal.ROUND_DOWN,size:"2xs",unit:"X",children:o}):jsx(bs,{symbol:e}),jsx(ChevronRightIcon,{size:14,opacity:1,className:"oui-text-base-contrast-36"})]})},bs=({symbol:t})=>{let e=useLeverageBySymbol(t);return jsx(Text.numeral,{dp:0,rm:Decimal.ROUND_DOWN,size:"2xs",unit:"X",children:e||1})};var di=t=>{let e=K();return jsx(Text.numeral,{dp:e.base_dp,rm:Decimal.ROUND_DOWN,padding:false,coloring:true,children:t})};var Te=t=>{let{tick:e="quote_dp",children:o,...i}=t,r=K();if(!r)throw new Error("NumeralWithCtx must be used inside SymbolProvider");return jsx(Text.numeral,{as:"span",dp:r[e],...i,children:o})};var fi=t=>{let{orderNum:e,tpTriggerPrice:o,slTriggerPrice:i,direction:r="column"}=t,{partialTPSLOrder:n,quoteDp:a,baseDp:s}=tt(),l=useSymbolsInfo(),{t:m}=useTranslation(),u=useMemo(()=>{let d=[];return n?.symbol?(o&&d.push(jsx(Text.formatted,{className:cn("oui-text-trade-profit oui-gap-0 oui-decoration-white/20"),rule:"price",dp:l[n.symbol]("quote_dp",2),children:o,prefix:!i||r==="column"?jsx(Text,{intensity:54,children:`${m("tpsl.tp")} - `}):""},"tp")),i&&d.push(jsx(Text.formatted,{className:cn("oui-text-trade-loss oui-gap-0 oui-decoration-white/20 "),rule:"price",dp:l[n.symbol]("quote_dp",2),prefix:jsx(Text,{intensity:54,children:`${m("tpsl.sl")} - `}),children:i},"sl")),d.length===0?jsx(dt,{positionType:PositionType.PARTIAL}):(d.length===2&&r==="row"&&d.splice(1,0,jsx(Text,{children:"/"},"split")),d)):jsx(dt,{positionType:PositionType.PARTIAL})},[o,i,n?.symbol,m]),c=Array.isArray(u)?!!u.length:!u;return jsxs(Flex,{className:"oui-gap-[6px]",children:[jsx("div",{className:cn("oui-inline-flex oui-text-base-contrast-36",r==="column"?"oui-flex-col":"oui-flex-row oui-gap-1"),children:u}),c&&jsxs(Fragment,{children:[jsxs(Text,{className:"oui-text-base-contrast-54",children:["(",e,")"]}),jsx(vt,{})]})]})};var so=t=>t.sharePnLConfig?jsx("button",{type:"button",onClick:e=>{e.stopPropagation(),t.showModal();},children:jsx(ShareIcon,{color:"white",opacity:.54,size:t.iconSize??16})}):null;var xi=t=>{let{position:e,sharePnLConfig:o,iconSize:i}=t,{getFirstRefCode:r}=useReferralInfo(),n=useSymbolsInfo(),{data:a}=useAccountInfo(),s=useMemo(()=>r()?.code,[r]),l=useLeverageBySymbol(e.symbol),m=()=>{let c=e.netPnL||0,d=Math.abs(e.avg_open_price),x=Math.abs(e.closed_position_qty),f,y=n[e.symbol],b=y("base_imr"),N=y("imr_factor");if(c!==0&&x!==0&&d!==0&&a?.max_leverage&&b&&N){let D=positions.notional(x,d),C=e.leverage?e.leverage:a.max_leverage,M=account.IMR({maxLeverage:C,baseIMR:b,IMR_Factor:N,positionNotional:D,ordersNotional:0,IMR_factor_power:4/5}),E=positions.unrealizedPnLROI({positionQty:x,openPrice:d,IMR:M,unrealizedPnL:c});f=new Decimal(E*100).toFixed(2,Decimal.ROUND_DOWN);}return {side:e.side,pnl:c,roi:f,openPrice:d,closePrice:Math.abs(e.avg_close_price),openTime:e.open_timestamp,closeTime:e.close_timestamp,quantity:e.closed_position_qty}};return {iconSize:i,sharePnLConfig:o,showModal:()=>{let c=t.isPositionHistory?m():{side:e.position_qty>0?"LONG":"SHORT",pnl:e.unrealized_pnl,roi:new Decimal(e.unrealized_pnl_ROI*100).toFixed(2,Decimal.ROUND_DOWN),openPrice:Math.abs(e.average_open_price),markPrice:e.mark_price,openTime:e.timestamp,quantity:e.position_qty};modal.show(t.modalId,{pnl:{entity:{symbol:e.symbol,leverage:e.leverage||l,...c},refCode:s,...o}});}}};var ft=t=>{let e=xi(t);return jsx(so,{...e})};var _i=t=>{let{stopLossPrice:e,takeProfitPrice:o}=t,{tpslOrder:i,position:r}=tt();return jsx(Qs,{stopLossPrice:e,takeProfitPrice:o,direction:"column",order:i,position:r,tooltip:true})},Ci=t=>{let{qty:e,price:o,entryPrice:i,orderSide:r,orderType:n,symbolInfo:a}=t,s=utils.priceToPnl({qty:e,price:o,entryPrice:i,orderSide:r,orderType:n},{symbol:a}),l=n===AlgoOrderType.TAKE_PROFIT?"TP":"SL";return jsxs(Flex,{children:[jsx(Text,{intensity:54,className:"oui-mr-1",children:`${l} PnL:`}),jsx(Text.formatted,{rule:"price",className:s===0?"oui-text-base-contrast-36":s>0?"oui-text-trade-profit oui-gap-0":"oui-text-trade-loss oui-gap-0",prefix:jsx(Text,{children:s===0?"":s>0?"+":"-"}),suffix:jsx(Text,{intensity:36,className:"oui-ml-1",children:"USDC"}),children:`${Math.abs(s)}`})]})},Qs=t=>{let{direction:e="row",order:o,position:i}=t,r=useSymbolsInfo(),{t:n}=useTranslation(),a=useMemo(()=>{let u=[];if(!t.tooltip||!o||!i)return;let c=o.quantity;return c===0&&o.child_orders[0].type==="CLOSE_POSITION"&&(c=i.position_qty),t.takeProfitPrice&&u.push(jsx(Ci,{qty:c,price:t.takeProfitPrice,entryPrice:i.average_open_price,orderSide:o.side,orderType:AlgoOrderType.TAKE_PROFIT,symbolInfo:r[o.symbol]()},"tp")),t.stopLossPrice&&u.push(jsx(Ci,{qty:c,price:t.stopLossPrice,entryPrice:i.average_open_price,orderSide:o.side,orderType:AlgoOrderType.STOP_LOSS,symbolInfo:r[o.symbol]()},"sl")),jsx("div",{children:u})},[t.takeProfitPrice,t.stopLossPrice,i?.average_open_price,o?.side,o?.quantity,o?.algo_type]),s=useMemo(()=>{let u=[];if(!o?.symbol)return jsx(dt,{positionType:PositionType.FULL});return t.takeProfitPrice&&u.push(jsx(Text.formatted,{className:cn("oui-text-trade-profit oui-gap-0 oui-decoration-white/20"),rule:"price",dp:r[o.symbol]("quote_dp",2),children:t.takeProfitPrice,prefix:!t.stopLossPrice||e==="column"?jsx(Text,{intensity:54,children:`${n("tpsl.tp")} - `}):""},"tp")),t.stopLossPrice&&u.push(jsx(Text.formatted,{className:cn("oui-text-trade-loss oui-gap-0 oui-decoration-white/20 "),rule:"price",dp:r[o.symbol]("quote_dp",2),children:t.stopLossPrice,prefix:!t.takeProfitPrice||e==="column"?jsx(Text,{intensity:54,children:`${n("tpsl.sl")} - `}):""},"sl")),u.length===0?jsx(dt,{positionType:PositionType.FULL}):(u.length===2&&e==="row"&&u.splice(1,0,jsx(Text,{children:"/"},"split")),u)},[t.takeProfitPrice,t.stopLossPrice,o?.symbol,n]),l=jsx("div",{className:cn("oui-inline-flex oui-text-base-contrast-36",t.direction==="column"?"oui-flex-col":"oui-flex-row oui-gap-1",t.className),children:s}),m=Array.isArray(s)?!!s.length:!s;return t.tooltip?jsxs(Flex,{gapX:2,children:[jsx(Tooltip,{content:a,children:l}),m&&jsx(vt,{})]}):l};var wi=t=>{let[e,o]=useLocalStorage("unPnlPriceBasis","markPrice"),{t:i}=useTranslation();return jsxs(Flex,{direction:"column",gap:3,className:"oui-text-base-contrast-54 oui-items-start",children:[jsx(Text,{children:i("positions.column.unrealPnl.tooltip")}),jsx(Divider,{className:"oui-w-full"}),jsx("div",{className:"oui-mb-0",children:i("positions.column.unrealPnl.priceBasis")}),jsx(Ks,{value:e,onValueChange:o})]})},Ks=t=>{let{value:e,onValueChange:o}=t,{t:i}=useTranslation();return jsxs(Flex,{gap:2,children:[jsx(Ti,{sel:e==="markPrice",label:i("common.markPrice"),value:"markPrice",onCheckChange:o}),jsx(Ti,{sel:e==="lastPrice",label:i("common.lastPrice"),value:"lastPrice",onCheckChange:o})]})},Ti=t=>{let{sel:e,label:o,value:i,onCheckChange:r}=t;return jsxs(Flex,{onClick:n=>{r(i),n.stopPropagation();},gap:1,className:"oui-cursor-pointer",children:[e?jsx(Gs,{}):jsx(Vs,{}),jsx(Text,{size:"xs",intensity:e?98:54,children:o})]})},Gs=()=>jsxs("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"currentColor",xmlns:"http://www.w3.org/2000/svg",className:"oui-fill-white",children:[jsx("path",{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",fill:"#fff",fillOpacity:".36"}),jsx("circle",{cx:"8",cy:"8",r:"3.333"})]}),Vs=()=>jsx("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:jsx("path",{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",fill:"#fff",fillOpacity:".54"})});var mo=t=>{let{pnlNotionalDecimalPrecision:e,sharePnLConfig:o,onSymbolChange:i}=t,{t:r}=useTranslation(),n=useRef(Date.now().toString());return useMemo(()=>[{title:r("common.symbol"),dataIndex:"symbol",fixed:"left",width:140,onSort:(s,l)=>s.symbol?.localeCompare(l.symbol||""),render:(s,l)=>jsxs(Flex,{gap:2,children:[jsx(Box,{width:4,height:20,className:cn("oui-h-[38px] oui-rounded-[1px]",l.position_qty>0?"oui-bg-trade-profit":"oui-bg-trade-loss")}),jsxs(Flex,{direction:"column",itemAlign:"start",children:[jsx(Text.formatted,{formatString:"base-type",className:"oui-cursor-pointer",onClick:m=>{i?.({symbol:s}),m.stopPropagation(),m.preventDefault();},children:`${s.split("_")[1]}-PERP`}),jsx(he,{symbol:s,leverage:l.leverage,modalId:SymbolLeverageDialogId})]})]})},{title:r("common.quantity"),dataIndex:"position_qty",onSort:(s,l)=>s.position_qty-l.position_qty,width:120,className:"oui-pl-6",render:di},{title:r("common.avgOpen"),className:"oui-h-[48px]",width:120,onSort:true,dataIndex:"average_open_price",render:s=>jsx(Te,{rm:Decimal.ROUND_DOWN,children:s})},{title:r("common.markPrice"),dataIndex:"mark_price",width:120,onSort:true,className:"oui-h-[48px]",render:s=>jsx(Te,{rm:Decimal.ROUND_DOWN,children:s})},{title:jsx(Tooltip,{className:"oui-max-w-[280px] oui-bg-base-8 oui-p-3 oui-text-2xs oui-text-base-contrast-54",content:r("positions.column.liqPrice.tooltip"),children:jsx(Text,{children:r("positions.column.liqPrice")})}),width:100,onSort:true,dataIndex:"est_liq_price",render:s=>Number(s)===0?"--":jsx(Te,{rm:Decimal.ROUND_DOWN,className:Number(s)>0?"oui-text-warning-light":"",children:s??"--"})},{title:jsx(HoverCard,{content:jsx(wi,{}),side:"top",align:"center",className:"oui-max-w-[280px] oui-text-2xs",children:jsx(Text,{children:r("common.unrealizedPnl")})}),dataIndex:"unrealized_pnl",width:180,onSort:true,rule:"price",numeralProps:{coloring:true},render:(s,l)=>jsxs(Flex,{gap:2,children:[jsxs(Flex,{children:[jsx(Text.numeral,{dp:e,rm:Decimal.ROUND_DOWN,coloring:true,className:"oui-font-semibold",children:s}),jsx(Text.numeral,{rule:"percentages",dp:e,rm:Decimal.ROUND_DOWN,coloring:true,className:"oui-font-semibold",prefix:"(",suffix:")",children:l.unrealized_pnl_ROI})]}),jsx(ft,{position:l,sharePnLConfig:o,modalId:SharePnLDialogId})]})},{title:r("common.fullTPSL"),dataIndex:"full_tpsl",width:150,render:(s,l)=>jsx(_i,{stopLossPrice:l.full_tp_sl?.sl_trigger_price,takeProfitPrice:l.full_tp_sl?.tp_trigger_price})},{title:r("common.partialTPSL"),dataIndex:"partial_tpsl",width:150,render:(s,l)=>jsx(fi,{orderNum:l.partial_tp_sl?.order_num,tpTriggerPrice:l.partial_tp_sl?.tp_trigger_price,slTriggerPrice:l.partial_tp_sl?.sl_trigger_price})},{title:r("common.notional"),dataIndex:"notional",className:"oui-h-[48px]",width:100,onSort:true,render:s=>jsx(Text.numeral,{dp:e,children:s})},{title:jsx(Tooltip,{className:"oui-max-w-[280px] oui-bg-base-8 oui-p-3 oui-text-2xs oui-text-base-contrast-54",content:jsxs(Flex,{direction:"column",gap:3,className:"oui-rounded-sm oui-bg-base-8 oui-text-base-contrast-54",children:[jsx("span",{children:r("positions.column.margin.tooltip")}),jsx(Divider,{className:"oui-w-full"}),jsx("span",{children:r("positions.column.margin.formula")})]}),children:jsx(Text,{children:r("positions.column.margin")})}),dataIndex:"mm",onSort:true,width:100,rule:"price",render:s=>jsx(Text.numeral,{children:s})},{title:r("funding.fundingFee"),dataIndex:"fundingFee",width:100,render:(s,l)=>jsx(mt,{fee:s,symbol:l.symbol,start_t:l.timestamp.toString(),end_t:n.current})},{title:null,dataIndex:"close_position",align:"right",width:70,fixed:"right",render(){return jsx(Flex,{gapX:2,justify:"end",children:jsx(kt,{})})}}],[e,o,r])};var Li=t=>{let{item:e}=t,o=e.position_qty>0,{t:i}=useTranslation();return jsx(Text.formatted,{rule:"symbol",formatString:"base-type",size:"2xs",suffix:jsxs("div",{className:"oui-flex oui-items-center oui-gap-1",children:[jsx(Badge,{color:o?"success":"danger",size:"xs",children:i(o?"common.long":"common.short")}),jsx(he,{symbol:e.symbol,leverage:e.leverage,modalId:SymbolLeverageSheetId})]}),showIcon:true,onClick:()=>{t.onSymbolChange?.({symbol:e.symbol});},children:e.symbol})},qi=t=>{let{item:e}=t,{t:o}=useTranslation();return jsxs(Flex,{gap:3,children:[jsxs(Flex,{direction:"column",className:"oui-text-2xs",itemAlign:"end",children:[jsxs("div",{children:[jsx(Text,{intensity:36,children:o("common.unrealizedPnl")}),jsx(Text,{intensity:20,children:"(USDC)"})]}),jsx(Text.numeral,{size:"xs",dp:t.pnlNotionalDecimalPrecision,rm:Decimal.ROUND_DOWN,coloring:true,className:"orderly-font-semibold",suffix:jsx(Text.numeral,{rule:"percentages",dp:t.pnlNotionalDecimalPrecision,rm:Decimal.ROUND_DOWN,prefix:"(",suffix:")",className:cn("oui-ml-1",e.unrealized_pnl_ROI>0?"oui-text-success-darken":"oui-text-danger-darken"),children:e.unrealized_pnl_ROI}),children:e.unrealized_pnl})]}),jsx(ft,{position:e,sharePnLConfig:t.sharePnLConfig,modalId:SharePnLBottomSheetId,iconSize:12})]})},Ri=t=>{let{item:e}=t,{t:o}=useTranslation();return jsx(Statistic,{label:o("common.qty"),classNames:{root:"oui-text-xs",label:"oui-text-2xs"},children:jsx(Text.numeral,{dp:t.base_dp,padding:false,coloring:true,children:e.position_qty})})},Mi=t=>{let{item:e}=t,{t:o}=useTranslation();return jsx(Statistic,{label:jsxs("span",{children:[o("positions.column.margin"),jsx(Text,{intensity:20,children:"(USDC)"})]}),classNames:{root:"oui-text-xs",label:"oui-text-2xs"},children:jsx(Text.numeral,{dp:t.quote_dp,intensity:80,children:e.mm})})},Oi=t=>{let{item:e}=t,{t:o}=useTranslation();return jsx(Statistic,{align:"end",label:jsxs("span",{children:[o("common.notional"),jsx(Text,{intensity:20,children:"(USDC)"})]}),classNames:{root:"oui-text-xs",label:"oui-text-2xs"},children:jsx(Text.numeral,{dp:t.quote_dp,intensity:80,children:e.notional})})},Ai=t=>{let{item:e}=t,{t:o}=useTranslation();return jsx(Statistic,{label:o("common.avgOpen"),classNames:{root:"oui-text-xs",label:"oui-text-2xs"},children:jsx(Text.numeral,{dp:t.quote_dp,rm:Decimal.ROUND_DOWN,intensity:80,children:e.average_open_price})})},ki=t=>{let{item:e}=t,{t:o}=useTranslation();return jsx(Statistic,{label:o("common.markPrice"),classNames:{root:"oui-text-xs",label:"oui-text-2xs"},children:jsx(Text.numeral,{dp:t.quote_dp,rm:Decimal.ROUND_DOWN,intensity:80,children:e.mark_price})})},Ei=t=>{let{item:e}=t,{t:o}=useTranslation(),i=e.est_liq_price&&e.est_liq_price>0?e.est_liq_price:"-";return jsx(Statistic,{label:o("positions.column.liqPrice"),align:"end",classNames:{root:"oui-text-xs",label:"oui-text-2xs"},children:jsx(Text.numeral,{dp:t.quote_dp,rm:Decimal.ROUND_DOWN,color:"warning",children:i})})},Hi=t=>{let{item:e}=t,{t:o}=useTranslation(),i=useMemo(()=>e.full_tp_sl?.tp_trigger_price==null&&e.full_tp_sl?.sl_trigger_price==null?jsx(dt,{positionType:PositionType.FULL}):jsxs(Flex,{className:"oui-gap-[2px]",children:[e.full_tp_sl?.tp_trigger_price&&jsx(Text.numeral,{color:"buy",children:e.full_tp_sl.tp_trigger_price}),e.full_tp_sl?.sl_trigger_price&&"/",e.full_tp_sl?.sl_trigger_price&&jsx(Text.numeral,{color:"sell",children:e.full_tp_sl.sl_trigger_price}),jsx(vt,{})]}),[e.full_tp_sl]),r=useMemo(()=>e.partial_tp_sl?.tp_trigger_price==null&&e.partial_tp_sl?.sl_trigger_price==null?jsx(dt,{positionType:PositionType.PARTIAL}):jsxs(Flex,{className:"oui-gap-[2px]",itemAlign:"center",children:[e.partial_tp_sl?.tp_trigger_price&&jsx(Text.numeral,{color:"buy",children:e.partial_tp_sl.tp_trigger_price}),e.partial_tp_sl?.sl_trigger_price&&"/",e.partial_tp_sl?.sl_trigger_price&&jsx(Text.numeral,{color:"sell",children:e.partial_tp_sl.sl_trigger_price}),jsx(Text,{children:`(${e.partial_tp_sl?.order_num})`}),jsx(vt,{})]}),[e.partial_tp_sl]);return jsxs(Grid,{cols:2,rows:1,gap:2,width:"100%",children:[jsxs(Flex,{className:"oui-text-2xs oui-text-base-contrast-36",direction:"column",itemAlign:"start",children:[jsxs(Text,{children:[o("common.fullTPSL"),": "]}),i]}),jsxs(Flex,{className:"oui-text-2xs oui-text-base-contrast-36 oui-grid-cols-end",direction:"column",itemAlign:"end",children:[jsxs(Text,{children:[o("common.partialTPSL"),": "]}),r]})]})},zi=t=>{let{t:e}=useTranslation(),o=useRef(Date.now().toString());return jsxs(Flex,{justify:"end",className:"oui-w-full oui-text-2xs",children:[jsxs(Text,{intensity:36,children:[e("funding.fundingFee"),": "]}),jsx(mt,{fee:t.item.fundingFee,symbol:t.item.symbol,start_t:t.item.timestamp.toString(),end_t:o.current})]})};var co=t=>{let{className:e,...o}=t,i=jsxs(Flex,{justify:"between",width:"100%",children:[jsx(Li,{...t}),jsx(qi,{...t})]}),r=jsxs(Grid,{cols:3,rows:2,gap:2,width:"100%",children:[jsx(Ri,{...t}),jsx(Mi,{...t}),jsx(Oi,{...t}),jsx(Ai,{...t}),jsx(ki,{...t}),jsx(Ei,{...t})]}),n=jsxs(Grid,{width:"100%",gap:2,cols:2,rows:1,children:[jsx(kt,{type:OrderType.LIMIT}),jsx(kt,{type:OrderType.MARKET})]});return jsxs(Flex,{direction:"column",width:"100%",gap:2,p:2,r:"xl",itemAlign:"start",className:cn(e,"oui-bg-base-9"),children:[i,jsx(Divider,{intensity:6,className:"oui-w-full"}),r,jsx(Hi,{...o}),jsx(zi,{...o}),n]})};var po=t=>{let e=K();return {...t,...e}};var fo=t=>{let e=po(t);return jsx(co,{...e,className:t.className})};var Ie=t=>{let{position:e,children:o,mutatePositions:i}=t,{t:r}=useTranslation(),[n,a]=useState(Math.abs(e.position_qty).toString()),[s,l]=useState(""),[m,u]=useState(OrderType.MARKET);useEffect(()=>{a(Math.abs(e.position_qty).toString());},[e.position_qty]);let c=e.symbol,d=useSymbolsInfo(),x=d?.[c],f=x("quote_dp"),y=x("base_dp"),b=x("base_tick"),{side:N,closeOrderData:D,submit:C,isMutating:M,errors:E,calculate:Q}=usePositionClose({position:e,order:{type:m,quantity:n,price:s}}),ut=useCallback(h=>{let z=Q({},"order_quantity",h,e.mark_price,x());a(z.order_quantity);},[Q,d,e.mark_price]),_=useCallback(h=>{let z=Q({},"order_price",h,e.mark_price,x());l(z.order_price);},[Q,d,e.mark_price]),p=useCallback(h=>{u(h),l(h===OrderType.LIMIT?e.mark_price?.toString():"");},[e.mark_price]),$=useCallback(async()=>{if(Number(n)>x("base_max")){toast.error(jsxs("div",{children:[r("positions.limitClose.errors.exceed.title"),jsx("br",{}),jsx("div",{className:"oui-break-normal",children:r("positions.limitClose.errors.exceed.description",{quantity:n,symbol:ba(c,"base"),maxQuantity:x("base_max")})})]}));return}return C().then(h=>{if(h.success)return i?.(),h;throw h.message&&toast.error(h.message),true}).catch(h=>(h.message&&toast.error(h.message),false))},[C]),X=useMemo(()=>({quantity:n,price:s,type:m,side:N,position:e,updatePriceChange:_,updateQuantity:ut,updateOrderType:p,tpslOrder:e.full_tp_sl?.algo_order,partialTPSLOrder:e.partial_tp_sl?.algo_order,onSubmit:$,submitting:M,closeOrderData:D,quoteDp:f,baseDp:y,baseTick:b,errors:E}),[n,s,m,N,e,_,ut,p,$,M,D,f,y,b,E]);return jsx(We.Provider,{value:X,children:o})};function ba(t,e="base"){let o=t.split("_"),i=o[0],r=o[1],n=o[2];return (e??"base-quote").replace("type",i).replace("base",r).replace("quote",n)}var Ki=t=>{let{pnlNotionalDecimalPrecision:e,sharePnLConfig:o,pagination:i,isLoading:r,dataSource:n,onSymbolChange:a}=t,s=mo({pnlNotionalDecimalPrecision:e,sharePnLConfig:o,onSymbolChange:a});return jsx(AuthGuardDataTable,{loading:r,id:"oui-desktop-positions-content",columns:s,bordered:true,dataSource:n,generatedRowKey:l=>l.symbol,renderRowContainer:(l,m,u)=>jsx(Nt,{symbol:l.symbol,children:jsx(Ie,{position:l,children:u})}),manualPagination:false,pagination:i,manualSorting:true,onSort:t.onSort,initialSort:t.initialSort?{sortKey:t.initialSort.sortKey,sort:t.initialSort.sortOrder}:void 0,testIds:{body:"oui-testid-dataList-position-tab-body"}})},Gi=t=>{let{pnlNotionalDecimalPrecision:e,sharePnLConfig:o,dataSource:i,onSymbolChange:r}=t;return jsx(ListView,{className:"oui-hide-scrollbar oui-w-full oui-space-y-0 oui-overflow-y-hidden",contentClassName:"!oui-space-y-1",dataSource:i,renderItem:(n,a)=>jsx(Nt,{symbol:n.symbol,children:jsx(Ie,{position:n,children:jsx(fo,{item:n,index:a,pnlNotionalDecimalPrecision:e,sharePnLConfig:o,onSymbolChange:r})})})})},Vi=t=>{let{pnlNotionalDecimalPrecision:e,sharePnLConfig:o,pagination:i,isLoading:r,tableData:n,onSymbolChange:a,mutatePositions:s}=t,l=mo({pnlNotionalDecimalPrecision:e,sharePnLConfig:o,onSymbolChange:a}),{dataSource:m=[]}=n;return jsx(AuthGuardDataTable,{bordered:true,loading:r,id:"oui-desktop-positions-content",columns:l,dataSource:m,expanded:true,getSubRows:u=>u.children,generatedRowKey:u=>u.id,onCell:(u,c)=>{if((c.children??[]).length>0)return {children:u.id==="symbol"?jsx(Badge,{color:"neutral",size:"xs",children:c?.description||formatAddress(c?.id)}):null}},renderRowContainer:(u,c,d)=>u.symbol?jsx(Nt,{symbol:u.symbol,children:jsx(Ie,{position:u,mutatePositions:s,children:d})}):d,manualPagination:false,pagination:i,testIds:{body:"oui-testid-dataList-position-tab-body"}})};var ha=t=>{let e=Xe(t);return jsx(Ki,{...e})},Ta=t=>{let e=Xe(t);return jsx(Gi,{...e})},Fa=t=>{let e=Xo(t);return jsx(Vi,{...e})};var Zi=t=>{let{onSymbolChange:e,pnlNotionalDecimalPrecision:o}=t,{t:i}=useTranslation();return useMemo(()=>[{title:i("common.symbol"),dataIndex:"symbol",fixed:"left",width:200,onSort:(n,a)=>n.symbol?.localeCompare(a.symbol||""),render:(n,a)=>jsx(La,{record:a,onSymbolChange:e})},{title:i("positions.history.column.closed&maxClosed"),dataIndex:"close_maxClose",width:200,render:(n,a)=>jsx(qa,{record:a})},{title:i("positions.history.column.netPnl"),dataIndex:"netPnL",width:140,onSort:(n,a)=>n.netPnL==null||a.netPnL==null?-1:(n.netPnL??0)-(a.netPnL??0),render:(n,a)=>jsxs(Flex,{gapX:1,children:[jsx(Ra,{record:a,pnlNotionalDecimalPrecision:o}),jsx(ft,{position:a,sharePnLConfig:t.sharePnLConfig,modalId:SharePnLDialogId,isPositionHistory:true})]})},{title:i("common.avgPrice"),dataIndex:"avg_open",width:140,render:(n,a)=>{let s=a.avg_open_price!=null?Math.abs(a.avg_open_price):"--",{quote_dp:l}=K();return jsx(Text.numeral,{dp:l,padding:false,children:s})}},{title:i("common.avgClose"),dataIndex:"avg_close",width:175,render:(n,a)=>{let s=a.avg_close_price!=null?Math.abs(a.avg_close_price):"--",{quote_dp:l}=K();return jsx(Text.numeral,{dp:l,padding:false,children:s})}},{title:i("funding.fundingFee"),dataIndex:"accumulated_funding_fee",render:(n,a)=>jsx(mt,{fee:-n,symbol:a.symbol,start_t:a.open_timestamp.toString(),end_t:a.close_timestamp?.toString()})},{title:i("positions.history.column.timeOpened"),dataIndex:"open_timestamp",width:175,onSort:true,render:(n,a)=>jsx(Text.formatted,{rule:"date",formatString:"yyyy-MM-dd HH:mm:ss",children:a.open_timestamp})},{title:i("positions.history.column.timeClosed"),dataIndex:"close_timestamp",width:175,onSort:true,render:(n,a)=>a.position_status=="closed"&&a.close_timestamp?jsx(Text.formatted,{rule:"date",formatString:"yyyy-MM-dd HH:mm:ss",children:a.close_timestamp??"--"}):"--"},{title:i("positions.history.column.updatedTime"),dataIndex:"last_update_time",width:175,onSort:true,render:(n,a)=>jsx(Text.formatted,{rule:"date",formatString:"yyyy-MM-dd HH:mm:ss",children:a.last_update_time})}],[o,i])},La=t=>{let{record:e,onSymbolChange:o}=t,{t:i}=useTranslation(),r=useMemo(()=>{let n=[],a=e.position_status,s=()=>a==="closed"?i("positions.history.status.closed"):a==="partial_closed"?i("positions.history.status.partialClosed"):capitalizeFirstLetter(a.replace("_"," "));return n.push(jsx(Badge,{color:a!=="closed"?"primaryLight":"neutral",size:"xs",className:"oui-whitespace-nowrap oui-break-normal",children:s()},`status-${a}`)),e.type==="adl"?n.push(jsx(Badge,{color:"danger",size:"xs",children:i("positions.history.type.adl")},`type-${e.type}`)):e.type==="liquidated"&&n.push(jsx(Tooltip,{className:"oui-min-w-[204px] oui-bg-base-5",arrow:{className:"oui-fill-base-5"},content:jsxs(Flex,{direction:"column",itemAlign:"start",className:"oui-text-2xs",children:[e.liquidation_id!=null&&jsxs(Flex,{justify:"between",width:"100%",gap:2,children:[jsx(Text,{intensity:54,children:i("positions.history.liquidated.liquidationId")}),jsx(Text,{intensity:98,children:e.liquidation_id})]}),jsxs(Flex,{justify:"between",width:"100%",gap:2,children:[jsx(Text,{intensity:54,children:i("positions.history.liquidated.liquidatorFee")}),jsxs(Text,{color:"lose",children:[e.liquidator_fee>0&&"-",commifyOptional(e.liquidator_fee)]})]}),jsxs(Flex,{justify:"between",width:"100%",gap:2,children:[jsx(Text,{intensity:54,children:i("positions.history.liquidated.insFundFee")}),jsxs(Text,{color:"lose",children:[e.insurance_fund_fee>0&&"-",commifyOptional(e.insurance_fund_fee)]})]})]}),children:jsx("div",{children:jsx(Badge,{size:"xs",color:"danger",className:"oui-cursor-pointer",children:jsx("span",{className:"oui-underline oui-decoration-dashed oui-decoration-1",children:i("positions.history.type.liquidated")})})})},`type-${e.type}`)),n.push(jsx(Ma,{symbol:e.symbol,leverage:e.leverage},`leverage-${e.symbol}`)),n},[e,i]);return jsxs(Flex,{gap:2,height:48,children:[jsx(Box,{width:4,height:38,className:cn("oui-shrink-0 oui-rounded-[1px]",e.side==="LONG"?"oui-bg-trade-profit":"oui-bg-trade-loss")}),jsxs(Flex,{direction:"column",itemAlign:"start",children:[jsx(Text.formatted,{formatString:"base-type",className:"oui-cursor-pointer",onClick:n=>{o?.({symbol:e.symbol}),n.stopPropagation(),n.preventDefault();},children:`${e.symbol.split("_")[1]}-PERP`}),jsx(Flex,{gap:1,children:r})]})]})},qa=t=>{let{record:e}=t,{base_dp:o}=K();return jsxs(Flex,{gap:1,direction:"column",itemAlign:"start",className:"oui-truncate",children:[jsx(Text.numeral,{dp:o,padding:false,children:Math.abs(e.closed_position_qty)}),jsx(Text.numeral,{dp:o,padding:false,className:"oui-truncate",children:Math.abs(e.max_position_qty)})]})},Ra=t=>{let{record:e,pnlNotionalDecimalPrecision:o}=t,{t:i}=useTranslation(),r=e.netPnL!=null?e.netPnL:void 0,n=()=>jsx(Text.numeral,{dp:o,color:e.netPnL!=null?e.netPnL>0?"profit":"lose":void 0,className:r==null?"":"oui-cursor-pointer oui-border-b oui-border-dashed oui-border-line-12",children:r??"--"});return e.netPnL==null?n():jsx(Tooltip,{delayDuration:200,content:jsxs(Flex,{direction:"column",itemAlign:"start",className:"oui-text-2xs",children:[jsx(Text,{intensity:80,children:i("positions.history.column.netPnl")}),jsxs(Flex,{justify:"between",width:"100%",gap:2,children:[jsx(Text,{intensity:54,children:i("common.realizedPnl")}),jsx(Text,{color:e.realized_pnl>=0?"profit":"lose",className:"oui-cursor-pointer",children:commifyOptional(e.realized_pnl)})]}),jsxs(Flex,{justify:"between",width:"100%",gap:2,children:[jsx(Text,{intensity:54,children:i("funding.fundingFee")}),jsx(Text,{color:e.accumulated_funding_fee>0?"lose":"profit",className:"oui-cursor-pointer",children:commifyOptional(-e.accumulated_funding_fee)})]}),jsxs(Flex,{justify:"between",width:"100%",gap:2,children:[jsx(Text,{intensity:54,children:i("positions.history.netPnl.tradingFee")}),jsx(Text,{color:e.trading_fee>0?"lose":"profit",className:"oui-cursor-pointer",children:commifyOptional(-e.trading_fee)})]})]}),className:"oui-min-w-[204px] oui-bg-base-5",arrow:{className:"oui-fill-base-5"},children:jsx("div",{children:n()})})},Ma=t=>{let{symbol:e,leverage:o}=t;return jsx(Badge,{color:"neutral",size:"xs",children:o?jsx(Text.numeral,{dp:0,size:"2xs",unit:"X",children:o}):jsx(Oa,{symbol:e})})},Oa=({symbol:t})=>{let e=useMaxLeverage(t);return jsx(Text.numeral,{dp:0,size:"2xs",unit:"X",children:e})};function B(t){if(t==null)return t;let e=new Date(t);return e.setHours(0,0,0,0),e}function W(t){if(t==null)return t;let e=new Date(t);return e.setHours(23,59,59,999),e}var Bt=t=>({from:B(t.from),to:W(t.to??t.from)}),Wt=(t,e)=>t.getTime()===e.getTime();var qe=t=>{let{onSymbolChange:e,symbol:o,pnlNotionalDecimalPrecision:i,enableSortingStorage:r=true}=t,{state:n}=useAccount(),{tabSort:a,onTabSort:s}=Yt({storageKey:ce}),{onSort:l,getSortedList:m}=Xt(r?a?.positionHistory:void 0,r?s("positionHistory"):void 0),{data:u,isLoading:c}=usePrivateQuery(o?`/v1/position_history?symbol=${o}&limit=1000`:"/v1/position_history?limit=1000",{formatter(_){return (_.rows??null)?.map(p=>{if(p.realized_pnl!=null&&p.accumulated_funding_fee!=null&&p.trading_fee!=null){let $=p.realized_pnl-p.accumulated_funding_fee-p.trading_fee;return {...p,netPnL:$}}return p})},revalidateOnFocus:true}),{pagination:d,setPage:x}=usePagination({pageSize:10}),{status:f,side:y,dateRange:b,filterDays:N,updateFilterDays:D,filterItems:C,onFilter:M}=Ua();useEffect(()=>{x(1);},[f,y,b,N,o]);let E=useMemo(()=>u==null?u:u.filter(_=>{let p=y==="all"?true:_.side.toLowerCase()===y.toLowerCase(),$=f==="all"?true:_.position_status.toLowerCase()===f.toLowerCase(),X=_?.last_update_time??_.open_timestamp,h=b.from&&b.to?X>=b.from.getTime()&&X<=b.to.getTime():true,z=o?_.symbol==o:true;return p&&$&&h&&z}),[f,y,b,u,o]),Q=useDataTap(E,{accountStatus:n.status===AccountStatusEnum.EnableTradingWithoutConnected?AccountStatusEnum.EnableTradingWithoutConnected:AccountStatusEnum.EnableTrading,fallbackData:[]});return {dataSource:m(Q||[]),isLoading:c,onSymbolChange:e,pagination:d,filterItems:C,onFilter:M,symbol:o,filterDays:N,updateFilterDays:D,pnlNotionalDecimalPrecision:i,onSort:l,initialSort:r?a?.positionHistory:void 0}},Ua=()=>{let{t}=useTranslation(),[e,o]=useState("all"),[i,r]=useState("all"),n=Bt({to:W(new Date),from:B(subDays(new Date,89))}),[a,s]=useState(90),[l,m]=useState(n),u=f=>{s(f),m({from:B(subDays(new Date,f-1)),to:W(new Date)});},c=f=>{if(f.name==="side"&&r(f.value),f.name==="status"&&o(f.value),f.name==="dateRange"){let y=Bt(f.value);if(m(y),y.from&&y.to){let b=Math.abs(differenceInDays(y.from,y.to))+1,D={1:{from:B(new Date),to:W(new Date)},7:{from:B(subDays(new Date,6)),to:W(new Date)},30:{from:B(subDays(new Date,29)),to:W(new Date)},90:{from:B(subDays(new Date,89)),to:W(new Date)}}[b];D&&Wt(D.from,y.from)&&Wt(D.to,y.to)?s(b):s(null);}}},{isMobile:d}=useScreen();return {filterItems:useMemo(()=>{let f={type:"select",name:"side",options:[{label:t("common.side.all"),value:"all"},{label:t("common.buy"),value:"LONG"},{label:t("common.sell"),value:"SHORT"}],value:i},y={type:"range",name:"dateRange",value:l,fromDate:B(subDays(new Date,89)),toDate:W(new Date)},b={type:"select",name:"status",options:[{label:t("common.status.all"),value:"all"},{label:t("positions.history.status.closed"),value:"closed"},{label:t("positions.history.status.partialClosed"),value:"partial_closed"}],value:e};return d?[f,b]:[f,b,y]},[i,e,l]),onFilter:c,side:i,dateRange:l,status:e,filterDays:a,updateFilterDays:u}};var tn=t=>{let{side:e,symbol:o}=t.item,{t:i}=useTranslation(),r=e==="LONG";return jsx(Text.formatted,{intensity:80,rule:"symbol",formatString:"base-type",size:"sm",prefix:jsx(Badge,{color:r?"success":"danger",size:"xs",children:i(r?"common.buy":"common.sell")}),onClick:()=>{t.onSymbolChange?.({symbol:o});},children:o})};var en=t=>{let{item:e}=t,{t:o}=useTranslation(),i=()=>{modal.alert({title:o("positions.liquidation"),message:jsxs(Flex,{direction:"column",width:"100%",gap:2,className:"oui-text-2xs oui-text-base-contrast-54",children:[e.liquidation_id!=null&&jsxs(Flex,{justify:"between",width:"100%",children:[jsx(Text,{children:o("positions.history.liquidated.liquidationId")}),jsx(Text,{intensity:98,children:e.liquidation_id})]}),jsxs(Flex,{justify:"between",width:"100%",children:[jsx(Text,{children:o("positions.history.liquidated.liquidatorFee")}),jsxs(Text,{color:"lose",children:[e.liquidator_fee>0&&"-",commifyOptional(e.liquidator_fee)]})]}),jsxs(Flex,{justify:"between",width:"100%",children:[jsx(Text,{children:o("positions.history.liquidated.insFundFee")}),jsxs(Text,{color:"lose",children:[e.insurance_fund_fee>0&&"-",commifyOptional(e.insurance_fund_fee)]})]})]})});},r=useMemo(()=>{let n=[],a=e.position_status,s=()=>a==="closed"?o("positions.history.status.closed"):a==="partial_closed"?o("positions.history.status.partialClosed"):capitalizeFirstLetter(a.replace("_"," "));return n.push(jsx(Badge,{color:a!=="closed"?"primaryLight":"neutral",size:"xs",children:s()},1)),e.type==="adl"?n.push(jsx(Badge,{color:"danger",size:"xs",children:o("positions.history.type.adl")},2)):e.type==="liquidated"&&n.push(jsx(Badge,{size:"xs",color:"danger",className:"oui-cursor-pointer",onClick:i,children:jsx("span",{className:"oui-underline oui-decoration-dashed oui-decoration-1",children:o("positions.history.type.liquidated")})},3)),n},[e]);return jsx(Flex,{gap:1,children:r})},on=t=>{let{item:e}=t,{t:o}=useTranslation(),i=e.closed_position_qty!=null?Math.abs(e.closed_position_qty):"--";return jsx(Statistic,{label:jsx(Text,{children:o("positions.history.column.closed")}),classNames:{root:"oui-text-xs",label:"oui-text-2xs"},children:jsx(Text.numeral,{dp:t.base_dp,padding:false,coloring:true,intensity:80,children:i})})},nn=t=>{let{item:e}=t,{t:o}=useTranslation(),i=e.max_position_qty!=null?Math.abs(e.max_position_qty):"--";return jsx(Statistic,{label:jsx(Text,{children:o("positions.history.column.maxClosed")}),classNames:{root:"oui-text-xs",label:"oui-text-2xs"},children:jsx(Text.numeral,{dp:t.base_dp,padding:false,coloring:true,intensity:80,children:i})})},rn=t=>{let{item:e}=t,o=e.avg_open_price!=null?Math.abs(e.avg_open_price):"--",{t:i}=useTranslation();return jsx(Statistic,{label:jsxs(Flex,{gap:1,children:[i("common.avgOpen"),jsx(Text,{intensity:20,children:"(USDC)"})]}),classNames:{root:"oui-text-xs",label:"oui-text-2xs"},children:jsx(Text.numeral,{dp:t.quote_dp,padding:false,coloring:true,intensity:80,children:o})})},sn=t=>{let{item:e}=t,o=e.avg_close_price!=null?Math.abs(e.avg_close_price):"--",{t:i}=useTranslation();return jsx(Statistic,{label:jsxs(Flex,{gap:1,children:[i("common.avgClose"),jsx(Text,{intensity:20,children:"(USDC)"})]}),classNames:{root:"oui-text-xs",label:"oui-text-2xs"},children:jsx(Text.numeral,{dp:t.quote_dp,padding:false,coloring:true,intensity:80,children:o})})},an=t=>{let{item:e}=t,{t:o}=useTranslation();return jsx(Statistic,{label:jsx(Text,{children:o("positions.history.column.timeOpened")}),classNames:{root:"oui-text-xs",label:"oui-text-2xs"},align:"end",children:jsx(Text.formatted,{intensity:80,formatString:"yyyy-MM-dd HH:mm:ss",rule:"date",children:e.open_timestamp})})},ln=t=>{let{item:e}=t,{t:o}=useTranslation(),i=e.position_status=="closed"&&e.close_timestamp?jsx(Text.formatted,{intensity:80,formatString:"yyyy-MM-dd HH:mm:ss",rule:"date",children:e.close_timestamp}):"--";return jsx(Statistic,{label:jsx(Text,{children:o("positions.history.column.timeClosed")}),classNames:{root:"oui-text-xs",label:"oui-text-2xs"},align:"end",children:i})},un=t=>{let{t:e}=useTranslation();return jsxs(Flex,{justify:"end",className:"oui-text-2xs oui-w-full oui-py-2 oui-gap-1 oui-gap-1",children:[jsxs(Text,{intensity:36,children:[e("funding.fundingFee"),": "]}),jsx(mt,{fee:-t.item.accumulated_funding_fee,symbol:t.item.symbol,start_t:t.item.open_timestamp.toString(),end_t:t.item.close_timestamp?.toString()})]})};var _o=t=>jsxs(Flex,{direction:"column",width:"100%",gap:2,itemAlign:"start",className:t.classNames?.root,children:[jsx(ja,{...t}),jsx(Divider,{intensity:6,className:"oui-w-full"}),jsx(tl,{...t})]}),ja=t=>{let{t:e}=useTranslation(),o=()=>{let{item:i}=t;modal.alert({title:e("positions.history.column.netPnl"),message:jsxs(Flex,{direction:"column",width:"100%",gap:2,className:"oui-text-2xs oui-text-base-contrast-54",children:[jsxs(Flex,{justify:"between",width:"100%",gap:2,children:[jsx(Text,{intensity:54,children:e("common.realizedPnl")}),jsx(Text,{color:i.realized_pnl>=0?"profit":"lose",children:commifyOptional(i.realized_pnl)})]}),jsxs(Flex,{justify:"between",width:"100%",gap:2,children:[jsx(Text,{intensity:54,children:e("funding.fundingFee")}),jsx(Text,{color:i.accumulated_funding_fee>0?"lose":"profit",children:commifyOptional(-i.accumulated_funding_fee)})]}),jsxs(Flex,{justify:"between",width:"100%",gap:2,children:[jsx(Text,{intensity:54,children:e("positions.history.netPnl.tradingFee")}),jsx(Text,{color:i.trading_fee>0?"lose":"profit",children:commifyOptional(-i.trading_fee)})]})]})});};return jsxs(Flex,{gap:1,width:"100%",children:[jsxs(Flex,{direction:"column",itemAlign:"start",className:"oui-flex-1",gap:1,children:[jsx(tn,{...t}),jsx(en,{...t})]}),jsxs(Flex,{direction:"column",itemAlign:"end",className:"oui-flex-1",children:[jsx(Text,{size:"2xs",intensity:36,children:e("positions.history.column.netPnl")}),jsxs(Flex,{gapX:1,children:[jsx("button",{onClick:o,children:jsx(Text.numeral,{size:"xs",coloring:true,children:t.item.netPnL??"--"})}),jsx(ft,{position:t.item,sharePnLConfig:t.sharePnLConfig,modalId:SharePnLBottomSheetId,iconSize:12,isPositionHistory:true})]})]})]})},tl=t=>jsxs("div",{className:"oui-w-full",children:[jsxs(Grid,{cols:3,rows:2,width:"100%",gap:0,className:"oui-grid-cols-[1fr,1fr,135px]",children:[jsx(on,{...t}),jsx(nn,{...t}),jsx(an,{...t}),jsx(rn,{...t}),jsx(sn,{...t}),jsx(ln,{...t})]}),jsx(un,{...t})]});var ho=t=>{let e=K();return {...t,...e}};var To=t=>{let e=ho(t);return jsx(_o,{...e})};var wo=t=>{let{onSymbolChange:e,pagination:o,pnlNotionalDecimalPrecision:i}=t,r=Zi({onSymbolChange:e,pnlNotionalDecimalPrecision:i,sharePnLConfig:t.sharePnLConfig}),{t:n}=useTranslation(),a=useMemo(()=>({1:n("common.select.1d"),7:n("common.select.7d"),30:n("common.select.30d"),90:n("common.select.90d")}),[n]);return jsxs(Flex,{direction:"column",width:"100%",height:"100%",itemAlign:"start",children:[jsxs(Flex,{gap:3,children:[t.filterItems.length>0&&jsx(DataFilter,{items:t.filterItems,onFilter:s=>{t.onFilter(s);}}),[1,7,30,90].map(s=>jsxs("button",{className:"oui-relative oui-px-2 oui-py-[2px] oui-text-sm",children:[jsx("div",{className:"oui-z-10",children:jsx(Text.gradient,{color:t.filterDays===s?"brand":void 0,className:cn("oui-whitespace-nowrap oui-break-normal",t.filterDays!==s?"oui-text-base-contrast-54":""),children:a[s]||`${s}D`})}),jsx("div",{className:"oui-absolute oui-inset-0 oui-rounded oui-opacity-[.12] oui-gradient-primary",onClick:()=>{t.updateFilterDays(s);}})]},`item-${s}`))]}),jsx(AuthGuardDataTable,{loading:t.isLoading,id:"oui-desktop-positions-content",columns:r,bordered:true,dataSource:t.dataSource,generatedRowKey:s=>`${s.symbol}_${s.position_id}`,renderRowContainer:(s,l,m)=>jsx(Nt,{symbol:s.symbol,children:m}),manualPagination:false,pagination:o,manualSorting:true,onSort:t.onSort,initialSort:t.initialSort?{sortKey:t.initialSort.sortKey,sort:t.initialSort.sortOrder}:void 0,testIds:{body:"oui-testid-dataList-positionHistory-tab-body"},classNames:{root:"!oui-h-[calc(100%_-_49px)]"}})]})},vo=t=>jsxs(Grid,{cols:1,rows:2,className:"oui-w-full oui-grid-rows-[auto,1fr]",gap:1,children:[jsx(Flex,{gap:2,p:2,className:"oui-rounded-b-xl oui-bg-base-9",children:jsx(DataFilter,{className:"oui-border-none oui-py-0",items:t.filterItems,onFilter:e=>{t.onFilter(e);}})}),jsx(ListView,{className:cn("oui-hide-scrollbar oui-w-full oui-space-y-0 oui-overflow-y-hidden",t.classNames?.root),contentClassName:cn("!oui-space-y-1",t.classNames?.content),dataSource:t.dataSource,renderItem:(e,o)=>jsx(Nt,{symbol:e.symbol,children:jsx(To,{item:e,index:o,onSymbolChange:t.onSymbolChange,classNames:{root:t.classNames?.cell},sharePnLConfig:t.sharePnLConfig})})})]});var ll=t=>{let e=qe(t);return jsx(wo,{...e,sharePnLConfig:t.sharePnLConfig})},ul=t=>{let{classNames:e,...o}=t,i=qe(o);return jsx(vo,{...i,classNames:e,sharePnLConfig:t.sharePnLConfig})};var dn=t=>jsx(Tooltip,{className:"oui-w-[275px] oui-bg-base-6",content:t.tooltip,arrow:{className:"oui-fill-base-6"},children:jsx("button",{className:"oui-border-b oui-border-dashed oui-border-line-12",children:t.label})}),pn=t=>{let{t:e}=useTranslation();return useMemo(()=>[{title:e("common.time"),dataIndex:"timestamp",width:202,render:i=>jsx(Text.formatted,{rule:"date",formatString:"yyyy-MM-dd HH:mm:ss",children:i})},{title:e("positions.Liquidation.column.liquidationId"),dataIndex:"liquidation_id",width:120,render:i=>jsx(Text,{children:i})},{title:e("common.symbol"),dataIndex:"Symbol",render:(i,r)=>jsx(Flex,{direction:"column",itemAlign:"start",children:r.positions_by_perp?.map(n=>jsx(Text.formatted,{rule:"symbol",formatString:"base-quote",children:n.symbol},n.symbol))})},{title:e("positions.Liquidation.column.markPrice"),dataIndex:"Price_(USDC)",render:(i,r)=>jsx(Flex,{direction:"column",itemAlign:"start",children:r.positions_by_perp?.map(n=>jsx(Io,{value:n.mark_price,type:"quote"},n.symbol))})},{title:e("common.quantity"),dataIndex:"Quantity",render:(i,r)=>jsx(Flex,{direction:"column",itemAlign:"start",children:r.positions_by_perp?.map(n=>jsx(Io,{value:n.position_qty,type:"base"},n.symbol))})},{title:jsx(dn,{tooltip:e("positions.Liquidation.col.tooltip.feeRate"),label:e("positions.Liquidation.column.liquidationFeeRate")}),dataIndex:"liquidationFeeRate",render:i=>jsx(Text.numeral,{rule:"percentages",children:i})},{title:jsx(dn,{tooltip:e("positions.Liquidation.col.tooltip.fee"),label:e("positions.Liquidation.column.liquidationFee")}),dataIndex:"abs_liquidation_fee",width:100,render:(i,r)=>jsx(Flex,{direction:"column",itemAlign:"start",children:r.positions_by_perp?.map(n=>jsx(Io,{value:n.abs_liquidation_fee,type:"quote"},n.symbol))})},{title:"",dataIndex:"actions",align:"right",width:40,render:(i,r,n,a)=>{let s=a.row.getIsExpanded();return jsx("button",{className:"oui-p-2",onClick:()=>{a.row.getToggleExpandedHandler()();},children:jsx(fl,{className:s?"oui-rotate-180":""})})}}],[e])},Io=t=>jsx(Text,{children:commifyOptional(t.value)}),fl=t=>jsx("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",xmlns:"http://www.w3.org/2000/svg",className:t.className,children:jsx("path",{d:"M3.884 6.02a.67.67 0 0 0-.436.27.68.68 0 0 0 .187.933L7.63 9.88a.68.68 0 0 0 .749 0l3.994-2.657a.68.68 0 0 0 .187-.934.68.68 0 0 0-.936-.186L8.003 8.51l-3.62-2.407a.65.65 0 0 0-.499-.084",fill:"#fff",fillOpacity:".54"})});var Do=t=>jsxs(Flex,{direction:"column",width:"100%",gap:2,itemAlign:"start",className:cn("oui-rounded-xl oui-bg-base-9 oui-p-2",t.classNames?.root),children:[jsx(bl,{...t}),jsx(Divider,{}),jsx(Pl,{...t})]},t.item.timestamp),bl=t=>{let{t:e}=useTranslation();return jsxs(Flex,{width:"100%",justify:"between",itemAlign:"start",children:[jsx(Flex,{direction:"column",itemAlign:"start",gap:1,children:jsx(Flex,{gap:2,itemAlign:"center",children:jsx(Flex,{direction:"column",gap:1,itemAlign:"start",children:jsx(Text.formatted,{rule:"symbol",formatString:"base-quote",size:"xs",intensity:80,children:t.item.positions_by_perp?.[0]?.symbol||""})})})}),jsxs(Flex,{direction:"column",itemAlign:"end",children:[jsx(Text,{size:"2xs",intensity:36,children:jsx(Text.formatted,{rule:"date",formatString:"yyyy-MM-dd HH:mm:ss",children:t.item.timestamp})}),jsxs(Text,{size:"2xs",intensity:36,children:[`${e("positions.Liquidation.column.liquidationId")}: `,jsx(Text,{as:"span",intensity:80,children:t.item.liquidation_id})]})]})]})},Pl=t=>{let e=t.item.positions_by_perp?.[0],{t:o}=useTranslation(),i=useMemo(()=>isNaN(t.item?.margin_ratio)?"--":`${new Decimal(t.item.margin_ratio).mul(100).todp(2,Decimal.ROUND_DOWN).toNumber()}%`,[t.item?.margin_ratio]);return e?jsxs(Flex,{direction:"column",width:"100%",gap:1,children:[jsxs(Flex,{gap:2,width:"100%",children:[jsx(Tt,{label:o("positions.Liquidation.column.markPrice"),value:commifyOptional(e.transfer_price),className:"oui-flex-1"}),jsx(Tt,{label:o("common.quantity"),value:commifyOptional(e.position_qty),className:"oui-flex-1"}),jsx(Tt,{label:o("positions.Liquidation.column.liquidationFeeRate"),value:t.item.liquidationFeeRate,className:"oui-flex-1",align:"end"})]}),jsxs(Flex,{gap:2,width:"100%",children:[jsx(Tt,{label:o("positions.Liquidation.column.liquidationFee"),value:commifyOptional(e.abs_liquidation_fee),className:"oui-flex-1"}),jsx(Tt,{label:o("positions.Liquidation.expand.label.mr"),value:i,className:"oui-flex-1"}),jsx(Tt,{label:o("positions.Liquidation.expand.label.mmr"),value:t.item.formatted_account_mmr?`${t.item.formatted_account_mmr}%`:"--",className:"oui-flex-1",align:"end"})]}),jsxs(Flex,{gap:2,width:"100%",children:[jsx(Tt,{label:o("positions.Liquidation.expand.label.collateral"),value:commifyOptional(t.item.collateral_value),className:"oui-flex-1"}),jsx(Tt,{label:o("positions.Liquidation.expand.label.notional"),value:commifyOptional(t.item.position_notional),className:"oui-flex-1"}),jsx("div",{className:"oui-flex-1 oui-opacity-0"})," "]})]}):null},Tt=({label:t,value:e,className:o,align:i="start"})=>jsxs(Flex,{direction:"column",itemAlign:i,className:o,children:[jsx(Text,{size:"2xs",intensity:36,children:t}),jsx(Text,{size:"xs",intensity:80,children:e})]});var Lo=t=>({...t});var qo=t=>{let{classNames:e,...o}=t,i=Lo(o);return jsx(Do,{classNames:e,...i})};var Oo=t=>{let[e,o]=useState({}),i=pn();return jsxs(Flex,{direction:"column",width:"100%",height:"100%",itemAlign:"start",children:[jsxs(Flex,{gap:3,children:[t.filterItems.length>0&&jsx(DataFilter,{items:t.filterItems,onFilter:r=>{t.onFilter(r);}}),[1,7,30,90].map(r=>jsxs("button",{className:"oui-relative oui-px-2 oui-py-[2px] oui-text-sm",children:[jsx("div",{className:"oui-z-10",children:jsx(Text.gradient,{color:t.filterDays===r?"brand":void 0,className:t.filterDays!==r?"oui-text-base-contrast-54":"",children:`${r}D`})}),jsx("div",{className:"oui-absolute oui-inset-0 oui-rounded oui-opacity-[.12] oui-gradient-primary",onClick:()=>{t.updateFilterDays(r);}})]},`item-${r}`))]}),jsx(AuthGuardDataTable,{loading:t.isLoading,id:"oui-desktop-liquidation-content",columns:i,bordered:true,dataSource:t.dataSource,generatedRowKey:r=>`${r.liquidation_id}`,pagination:t.pagination,testIds:{body:"oui-testid-dataList-liquidation-tab-body"},classNames:{root:"!oui-h-[calc(100%_-_49px)]"},expanded:e,onExpandedChange:o,getRowCanExpand:()=>true,expandRowRender:r=>jsx(wl,{record:r.original})})]})},Ae=t=>jsx("th",{className:"oui-h-10 oui-border-b oui-border-line oui-text-left oui-text-base-contrast-36",children:jsx(Tooltip,{content:t.tooltip,className:"oui-w-[275px] oui-bg-base-6",side:t.side,arrow:{className:"oui-fill-base-6"},children:jsx("button",{className:"oui-border-b oui-border-dashed oui-border-line-12",children:t.label})})}),wl=t=>{let{margin_ratio:e,account_mmr:o,collateral_value:i,position_notional:r}=t.record,{t:n}=useTranslation();return jsx("div",{className:"oui-w-full oui-bg-base-8 oui-px-6",children:jsxs("table",{className:"oui-w-full",children:[jsx("thead",{children:jsxs("tr",{children:[jsx(Ae,{tooltip:n("positions.Liquidation.expand.tooltip.mr"),label:n("positions.Liquidation.expand.label.mr"),side:"left"}),jsx(Ae,{tooltip:n("positions.Liquidation.expand.tooltip.mmr"),label:n("positions.Liquidation.expand.label.mmr")}),jsx(Ae,{tooltip:n("positions.Liquidation.expand.tooltip.collateral"),label:n("positions.Liquidation.expand.label.collateral")}),jsx(Ae,{tooltip:n("positions.Liquidation.expand.tooltip.notional"),label:n("positions.Liquidation.expand.label.notional")})]})}),jsx("tbody",{children:jsxs("tr",{children:[jsx("td",{className:"oui-h-10",children:jsx(Text.numeral,{rule:"percentages",children:e})}),jsx("td",{className:"oui-h-10",children:jsx(Text.numeral,{rule:"percentages",children:o})}),jsx("td",{className:"oui-h-10",children:commifyOptional(i)}),jsx("td",{className:"oui-h-10",children:commifyOptional(r)})]})})]})})},Ao=t=>jsxs(Grid,{cols:1,rows:2,className:"oui-w-full oui-grid-rows-[auto,1fr]",gap:1,children:[jsx(Flex,{gap:2,p:2,className:"oui-rounded-b-xl oui-bg-base-9",children:jsx(DataFilter,{className:"oui-border-none oui-py-0",items:t.filterItems,onFilter:e=>{t.onFilter(e);}})}),jsx(ListView,{className:cn("oui-hide-scrollbar oui-w-full oui-space-y-0 oui-overflow-y-hidden",t.classNames?.root),contentClassName:cn("!oui-space-y-1",t.classNames?.content),dataSource:t.dataSource,loadMore:t.loadMore,renderItem:(e,o)=>jsx(qo,{item:e,index:o,classNames:{root:t.classNames?.cell}})})]});var ke=t=>{let{symbol:e,enableLoadMore:o}=t,{page:i,pageSize:r,setPage:n,pagination:a,parsePagination:s}=usePagination({pageSize:10}),{dateRange:l,filterDays:m,updateFilterDays:u,filterItems:c,onFilter:d}=Ol();useEffect(()=>{n(1);},[e,l,m]);let[x,{meta:f,isLoading:y,loadMore:b}]=Ml({page:o?void 0:i,size:r,symbol:e,start_t:l.from!=null?l.from.getTime():void 0,end_t:l.to!=null?l.to.getTime():void 0});return {dataSource:useDataTap(x,{fallbackData:[]}),isLoading:y,loadMore:b,pagination:s(f),dateRange:l,filterDays:m,updateFilterDays:u,filterItems:c,onFilter:d}},Ml=t=>{let e=usePrivateInfiniteQuery(Al(t),{initialSize:1,formatter:a=>a,revalidateOnFocus:true}),o=useMemo(()=>e.data?.[0]?.meta,[e.data?.[0]]),i=useMemo(()=>e.data?.map(a=>a.rows?.map(s=>{let l=null,m=s.positions_by_perp[0];return m&&(l=new Decimal(m.liquidator_fee).add(m.insurance_fund_fee).toNumber()),{...s,formatted_account_mmr:isNaN(s.account_mmr)?null:new Decimal(s.account_mmr).mul(100).toFixed(2).toString(),liquidationFeeRate:l}}))?.flat(),[e.data]),r=e.isLoading;return [i,{meta:o,isLoading:r,loadMore:()=>{e.setSize(e.size+1);}}]},Ol=()=>{let t=Bt({to:W(new Date),from:B(subDays(new Date,89))}),[e,o]=useState(90),[i,r]=useState(t),n=m=>{o(m),r({from:B(subDays(new Date,m-1)),to:W(new Date)});},a=m=>{if(m.name==="dateRange"){let u=Bt(m.value);if(r(u),u.from&&u.to){let c=Math.abs(differenceInDays(u.from,u.to))+1,x={1:{from:B(new Date),to:W(new Date)},7:{from:B(subDays(new Date,6)),to:W(new Date)},30:{from:B(subDays(new Date,29)),to:W(new Date)},90:{from:B(subDays(new Date,89)),to:W(new Date)}}[c];x&&Wt(x.from,u.from)&&Wt(x.to,u.to)?o(c):o(null);}}},{isMobile:s}=useScreen();return {filterItems:useMemo(()=>{let m={type:"range",name:"dateRange",value:i,fromDate:B(subDays(new Date,89)),toDate:W(new Date)};return s?[m]:[m]},[i]),onFilter:a,dateRange:i,filterDays:e,updateFilterDays:n}},Al=t=>(e,o)=>{if(o&&!o.rows?.length)return null;let{symbol:i,size:r=10,page:n,end_t:a,start_t:s}=t,l=new URLSearchParams([["size",r.toString()],["page",`${e+1}`]]);return n&&l.set("page",`${n}`),i&&l.set("symbol",i),a&&l.set("end_t",`${a}`),s&&l.set("start_t",`${s}`),`/v1/liquidations?${l.toString()}`};var kl=t=>{let e=ke(t);return jsx(Oo,{...e})},El=t=>{let{classNames:e,...o}=t,i=ke(o);return jsx(Ao,{classNames:e,...i})};var zl="MarketCloseConfirmID";registerSimpleDialog(zl,Rt,{size:"md",closable:false});
|
|
18
18
|
|
|
19
|
-
export {
|
|
19
|
+
export { Fa as CombinePositionsWidget, mt as FundingFeeButton, me as FundingFeeHistoryUI, Oo as Liquidation, kl as LiquidationWidget, zl as MarketCloseConfirmID, Ao as MobileLiquidation, El as MobileLiquidationWidget, vo as MobilePositionHistory, ul as MobilePositionHistoryWidget, Ta as MobilePositionsWidget, wo as PositionHistory, ll as PositionHistoryWidget, de as PositionsTabName, ha as PositionsWidget, Zo as sortList, ke as useLiquidationScript, qe as usePositionHistoryScript, tt as usePositionsRowContext, Xt as useSort, Yt as useTabSort };
|
|
20
20
|
//# sourceMappingURL=out.js.map
|
|
21
21
|
//# sourceMappingURL=index.mjs.map
|