@orderly.network/react-app 2.0.3 → 2.0.4-alpha.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.d.mts +9 -7
- package/dist/index.d.ts +9 -7
- package/dist/index.js +3 -3
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +7 -7
- package/dist/index.mjs.map +1 -1
- package/package.json +6 -6
package/dist/index.d.mts
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
2
2
|
import { ReactNode, ComponentType, PropsWithChildren } from 'react';
|
|
3
|
-
import { ConfigProviderProps, ExclusiveConfigProviderProps, WalletState, IRestrictedAreasParams, RestrictedAreasReturns } from '@orderly.network/hooks';
|
|
3
|
+
import { ConfigProviderProps, ExclusiveConfigProviderProps, WalletState, IRestrictedAreasParams, Chains, RestrictedAreasReturns } from '@orderly.network/hooks';
|
|
4
4
|
import { ExtensionPosition } from '@orderly.network/ui';
|
|
5
|
-
import { AccountStatusEnum } from '@orderly.network/types';
|
|
5
|
+
import { AccountStatusEnum, Chain, NetworkId } from '@orderly.network/types';
|
|
6
6
|
import { OrderlyThemeProviderProps } from '@orderly.network/ui/src/provider/orderlyThemeProvider';
|
|
7
7
|
|
|
8
8
|
type Logo = {
|
|
@@ -33,6 +33,11 @@ declare const useWalletStateHandle: (options: {
|
|
|
33
33
|
wrongNetwork: boolean;
|
|
34
34
|
};
|
|
35
35
|
|
|
36
|
+
type ReturnChain = Pick<Chain, "id"> & Partial<Omit<Chain, "id">>;
|
|
37
|
+
type DefaultChain = {
|
|
38
|
+
mainnet?: ReturnChain;
|
|
39
|
+
testnet?: ReturnChain;
|
|
40
|
+
} | ((networkId: NetworkId, chains: Chains) => ReturnChain) | undefined;
|
|
36
41
|
type AppContextState = {
|
|
37
42
|
connectWallet: ReturnType<typeof useWalletStateHandle>["connectWallet"];
|
|
38
43
|
/**
|
|
@@ -45,16 +50,13 @@ type AppContextState = {
|
|
|
45
50
|
isTestnet: boolean;
|
|
46
51
|
isWalletConnected: boolean;
|
|
47
52
|
}) => void;
|
|
53
|
+
defaultChain?: DefaultChain;
|
|
48
54
|
restrictedInfo?: RestrictedAreasReturns;
|
|
49
55
|
};
|
|
50
56
|
declare const useAppContext: () => AppContextState;
|
|
51
57
|
type AppStateProviderProps = {
|
|
52
|
-
onChainChanged?: (chainId: number, state: {
|
|
53
|
-
isTestnet: boolean;
|
|
54
|
-
isWalletConnected: boolean;
|
|
55
|
-
}) => void;
|
|
56
58
|
restrictedInfo?: IRestrictedAreasParams;
|
|
57
|
-
}
|
|
59
|
+
} & Pick<AppContextState, "onChainChanged" | "defaultChain">;
|
|
58
60
|
|
|
59
61
|
type OrderlyAppProviderProps = PropsWithChildren<OrderlyAppConfig & AppStateProviderProps & OrderlyThemeProviderProps>;
|
|
60
62
|
declare const OrderlyAppProvider: {
|
package/dist/index.d.ts
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
2
2
|
import { ReactNode, ComponentType, PropsWithChildren } from 'react';
|
|
3
|
-
import { ConfigProviderProps, ExclusiveConfigProviderProps, WalletState, IRestrictedAreasParams, RestrictedAreasReturns } from '@orderly.network/hooks';
|
|
3
|
+
import { ConfigProviderProps, ExclusiveConfigProviderProps, WalletState, IRestrictedAreasParams, Chains, RestrictedAreasReturns } from '@orderly.network/hooks';
|
|
4
4
|
import { ExtensionPosition } from '@orderly.network/ui';
|
|
5
|
-
import { AccountStatusEnum } from '@orderly.network/types';
|
|
5
|
+
import { AccountStatusEnum, Chain, NetworkId } from '@orderly.network/types';
|
|
6
6
|
import { OrderlyThemeProviderProps } from '@orderly.network/ui/src/provider/orderlyThemeProvider';
|
|
7
7
|
|
|
8
8
|
type Logo = {
|
|
@@ -33,6 +33,11 @@ declare const useWalletStateHandle: (options: {
|
|
|
33
33
|
wrongNetwork: boolean;
|
|
34
34
|
};
|
|
35
35
|
|
|
36
|
+
type ReturnChain = Pick<Chain, "id"> & Partial<Omit<Chain, "id">>;
|
|
37
|
+
type DefaultChain = {
|
|
38
|
+
mainnet?: ReturnChain;
|
|
39
|
+
testnet?: ReturnChain;
|
|
40
|
+
} | ((networkId: NetworkId, chains: Chains) => ReturnChain) | undefined;
|
|
36
41
|
type AppContextState = {
|
|
37
42
|
connectWallet: ReturnType<typeof useWalletStateHandle>["connectWallet"];
|
|
38
43
|
/**
|
|
@@ -45,16 +50,13 @@ type AppContextState = {
|
|
|
45
50
|
isTestnet: boolean;
|
|
46
51
|
isWalletConnected: boolean;
|
|
47
52
|
}) => void;
|
|
53
|
+
defaultChain?: DefaultChain;
|
|
48
54
|
restrictedInfo?: RestrictedAreasReturns;
|
|
49
55
|
};
|
|
50
56
|
declare const useAppContext: () => AppContextState;
|
|
51
57
|
type AppStateProviderProps = {
|
|
52
|
-
onChainChanged?: (chainId: number, state: {
|
|
53
|
-
isTestnet: boolean;
|
|
54
|
-
isWalletConnected: boolean;
|
|
55
|
-
}) => void;
|
|
56
58
|
restrictedInfo?: IRestrictedAreasParams;
|
|
57
|
-
}
|
|
59
|
+
} & Pick<AppContextState, "onChainChanged" | "defaultChain">;
|
|
58
60
|
|
|
59
61
|
type OrderlyAppProviderProps = PropsWithChildren<OrderlyAppConfig & AppStateProviderProps & OrderlyThemeProviderProps>;
|
|
60
62
|
declare const OrderlyAppProvider: {
|
package/dist/index.js
CHANGED
|
@@ -7,11 +7,11 @@ var utils = require('@orderly.network/utils');
|
|
|
7
7
|
var types = require('@orderly.network/types');
|
|
8
8
|
var jsxRuntime = require('react/jsx-runtime');
|
|
9
9
|
|
|
10
|
-
var
|
|
10
|
+
var x=()=>{react.useEffect(()=>{let t=new URLSearchParams(window.location.search).get("ref");t&&localStorage.setItem("referral_code",t);},[]);};var E="orderly:wallet-info";function D(){let{connectedChain:e,disconnect:t}=hooks.useWalletConnector(),[r,o]=hooks.useLocalStorage("orderly_link_device",{}),{account:n}=hooks.useAccount(),{isMobile:s}=ui.useScreen(),f=hooks.useConfig(),a=async c=>{localStorage.removeItem(E),await n.disconnect(),await t({label:c});};react.useEffect(()=>{let c=A(),l=JSON.parse(localStorage.getItem(E)??"{}");c&&l&&a(l.label);},[]);let i=async()=>{let c=A();if(!c)return;let{address:l,secretKey:u,chainId:m,chainNamespace:g}=c;if(!await n.importOrderlyKey({address:l,secretKey:u,chainNamespace:g}))return;o({chainId:m,chainNamespace:g});let C=new URL(window.location.href);C.searchParams.delete("link");let b=decodeURIComponent(C.toString());history.replaceState(null,"",b);};react.useEffect(()=>{s&&!e&&i();},[n,e,s]);let d=async()=>{let{chainId:c,chainNamespace:l}=se()||{};if(s&&!e&&c&&l){let u=n.keyStore.getAddress(),m=n.keyStore.getOrderlyKey(),g=n.keyStore.getAccountId(u);await n.checkOrderlyKey(u,m,g)&&f.set("chainNamespace",l);}};return react.useEffect(()=>{d();},[n,s,e]),{linkDevice:i}}function se(){try{let e=localStorage.getItem("orderly_link_device");return e?hooks.parseJSON(e):null}catch{}}function A(){let t=new URL(window.location.href).searchParams.get("link");if(!t)return;let{a:r,k:o,i:n,n:s}=ie(t)||{};if(r&&o&&n&&s)return {address:r,secretKey:o,chainId:n,chainNamespace:s}}function ie(e){try{let t=JSON.parse(window.atob(e)),r=Math.floor(Date.now()/1e3),o=t.t;return !o||r>o?void 0:t}catch{}}var T="orderly:wallet-info";var W=e=>{let{wallet:t,connect:r,connectedChain:o,disconnect:n,namespace:s}=hooks.useWalletConnector();if(typeof r!="function")throw new types.SDKError("Please provide a wallet connector provider");let f=react.useRef(false),{account:a,state:i}=hooks.useAccount(),d=hooks.useKeyStore(),c=hooks.useConfig("networkId"),[l,{checkChainSupport:u}]=hooks.useChains(),[m,g]=react.useState(false),S=react.useMemo(()=>t?.accounts?.[0]?.address,[t]),C=react.useMemo(()=>{let p=t?.chains?.[0]?.id,h=t?.chains?.[0]?.namespace;if(!(typeof p>"u"))return {id:utils.parseChainIdToNumber(p),namespace:h}},[t]);return react.useEffect(()=>{if(!o){g(false);return}let p=u(o.id,c);g(!p);},[o,l,u,c]),react.useEffect(()=>{utils.windowGuard(()=>{let p=d.getAddress(),h=JSON.parse(localStorage.getItem(T)??"{}");o?.namespace!==types.ChainNamespace.solana&&p&&a.address!==p&&h.label&&r({autoSelect:{label:h.label,disableModals:true}}).then(P=>{},P=>{});});},[t,a.address]),react.useEffect(()=>{if(t===null&&i.status>types.AccountStatusEnum.NotConnected&&!i.validating){a.disconnect();return}if(m||!o||f.current)return;let p=A();S&&S!==a.address&&!p&&(a.setAddress(S,{provider:t?.provider,chain:{id:utils.praseChainIdToNumber(C.id),namespace:C.namespace.toUpperCase()},wallet:{name:t.label}}),utils.windowGuard(()=>{localStorage.setItem(T,JSON.stringify({label:t.label}));})),C?.id!==a.chainId&&a.switchChainId(C?.id);},[t,o,S,C,a.address,i,a.chainId,m]),{connectWallet:async()=>(f.current=true,r({chainId:e.currentChainId}).then(async p=>{if(Array.isArray(p)&&p.length>0&&p[0]&&p[0].accounts.length>0){let h=p[0],P=utils.praseChainIdToNumber(h.chains[0].id);if(!u(P,c))return {wrongNetwork:true};if(!a)throw new Error("account is not initialized");i.status===types.AccountStatusEnum.EnableTradingWithoutConnected&&(localStorage.removeItem("orderly_link_device"),await a.disconnect());let Z=await a.setAddress(h.accounts[0].address,{provider:h.provider,chain:{id:utils.praseChainIdToNumber(h.chains[0].id),namespace:h.chains[0].namespace.toUpperCase()},wallet:{name:h.label}});return {wallet:h,status:Z,wrongNetwork:false}}return null}).finally(()=>{f.current=false;})),wrongNetwork:m}};function $(){let e=hooks.useEventEmitter(),t=react.useRef({}),[r,o]=hooks.useSessionStorage("orderly_wallet_change_id",{});t.current=r,hooks.useWalletSubscription({onMessage:n=>{let{id:s,side:f,transStatus:a}=n,i=true;if(["DEPOSIT","WITHDRAW"].includes(f)&&["COMPLETED","FAILED"].includes(a)){let d=t.current[s];o({...r,[s]:d?void 0:true}),i=!d;}if(a==="COMPLETED"&&i){let d=`${utils.capitalizeString(f)} completed`;ui.toast.success(d);}else if(a==="FAILED"&&i){let d=`${utils.capitalizeString(f)} failed`;ui.toast.error(d);}e.emit("wallet:changed",n);}});}function K(){hooks.useSettleSubscription({onMessage:e=>{let{status:t}=e;switch(t){case "COMPLETED":ui.toast.success("Settlement completed");break;case "FAILED":ui.toast.error("Settlement failed");break;}}});}function U(){let e=hooks.useEventEmitter(),{setLedgerAddress:t}=hooks.useStorageLedgerAddress();return react.useEffect(()=>{e.on("wallet:connect-error",r=>{ui.toast.error(r.message);}),e.on("wallet:sign-message-with-ledger-error",r=>{window.setTimeout(()=>{ui.modal.confirm({title:"Sign Message Failed",content:"Are you using Ledger Wallet?",size:"sm",onOk:async()=>(t(r.userAddress),Promise.resolve()),okLabel:"OK",onCancel:async()=>(ui.toast.error(r.message),Promise.resolve()),cancelLabel:"No"}).then(o=>{});});});},[e]),{}}var J=react.createContext({}),I=()=>react.useContext(J),H=e=>{let[t,r]=react.useState();D();let{connectWallet:o,wrongNetwork:n}=W({currentChainId:t});$(),K(),U();let s=hooks.useRestrictedAreas(e?.restrictedInfo??{});return jsxRuntime.jsx(J.Provider,{value:{connectWallet:o,wrongNetwork:n,currentChainId:t,setCurrentChainId:r,onChainChanged:e.onChainChanged,defaultChain:e.defaultChain,restrictedInfo:s},children:e.children})};var q=react.createContext({}),We=()=>react.useContext(q),z=e=>jsxRuntime.jsx(q.Provider,{value:e,children:e.children});function Q(e,t){let{symbol:r,side:o,quantity:n}=e,s="total_executed_quantity"in e?e.total_executed_quantity:0,f="status"in e?e.status:e.algo_status,a=t[r],i=a("base_dp"),d=utils.capitalizeString(o),c=utils.transSymbolformString(r),l="algo_type"in e&&e.algo_type===types.AlgoOrderRootType.POSITIONAL_TP_SL?"Entire position":i===void 0?n:ui.parseNumber(n,{dp:i}),u="",m="";switch(f){case "NEW":u="Order opened",m=`${d} ${c} ${l}`;break;case "FILLED":case "PARTIAL_FILLED":let g=i===void 0?s:ui.parseNumber(s,{dp:i});u="Order filled",m=`${d} ${c} ${g} / ${l}`;break;case "CANCELLED":u="Order cancelled",m=`${d} ${c} ${l}`;break;case "REJECTED":u="Order rejected",m=`${d} ${c} ${l}`;break;case "REPLACED":u="Order edited",m=`${o} ${c} ${s} / ${l}`;break;}return {title:u,msg:m}}function V(){let e=hooks.useEventEmitter(),t=hooks.useSymbolsInfo(),r=react.useRef({});react.useEffect(()=>{r.current=t;},[t]);let o=hooks.useDebouncedCallback(n=>{(f=>{let{title:a,msg:i}=Q(f,r.current);a&&i&&ui.toast.success(jsxRuntime.jsxs("div",{children:[a,jsxRuntime.jsx("br",{}),jsxRuntime.jsx("div",{className:"orderly-text-white/[0.54] orderly-text-xs",children:i})]}));})(n);},100);react.useEffect(()=>(e.on("orders:changed",o),()=>{e.off("orders:changed",o);}),[]);}var X=e=>{let{components:t,appIcons:r,onChainChanged:o,defaultChain:n,...s}=e;return x(),V(),jsxRuntime.jsx(z,{appIcons:r,brokerName:e.brokerName,children:jsxRuntime.jsx(ui.OrderlyThemeProvider,{components:t,overrides:e.overrides,children:jsxRuntime.jsxs(hooks.OrderlyConfigProvider,{...s,children:[jsxRuntime.jsx(H,{onChainChanged:o,defaultChain:n,restrictedInfo:e.restrictedInfo,children:jsxRuntime.jsx(hooks.OrderlyTrackerProvider,{children:jsxRuntime.jsx(ui.TooltipProvider,{delayDuration:300,children:jsxRuntime.jsx(ui.ModalProvider,{children:e.children})})})}),jsxRuntime.jsx(ui.Toaster,{})]})})})};X.displayName="OrderlyAppProvider";var je=(e,t)=>{let{wrongNetwork:r}=I(),{state:o}=hooks.useAccount();return t?.skip?e:r||typeof t?.accountStatus<"u"&&o.status<t.accountStatus?typeof t?.fallbackData<"u"?t.fallbackData:null:e};
|
|
11
11
|
|
|
12
|
-
exports.OrderlyAppProvider =
|
|
12
|
+
exports.OrderlyAppProvider = X;
|
|
13
13
|
exports.useAppConfig = We;
|
|
14
|
-
exports.useAppContext =
|
|
14
|
+
exports.useAppContext = I;
|
|
15
15
|
exports.useDataTap = je;
|
|
16
16
|
//# sourceMappingURL=out.js.map
|
|
17
17
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/provider/orderlyAppProvider.tsx","../src/hooks/useBootstrap.ts","../src/provider/appContext.tsx","../src/hooks/useWalletStateHandle.ts","../src/hooks/useLinkDevice.ts","../src/hooks/useWalletEvent.ts","../src/hooks/useSettleEvent.ts","../src/hooks/useWalletConnectError.ts","../src/provider/configContext.tsx","../src/hooks/useExecutionReport.tsx","../src/hooks/getOrderExecutionReportMsg.ts","../src/hooks/useDataTap.ts"],"names":["ModalProvider","OrderlyThemeProvider","Toaster","TooltipProvider","useEffect","useBootstrap","refCode","OrderlyConfigProvider","OrderlyTrackerProvider","createContext","useContext","useState","useMemo","useRef","useConfig","useAccount","useChains","useKeyStore","useWalletConnector","parseChainIdToNumber","praseChainIdToNumber","windowGuard","AccountStatusEnum","SDKError","ChainNamespace","parseJSON","useLocalStorage","useScreen","WALLET_KEY","useLinkDevice","connectedChain","disconnect","_","setLinkDeviceStorage","account","isMobile","configStore","onDisconnect","label","linkData","getLinkDeviceData","walletInfo","linkDevice","address","secretKey","chainId","chainNamespace","url","decodedUrl","autoLinkDevice","getLinkDeviceStorage","orderlyKey","accountId","linkDeviceStorage","link","decodeBase64","base64","data","currentTime","expiredTime","useWalletStateHandle","options","connectedWallet","connect","namespace","isManualConnect","accountState","keyStore","networkId","chains","checkChainSupport","unsupported","setUnsupported","currentWalletAddress","currentChain","id","isSupported","localAddress","res","error","walletState","wallet","status","toast","capitalizeString","useEventEmitter","useSessionStorage","useWalletSubscription","useWalletEvent","ee","recordRef","record","setRecord","side","transStatus","showToast","isPushOnce","msg","useSettleSubscription","useSettleEvent","modal","LedgerWalletKey","useWalletConnectError","info","ledgerWallet","useRestrictedAreas","jsx","AppContext","useAppContext","AppStateProvider","props","currentChainId","setCurrentChainId","connectWallet","wrongNetwork","restrictedInfo","AppConfigContext","useAppConfig","AppConfigProvider","transSymbolformString","AlgoOrderRootType","parseNumber","getOrderExecutionReportMsg","symbolsInfo","symbol","quantity","total_executed_quantity","getSymbolInfo","base_dp","displaySide","displaySymbol","displayQuantity","title","displayTotalExecutedQuantity","useSymbolsInfo","useDebouncedCallback","jsxs","useExecutionReport","symbolsInfoRef","handler","OrderlyAppProvider","onChainChanged","components","appIcons","configProps","useDataTap","state"],"mappings":"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","sourcesContent":["import { PropsWithChildren } from \"react\";\nimport { OrderlyAppConfig } from \"../types\";\nimport {\n ModalProvider,\n OrderlyThemeProvider,\n Toaster,\n TooltipProvider,\n} from \"@orderly.network/ui\";\nimport { useBootstrap } from \"../hooks/useBootstrap\";\nimport {\n ConfigProviderProps,\n OrderlyConfigProvider,\n OrderlyTrackerProvider,\n} from \"@orderly.network/hooks\";\nimport { AppStateProvider, AppStateProviderProps } from \"./appContext\";\nimport { AppConfigProvider } from \"./configContext\";\nimport { useExecutionReport } from \"../hooks/useExecutionReport\";\nimport { OrderlyThemeProviderProps } from \"@orderly.network/ui/src/provider/orderlyThemeProvider\";\n\nexport type OrderlyAppProviderProps = PropsWithChildren<\n OrderlyAppConfig & AppStateProviderProps & OrderlyThemeProviderProps\n>;\n\nconst OrderlyAppProvider = (props: OrderlyAppProviderProps) => {\n const {\n onChainChanged,\n // dateFormatting,\n components,\n appIcons,\n ...configProps\n } = props;\n\n useBootstrap();\n useExecutionReport();\n\n return (\n <AppConfigProvider appIcons={appIcons} brokerName={props.brokerName!}>\n <OrderlyThemeProvider\n // dateFormatting={dateFormatting}\n components={components}\n overrides={props.overrides}\n >\n <OrderlyConfigProvider {...(configProps as ConfigProviderProps)}>\n <AppStateProvider\n onChainChanged={onChainChanged}\n restrictedInfo={props.restrictedInfo}\n >\n <OrderlyTrackerProvider>\n <TooltipProvider delayDuration={300}>\n <ModalProvider>{props.children}</ModalProvider>\n </TooltipProvider>\n </OrderlyTrackerProvider>\n </AppStateProvider>\n <Toaster />\n </OrderlyConfigProvider>\n </OrderlyThemeProvider>\n </AppConfigProvider>\n );\n};\n\nOrderlyAppProvider.displayName = \"OrderlyAppProvider\";\n\nexport { OrderlyAppProvider };\n","import { useEffect } from \"react\";\nimport { useAccount, useWalletConnector } from \"@orderly.network/hooks\";\n\nexport const useBootstrap = () => {\n useEffect(() => {\n const searchParams = new URLSearchParams(window.location.search);\n const refCode = searchParams.get(\"ref\");\n if (refCode) {\n localStorage.setItem(\"referral_code\", refCode);\n }\n }, []);\n};\n","import {\n FC,\n createContext,\n PropsWithChildren,\n useContext,\n useState,\n} from \"react\";\nimport { useWalletStateHandle } from \"../hooks/useWalletStateHandle\";\nimport { useAppState } from \"../hooks/useAppState\";\nimport { useWalletEvent } from \"../hooks/useWalletEvent\";\nimport { useSettleEvent } from \"../hooks/useSettleEvent\";\nimport { useWalletConnectError } from \"../hooks/useWalletConnectError\";\nimport {\n useRestrictedAreas,\n RestrictedAreasReturns,\n IRestrictedAreasParams,\n} from \"@orderly.network/hooks\";\nimport { useLinkDevice } from \"../hooks/useLinkDevice\";\n\ntype AppContextState = {\n connectWallet: ReturnType<typeof useWalletStateHandle>[\"connectWallet\"];\n /**\n * Whether the current network is not supported\n */\n wrongNetwork: boolean;\n currentChainId: number | undefined;\n setCurrentChainId: (chainId: number | undefined) => void;\n onChainChanged?: (\n chainId: number,\n state: { isTestnet: boolean; isWalletConnected: boolean }\n ) => void;\n // networkStatus: ReturnType<typeof useAppState>[\"networkStatus\"];\n restrictedInfo?: RestrictedAreasReturns;\n};\n\nconst AppContext = createContext<AppContextState>({} as AppContextState);\n\nexport const useAppContext = () => {\n return useContext(AppContext);\n};\n\nexport type AppStateProviderProps = {\n onChainChanged?: (\n chainId: number,\n state: { isTestnet: boolean; isWalletConnected: boolean }\n ) => void;\n restrictedInfo?: IRestrictedAreasParams;\n};\n\nexport const AppStateProvider: FC<PropsWithChildren<AppStateProviderProps>> = (\n props\n) => {\n const [currentChainId, setCurrentChainId] = useState<number | undefined>();\n useLinkDevice();\n\n const { connectWallet, wrongNetwork } = useWalletStateHandle({\n // onChainChanged: props.onChainChanged,\n currentChainId,\n });\n\n useWalletEvent();\n useSettleEvent();\n useWalletConnectError();\n const restrictedInfo = useRestrictedAreas(props?.restrictedInfo ?? {});\n\n // const { networkStatus } = useAppState();\n\n return (\n <AppContext.Provider\n value={{\n connectWallet,\n wrongNetwork,\n currentChainId,\n setCurrentChainId,\n onChainChanged: props.onChainChanged,\n restrictedInfo,\n }}\n >\n {props.children}\n </AppContext.Provider>\n );\n};\n","import { useEffect, useMemo, useRef, useState } from \"react\";\nimport { useConfig, WalletState } from \"@orderly.network/hooks\";\nimport {\n useAccount,\n useChains,\n useKeyStore,\n useWalletConnector,\n} from \"@orderly.network/hooks\";\nimport {\n parseChainIdToNumber,\n praseChainIdToNumber,\n windowGuard,\n} from \"@orderly.network/utils\";\nimport {\n AccountStatusEnum,\n SDKError,\n ChainNamespace,\n NetworkId,\n} from \"@orderly.network/types\";\nimport { getLinkDeviceData } from \"./useLinkDevice\";\n\nconst WALLET_KEY = \"orderly:wallet-info\";\nconst CHAIN_NAMESPACE = \"orderly:chain-namespace\";\n\nexport const useWalletStateHandle = (options: {\n // onChainChanged?: (chainId: number, isTestnet: boolean) => void;\n currentChainId?: number;\n}) => {\n const {\n wallet: connectedWallet,\n connect,\n connectedChain,\n disconnect,\n namespace,\n } = useWalletConnector();\n //\n // console.log(\"🔗 wallet state handle\", {\n // connectedWallet,\n // connectedChain,\n // namespace,\n // });\n\n if (typeof connect !== \"function\") {\n throw new SDKError(\"Please provide a wallet connector provider\");\n }\n\n const isManualConnect = useRef<boolean>(false);\n\n const { account, state: accountState } = useAccount();\n const keyStore = useKeyStore();\n const networkId = useConfig(\"networkId\") as NetworkId;\n const [chains, { checkChainSupport }] = useChains();\n\n const [unsupported, setUnsupported] = useState(false);\n\n // current connected wallet address\n const currentWalletAddress = useMemo<string | undefined>(() => {\n return connectedWallet?.accounts?.[0]?.address;\n }, [connectedWallet]);\n\n // current connected chain id\n const currentChain = useMemo<\n { id: number; namespace: string } | undefined\n >(() => {\n const id = connectedWallet?.chains?.[0]?.id;\n const namespace = connectedWallet?.chains?.[0]?.namespace;\n if (typeof id === \"undefined\") return undefined;\n return {\n id: parseChainIdToNumber(id),\n namespace,\n };\n }, [connectedWallet]);\n\n useEffect(() => {\n if (!connectedChain) {\n setUnsupported(false);\n return;\n }\n\n let isSupported = checkChainSupport(\n connectedChain.id,\n networkId\n // networkId === \"testnet\" ? chains.testnet : chains.mainnet\n );\n\n setUnsupported(!isSupported);\n }, [connectedChain, chains, checkChainSupport, networkId]);\n\n useEffect(() => {\n // if (unsupported) return;\n\n windowGuard(() => {\n const localAddress = keyStore.getAddress();\n const walletInfo = JSON.parse(localStorage.getItem(WALLET_KEY) ?? \"{}\");\n\n /**\n * if locale address is exist, restore account state\n */\n if (connectedChain?.namespace === ChainNamespace.solana) {\n return;\n }\n if (\n localAddress &&\n account.address !== localAddress &&\n walletInfo.label\n ) {\n connect({\n autoSelect: {\n label: walletInfo.label,\n disableModals: true,\n },\n }).then(\n (res) => {\n console.log(\"silent connect wallet successes\", res);\n },\n (error) => console.log(\"connect error\", error)\n );\n }\n });\n }, [connectedWallet, account.address]);\n\n /**\n * handle wallet connection\n */\n useEffect(() => {\n if (\n connectedWallet === null &&\n accountState.status > AccountStatusEnum.NotConnected &&\n !accountState.validating\n ) {\n account.disconnect();\n return;\n }\n\n if (unsupported || !connectedChain) return;\n if (isManualConnect.current) return;\n\n const linkData = getLinkDeviceData();\n\n // updateAccount(currentWalletAddress!, connectedWallet!, currentChainId!);\n /**\n * switch account\n */\n if (\n !!currentWalletAddress &&\n currentWalletAddress !== account.address &&\n !linkData\n ) {\n account.setAddress(currentWalletAddress, {\n provider: connectedWallet?.provider,\n chain: {\n id: praseChainIdToNumber(currentChain!.id),\n namespace: currentChain!.namespace.toUpperCase() as ChainNamespace,\n },\n wallet: {\n name: connectedWallet.label,\n },\n });\n\n // save wallet connector info to local storage\n windowGuard(() => {\n localStorage.setItem(\n WALLET_KEY,\n JSON.stringify({\n label: connectedWallet.label,\n })\n );\n });\n }\n\n /**\n * switch chainId\n */\n if (currentChain?.id !== account.chainId) {\n account.switchChainId(currentChain?.id!);\n\n // emit chain changed event\n // options.onChainChanged?.(currentChainId!, isTestnet(networkId));\n }\n }, [\n connectedWallet,\n connectedChain,\n currentWalletAddress,\n currentChain,\n account.address,\n accountState,\n account.chainId,\n unsupported,\n ]);\n\n /**\n * User manually connects to wallet\n */\n const connectWallet = async (): Promise<{\n wallet?: WalletState;\n status?: AccountStatusEnum;\n wrongNetwork?: boolean;\n } | null> => {\n isManualConnect.current = true;\n // const walletState = await connect();\n\n return connect({ chainId: options.currentChainId })\n .then(async (walletState) => {\n if (\n Array.isArray(walletState) &&\n walletState.length > 0 &&\n walletState[0] &&\n walletState[0].accounts.length > 0\n ) {\n const wallet = walletState[0];\n const chainId = praseChainIdToNumber(wallet.chains[0].id);\n\n if (!checkChainSupport(chainId, networkId)) {\n return {\n wrongNetwork: true,\n };\n }\n\n //\n if (!account) {\n throw new Error(\"account is not initialized\");\n }\n console.log(\"-- aaaaa wallet\", wallet);\n // clear link device data when connect wallt\n if (\n accountState.status ===\n AccountStatusEnum.EnableTradingWithoutConnected\n ) {\n localStorage.removeItem(\"orderly_link_device\");\n await account.disconnect();\n }\n const status = await account.setAddress(wallet.accounts[0].address, {\n provider: wallet.provider,\n chain: {\n id: praseChainIdToNumber(wallet.chains[0].id),\n namespace:\n wallet.chains[0].namespace.toUpperCase() as ChainNamespace,\n },\n wallet: {\n name: wallet.label,\n },\n // label: ,\n });\n console.log(\"-- xxxxxx status\", status);\n\n return { wallet, status, wrongNetwork: false };\n }\n\n return null;\n })\n .finally(() => {\n isManualConnect.current = false;\n });\n };\n\n return {\n connectWallet,\n wrongNetwork: unsupported,\n };\n};\n","import { useCallback, useEffect } from \"react\";\nimport {\n parseJSON,\n useAccount,\n useConfig,\n useLocalStorage,\n useWalletConnector,\n} from \"@orderly.network/hooks\";\nimport { useScreen } from \"@orderly.network/ui\";\nimport { ChainNamespace } from \"@orderly.network/types\";\n\ntype DecodedData = {\n /** secret key */\n k: string;\n /* timestamp */\n t: number;\n /** address */\n a: string;\n /** chain id */\n i: number;\n /** chain namespace */\n n: ChainNamespace;\n};\n\ntype LinkDeviceStorage = { chainId: number; chainNamespace: ChainNamespace };\n\nconst WALLET_KEY = \"orderly:wallet-info\";\n\nexport function useLinkDevice() {\n const { connectedChain, disconnect } = useWalletConnector();\n const [_, setLinkDeviceStorage] = useLocalStorage(\n \"orderly_link_device\",\n {} as LinkDeviceStorage\n );\n\n const { account } = useAccount();\n const { isMobile } = useScreen();\n const configStore = useConfig();\n\n const onDisconnect = async (label: string) => {\n // The cache must be cleared first, otherwise it will be auto connect wallet\n localStorage.removeItem(WALLET_KEY);\n await account.disconnect();\n await disconnect({ label });\n };\n\n useEffect(() => {\n const linkData = getLinkDeviceData();\n const walletInfo = JSON.parse(localStorage.getItem(WALLET_KEY) ?? \"{}\");\n if (linkData && walletInfo) {\n // clear connect data when link device\n onDisconnect(walletInfo.label);\n }\n }, []);\n\n const linkDevice = async () => {\n const linkData = getLinkDeviceData();\n if (!linkData) return;\n\n const { address, secretKey, chainId, chainNamespace } = linkData;\n const isSuccess = await account.importOrderlyKey({\n address,\n secretKey,\n chainNamespace,\n });\n if (!isSuccess) return;\n setLinkDeviceStorage({\n chainId,\n chainNamespace,\n });\n\n const url = new URL(window.location.href);\n url.searchParams.delete(\"link\");\n const decodedUrl = decodeURIComponent(url.toString());\n history.replaceState(null, \"\", decodedUrl);\n };\n\n useEffect(() => {\n if (isMobile && !connectedChain) {\n linkDevice();\n }\n }, [account, connectedChain, isMobile]);\n\n const autoLinkDevice = async () => {\n // this can't use the value returned by useLocalStorage here, because it will trigger extra state change\n const { chainId, chainNamespace } = getLinkDeviceStorage() || {};\n if (isMobile && !connectedChain && chainId && chainNamespace) {\n const address = account.keyStore.getAddress();\n const orderlyKey = account.keyStore.getOrderlyKey();\n const accountId = account.keyStore.getAccountId(address!);\n const res = await account.checkOrderlyKey(\n address!,\n orderlyKey!,\n accountId!\n );\n if (res) {\n configStore.set(\"chainNamespace\", chainNamespace);\n }\n }\n };\n\n // persist status when refresh page\n useEffect(() => {\n autoLinkDevice();\n }, [account, isMobile, connectedChain]);\n\n return { linkDevice };\n}\n\nfunction getLinkDeviceStorage() {\n try {\n const linkDeviceStorage = localStorage.getItem(\"orderly_link_device\");\n const json = linkDeviceStorage ? parseJSON(linkDeviceStorage) : null;\n return json as LinkDeviceStorage;\n } catch (err) {\n console.error(\"getLinkDeviceStorage\", err);\n }\n}\n\nexport function getLinkDeviceData() {\n const url = new URL(window.location.href);\n const link = url.searchParams.get(\"link\");\n\n if (!link) return;\n\n const {\n a: address,\n k: secretKey,\n i: chainId,\n n: chainNamespace,\n } = decodeBase64(link) || {};\n\n if (address && secretKey && chainId && chainNamespace) {\n return {\n address,\n secretKey,\n chainId,\n chainNamespace,\n };\n }\n}\n\nfunction decodeBase64(base64: string) {\n try {\n const data = JSON.parse(window.atob(base64)) as DecodedData;\n console.log(\"decodeBase64\", data);\n const currentTime = Math.floor(Date.now() / 1000);\n const expiredTime = data.t;\n\n if (!expiredTime || currentTime > expiredTime) {\n console.error(\"Orderly key has expired.\");\n return;\n }\n\n return data;\n } catch (error) {\n console.error(\"Invalid or expired orderly key.\");\n }\n}\n","import { useRef } from \"react\";\nimport { toast } from \"@orderly.network/ui\";\nimport { capitalizeString } from \"@orderly.network/utils\";\nimport {\n useEventEmitter,\n useSessionStorage,\n useWalletSubscription,\n} from \"@orderly.network/hooks\";\n\nexport function useWalletEvent() {\n const ee = useEventEmitter();\n\n const recordRef = useRef<Record<number, boolean>>({});\n\n const [record, setRecord] = useSessionStorage(\n \"orderly_wallet_change_id\",\n {} as Record<number, boolean>\n );\n\n recordRef.current = record;\n\n useWalletSubscription({\n onMessage: (data: any) => {\n console.log(\"wallet:changed\", data);\n const { id, side, transStatus } = data;\n let showToast = true;\n\n // DEPOSIT and WITHDRAW will push twice COMPLETED and FAILED event\n if (\n [\"DEPOSIT\", \"WITHDRAW\"].includes(side) &&\n [\"COMPLETED\", \"FAILED\"].includes(transStatus)\n ) {\n const isPushOnce = recordRef.current[id];\n setRecord({\n ...record,\n [id]: isPushOnce ? undefined : true,\n });\n\n showToast = !isPushOnce;\n }\n\n if (transStatus === \"COMPLETED\" && showToast) {\n let msg = `${capitalizeString(side)} completed`;\n toast.success(msg);\n } else if (transStatus === \"FAILED\" && showToast) {\n let msg = `${capitalizeString(side)} failed`;\n toast.error(msg);\n }\n\n ee.emit(\"wallet:changed\", data);\n },\n });\n}\n","import { useSettleSubscription } from \"@orderly.network/hooks\";\nimport { toast } from \"@orderly.network/ui\";\n\nexport function useSettleEvent() {\n useSettleSubscription({\n onMessage: (data: any) => {\n const { status } = data;\n\n // console.log(\"settle ws: \", data);\n\n switch (status) {\n case \"COMPLETED\":\n toast.success(\"Settlement completed\");\n break;\n case \"FAILED\":\n toast.error(\"Settlement failed\");\n break;\n default:\n break;\n }\n },\n });\n}\n","import { useEventEmitter } from \"@orderly.network/hooks\";\nimport { useEffect } from \"react\";\nimport { modal, toast } from \"@orderly.network/ui\";\nimport { LedgerWalletKey } from \"@orderly.network/types\";\n\n\nexport function useWalletConnectError() {\n const ee = useEventEmitter();\n\n\n useEffect(() => {\n ee.on('wallet:connect-error', (data) => {\n toast.error(data.message);\n\n })\n ee.on('wallet:sign-message-with-ledger-error', (data: { userAddress: string; message: string }) => {\n window.setTimeout(() => {\n\n modal.confirm({\n title: 'Sign Message Failed',\n content: \"Are you using Ledger Wallet?\",\n size: 'sm',\n onOk: async () => {\n console.log('-- use ledger', true);\n const info = window.localStorage.getItem(LedgerWalletKey);\n if (!info) {\n window.localStorage.setItem(LedgerWalletKey, JSON.stringify([data.userAddress]));\n } else {\n const ledgerWallet = JSON.parse(info ?? '[]');\n ledgerWallet.push(data.userAddress);\n window.localStorage.setItem(LedgerWalletKey, ledgerWallet);\n }\n // todo localstorage\n return Promise.resolve();\n },\n okLabel: 'OK',\n onCancel: async () => {\n toast.error(data.message);\n return Promise.resolve();\n },\n cancelLabel: 'No',\n\n }).then(res => {\n console.log('-- dialog res', res);\n });\n\n });\n\n })\n\n }, [ee])\n\n return {}\n}","import { createContext, PropsWithChildren, useContext } from \"react\";\nimport { AppLogos } from \"../types\";\n\nexport type ThemeContextState = {\n appIcons?: AppLogos;\n brokerName: string;\n};\n\nconst AppConfigContext = createContext<ThemeContextState>(\n {} as ThemeContextState\n);\n\nexport const useAppConfig = () => {\n return useContext(AppConfigContext);\n};\n\nexport const AppConfigProvider = (\n props: PropsWithChildren<{\n appIcons?: AppLogos;\n brokerName: string;\n }>\n) => {\n return (\n <AppConfigContext.Provider value={props}>\n {props.children}\n </AppConfigContext.Provider>\n );\n};\n","import { useEffect, useRef } from \"react\";\nimport { getOrderExecutionReportMsg } from \"./getOrderExecutionReportMsg\";\nimport {\n useSymbolsInfo,\n useWS,\n useEventEmitter,\n useDebouncedCallback,\n} from \"@orderly.network/hooks\";\nimport { toast } from \"@orderly.network/ui\";\n\nexport function useExecutionReport() {\n const ee = useEventEmitter();\n\n const symbolsInfo = useSymbolsInfo();\n const symbolsInfoRef = useRef({});\n\n useEffect(() => {\n symbolsInfoRef.current = symbolsInfo;\n }, [symbolsInfo]);\n\n const handler = useDebouncedCallback((data: any) => {\n const showToast = (data: any) => {\n const { title, msg } = getOrderExecutionReportMsg(\n data,\n symbolsInfoRef.current\n );\n\n if (title && msg) {\n toast.success(\n <div>\n {title}\n <br />\n <div className=\"orderly-text-white/[0.54] orderly-text-xs\">\n {msg}\n </div>\n </div>\n );\n }\n };\n\n showToast(data);\n }, 100);\n\n useEffect(() => {\n ee.on(\"orders:changed\", handler);\n\n return () => {\n ee.off(\"orders:changed\", handler);\n };\n }, []);\n}\n","import {\n capitalizeString,\n transSymbolformString,\n} from \"@orderly.network/utils\";\nimport { API } from \"@orderly.network/types\";\nimport { AlgoOrderRootType } from \"@orderly.network/types\";\nimport { parseNumber } from \"@orderly.network/ui\";\n\nexport function getOrderExecutionReportMsg(\n data: API.AlgoOrder | API.Order,\n symbolsInfo: any\n) {\n const { symbol, side, quantity } = data;\n const total_executed_quantity =\n \"total_executed_quantity\" in data ? data.total_executed_quantity : 0;\n const status = \"status\" in data ? data.status : data.algo_status;\n const getSymbolInfo = symbolsInfo[symbol];\n const base_dp = getSymbolInfo(\"base_dp\");\n const displaySide = capitalizeString(side);\n const displaySymbol = transSymbolformString(symbol);\n const displayQuantity =\n \"algo_type\" in data && data.algo_type === AlgoOrderRootType.POSITIONAL_TP_SL\n ? \"Entire position\"\n : base_dp === undefined\n ? quantity\n : parseNumber(quantity, { dp: base_dp });\n\n let title = \"\";\n let msg = \"\";\n switch (status) {\n case \"NEW\":\n title = \"Order opened\";\n msg = `${displaySide} ${displaySymbol} ${displayQuantity}`;\n break;\n case \"FILLED\":\n case \"PARTIAL_FILLED\":\n const displayTotalExecutedQuantity =\n base_dp === undefined\n ? total_executed_quantity\n : parseNumber(total_executed_quantity, { dp: base_dp });\n title = \"Order filled\";\n msg = `${displaySide} ${displaySymbol} ${displayTotalExecutedQuantity} / ${displayQuantity}`;\n break;\n case \"CANCELLED\":\n title = \"Order cancelled\";\n msg = `${displaySide} ${displaySymbol} ${displayQuantity}`;\n break;\n case \"REJECTED\":\n title = \"Order rejected\";\n msg = `${displaySide} ${displaySymbol} ${displayQuantity}`;\n break;\n case \"REPLACED\":\n title = \"Order edited\";\n msg = `${side} ${displaySymbol} ${total_executed_quantity} / ${displayQuantity}`;\n break;\n default:\n break;\n }\n\n return {\n title,\n msg,\n };\n}\n","import { AccountStatusEnum } from \"@orderly.network/types\";\nimport { useAppContext } from \"../provider/appContext\";\nimport { useAccount } from \"@orderly.network/hooks\";\n\nexport const useDataTap = <T = any>(\n data: T,\n options?: {\n skip?: false;\n fallbackData?: T;\n accountStatus?: AccountStatusEnum;\n }\n): T | null => {\n const { wrongNetwork } = useAppContext();\n const { state } = useAccount();\n /**\n * ignore\n */\n if (options?.skip) return data;\n\n if (wrongNetwork) {\n return typeof options?.fallbackData !== \"undefined\"\n ? options.fallbackData\n : null;\n }\n\n if (typeof options?.accountStatus !== \"undefined\") {\n if (state.status < options.accountStatus) {\n return typeof options?.fallbackData !== \"undefined\"\n ? options.fallbackData\n : null;\n }\n }\n\n // return wrongNetwork\n // ? typeof options?.fallbackData !== \"undefined\"\n // ? options.fallbackData\n // : null\n // : data;\n //\n return data;\n};\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/provider/orderlyAppProvider.tsx","../src/hooks/useBootstrap.ts","../src/provider/appContext.tsx","../src/hooks/useWalletStateHandle.ts","../src/hooks/useLinkDevice.ts","../src/hooks/useWalletEvent.ts","../src/hooks/useSettleEvent.ts","../src/hooks/useWalletConnectError.ts","../src/provider/configContext.tsx","../src/hooks/useExecutionReport.tsx","../src/hooks/getOrderExecutionReportMsg.ts","../src/hooks/useDataTap.ts"],"names":["ModalProvider","OrderlyThemeProvider","Toaster","TooltipProvider","useEffect","useBootstrap","refCode","OrderlyConfigProvider","OrderlyTrackerProvider","createContext","useContext","useState","useMemo","useRef","useConfig","useAccount","useChains","useKeyStore","useWalletConnector","parseChainIdToNumber","praseChainIdToNumber","windowGuard","AccountStatusEnum","SDKError","ChainNamespace","parseJSON","useLocalStorage","useScreen","WALLET_KEY","useLinkDevice","connectedChain","disconnect","_","setLinkDeviceStorage","account","isMobile","configStore","onDisconnect","label","linkData","getLinkDeviceData","walletInfo","linkDevice","address","secretKey","chainId","chainNamespace","url","decodedUrl","autoLinkDevice","getLinkDeviceStorage","orderlyKey","accountId","linkDeviceStorage","link","decodeBase64","base64","data","currentTime","expiredTime","useWalletStateHandle","options","connectedWallet","connect","namespace","isManualConnect","accountState","keyStore","networkId","chains","checkChainSupport","unsupported","setUnsupported","currentWalletAddress","currentChain","id","isSupported","localAddress","res","error","walletState","wallet","status","toast","capitalizeString","useEventEmitter","useSessionStorage","useWalletSubscription","useWalletEvent","ee","recordRef","record","setRecord","side","transStatus","showToast","isPushOnce","msg","useSettleSubscription","useSettleEvent","modal","useStorageLedgerAddress","useWalletConnectError","setLedgerAddress","useRestrictedAreas","jsx","AppContext","useAppContext","AppStateProvider","props","currentChainId","setCurrentChainId","connectWallet","wrongNetwork","restrictedInfo","AppConfigContext","useAppConfig","AppConfigProvider","transSymbolformString","AlgoOrderRootType","parseNumber","getOrderExecutionReportMsg","symbolsInfo","symbol","quantity","total_executed_quantity","getSymbolInfo","base_dp","displaySide","displaySymbol","displayQuantity","title","displayTotalExecutedQuantity","useSymbolsInfo","useDebouncedCallback","jsxs","useExecutionReport","symbolsInfoRef","handler","OrderlyAppProvider","components","appIcons","onChainChanged","defaultChain","configProps","useDataTap","state"],"mappings":"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","sourcesContent":["import { PropsWithChildren } from \"react\";\nimport { OrderlyAppConfig } from \"../types\";\nimport {\n ModalProvider,\n OrderlyThemeProvider,\n Toaster,\n TooltipProvider,\n} from \"@orderly.network/ui\";\nimport { useBootstrap } from \"../hooks/useBootstrap\";\nimport {\n ConfigProviderProps,\n OrderlyConfigProvider,\n OrderlyTrackerProvider,\n} from \"@orderly.network/hooks\";\nimport { AppStateProvider, AppStateProviderProps } from \"./appContext\";\nimport { AppConfigProvider } from \"./configContext\";\nimport { useExecutionReport } from \"../hooks/useExecutionReport\";\nimport { OrderlyThemeProviderProps } from \"@orderly.network/ui/src/provider/orderlyThemeProvider\";\n\nexport type OrderlyAppProviderProps = PropsWithChildren<\n OrderlyAppConfig & AppStateProviderProps & OrderlyThemeProviderProps\n>;\n\nconst OrderlyAppProvider = (props: OrderlyAppProviderProps) => {\n const {\n // dateFormatting,\n components,\n appIcons,\n onChainChanged,\n defaultChain,\n ...configProps\n } = props;\n\n useBootstrap();\n useExecutionReport();\n\n return (\n <AppConfigProvider appIcons={appIcons} brokerName={props.brokerName!}>\n <OrderlyThemeProvider\n // dateFormatting={dateFormatting}\n components={components}\n overrides={props.overrides}\n >\n <OrderlyConfigProvider {...(configProps as ConfigProviderProps)}>\n <AppStateProvider\n onChainChanged={onChainChanged}\n defaultChain={defaultChain}\n restrictedInfo={props.restrictedInfo}\n >\n <OrderlyTrackerProvider>\n <TooltipProvider delayDuration={300}>\n <ModalProvider>{props.children}</ModalProvider>\n </TooltipProvider>\n </OrderlyTrackerProvider>\n </AppStateProvider>\n <Toaster />\n </OrderlyConfigProvider>\n </OrderlyThemeProvider>\n </AppConfigProvider>\n );\n};\n\nOrderlyAppProvider.displayName = \"OrderlyAppProvider\";\n\nexport { OrderlyAppProvider };\n","import { useEffect } from \"react\";\nimport { useAccount, useWalletConnector } from \"@orderly.network/hooks\";\n\nexport const useBootstrap = () => {\n useEffect(() => {\n const searchParams = new URLSearchParams(window.location.search);\n const refCode = searchParams.get(\"ref\");\n if (refCode) {\n localStorage.setItem(\"referral_code\", refCode);\n }\n }, []);\n};\n","import {\n FC,\n createContext,\n PropsWithChildren,\n useContext,\n useState,\n} from \"react\";\nimport { useWalletStateHandle } from \"../hooks/useWalletStateHandle\";\nimport { useAppState } from \"../hooks/useAppState\";\nimport { useWalletEvent } from \"../hooks/useWalletEvent\";\nimport { useSettleEvent } from \"../hooks/useSettleEvent\";\nimport { useWalletConnectError } from \"../hooks/useWalletConnectError\";\nimport {\n useRestrictedAreas,\n RestrictedAreasReturns,\n IRestrictedAreasParams,\n Chains,\n} from \"@orderly.network/hooks\";\nimport { useLinkDevice } from \"../hooks/useLinkDevice\";\nimport { Chain, NetworkId } from \"@orderly.network/types\";\n\ntype ReturnChain = Pick<Chain, \"id\"> & Partial<Omit<Chain, \"id\">>;\n\ntype DefaultChain =\n | {\n mainnet?: ReturnChain;\n testnet?: ReturnChain;\n }\n | ((networkId: NetworkId, chains: Chains) => ReturnChain)\n | undefined;\n\ntype AppContextState = {\n connectWallet: ReturnType<typeof useWalletStateHandle>[\"connectWallet\"];\n /**\n * Whether the current network is not supported\n */\n wrongNetwork: boolean;\n currentChainId: number | undefined;\n setCurrentChainId: (chainId: number | undefined) => void;\n onChainChanged?: (\n chainId: number,\n state: { isTestnet: boolean; isWalletConnected: boolean }\n ) => void;\n defaultChain?: DefaultChain;\n // networkStatus: ReturnType<typeof useAppState>[\"networkStatus\"];\n restrictedInfo?: RestrictedAreasReturns;\n};\n\nconst AppContext = createContext<AppContextState>({} as AppContextState);\n\nexport const useAppContext = () => {\n return useContext(AppContext);\n};\n\nexport type AppStateProviderProps = {\n restrictedInfo?: IRestrictedAreasParams;\n} & Pick<AppContextState, \"onChainChanged\" | \"defaultChain\">;\n\nexport const AppStateProvider: FC<PropsWithChildren<AppStateProviderProps>> = (\n props\n) => {\n const [currentChainId, setCurrentChainId] = useState<number | undefined>();\n useLinkDevice();\n\n const { connectWallet, wrongNetwork } = useWalletStateHandle({\n // onChainChanged: props.onChainChanged,\n currentChainId,\n });\n\n useWalletEvent();\n useSettleEvent();\n useWalletConnectError();\n const restrictedInfo = useRestrictedAreas(props?.restrictedInfo ?? {});\n\n // const { networkStatus } = useAppState();\n\n return (\n <AppContext.Provider\n value={{\n connectWallet,\n wrongNetwork,\n currentChainId,\n setCurrentChainId,\n onChainChanged: props.onChainChanged,\n defaultChain: props.defaultChain,\n restrictedInfo,\n }}\n >\n {props.children}\n </AppContext.Provider>\n );\n};\n","import { useEffect, useMemo, useRef, useState } from \"react\";\nimport { useConfig, WalletState } from \"@orderly.network/hooks\";\nimport {\n useAccount,\n useChains,\n useKeyStore,\n useWalletConnector,\n} from \"@orderly.network/hooks\";\nimport {\n parseChainIdToNumber,\n praseChainIdToNumber,\n windowGuard,\n} from \"@orderly.network/utils\";\nimport {\n AccountStatusEnum,\n SDKError,\n ChainNamespace,\n NetworkId,\n} from \"@orderly.network/types\";\nimport { getLinkDeviceData } from \"./useLinkDevice\";\n\nconst WALLET_KEY = \"orderly:wallet-info\";\nconst CHAIN_NAMESPACE = \"orderly:chain-namespace\";\n\nexport const useWalletStateHandle = (options: {\n // onChainChanged?: (chainId: number, isTestnet: boolean) => void;\n currentChainId?: number;\n}) => {\n const {\n wallet: connectedWallet,\n connect,\n connectedChain,\n disconnect,\n namespace,\n } = useWalletConnector();\n //\n // console.log(\"🔗 wallet state handle\", {\n // connectedWallet,\n // connectedChain,\n // namespace,\n // });\n\n if (typeof connect !== \"function\") {\n throw new SDKError(\"Please provide a wallet connector provider\");\n }\n\n const isManualConnect = useRef<boolean>(false);\n\n const { account, state: accountState } = useAccount();\n const keyStore = useKeyStore();\n const networkId = useConfig(\"networkId\") as NetworkId;\n const [chains, { checkChainSupport }] = useChains();\n\n const [unsupported, setUnsupported] = useState(false);\n\n // current connected wallet address\n const currentWalletAddress = useMemo<string | undefined>(() => {\n return connectedWallet?.accounts?.[0]?.address;\n }, [connectedWallet]);\n\n // current connected chain id\n const currentChain = useMemo<\n { id: number; namespace: string } | undefined\n >(() => {\n const id = connectedWallet?.chains?.[0]?.id;\n const namespace = connectedWallet?.chains?.[0]?.namespace;\n if (typeof id === \"undefined\") return undefined;\n return {\n id: parseChainIdToNumber(id),\n namespace,\n };\n }, [connectedWallet]);\n\n useEffect(() => {\n if (!connectedChain) {\n setUnsupported(false);\n return;\n }\n\n let isSupported = checkChainSupport(\n connectedChain.id,\n networkId\n // networkId === \"testnet\" ? chains.testnet : chains.mainnet\n );\n\n setUnsupported(!isSupported);\n }, [connectedChain, chains, checkChainSupport, networkId]);\n\n useEffect(() => {\n // if (unsupported) return;\n\n windowGuard(() => {\n const localAddress = keyStore.getAddress();\n const walletInfo = JSON.parse(localStorage.getItem(WALLET_KEY) ?? \"{}\");\n\n /**\n * if locale address is exist, restore account state\n */\n if (connectedChain?.namespace === ChainNamespace.solana) {\n return;\n }\n if (\n localAddress &&\n account.address !== localAddress &&\n walletInfo.label\n ) {\n connect({\n autoSelect: {\n label: walletInfo.label,\n disableModals: true,\n },\n }).then(\n (res) => {\n console.log(\"silent connect wallet successes\", res);\n },\n (error) => console.log(\"connect error\", error)\n );\n }\n });\n }, [connectedWallet, account.address]);\n\n /**\n * handle wallet connection\n */\n useEffect(() => {\n if (\n connectedWallet === null &&\n accountState.status > AccountStatusEnum.NotConnected &&\n !accountState.validating\n ) {\n account.disconnect();\n return;\n }\n\n if (unsupported || !connectedChain) return;\n if (isManualConnect.current) return;\n\n const linkData = getLinkDeviceData();\n\n // updateAccount(currentWalletAddress!, connectedWallet!, currentChainId!);\n /**\n * switch account\n */\n if (\n !!currentWalletAddress &&\n currentWalletAddress !== account.address &&\n !linkData\n ) {\n account.setAddress(currentWalletAddress, {\n provider: connectedWallet?.provider,\n chain: {\n id: praseChainIdToNumber(currentChain!.id),\n namespace: currentChain!.namespace.toUpperCase() as ChainNamespace,\n },\n wallet: {\n name: connectedWallet.label,\n },\n });\n\n // save wallet connector info to local storage\n windowGuard(() => {\n localStorage.setItem(\n WALLET_KEY,\n JSON.stringify({\n label: connectedWallet.label,\n })\n );\n });\n }\n\n /**\n * switch chainId\n */\n if (currentChain?.id !== account.chainId) {\n account.switchChainId(currentChain?.id!);\n\n // emit chain changed event\n // options.onChainChanged?.(currentChainId!, isTestnet(networkId));\n }\n }, [\n connectedWallet,\n connectedChain,\n currentWalletAddress,\n currentChain,\n account.address,\n accountState,\n account.chainId,\n unsupported,\n ]);\n\n /**\n * User manually connects to wallet\n */\n const connectWallet = async (): Promise<{\n wallet?: WalletState;\n status?: AccountStatusEnum;\n wrongNetwork?: boolean;\n } | null> => {\n isManualConnect.current = true;\n // const walletState = await connect();\n\n return connect({ chainId: options.currentChainId })\n .then(async (walletState) => {\n if (\n Array.isArray(walletState) &&\n walletState.length > 0 &&\n walletState[0] &&\n walletState[0].accounts.length > 0\n ) {\n const wallet = walletState[0];\n const chainId = praseChainIdToNumber(wallet.chains[0].id);\n\n if (!checkChainSupport(chainId, networkId)) {\n return {\n wrongNetwork: true,\n };\n }\n\n //\n if (!account) {\n throw new Error(\"account is not initialized\");\n }\n console.log(\"-- aaaaa wallet\", wallet);\n // clear link device data when connect wallt\n if (\n accountState.status ===\n AccountStatusEnum.EnableTradingWithoutConnected\n ) {\n localStorage.removeItem(\"orderly_link_device\");\n await account.disconnect();\n }\n const status = await account.setAddress(wallet.accounts[0].address, {\n provider: wallet.provider,\n chain: {\n id: praseChainIdToNumber(wallet.chains[0].id),\n namespace:\n wallet.chains[0].namespace.toUpperCase() as ChainNamespace,\n },\n wallet: {\n name: wallet.label,\n },\n // label: ,\n });\n console.log(\"-- xxxxxx status\", status);\n\n return { wallet, status, wrongNetwork: false };\n }\n\n return null;\n })\n .finally(() => {\n isManualConnect.current = false;\n });\n };\n\n return {\n connectWallet,\n wrongNetwork: unsupported,\n };\n};\n","import { useCallback, useEffect } from \"react\";\nimport {\n parseJSON,\n useAccount,\n useConfig,\n useLocalStorage,\n useWalletConnector,\n} from \"@orderly.network/hooks\";\nimport { useScreen } from \"@orderly.network/ui\";\nimport { ChainNamespace } from \"@orderly.network/types\";\n\ntype DecodedData = {\n /** secret key */\n k: string;\n /* timestamp */\n t: number;\n /** address */\n a: string;\n /** chain id */\n i: number;\n /** chain namespace */\n n: ChainNamespace;\n};\n\ntype LinkDeviceStorage = { chainId: number; chainNamespace: ChainNamespace };\n\nconst WALLET_KEY = \"orderly:wallet-info\";\n\nexport function useLinkDevice() {\n const { connectedChain, disconnect } = useWalletConnector();\n const [_, setLinkDeviceStorage] = useLocalStorage(\n \"orderly_link_device\",\n {} as LinkDeviceStorage\n );\n\n const { account } = useAccount();\n const { isMobile } = useScreen();\n const configStore = useConfig();\n\n const onDisconnect = async (label: string) => {\n // The cache must be cleared first, otherwise it will be auto connect wallet\n localStorage.removeItem(WALLET_KEY);\n await account.disconnect();\n await disconnect({ label });\n };\n\n useEffect(() => {\n const linkData = getLinkDeviceData();\n const walletInfo = JSON.parse(localStorage.getItem(WALLET_KEY) ?? \"{}\");\n if (linkData && walletInfo) {\n // clear connect data when link device\n onDisconnect(walletInfo.label);\n }\n }, []);\n\n const linkDevice = async () => {\n const linkData = getLinkDeviceData();\n if (!linkData) return;\n\n const { address, secretKey, chainId, chainNamespace } = linkData;\n const isSuccess = await account.importOrderlyKey({\n address,\n secretKey,\n chainNamespace,\n });\n if (!isSuccess) return;\n setLinkDeviceStorage({\n chainId,\n chainNamespace,\n });\n\n const url = new URL(window.location.href);\n url.searchParams.delete(\"link\");\n const decodedUrl = decodeURIComponent(url.toString());\n history.replaceState(null, \"\", decodedUrl);\n };\n\n useEffect(() => {\n if (isMobile && !connectedChain) {\n linkDevice();\n }\n }, [account, connectedChain, isMobile]);\n\n const autoLinkDevice = async () => {\n // this can't use the value returned by useLocalStorage here, because it will trigger extra state change\n const { chainId, chainNamespace } = getLinkDeviceStorage() || {};\n if (isMobile && !connectedChain && chainId && chainNamespace) {\n const address = account.keyStore.getAddress();\n const orderlyKey = account.keyStore.getOrderlyKey();\n const accountId = account.keyStore.getAccountId(address!);\n const res = await account.checkOrderlyKey(\n address!,\n orderlyKey!,\n accountId!\n );\n if (res) {\n configStore.set(\"chainNamespace\", chainNamespace);\n }\n }\n };\n\n // persist status when refresh page\n useEffect(() => {\n autoLinkDevice();\n }, [account, isMobile, connectedChain]);\n\n return { linkDevice };\n}\n\nfunction getLinkDeviceStorage() {\n try {\n const linkDeviceStorage = localStorage.getItem(\"orderly_link_device\");\n const json = linkDeviceStorage ? parseJSON(linkDeviceStorage) : null;\n return json as LinkDeviceStorage;\n } catch (err) {\n console.error(\"getLinkDeviceStorage\", err);\n }\n}\n\nexport function getLinkDeviceData() {\n const url = new URL(window.location.href);\n const link = url.searchParams.get(\"link\");\n\n if (!link) return;\n\n const {\n a: address,\n k: secretKey,\n i: chainId,\n n: chainNamespace,\n } = decodeBase64(link) || {};\n\n if (address && secretKey && chainId && chainNamespace) {\n return {\n address,\n secretKey,\n chainId,\n chainNamespace,\n };\n }\n}\n\nfunction decodeBase64(base64: string) {\n try {\n const data = JSON.parse(window.atob(base64)) as DecodedData;\n console.log(\"decodeBase64\", data);\n const currentTime = Math.floor(Date.now() / 1000);\n const expiredTime = data.t;\n\n if (!expiredTime || currentTime > expiredTime) {\n console.error(\"Orderly key has expired.\");\n return;\n }\n\n return data;\n } catch (error) {\n console.error(\"Invalid or expired orderly key.\");\n }\n}\n","import { useRef } from \"react\";\nimport { toast } from \"@orderly.network/ui\";\nimport { capitalizeString } from \"@orderly.network/utils\";\nimport {\n useEventEmitter,\n useSessionStorage,\n useWalletSubscription,\n} from \"@orderly.network/hooks\";\n\nexport function useWalletEvent() {\n const ee = useEventEmitter();\n\n const recordRef = useRef<Record<number, boolean>>({});\n\n const [record, setRecord] = useSessionStorage(\n \"orderly_wallet_change_id\",\n {} as Record<number, boolean>\n );\n\n recordRef.current = record;\n\n useWalletSubscription({\n onMessage: (data: any) => {\n console.log(\"wallet:changed\", data);\n const { id, side, transStatus } = data;\n let showToast = true;\n\n // DEPOSIT and WITHDRAW will push twice COMPLETED and FAILED event\n if (\n [\"DEPOSIT\", \"WITHDRAW\"].includes(side) &&\n [\"COMPLETED\", \"FAILED\"].includes(transStatus)\n ) {\n const isPushOnce = recordRef.current[id];\n setRecord({\n ...record,\n [id]: isPushOnce ? undefined : true,\n });\n\n showToast = !isPushOnce;\n }\n\n if (transStatus === \"COMPLETED\" && showToast) {\n let msg = `${capitalizeString(side)} completed`;\n toast.success(msg);\n } else if (transStatus === \"FAILED\" && showToast) {\n let msg = `${capitalizeString(side)} failed`;\n toast.error(msg);\n }\n\n ee.emit(\"wallet:changed\", data);\n },\n });\n}\n","import { useSettleSubscription } from \"@orderly.network/hooks\";\nimport { toast } from \"@orderly.network/ui\";\n\nexport function useSettleEvent() {\n useSettleSubscription({\n onMessage: (data: any) => {\n const { status } = data;\n\n // console.log(\"settle ws: \", data);\n\n switch (status) {\n case \"COMPLETED\":\n toast.success(\"Settlement completed\");\n break;\n case \"FAILED\":\n toast.error(\"Settlement failed\");\n break;\n default:\n break;\n }\n },\n });\n}\n","import { useEventEmitter } from \"@orderly.network/hooks\";\nimport { useEffect } from \"react\";\nimport { modal, toast } from \"@orderly.network/ui\";\nimport { LedgerWalletKey } from \"@orderly.network/types\";\nimport { useStorageLedgerAddress } from \"@orderly.network/hooks\"; \n\n\nexport function useWalletConnectError() {\n const ee = useEventEmitter();\n const {setLedgerAddress} = useStorageLedgerAddress(); \n\n\n useEffect(() => {\n ee.on('wallet:connect-error', (data) => {\n toast.error(data.message);\n\n })\n ee.on('wallet:sign-message-with-ledger-error', (data: { userAddress: string; message: string }) => {\n window.setTimeout(() => {\n\n modal.confirm({\n title: 'Sign Message Failed',\n content: \"Are you using Ledger Wallet?\",\n size: 'sm',\n onOk: async () => {\n console.log('-- use ledger', true);\n setLedgerAddress(data.userAddress);\n \n return Promise.resolve();\n },\n okLabel: 'OK',\n onCancel: async () => {\n toast.error(data.message);\n return Promise.resolve();\n },\n cancelLabel: 'No',\n\n }).then(res => {\n console.log('-- dialog res', res);\n });\n\n });\n\n })\n\n }, [ee])\n\n return {}\n}","import { createContext, PropsWithChildren, useContext } from \"react\";\nimport { AppLogos } from \"../types\";\n\nexport type ThemeContextState = {\n appIcons?: AppLogos;\n brokerName: string;\n};\n\nconst AppConfigContext = createContext<ThemeContextState>(\n {} as ThemeContextState\n);\n\nexport const useAppConfig = () => {\n return useContext(AppConfigContext);\n};\n\nexport const AppConfigProvider = (\n props: PropsWithChildren<{\n appIcons?: AppLogos;\n brokerName: string;\n }>\n) => {\n return (\n <AppConfigContext.Provider value={props}>\n {props.children}\n </AppConfigContext.Provider>\n );\n};\n","import { useEffect, useRef } from \"react\";\nimport { getOrderExecutionReportMsg } from \"./getOrderExecutionReportMsg\";\nimport {\n useSymbolsInfo,\n useWS,\n useEventEmitter,\n useDebouncedCallback,\n} from \"@orderly.network/hooks\";\nimport { toast } from \"@orderly.network/ui\";\n\nexport function useExecutionReport() {\n const ee = useEventEmitter();\n\n const symbolsInfo = useSymbolsInfo();\n const symbolsInfoRef = useRef({});\n\n useEffect(() => {\n symbolsInfoRef.current = symbolsInfo;\n }, [symbolsInfo]);\n\n const handler = useDebouncedCallback((data: any) => {\n const showToast = (data: any) => {\n const { title, msg } = getOrderExecutionReportMsg(\n data,\n symbolsInfoRef.current\n );\n\n if (title && msg) {\n toast.success(\n <div>\n {title}\n <br />\n <div className=\"orderly-text-white/[0.54] orderly-text-xs\">\n {msg}\n </div>\n </div>\n );\n }\n };\n\n showToast(data);\n }, 100);\n\n useEffect(() => {\n ee.on(\"orders:changed\", handler);\n\n return () => {\n ee.off(\"orders:changed\", handler);\n };\n }, []);\n}\n","import {\n capitalizeString,\n transSymbolformString,\n} from \"@orderly.network/utils\";\nimport { API } from \"@orderly.network/types\";\nimport { AlgoOrderRootType } from \"@orderly.network/types\";\nimport { parseNumber } from \"@orderly.network/ui\";\n\nexport function getOrderExecutionReportMsg(\n data: API.AlgoOrder | API.Order,\n symbolsInfo: any\n) {\n const { symbol, side, quantity } = data;\n const total_executed_quantity =\n \"total_executed_quantity\" in data ? data.total_executed_quantity : 0;\n const status = \"status\" in data ? data.status : data.algo_status;\n const getSymbolInfo = symbolsInfo[symbol];\n const base_dp = getSymbolInfo(\"base_dp\");\n const displaySide = capitalizeString(side);\n const displaySymbol = transSymbolformString(symbol);\n const displayQuantity =\n \"algo_type\" in data && data.algo_type === AlgoOrderRootType.POSITIONAL_TP_SL\n ? \"Entire position\"\n : base_dp === undefined\n ? quantity\n : parseNumber(quantity, { dp: base_dp });\n\n let title = \"\";\n let msg = \"\";\n switch (status) {\n case \"NEW\":\n title = \"Order opened\";\n msg = `${displaySide} ${displaySymbol} ${displayQuantity}`;\n break;\n case \"FILLED\":\n case \"PARTIAL_FILLED\":\n const displayTotalExecutedQuantity =\n base_dp === undefined\n ? total_executed_quantity\n : parseNumber(total_executed_quantity, { dp: base_dp });\n title = \"Order filled\";\n msg = `${displaySide} ${displaySymbol} ${displayTotalExecutedQuantity} / ${displayQuantity}`;\n break;\n case \"CANCELLED\":\n title = \"Order cancelled\";\n msg = `${displaySide} ${displaySymbol} ${displayQuantity}`;\n break;\n case \"REJECTED\":\n title = \"Order rejected\";\n msg = `${displaySide} ${displaySymbol} ${displayQuantity}`;\n break;\n case \"REPLACED\":\n title = \"Order edited\";\n msg = `${side} ${displaySymbol} ${total_executed_quantity} / ${displayQuantity}`;\n break;\n default:\n break;\n }\n\n return {\n title,\n msg,\n };\n}\n","import { AccountStatusEnum } from \"@orderly.network/types\";\nimport { useAppContext } from \"../provider/appContext\";\nimport { useAccount } from \"@orderly.network/hooks\";\n\nexport const useDataTap = <T = any>(\n data: T,\n options?: {\n skip?: false;\n fallbackData?: T;\n accountStatus?: AccountStatusEnum;\n }\n): T | null => {\n const { wrongNetwork } = useAppContext();\n const { state } = useAccount();\n /**\n * ignore\n */\n if (options?.skip) return data;\n\n if (wrongNetwork) {\n return typeof options?.fallbackData !== \"undefined\"\n ? options.fallbackData\n : null;\n }\n\n if (typeof options?.accountStatus !== \"undefined\") {\n if (state.status < options.accountStatus) {\n return typeof options?.fallbackData !== \"undefined\"\n ? options.fallbackData\n : null;\n }\n }\n\n // return wrongNetwork\n // ? typeof options?.fallbackData !== \"undefined\"\n // ? options.fallbackData\n // : null\n // : data;\n //\n return data;\n};\n"]}
|
package/dist/index.mjs
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
import { OrderlyThemeProvider, TooltipProvider, ModalProvider, Toaster, toast, useScreen, modal
|
|
2
|
-
import { createContext, useContext, useEffect,
|
|
3
|
-
import { OrderlyConfigProvider, OrderlyTrackerProvider, useAccount,
|
|
4
|
-
import {
|
|
5
|
-
import { SDKError, ChainNamespace, AccountStatusEnum
|
|
1
|
+
import { OrderlyThemeProvider, TooltipProvider, ModalProvider, Toaster, toast, parseNumber, useScreen, modal } from '@orderly.network/ui';
|
|
2
|
+
import { createContext, useContext, useEffect, useRef, useState, useMemo } from 'react';
|
|
3
|
+
import { OrderlyConfigProvider, OrderlyTrackerProvider, useAccount, useEventEmitter, useSymbolsInfo, useDebouncedCallback, useRestrictedAreas, useWalletConnector, useLocalStorage, useConfig, useKeyStore, useChains, useSessionStorage, useWalletSubscription, useSettleSubscription, useStorageLedgerAddress, parseJSON } from '@orderly.network/hooks';
|
|
4
|
+
import { capitalizeString, transSymbolformString, parseChainIdToNumber, windowGuard, praseChainIdToNumber } from '@orderly.network/utils';
|
|
5
|
+
import { AlgoOrderRootType, SDKError, ChainNamespace, AccountStatusEnum } from '@orderly.network/types';
|
|
6
6
|
import { jsx, jsxs } from 'react/jsx-runtime';
|
|
7
7
|
|
|
8
|
-
var
|
|
8
|
+
var x=()=>{useEffect(()=>{let t=new URLSearchParams(window.location.search).get("ref");t&&localStorage.setItem("referral_code",t);},[]);};var E="orderly:wallet-info";function D(){let{connectedChain:e,disconnect:t}=useWalletConnector(),[r,o]=useLocalStorage("orderly_link_device",{}),{account:n}=useAccount(),{isMobile:s}=useScreen(),f=useConfig(),a=async c=>{localStorage.removeItem(E),await n.disconnect(),await t({label:c});};useEffect(()=>{let c=A(),l=JSON.parse(localStorage.getItem(E)??"{}");c&&l&&a(l.label);},[]);let i=async()=>{let c=A();if(!c)return;let{address:l,secretKey:u,chainId:m,chainNamespace:g}=c;if(!await n.importOrderlyKey({address:l,secretKey:u,chainNamespace:g}))return;o({chainId:m,chainNamespace:g});let C=new URL(window.location.href);C.searchParams.delete("link");let b=decodeURIComponent(C.toString());history.replaceState(null,"",b);};useEffect(()=>{s&&!e&&i();},[n,e,s]);let d=async()=>{let{chainId:c,chainNamespace:l}=se()||{};if(s&&!e&&c&&l){let u=n.keyStore.getAddress(),m=n.keyStore.getOrderlyKey(),g=n.keyStore.getAccountId(u);await n.checkOrderlyKey(u,m,g)&&f.set("chainNamespace",l);}};return useEffect(()=>{d();},[n,s,e]),{linkDevice:i}}function se(){try{let e=localStorage.getItem("orderly_link_device");return e?parseJSON(e):null}catch{}}function A(){let t=new URL(window.location.href).searchParams.get("link");if(!t)return;let{a:r,k:o,i:n,n:s}=ie(t)||{};if(r&&o&&n&&s)return {address:r,secretKey:o,chainId:n,chainNamespace:s}}function ie(e){try{let t=JSON.parse(window.atob(e)),r=Math.floor(Date.now()/1e3),o=t.t;return !o||r>o?void 0:t}catch{}}var T="orderly:wallet-info";var W=e=>{let{wallet:t,connect:r,connectedChain:o,disconnect:n,namespace:s}=useWalletConnector();if(typeof r!="function")throw new SDKError("Please provide a wallet connector provider");let f=useRef(false),{account:a,state:i}=useAccount(),d=useKeyStore(),c=useConfig("networkId"),[l,{checkChainSupport:u}]=useChains(),[m,g]=useState(false),S=useMemo(()=>t?.accounts?.[0]?.address,[t]),C=useMemo(()=>{let p=t?.chains?.[0]?.id,h=t?.chains?.[0]?.namespace;if(!(typeof p>"u"))return {id:parseChainIdToNumber(p),namespace:h}},[t]);return useEffect(()=>{if(!o){g(false);return}let p=u(o.id,c);g(!p);},[o,l,u,c]),useEffect(()=>{windowGuard(()=>{let p=d.getAddress(),h=JSON.parse(localStorage.getItem(T)??"{}");o?.namespace!==ChainNamespace.solana&&p&&a.address!==p&&h.label&&r({autoSelect:{label:h.label,disableModals:true}}).then(P=>{},P=>{});});},[t,a.address]),useEffect(()=>{if(t===null&&i.status>AccountStatusEnum.NotConnected&&!i.validating){a.disconnect();return}if(m||!o||f.current)return;let p=A();S&&S!==a.address&&!p&&(a.setAddress(S,{provider:t?.provider,chain:{id:praseChainIdToNumber(C.id),namespace:C.namespace.toUpperCase()},wallet:{name:t.label}}),windowGuard(()=>{localStorage.setItem(T,JSON.stringify({label:t.label}));})),C?.id!==a.chainId&&a.switchChainId(C?.id);},[t,o,S,C,a.address,i,a.chainId,m]),{connectWallet:async()=>(f.current=true,r({chainId:e.currentChainId}).then(async p=>{if(Array.isArray(p)&&p.length>0&&p[0]&&p[0].accounts.length>0){let h=p[0],P=praseChainIdToNumber(h.chains[0].id);if(!u(P,c))return {wrongNetwork:true};if(!a)throw new Error("account is not initialized");i.status===AccountStatusEnum.EnableTradingWithoutConnected&&(localStorage.removeItem("orderly_link_device"),await a.disconnect());let Z=await a.setAddress(h.accounts[0].address,{provider:h.provider,chain:{id:praseChainIdToNumber(h.chains[0].id),namespace:h.chains[0].namespace.toUpperCase()},wallet:{name:h.label}});return {wallet:h,status:Z,wrongNetwork:false}}return null}).finally(()=>{f.current=false;})),wrongNetwork:m}};function $(){let e=useEventEmitter(),t=useRef({}),[r,o]=useSessionStorage("orderly_wallet_change_id",{});t.current=r,useWalletSubscription({onMessage:n=>{let{id:s,side:f,transStatus:a}=n,i=true;if(["DEPOSIT","WITHDRAW"].includes(f)&&["COMPLETED","FAILED"].includes(a)){let d=t.current[s];o({...r,[s]:d?void 0:true}),i=!d;}if(a==="COMPLETED"&&i){let d=`${capitalizeString(f)} completed`;toast.success(d);}else if(a==="FAILED"&&i){let d=`${capitalizeString(f)} failed`;toast.error(d);}e.emit("wallet:changed",n);}});}function K(){useSettleSubscription({onMessage:e=>{let{status:t}=e;switch(t){case "COMPLETED":toast.success("Settlement completed");break;case "FAILED":toast.error("Settlement failed");break;}}});}function U(){let e=useEventEmitter(),{setLedgerAddress:t}=useStorageLedgerAddress();return useEffect(()=>{e.on("wallet:connect-error",r=>{toast.error(r.message);}),e.on("wallet:sign-message-with-ledger-error",r=>{window.setTimeout(()=>{modal.confirm({title:"Sign Message Failed",content:"Are you using Ledger Wallet?",size:"sm",onOk:async()=>(t(r.userAddress),Promise.resolve()),okLabel:"OK",onCancel:async()=>(toast.error(r.message),Promise.resolve()),cancelLabel:"No"}).then(o=>{});});});},[e]),{}}var J=createContext({}),I=()=>useContext(J),H=e=>{let[t,r]=useState();D();let{connectWallet:o,wrongNetwork:n}=W({currentChainId:t});$(),K(),U();let s=useRestrictedAreas(e?.restrictedInfo??{});return jsx(J.Provider,{value:{connectWallet:o,wrongNetwork:n,currentChainId:t,setCurrentChainId:r,onChainChanged:e.onChainChanged,defaultChain:e.defaultChain,restrictedInfo:s},children:e.children})};var q=createContext({}),We=()=>useContext(q),z=e=>jsx(q.Provider,{value:e,children:e.children});function Q(e,t){let{symbol:r,side:o,quantity:n}=e,s="total_executed_quantity"in e?e.total_executed_quantity:0,f="status"in e?e.status:e.algo_status,a=t[r],i=a("base_dp"),d=capitalizeString(o),c=transSymbolformString(r),l="algo_type"in e&&e.algo_type===AlgoOrderRootType.POSITIONAL_TP_SL?"Entire position":i===void 0?n:parseNumber(n,{dp:i}),u="",m="";switch(f){case "NEW":u="Order opened",m=`${d} ${c} ${l}`;break;case "FILLED":case "PARTIAL_FILLED":let g=i===void 0?s:parseNumber(s,{dp:i});u="Order filled",m=`${d} ${c} ${g} / ${l}`;break;case "CANCELLED":u="Order cancelled",m=`${d} ${c} ${l}`;break;case "REJECTED":u="Order rejected",m=`${d} ${c} ${l}`;break;case "REPLACED":u="Order edited",m=`${o} ${c} ${s} / ${l}`;break;}return {title:u,msg:m}}function V(){let e=useEventEmitter(),t=useSymbolsInfo(),r=useRef({});useEffect(()=>{r.current=t;},[t]);let o=useDebouncedCallback(n=>{(f=>{let{title:a,msg:i}=Q(f,r.current);a&&i&&toast.success(jsxs("div",{children:[a,jsx("br",{}),jsx("div",{className:"orderly-text-white/[0.54] orderly-text-xs",children:i})]}));})(n);},100);useEffect(()=>(e.on("orders:changed",o),()=>{e.off("orders:changed",o);}),[]);}var X=e=>{let{components:t,appIcons:r,onChainChanged:o,defaultChain:n,...s}=e;return x(),V(),jsx(z,{appIcons:r,brokerName:e.brokerName,children:jsx(OrderlyThemeProvider,{components:t,overrides:e.overrides,children:jsxs(OrderlyConfigProvider,{...s,children:[jsx(H,{onChainChanged:o,defaultChain:n,restrictedInfo:e.restrictedInfo,children:jsx(OrderlyTrackerProvider,{children:jsx(TooltipProvider,{delayDuration:300,children:jsx(ModalProvider,{children:e.children})})})}),jsx(Toaster,{})]})})})};X.displayName="OrderlyAppProvider";var je=(e,t)=>{let{wrongNetwork:r}=I(),{state:o}=useAccount();return t?.skip?e:r||typeof t?.accountStatus<"u"&&o.status<t.accountStatus?typeof t?.fallbackData<"u"?t.fallbackData:null:e};
|
|
9
9
|
|
|
10
|
-
export {
|
|
10
|
+
export { X as OrderlyAppProvider, We as useAppConfig, I as useAppContext, je as useDataTap };
|
|
11
11
|
//# sourceMappingURL=out.js.map
|
|
12
12
|
//# sourceMappingURL=index.mjs.map
|
package/dist/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/provider/orderlyAppProvider.tsx","../src/hooks/useBootstrap.ts","../src/provider/appContext.tsx","../src/hooks/useWalletStateHandle.ts","../src/hooks/useLinkDevice.ts","../src/hooks/useWalletEvent.ts","../src/hooks/useSettleEvent.ts","../src/hooks/useWalletConnectError.ts","../src/provider/configContext.tsx","../src/hooks/useExecutionReport.tsx","../src/hooks/getOrderExecutionReportMsg.ts","../src/hooks/useDataTap.ts"],"names":["ModalProvider","OrderlyThemeProvider","Toaster","TooltipProvider","useEffect","useBootstrap","refCode","OrderlyConfigProvider","OrderlyTrackerProvider","createContext","useContext","useState","useMemo","useRef","useConfig","useAccount","useChains","useKeyStore","useWalletConnector","parseChainIdToNumber","praseChainIdToNumber","windowGuard","AccountStatusEnum","SDKError","ChainNamespace","parseJSON","useLocalStorage","useScreen","WALLET_KEY","useLinkDevice","connectedChain","disconnect","_","setLinkDeviceStorage","account","isMobile","configStore","onDisconnect","label","linkData","getLinkDeviceData","walletInfo","linkDevice","address","secretKey","chainId","chainNamespace","url","decodedUrl","autoLinkDevice","getLinkDeviceStorage","orderlyKey","accountId","linkDeviceStorage","link","decodeBase64","base64","data","currentTime","expiredTime","useWalletStateHandle","options","connectedWallet","connect","namespace","isManualConnect","accountState","keyStore","networkId","chains","checkChainSupport","unsupported","setUnsupported","currentWalletAddress","currentChain","id","isSupported","localAddress","res","error","walletState","wallet","status","toast","capitalizeString","useEventEmitter","useSessionStorage","useWalletSubscription","useWalletEvent","ee","recordRef","record","setRecord","side","transStatus","showToast","isPushOnce","msg","useSettleSubscription","useSettleEvent","modal","LedgerWalletKey","useWalletConnectError","info","ledgerWallet","useRestrictedAreas","jsx","AppContext","useAppContext","AppStateProvider","props","currentChainId","setCurrentChainId","connectWallet","wrongNetwork","restrictedInfo","AppConfigContext","useAppConfig","AppConfigProvider","transSymbolformString","AlgoOrderRootType","parseNumber","getOrderExecutionReportMsg","symbolsInfo","symbol","quantity","total_executed_quantity","getSymbolInfo","base_dp","displaySide","displaySymbol","displayQuantity","title","displayTotalExecutedQuantity","useSymbolsInfo","useDebouncedCallback","jsxs","useExecutionReport","symbolsInfoRef","handler","OrderlyAppProvider","onChainChanged","components","appIcons","configProps","useDataTap","state"],"mappings":"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","sourcesContent":["import { PropsWithChildren } from \"react\";\nimport { OrderlyAppConfig } from \"../types\";\nimport {\n ModalProvider,\n OrderlyThemeProvider,\n Toaster,\n TooltipProvider,\n} from \"@orderly.network/ui\";\nimport { useBootstrap } from \"../hooks/useBootstrap\";\nimport {\n ConfigProviderProps,\n OrderlyConfigProvider,\n OrderlyTrackerProvider,\n} from \"@orderly.network/hooks\";\nimport { AppStateProvider, AppStateProviderProps } from \"./appContext\";\nimport { AppConfigProvider } from \"./configContext\";\nimport { useExecutionReport } from \"../hooks/useExecutionReport\";\nimport { OrderlyThemeProviderProps } from \"@orderly.network/ui/src/provider/orderlyThemeProvider\";\n\nexport type OrderlyAppProviderProps = PropsWithChildren<\n OrderlyAppConfig & AppStateProviderProps & OrderlyThemeProviderProps\n>;\n\nconst OrderlyAppProvider = (props: OrderlyAppProviderProps) => {\n const {\n onChainChanged,\n // dateFormatting,\n components,\n appIcons,\n ...configProps\n } = props;\n\n useBootstrap();\n useExecutionReport();\n\n return (\n <AppConfigProvider appIcons={appIcons} brokerName={props.brokerName!}>\n <OrderlyThemeProvider\n // dateFormatting={dateFormatting}\n components={components}\n overrides={props.overrides}\n >\n <OrderlyConfigProvider {...(configProps as ConfigProviderProps)}>\n <AppStateProvider\n onChainChanged={onChainChanged}\n restrictedInfo={props.restrictedInfo}\n >\n <OrderlyTrackerProvider>\n <TooltipProvider delayDuration={300}>\n <ModalProvider>{props.children}</ModalProvider>\n </TooltipProvider>\n </OrderlyTrackerProvider>\n </AppStateProvider>\n <Toaster />\n </OrderlyConfigProvider>\n </OrderlyThemeProvider>\n </AppConfigProvider>\n );\n};\n\nOrderlyAppProvider.displayName = \"OrderlyAppProvider\";\n\nexport { OrderlyAppProvider };\n","import { useEffect } from \"react\";\nimport { useAccount, useWalletConnector } from \"@orderly.network/hooks\";\n\nexport const useBootstrap = () => {\n useEffect(() => {\n const searchParams = new URLSearchParams(window.location.search);\n const refCode = searchParams.get(\"ref\");\n if (refCode) {\n localStorage.setItem(\"referral_code\", refCode);\n }\n }, []);\n};\n","import {\n FC,\n createContext,\n PropsWithChildren,\n useContext,\n useState,\n} from \"react\";\nimport { useWalletStateHandle } from \"../hooks/useWalletStateHandle\";\nimport { useAppState } from \"../hooks/useAppState\";\nimport { useWalletEvent } from \"../hooks/useWalletEvent\";\nimport { useSettleEvent } from \"../hooks/useSettleEvent\";\nimport { useWalletConnectError } from \"../hooks/useWalletConnectError\";\nimport {\n useRestrictedAreas,\n RestrictedAreasReturns,\n IRestrictedAreasParams,\n} from \"@orderly.network/hooks\";\nimport { useLinkDevice } from \"../hooks/useLinkDevice\";\n\ntype AppContextState = {\n connectWallet: ReturnType<typeof useWalletStateHandle>[\"connectWallet\"];\n /**\n * Whether the current network is not supported\n */\n wrongNetwork: boolean;\n currentChainId: number | undefined;\n setCurrentChainId: (chainId: number | undefined) => void;\n onChainChanged?: (\n chainId: number,\n state: { isTestnet: boolean; isWalletConnected: boolean }\n ) => void;\n // networkStatus: ReturnType<typeof useAppState>[\"networkStatus\"];\n restrictedInfo?: RestrictedAreasReturns;\n};\n\nconst AppContext = createContext<AppContextState>({} as AppContextState);\n\nexport const useAppContext = () => {\n return useContext(AppContext);\n};\n\nexport type AppStateProviderProps = {\n onChainChanged?: (\n chainId: number,\n state: { isTestnet: boolean; isWalletConnected: boolean }\n ) => void;\n restrictedInfo?: IRestrictedAreasParams;\n};\n\nexport const AppStateProvider: FC<PropsWithChildren<AppStateProviderProps>> = (\n props\n) => {\n const [currentChainId, setCurrentChainId] = useState<number | undefined>();\n useLinkDevice();\n\n const { connectWallet, wrongNetwork } = useWalletStateHandle({\n // onChainChanged: props.onChainChanged,\n currentChainId,\n });\n\n useWalletEvent();\n useSettleEvent();\n useWalletConnectError();\n const restrictedInfo = useRestrictedAreas(props?.restrictedInfo ?? {});\n\n // const { networkStatus } = useAppState();\n\n return (\n <AppContext.Provider\n value={{\n connectWallet,\n wrongNetwork,\n currentChainId,\n setCurrentChainId,\n onChainChanged: props.onChainChanged,\n restrictedInfo,\n }}\n >\n {props.children}\n </AppContext.Provider>\n );\n};\n","import { useEffect, useMemo, useRef, useState } from \"react\";\nimport { useConfig, WalletState } from \"@orderly.network/hooks\";\nimport {\n useAccount,\n useChains,\n useKeyStore,\n useWalletConnector,\n} from \"@orderly.network/hooks\";\nimport {\n parseChainIdToNumber,\n praseChainIdToNumber,\n windowGuard,\n} from \"@orderly.network/utils\";\nimport {\n AccountStatusEnum,\n SDKError,\n ChainNamespace,\n NetworkId,\n} from \"@orderly.network/types\";\nimport { getLinkDeviceData } from \"./useLinkDevice\";\n\nconst WALLET_KEY = \"orderly:wallet-info\";\nconst CHAIN_NAMESPACE = \"orderly:chain-namespace\";\n\nexport const useWalletStateHandle = (options: {\n // onChainChanged?: (chainId: number, isTestnet: boolean) => void;\n currentChainId?: number;\n}) => {\n const {\n wallet: connectedWallet,\n connect,\n connectedChain,\n disconnect,\n namespace,\n } = useWalletConnector();\n //\n // console.log(\"🔗 wallet state handle\", {\n // connectedWallet,\n // connectedChain,\n // namespace,\n // });\n\n if (typeof connect !== \"function\") {\n throw new SDKError(\"Please provide a wallet connector provider\");\n }\n\n const isManualConnect = useRef<boolean>(false);\n\n const { account, state: accountState } = useAccount();\n const keyStore = useKeyStore();\n const networkId = useConfig(\"networkId\") as NetworkId;\n const [chains, { checkChainSupport }] = useChains();\n\n const [unsupported, setUnsupported] = useState(false);\n\n // current connected wallet address\n const currentWalletAddress = useMemo<string | undefined>(() => {\n return connectedWallet?.accounts?.[0]?.address;\n }, [connectedWallet]);\n\n // current connected chain id\n const currentChain = useMemo<\n { id: number; namespace: string } | undefined\n >(() => {\n const id = connectedWallet?.chains?.[0]?.id;\n const namespace = connectedWallet?.chains?.[0]?.namespace;\n if (typeof id === \"undefined\") return undefined;\n return {\n id: parseChainIdToNumber(id),\n namespace,\n };\n }, [connectedWallet]);\n\n useEffect(() => {\n if (!connectedChain) {\n setUnsupported(false);\n return;\n }\n\n let isSupported = checkChainSupport(\n connectedChain.id,\n networkId\n // networkId === \"testnet\" ? chains.testnet : chains.mainnet\n );\n\n setUnsupported(!isSupported);\n }, [connectedChain, chains, checkChainSupport, networkId]);\n\n useEffect(() => {\n // if (unsupported) return;\n\n windowGuard(() => {\n const localAddress = keyStore.getAddress();\n const walletInfo = JSON.parse(localStorage.getItem(WALLET_KEY) ?? \"{}\");\n\n /**\n * if locale address is exist, restore account state\n */\n if (connectedChain?.namespace === ChainNamespace.solana) {\n return;\n }\n if (\n localAddress &&\n account.address !== localAddress &&\n walletInfo.label\n ) {\n connect({\n autoSelect: {\n label: walletInfo.label,\n disableModals: true,\n },\n }).then(\n (res) => {\n console.log(\"silent connect wallet successes\", res);\n },\n (error) => console.log(\"connect error\", error)\n );\n }\n });\n }, [connectedWallet, account.address]);\n\n /**\n * handle wallet connection\n */\n useEffect(() => {\n if (\n connectedWallet === null &&\n accountState.status > AccountStatusEnum.NotConnected &&\n !accountState.validating\n ) {\n account.disconnect();\n return;\n }\n\n if (unsupported || !connectedChain) return;\n if (isManualConnect.current) return;\n\n const linkData = getLinkDeviceData();\n\n // updateAccount(currentWalletAddress!, connectedWallet!, currentChainId!);\n /**\n * switch account\n */\n if (\n !!currentWalletAddress &&\n currentWalletAddress !== account.address &&\n !linkData\n ) {\n account.setAddress(currentWalletAddress, {\n provider: connectedWallet?.provider,\n chain: {\n id: praseChainIdToNumber(currentChain!.id),\n namespace: currentChain!.namespace.toUpperCase() as ChainNamespace,\n },\n wallet: {\n name: connectedWallet.label,\n },\n });\n\n // save wallet connector info to local storage\n windowGuard(() => {\n localStorage.setItem(\n WALLET_KEY,\n JSON.stringify({\n label: connectedWallet.label,\n })\n );\n });\n }\n\n /**\n * switch chainId\n */\n if (currentChain?.id !== account.chainId) {\n account.switchChainId(currentChain?.id!);\n\n // emit chain changed event\n // options.onChainChanged?.(currentChainId!, isTestnet(networkId));\n }\n }, [\n connectedWallet,\n connectedChain,\n currentWalletAddress,\n currentChain,\n account.address,\n accountState,\n account.chainId,\n unsupported,\n ]);\n\n /**\n * User manually connects to wallet\n */\n const connectWallet = async (): Promise<{\n wallet?: WalletState;\n status?: AccountStatusEnum;\n wrongNetwork?: boolean;\n } | null> => {\n isManualConnect.current = true;\n // const walletState = await connect();\n\n return connect({ chainId: options.currentChainId })\n .then(async (walletState) => {\n if (\n Array.isArray(walletState) &&\n walletState.length > 0 &&\n walletState[0] &&\n walletState[0].accounts.length > 0\n ) {\n const wallet = walletState[0];\n const chainId = praseChainIdToNumber(wallet.chains[0].id);\n\n if (!checkChainSupport(chainId, networkId)) {\n return {\n wrongNetwork: true,\n };\n }\n\n //\n if (!account) {\n throw new Error(\"account is not initialized\");\n }\n console.log(\"-- aaaaa wallet\", wallet);\n // clear link device data when connect wallt\n if (\n accountState.status ===\n AccountStatusEnum.EnableTradingWithoutConnected\n ) {\n localStorage.removeItem(\"orderly_link_device\");\n await account.disconnect();\n }\n const status = await account.setAddress(wallet.accounts[0].address, {\n provider: wallet.provider,\n chain: {\n id: praseChainIdToNumber(wallet.chains[0].id),\n namespace:\n wallet.chains[0].namespace.toUpperCase() as ChainNamespace,\n },\n wallet: {\n name: wallet.label,\n },\n // label: ,\n });\n console.log(\"-- xxxxxx status\", status);\n\n return { wallet, status, wrongNetwork: false };\n }\n\n return null;\n })\n .finally(() => {\n isManualConnect.current = false;\n });\n };\n\n return {\n connectWallet,\n wrongNetwork: unsupported,\n };\n};\n","import { useCallback, useEffect } from \"react\";\nimport {\n parseJSON,\n useAccount,\n useConfig,\n useLocalStorage,\n useWalletConnector,\n} from \"@orderly.network/hooks\";\nimport { useScreen } from \"@orderly.network/ui\";\nimport { ChainNamespace } from \"@orderly.network/types\";\n\ntype DecodedData = {\n /** secret key */\n k: string;\n /* timestamp */\n t: number;\n /** address */\n a: string;\n /** chain id */\n i: number;\n /** chain namespace */\n n: ChainNamespace;\n};\n\ntype LinkDeviceStorage = { chainId: number; chainNamespace: ChainNamespace };\n\nconst WALLET_KEY = \"orderly:wallet-info\";\n\nexport function useLinkDevice() {\n const { connectedChain, disconnect } = useWalletConnector();\n const [_, setLinkDeviceStorage] = useLocalStorage(\n \"orderly_link_device\",\n {} as LinkDeviceStorage\n );\n\n const { account } = useAccount();\n const { isMobile } = useScreen();\n const configStore = useConfig();\n\n const onDisconnect = async (label: string) => {\n // The cache must be cleared first, otherwise it will be auto connect wallet\n localStorage.removeItem(WALLET_KEY);\n await account.disconnect();\n await disconnect({ label });\n };\n\n useEffect(() => {\n const linkData = getLinkDeviceData();\n const walletInfo = JSON.parse(localStorage.getItem(WALLET_KEY) ?? \"{}\");\n if (linkData && walletInfo) {\n // clear connect data when link device\n onDisconnect(walletInfo.label);\n }\n }, []);\n\n const linkDevice = async () => {\n const linkData = getLinkDeviceData();\n if (!linkData) return;\n\n const { address, secretKey, chainId, chainNamespace } = linkData;\n const isSuccess = await account.importOrderlyKey({\n address,\n secretKey,\n chainNamespace,\n });\n if (!isSuccess) return;\n setLinkDeviceStorage({\n chainId,\n chainNamespace,\n });\n\n const url = new URL(window.location.href);\n url.searchParams.delete(\"link\");\n const decodedUrl = decodeURIComponent(url.toString());\n history.replaceState(null, \"\", decodedUrl);\n };\n\n useEffect(() => {\n if (isMobile && !connectedChain) {\n linkDevice();\n }\n }, [account, connectedChain, isMobile]);\n\n const autoLinkDevice = async () => {\n // this can't use the value returned by useLocalStorage here, because it will trigger extra state change\n const { chainId, chainNamespace } = getLinkDeviceStorage() || {};\n if (isMobile && !connectedChain && chainId && chainNamespace) {\n const address = account.keyStore.getAddress();\n const orderlyKey = account.keyStore.getOrderlyKey();\n const accountId = account.keyStore.getAccountId(address!);\n const res = await account.checkOrderlyKey(\n address!,\n orderlyKey!,\n accountId!\n );\n if (res) {\n configStore.set(\"chainNamespace\", chainNamespace);\n }\n }\n };\n\n // persist status when refresh page\n useEffect(() => {\n autoLinkDevice();\n }, [account, isMobile, connectedChain]);\n\n return { linkDevice };\n}\n\nfunction getLinkDeviceStorage() {\n try {\n const linkDeviceStorage = localStorage.getItem(\"orderly_link_device\");\n const json = linkDeviceStorage ? parseJSON(linkDeviceStorage) : null;\n return json as LinkDeviceStorage;\n } catch (err) {\n console.error(\"getLinkDeviceStorage\", err);\n }\n}\n\nexport function getLinkDeviceData() {\n const url = new URL(window.location.href);\n const link = url.searchParams.get(\"link\");\n\n if (!link) return;\n\n const {\n a: address,\n k: secretKey,\n i: chainId,\n n: chainNamespace,\n } = decodeBase64(link) || {};\n\n if (address && secretKey && chainId && chainNamespace) {\n return {\n address,\n secretKey,\n chainId,\n chainNamespace,\n };\n }\n}\n\nfunction decodeBase64(base64: string) {\n try {\n const data = JSON.parse(window.atob(base64)) as DecodedData;\n console.log(\"decodeBase64\", data);\n const currentTime = Math.floor(Date.now() / 1000);\n const expiredTime = data.t;\n\n if (!expiredTime || currentTime > expiredTime) {\n console.error(\"Orderly key has expired.\");\n return;\n }\n\n return data;\n } catch (error) {\n console.error(\"Invalid or expired orderly key.\");\n }\n}\n","import { useRef } from \"react\";\nimport { toast } from \"@orderly.network/ui\";\nimport { capitalizeString } from \"@orderly.network/utils\";\nimport {\n useEventEmitter,\n useSessionStorage,\n useWalletSubscription,\n} from \"@orderly.network/hooks\";\n\nexport function useWalletEvent() {\n const ee = useEventEmitter();\n\n const recordRef = useRef<Record<number, boolean>>({});\n\n const [record, setRecord] = useSessionStorage(\n \"orderly_wallet_change_id\",\n {} as Record<number, boolean>\n );\n\n recordRef.current = record;\n\n useWalletSubscription({\n onMessage: (data: any) => {\n console.log(\"wallet:changed\", data);\n const { id, side, transStatus } = data;\n let showToast = true;\n\n // DEPOSIT and WITHDRAW will push twice COMPLETED and FAILED event\n if (\n [\"DEPOSIT\", \"WITHDRAW\"].includes(side) &&\n [\"COMPLETED\", \"FAILED\"].includes(transStatus)\n ) {\n const isPushOnce = recordRef.current[id];\n setRecord({\n ...record,\n [id]: isPushOnce ? undefined : true,\n });\n\n showToast = !isPushOnce;\n }\n\n if (transStatus === \"COMPLETED\" && showToast) {\n let msg = `${capitalizeString(side)} completed`;\n toast.success(msg);\n } else if (transStatus === \"FAILED\" && showToast) {\n let msg = `${capitalizeString(side)} failed`;\n toast.error(msg);\n }\n\n ee.emit(\"wallet:changed\", data);\n },\n });\n}\n","import { useSettleSubscription } from \"@orderly.network/hooks\";\nimport { toast } from \"@orderly.network/ui\";\n\nexport function useSettleEvent() {\n useSettleSubscription({\n onMessage: (data: any) => {\n const { status } = data;\n\n // console.log(\"settle ws: \", data);\n\n switch (status) {\n case \"COMPLETED\":\n toast.success(\"Settlement completed\");\n break;\n case \"FAILED\":\n toast.error(\"Settlement failed\");\n break;\n default:\n break;\n }\n },\n });\n}\n","import { useEventEmitter } from \"@orderly.network/hooks\";\nimport { useEffect } from \"react\";\nimport { modal, toast } from \"@orderly.network/ui\";\nimport { LedgerWalletKey } from \"@orderly.network/types\";\n\n\nexport function useWalletConnectError() {\n const ee = useEventEmitter();\n\n\n useEffect(() => {\n ee.on('wallet:connect-error', (data) => {\n toast.error(data.message);\n\n })\n ee.on('wallet:sign-message-with-ledger-error', (data: { userAddress: string; message: string }) => {\n window.setTimeout(() => {\n\n modal.confirm({\n title: 'Sign Message Failed',\n content: \"Are you using Ledger Wallet?\",\n size: 'sm',\n onOk: async () => {\n console.log('-- use ledger', true);\n const info = window.localStorage.getItem(LedgerWalletKey);\n if (!info) {\n window.localStorage.setItem(LedgerWalletKey, JSON.stringify([data.userAddress]));\n } else {\n const ledgerWallet = JSON.parse(info ?? '[]');\n ledgerWallet.push(data.userAddress);\n window.localStorage.setItem(LedgerWalletKey, ledgerWallet);\n }\n // todo localstorage\n return Promise.resolve();\n },\n okLabel: 'OK',\n onCancel: async () => {\n toast.error(data.message);\n return Promise.resolve();\n },\n cancelLabel: 'No',\n\n }).then(res => {\n console.log('-- dialog res', res);\n });\n\n });\n\n })\n\n }, [ee])\n\n return {}\n}","import { createContext, PropsWithChildren, useContext } from \"react\";\nimport { AppLogos } from \"../types\";\n\nexport type ThemeContextState = {\n appIcons?: AppLogos;\n brokerName: string;\n};\n\nconst AppConfigContext = createContext<ThemeContextState>(\n {} as ThemeContextState\n);\n\nexport const useAppConfig = () => {\n return useContext(AppConfigContext);\n};\n\nexport const AppConfigProvider = (\n props: PropsWithChildren<{\n appIcons?: AppLogos;\n brokerName: string;\n }>\n) => {\n return (\n <AppConfigContext.Provider value={props}>\n {props.children}\n </AppConfigContext.Provider>\n );\n};\n","import { useEffect, useRef } from \"react\";\nimport { getOrderExecutionReportMsg } from \"./getOrderExecutionReportMsg\";\nimport {\n useSymbolsInfo,\n useWS,\n useEventEmitter,\n useDebouncedCallback,\n} from \"@orderly.network/hooks\";\nimport { toast } from \"@orderly.network/ui\";\n\nexport function useExecutionReport() {\n const ee = useEventEmitter();\n\n const symbolsInfo = useSymbolsInfo();\n const symbolsInfoRef = useRef({});\n\n useEffect(() => {\n symbolsInfoRef.current = symbolsInfo;\n }, [symbolsInfo]);\n\n const handler = useDebouncedCallback((data: any) => {\n const showToast = (data: any) => {\n const { title, msg } = getOrderExecutionReportMsg(\n data,\n symbolsInfoRef.current\n );\n\n if (title && msg) {\n toast.success(\n <div>\n {title}\n <br />\n <div className=\"orderly-text-white/[0.54] orderly-text-xs\">\n {msg}\n </div>\n </div>\n );\n }\n };\n\n showToast(data);\n }, 100);\n\n useEffect(() => {\n ee.on(\"orders:changed\", handler);\n\n return () => {\n ee.off(\"orders:changed\", handler);\n };\n }, []);\n}\n","import {\n capitalizeString,\n transSymbolformString,\n} from \"@orderly.network/utils\";\nimport { API } from \"@orderly.network/types\";\nimport { AlgoOrderRootType } from \"@orderly.network/types\";\nimport { parseNumber } from \"@orderly.network/ui\";\n\nexport function getOrderExecutionReportMsg(\n data: API.AlgoOrder | API.Order,\n symbolsInfo: any\n) {\n const { symbol, side, quantity } = data;\n const total_executed_quantity =\n \"total_executed_quantity\" in data ? data.total_executed_quantity : 0;\n const status = \"status\" in data ? data.status : data.algo_status;\n const getSymbolInfo = symbolsInfo[symbol];\n const base_dp = getSymbolInfo(\"base_dp\");\n const displaySide = capitalizeString(side);\n const displaySymbol = transSymbolformString(symbol);\n const displayQuantity =\n \"algo_type\" in data && data.algo_type === AlgoOrderRootType.POSITIONAL_TP_SL\n ? \"Entire position\"\n : base_dp === undefined\n ? quantity\n : parseNumber(quantity, { dp: base_dp });\n\n let title = \"\";\n let msg = \"\";\n switch (status) {\n case \"NEW\":\n title = \"Order opened\";\n msg = `${displaySide} ${displaySymbol} ${displayQuantity}`;\n break;\n case \"FILLED\":\n case \"PARTIAL_FILLED\":\n const displayTotalExecutedQuantity =\n base_dp === undefined\n ? total_executed_quantity\n : parseNumber(total_executed_quantity, { dp: base_dp });\n title = \"Order filled\";\n msg = `${displaySide} ${displaySymbol} ${displayTotalExecutedQuantity} / ${displayQuantity}`;\n break;\n case \"CANCELLED\":\n title = \"Order cancelled\";\n msg = `${displaySide} ${displaySymbol} ${displayQuantity}`;\n break;\n case \"REJECTED\":\n title = \"Order rejected\";\n msg = `${displaySide} ${displaySymbol} ${displayQuantity}`;\n break;\n case \"REPLACED\":\n title = \"Order edited\";\n msg = `${side} ${displaySymbol} ${total_executed_quantity} / ${displayQuantity}`;\n break;\n default:\n break;\n }\n\n return {\n title,\n msg,\n };\n}\n","import { AccountStatusEnum } from \"@orderly.network/types\";\nimport { useAppContext } from \"../provider/appContext\";\nimport { useAccount } from \"@orderly.network/hooks\";\n\nexport const useDataTap = <T = any>(\n data: T,\n options?: {\n skip?: false;\n fallbackData?: T;\n accountStatus?: AccountStatusEnum;\n }\n): T | null => {\n const { wrongNetwork } = useAppContext();\n const { state } = useAccount();\n /**\n * ignore\n */\n if (options?.skip) return data;\n\n if (wrongNetwork) {\n return typeof options?.fallbackData !== \"undefined\"\n ? options.fallbackData\n : null;\n }\n\n if (typeof options?.accountStatus !== \"undefined\") {\n if (state.status < options.accountStatus) {\n return typeof options?.fallbackData !== \"undefined\"\n ? options.fallbackData\n : null;\n }\n }\n\n // return wrongNetwork\n // ? typeof options?.fallbackData !== \"undefined\"\n // ? options.fallbackData\n // : null\n // : data;\n //\n return data;\n};\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/provider/orderlyAppProvider.tsx","../src/hooks/useBootstrap.ts","../src/provider/appContext.tsx","../src/hooks/useWalletStateHandle.ts","../src/hooks/useLinkDevice.ts","../src/hooks/useWalletEvent.ts","../src/hooks/useSettleEvent.ts","../src/hooks/useWalletConnectError.ts","../src/provider/configContext.tsx","../src/hooks/useExecutionReport.tsx","../src/hooks/getOrderExecutionReportMsg.ts","../src/hooks/useDataTap.ts"],"names":["ModalProvider","OrderlyThemeProvider","Toaster","TooltipProvider","useEffect","useBootstrap","refCode","OrderlyConfigProvider","OrderlyTrackerProvider","createContext","useContext","useState","useMemo","useRef","useConfig","useAccount","useChains","useKeyStore","useWalletConnector","parseChainIdToNumber","praseChainIdToNumber","windowGuard","AccountStatusEnum","SDKError","ChainNamespace","parseJSON","useLocalStorage","useScreen","WALLET_KEY","useLinkDevice","connectedChain","disconnect","_","setLinkDeviceStorage","account","isMobile","configStore","onDisconnect","label","linkData","getLinkDeviceData","walletInfo","linkDevice","address","secretKey","chainId","chainNamespace","url","decodedUrl","autoLinkDevice","getLinkDeviceStorage","orderlyKey","accountId","linkDeviceStorage","link","decodeBase64","base64","data","currentTime","expiredTime","useWalletStateHandle","options","connectedWallet","connect","namespace","isManualConnect","accountState","keyStore","networkId","chains","checkChainSupport","unsupported","setUnsupported","currentWalletAddress","currentChain","id","isSupported","localAddress","res","error","walletState","wallet","status","toast","capitalizeString","useEventEmitter","useSessionStorage","useWalletSubscription","useWalletEvent","ee","recordRef","record","setRecord","side","transStatus","showToast","isPushOnce","msg","useSettleSubscription","useSettleEvent","modal","useStorageLedgerAddress","useWalletConnectError","setLedgerAddress","useRestrictedAreas","jsx","AppContext","useAppContext","AppStateProvider","props","currentChainId","setCurrentChainId","connectWallet","wrongNetwork","restrictedInfo","AppConfigContext","useAppConfig","AppConfigProvider","transSymbolformString","AlgoOrderRootType","parseNumber","getOrderExecutionReportMsg","symbolsInfo","symbol","quantity","total_executed_quantity","getSymbolInfo","base_dp","displaySide","displaySymbol","displayQuantity","title","displayTotalExecutedQuantity","useSymbolsInfo","useDebouncedCallback","jsxs","useExecutionReport","symbolsInfoRef","handler","OrderlyAppProvider","components","appIcons","onChainChanged","defaultChain","configProps","useDataTap","state"],"mappings":"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","sourcesContent":["import { PropsWithChildren } from \"react\";\nimport { OrderlyAppConfig } from \"../types\";\nimport {\n ModalProvider,\n OrderlyThemeProvider,\n Toaster,\n TooltipProvider,\n} from \"@orderly.network/ui\";\nimport { useBootstrap } from \"../hooks/useBootstrap\";\nimport {\n ConfigProviderProps,\n OrderlyConfigProvider,\n OrderlyTrackerProvider,\n} from \"@orderly.network/hooks\";\nimport { AppStateProvider, AppStateProviderProps } from \"./appContext\";\nimport { AppConfigProvider } from \"./configContext\";\nimport { useExecutionReport } from \"../hooks/useExecutionReport\";\nimport { OrderlyThemeProviderProps } from \"@orderly.network/ui/src/provider/orderlyThemeProvider\";\n\nexport type OrderlyAppProviderProps = PropsWithChildren<\n OrderlyAppConfig & AppStateProviderProps & OrderlyThemeProviderProps\n>;\n\nconst OrderlyAppProvider = (props: OrderlyAppProviderProps) => {\n const {\n // dateFormatting,\n components,\n appIcons,\n onChainChanged,\n defaultChain,\n ...configProps\n } = props;\n\n useBootstrap();\n useExecutionReport();\n\n return (\n <AppConfigProvider appIcons={appIcons} brokerName={props.brokerName!}>\n <OrderlyThemeProvider\n // dateFormatting={dateFormatting}\n components={components}\n overrides={props.overrides}\n >\n <OrderlyConfigProvider {...(configProps as ConfigProviderProps)}>\n <AppStateProvider\n onChainChanged={onChainChanged}\n defaultChain={defaultChain}\n restrictedInfo={props.restrictedInfo}\n >\n <OrderlyTrackerProvider>\n <TooltipProvider delayDuration={300}>\n <ModalProvider>{props.children}</ModalProvider>\n </TooltipProvider>\n </OrderlyTrackerProvider>\n </AppStateProvider>\n <Toaster />\n </OrderlyConfigProvider>\n </OrderlyThemeProvider>\n </AppConfigProvider>\n );\n};\n\nOrderlyAppProvider.displayName = \"OrderlyAppProvider\";\n\nexport { OrderlyAppProvider };\n","import { useEffect } from \"react\";\nimport { useAccount, useWalletConnector } from \"@orderly.network/hooks\";\n\nexport const useBootstrap = () => {\n useEffect(() => {\n const searchParams = new URLSearchParams(window.location.search);\n const refCode = searchParams.get(\"ref\");\n if (refCode) {\n localStorage.setItem(\"referral_code\", refCode);\n }\n }, []);\n};\n","import {\n FC,\n createContext,\n PropsWithChildren,\n useContext,\n useState,\n} from \"react\";\nimport { useWalletStateHandle } from \"../hooks/useWalletStateHandle\";\nimport { useAppState } from \"../hooks/useAppState\";\nimport { useWalletEvent } from \"../hooks/useWalletEvent\";\nimport { useSettleEvent } from \"../hooks/useSettleEvent\";\nimport { useWalletConnectError } from \"../hooks/useWalletConnectError\";\nimport {\n useRestrictedAreas,\n RestrictedAreasReturns,\n IRestrictedAreasParams,\n Chains,\n} from \"@orderly.network/hooks\";\nimport { useLinkDevice } from \"../hooks/useLinkDevice\";\nimport { Chain, NetworkId } from \"@orderly.network/types\";\n\ntype ReturnChain = Pick<Chain, \"id\"> & Partial<Omit<Chain, \"id\">>;\n\ntype DefaultChain =\n | {\n mainnet?: ReturnChain;\n testnet?: ReturnChain;\n }\n | ((networkId: NetworkId, chains: Chains) => ReturnChain)\n | undefined;\n\ntype AppContextState = {\n connectWallet: ReturnType<typeof useWalletStateHandle>[\"connectWallet\"];\n /**\n * Whether the current network is not supported\n */\n wrongNetwork: boolean;\n currentChainId: number | undefined;\n setCurrentChainId: (chainId: number | undefined) => void;\n onChainChanged?: (\n chainId: number,\n state: { isTestnet: boolean; isWalletConnected: boolean }\n ) => void;\n defaultChain?: DefaultChain;\n // networkStatus: ReturnType<typeof useAppState>[\"networkStatus\"];\n restrictedInfo?: RestrictedAreasReturns;\n};\n\nconst AppContext = createContext<AppContextState>({} as AppContextState);\n\nexport const useAppContext = () => {\n return useContext(AppContext);\n};\n\nexport type AppStateProviderProps = {\n restrictedInfo?: IRestrictedAreasParams;\n} & Pick<AppContextState, \"onChainChanged\" | \"defaultChain\">;\n\nexport const AppStateProvider: FC<PropsWithChildren<AppStateProviderProps>> = (\n props\n) => {\n const [currentChainId, setCurrentChainId] = useState<number | undefined>();\n useLinkDevice();\n\n const { connectWallet, wrongNetwork } = useWalletStateHandle({\n // onChainChanged: props.onChainChanged,\n currentChainId,\n });\n\n useWalletEvent();\n useSettleEvent();\n useWalletConnectError();\n const restrictedInfo = useRestrictedAreas(props?.restrictedInfo ?? {});\n\n // const { networkStatus } = useAppState();\n\n return (\n <AppContext.Provider\n value={{\n connectWallet,\n wrongNetwork,\n currentChainId,\n setCurrentChainId,\n onChainChanged: props.onChainChanged,\n defaultChain: props.defaultChain,\n restrictedInfo,\n }}\n >\n {props.children}\n </AppContext.Provider>\n );\n};\n","import { useEffect, useMemo, useRef, useState } from \"react\";\nimport { useConfig, WalletState } from \"@orderly.network/hooks\";\nimport {\n useAccount,\n useChains,\n useKeyStore,\n useWalletConnector,\n} from \"@orderly.network/hooks\";\nimport {\n parseChainIdToNumber,\n praseChainIdToNumber,\n windowGuard,\n} from \"@orderly.network/utils\";\nimport {\n AccountStatusEnum,\n SDKError,\n ChainNamespace,\n NetworkId,\n} from \"@orderly.network/types\";\nimport { getLinkDeviceData } from \"./useLinkDevice\";\n\nconst WALLET_KEY = \"orderly:wallet-info\";\nconst CHAIN_NAMESPACE = \"orderly:chain-namespace\";\n\nexport const useWalletStateHandle = (options: {\n // onChainChanged?: (chainId: number, isTestnet: boolean) => void;\n currentChainId?: number;\n}) => {\n const {\n wallet: connectedWallet,\n connect,\n connectedChain,\n disconnect,\n namespace,\n } = useWalletConnector();\n //\n // console.log(\"🔗 wallet state handle\", {\n // connectedWallet,\n // connectedChain,\n // namespace,\n // });\n\n if (typeof connect !== \"function\") {\n throw new SDKError(\"Please provide a wallet connector provider\");\n }\n\n const isManualConnect = useRef<boolean>(false);\n\n const { account, state: accountState } = useAccount();\n const keyStore = useKeyStore();\n const networkId = useConfig(\"networkId\") as NetworkId;\n const [chains, { checkChainSupport }] = useChains();\n\n const [unsupported, setUnsupported] = useState(false);\n\n // current connected wallet address\n const currentWalletAddress = useMemo<string | undefined>(() => {\n return connectedWallet?.accounts?.[0]?.address;\n }, [connectedWallet]);\n\n // current connected chain id\n const currentChain = useMemo<\n { id: number; namespace: string } | undefined\n >(() => {\n const id = connectedWallet?.chains?.[0]?.id;\n const namespace = connectedWallet?.chains?.[0]?.namespace;\n if (typeof id === \"undefined\") return undefined;\n return {\n id: parseChainIdToNumber(id),\n namespace,\n };\n }, [connectedWallet]);\n\n useEffect(() => {\n if (!connectedChain) {\n setUnsupported(false);\n return;\n }\n\n let isSupported = checkChainSupport(\n connectedChain.id,\n networkId\n // networkId === \"testnet\" ? chains.testnet : chains.mainnet\n );\n\n setUnsupported(!isSupported);\n }, [connectedChain, chains, checkChainSupport, networkId]);\n\n useEffect(() => {\n // if (unsupported) return;\n\n windowGuard(() => {\n const localAddress = keyStore.getAddress();\n const walletInfo = JSON.parse(localStorage.getItem(WALLET_KEY) ?? \"{}\");\n\n /**\n * if locale address is exist, restore account state\n */\n if (connectedChain?.namespace === ChainNamespace.solana) {\n return;\n }\n if (\n localAddress &&\n account.address !== localAddress &&\n walletInfo.label\n ) {\n connect({\n autoSelect: {\n label: walletInfo.label,\n disableModals: true,\n },\n }).then(\n (res) => {\n console.log(\"silent connect wallet successes\", res);\n },\n (error) => console.log(\"connect error\", error)\n );\n }\n });\n }, [connectedWallet, account.address]);\n\n /**\n * handle wallet connection\n */\n useEffect(() => {\n if (\n connectedWallet === null &&\n accountState.status > AccountStatusEnum.NotConnected &&\n !accountState.validating\n ) {\n account.disconnect();\n return;\n }\n\n if (unsupported || !connectedChain) return;\n if (isManualConnect.current) return;\n\n const linkData = getLinkDeviceData();\n\n // updateAccount(currentWalletAddress!, connectedWallet!, currentChainId!);\n /**\n * switch account\n */\n if (\n !!currentWalletAddress &&\n currentWalletAddress !== account.address &&\n !linkData\n ) {\n account.setAddress(currentWalletAddress, {\n provider: connectedWallet?.provider,\n chain: {\n id: praseChainIdToNumber(currentChain!.id),\n namespace: currentChain!.namespace.toUpperCase() as ChainNamespace,\n },\n wallet: {\n name: connectedWallet.label,\n },\n });\n\n // save wallet connector info to local storage\n windowGuard(() => {\n localStorage.setItem(\n WALLET_KEY,\n JSON.stringify({\n label: connectedWallet.label,\n })\n );\n });\n }\n\n /**\n * switch chainId\n */\n if (currentChain?.id !== account.chainId) {\n account.switchChainId(currentChain?.id!);\n\n // emit chain changed event\n // options.onChainChanged?.(currentChainId!, isTestnet(networkId));\n }\n }, [\n connectedWallet,\n connectedChain,\n currentWalletAddress,\n currentChain,\n account.address,\n accountState,\n account.chainId,\n unsupported,\n ]);\n\n /**\n * User manually connects to wallet\n */\n const connectWallet = async (): Promise<{\n wallet?: WalletState;\n status?: AccountStatusEnum;\n wrongNetwork?: boolean;\n } | null> => {\n isManualConnect.current = true;\n // const walletState = await connect();\n\n return connect({ chainId: options.currentChainId })\n .then(async (walletState) => {\n if (\n Array.isArray(walletState) &&\n walletState.length > 0 &&\n walletState[0] &&\n walletState[0].accounts.length > 0\n ) {\n const wallet = walletState[0];\n const chainId = praseChainIdToNumber(wallet.chains[0].id);\n\n if (!checkChainSupport(chainId, networkId)) {\n return {\n wrongNetwork: true,\n };\n }\n\n //\n if (!account) {\n throw new Error(\"account is not initialized\");\n }\n console.log(\"-- aaaaa wallet\", wallet);\n // clear link device data when connect wallt\n if (\n accountState.status ===\n AccountStatusEnum.EnableTradingWithoutConnected\n ) {\n localStorage.removeItem(\"orderly_link_device\");\n await account.disconnect();\n }\n const status = await account.setAddress(wallet.accounts[0].address, {\n provider: wallet.provider,\n chain: {\n id: praseChainIdToNumber(wallet.chains[0].id),\n namespace:\n wallet.chains[0].namespace.toUpperCase() as ChainNamespace,\n },\n wallet: {\n name: wallet.label,\n },\n // label: ,\n });\n console.log(\"-- xxxxxx status\", status);\n\n return { wallet, status, wrongNetwork: false };\n }\n\n return null;\n })\n .finally(() => {\n isManualConnect.current = false;\n });\n };\n\n return {\n connectWallet,\n wrongNetwork: unsupported,\n };\n};\n","import { useCallback, useEffect } from \"react\";\nimport {\n parseJSON,\n useAccount,\n useConfig,\n useLocalStorage,\n useWalletConnector,\n} from \"@orderly.network/hooks\";\nimport { useScreen } from \"@orderly.network/ui\";\nimport { ChainNamespace } from \"@orderly.network/types\";\n\ntype DecodedData = {\n /** secret key */\n k: string;\n /* timestamp */\n t: number;\n /** address */\n a: string;\n /** chain id */\n i: number;\n /** chain namespace */\n n: ChainNamespace;\n};\n\ntype LinkDeviceStorage = { chainId: number; chainNamespace: ChainNamespace };\n\nconst WALLET_KEY = \"orderly:wallet-info\";\n\nexport function useLinkDevice() {\n const { connectedChain, disconnect } = useWalletConnector();\n const [_, setLinkDeviceStorage] = useLocalStorage(\n \"orderly_link_device\",\n {} as LinkDeviceStorage\n );\n\n const { account } = useAccount();\n const { isMobile } = useScreen();\n const configStore = useConfig();\n\n const onDisconnect = async (label: string) => {\n // The cache must be cleared first, otherwise it will be auto connect wallet\n localStorage.removeItem(WALLET_KEY);\n await account.disconnect();\n await disconnect({ label });\n };\n\n useEffect(() => {\n const linkData = getLinkDeviceData();\n const walletInfo = JSON.parse(localStorage.getItem(WALLET_KEY) ?? \"{}\");\n if (linkData && walletInfo) {\n // clear connect data when link device\n onDisconnect(walletInfo.label);\n }\n }, []);\n\n const linkDevice = async () => {\n const linkData = getLinkDeviceData();\n if (!linkData) return;\n\n const { address, secretKey, chainId, chainNamespace } = linkData;\n const isSuccess = await account.importOrderlyKey({\n address,\n secretKey,\n chainNamespace,\n });\n if (!isSuccess) return;\n setLinkDeviceStorage({\n chainId,\n chainNamespace,\n });\n\n const url = new URL(window.location.href);\n url.searchParams.delete(\"link\");\n const decodedUrl = decodeURIComponent(url.toString());\n history.replaceState(null, \"\", decodedUrl);\n };\n\n useEffect(() => {\n if (isMobile && !connectedChain) {\n linkDevice();\n }\n }, [account, connectedChain, isMobile]);\n\n const autoLinkDevice = async () => {\n // this can't use the value returned by useLocalStorage here, because it will trigger extra state change\n const { chainId, chainNamespace } = getLinkDeviceStorage() || {};\n if (isMobile && !connectedChain && chainId && chainNamespace) {\n const address = account.keyStore.getAddress();\n const orderlyKey = account.keyStore.getOrderlyKey();\n const accountId = account.keyStore.getAccountId(address!);\n const res = await account.checkOrderlyKey(\n address!,\n orderlyKey!,\n accountId!\n );\n if (res) {\n configStore.set(\"chainNamespace\", chainNamespace);\n }\n }\n };\n\n // persist status when refresh page\n useEffect(() => {\n autoLinkDevice();\n }, [account, isMobile, connectedChain]);\n\n return { linkDevice };\n}\n\nfunction getLinkDeviceStorage() {\n try {\n const linkDeviceStorage = localStorage.getItem(\"orderly_link_device\");\n const json = linkDeviceStorage ? parseJSON(linkDeviceStorage) : null;\n return json as LinkDeviceStorage;\n } catch (err) {\n console.error(\"getLinkDeviceStorage\", err);\n }\n}\n\nexport function getLinkDeviceData() {\n const url = new URL(window.location.href);\n const link = url.searchParams.get(\"link\");\n\n if (!link) return;\n\n const {\n a: address,\n k: secretKey,\n i: chainId,\n n: chainNamespace,\n } = decodeBase64(link) || {};\n\n if (address && secretKey && chainId && chainNamespace) {\n return {\n address,\n secretKey,\n chainId,\n chainNamespace,\n };\n }\n}\n\nfunction decodeBase64(base64: string) {\n try {\n const data = JSON.parse(window.atob(base64)) as DecodedData;\n console.log(\"decodeBase64\", data);\n const currentTime = Math.floor(Date.now() / 1000);\n const expiredTime = data.t;\n\n if (!expiredTime || currentTime > expiredTime) {\n console.error(\"Orderly key has expired.\");\n return;\n }\n\n return data;\n } catch (error) {\n console.error(\"Invalid or expired orderly key.\");\n }\n}\n","import { useRef } from \"react\";\nimport { toast } from \"@orderly.network/ui\";\nimport { capitalizeString } from \"@orderly.network/utils\";\nimport {\n useEventEmitter,\n useSessionStorage,\n useWalletSubscription,\n} from \"@orderly.network/hooks\";\n\nexport function useWalletEvent() {\n const ee = useEventEmitter();\n\n const recordRef = useRef<Record<number, boolean>>({});\n\n const [record, setRecord] = useSessionStorage(\n \"orderly_wallet_change_id\",\n {} as Record<number, boolean>\n );\n\n recordRef.current = record;\n\n useWalletSubscription({\n onMessage: (data: any) => {\n console.log(\"wallet:changed\", data);\n const { id, side, transStatus } = data;\n let showToast = true;\n\n // DEPOSIT and WITHDRAW will push twice COMPLETED and FAILED event\n if (\n [\"DEPOSIT\", \"WITHDRAW\"].includes(side) &&\n [\"COMPLETED\", \"FAILED\"].includes(transStatus)\n ) {\n const isPushOnce = recordRef.current[id];\n setRecord({\n ...record,\n [id]: isPushOnce ? undefined : true,\n });\n\n showToast = !isPushOnce;\n }\n\n if (transStatus === \"COMPLETED\" && showToast) {\n let msg = `${capitalizeString(side)} completed`;\n toast.success(msg);\n } else if (transStatus === \"FAILED\" && showToast) {\n let msg = `${capitalizeString(side)} failed`;\n toast.error(msg);\n }\n\n ee.emit(\"wallet:changed\", data);\n },\n });\n}\n","import { useSettleSubscription } from \"@orderly.network/hooks\";\nimport { toast } from \"@orderly.network/ui\";\n\nexport function useSettleEvent() {\n useSettleSubscription({\n onMessage: (data: any) => {\n const { status } = data;\n\n // console.log(\"settle ws: \", data);\n\n switch (status) {\n case \"COMPLETED\":\n toast.success(\"Settlement completed\");\n break;\n case \"FAILED\":\n toast.error(\"Settlement failed\");\n break;\n default:\n break;\n }\n },\n });\n}\n","import { useEventEmitter } from \"@orderly.network/hooks\";\nimport { useEffect } from \"react\";\nimport { modal, toast } from \"@orderly.network/ui\";\nimport { LedgerWalletKey } from \"@orderly.network/types\";\nimport { useStorageLedgerAddress } from \"@orderly.network/hooks\"; \n\n\nexport function useWalletConnectError() {\n const ee = useEventEmitter();\n const {setLedgerAddress} = useStorageLedgerAddress(); \n\n\n useEffect(() => {\n ee.on('wallet:connect-error', (data) => {\n toast.error(data.message);\n\n })\n ee.on('wallet:sign-message-with-ledger-error', (data: { userAddress: string; message: string }) => {\n window.setTimeout(() => {\n\n modal.confirm({\n title: 'Sign Message Failed',\n content: \"Are you using Ledger Wallet?\",\n size: 'sm',\n onOk: async () => {\n console.log('-- use ledger', true);\n setLedgerAddress(data.userAddress);\n \n return Promise.resolve();\n },\n okLabel: 'OK',\n onCancel: async () => {\n toast.error(data.message);\n return Promise.resolve();\n },\n cancelLabel: 'No',\n\n }).then(res => {\n console.log('-- dialog res', res);\n });\n\n });\n\n })\n\n }, [ee])\n\n return {}\n}","import { createContext, PropsWithChildren, useContext } from \"react\";\nimport { AppLogos } from \"../types\";\n\nexport type ThemeContextState = {\n appIcons?: AppLogos;\n brokerName: string;\n};\n\nconst AppConfigContext = createContext<ThemeContextState>(\n {} as ThemeContextState\n);\n\nexport const useAppConfig = () => {\n return useContext(AppConfigContext);\n};\n\nexport const AppConfigProvider = (\n props: PropsWithChildren<{\n appIcons?: AppLogos;\n brokerName: string;\n }>\n) => {\n return (\n <AppConfigContext.Provider value={props}>\n {props.children}\n </AppConfigContext.Provider>\n );\n};\n","import { useEffect, useRef } from \"react\";\nimport { getOrderExecutionReportMsg } from \"./getOrderExecutionReportMsg\";\nimport {\n useSymbolsInfo,\n useWS,\n useEventEmitter,\n useDebouncedCallback,\n} from \"@orderly.network/hooks\";\nimport { toast } from \"@orderly.network/ui\";\n\nexport function useExecutionReport() {\n const ee = useEventEmitter();\n\n const symbolsInfo = useSymbolsInfo();\n const symbolsInfoRef = useRef({});\n\n useEffect(() => {\n symbolsInfoRef.current = symbolsInfo;\n }, [symbolsInfo]);\n\n const handler = useDebouncedCallback((data: any) => {\n const showToast = (data: any) => {\n const { title, msg } = getOrderExecutionReportMsg(\n data,\n symbolsInfoRef.current\n );\n\n if (title && msg) {\n toast.success(\n <div>\n {title}\n <br />\n <div className=\"orderly-text-white/[0.54] orderly-text-xs\">\n {msg}\n </div>\n </div>\n );\n }\n };\n\n showToast(data);\n }, 100);\n\n useEffect(() => {\n ee.on(\"orders:changed\", handler);\n\n return () => {\n ee.off(\"orders:changed\", handler);\n };\n }, []);\n}\n","import {\n capitalizeString,\n transSymbolformString,\n} from \"@orderly.network/utils\";\nimport { API } from \"@orderly.network/types\";\nimport { AlgoOrderRootType } from \"@orderly.network/types\";\nimport { parseNumber } from \"@orderly.network/ui\";\n\nexport function getOrderExecutionReportMsg(\n data: API.AlgoOrder | API.Order,\n symbolsInfo: any\n) {\n const { symbol, side, quantity } = data;\n const total_executed_quantity =\n \"total_executed_quantity\" in data ? data.total_executed_quantity : 0;\n const status = \"status\" in data ? data.status : data.algo_status;\n const getSymbolInfo = symbolsInfo[symbol];\n const base_dp = getSymbolInfo(\"base_dp\");\n const displaySide = capitalizeString(side);\n const displaySymbol = transSymbolformString(symbol);\n const displayQuantity =\n \"algo_type\" in data && data.algo_type === AlgoOrderRootType.POSITIONAL_TP_SL\n ? \"Entire position\"\n : base_dp === undefined\n ? quantity\n : parseNumber(quantity, { dp: base_dp });\n\n let title = \"\";\n let msg = \"\";\n switch (status) {\n case \"NEW\":\n title = \"Order opened\";\n msg = `${displaySide} ${displaySymbol} ${displayQuantity}`;\n break;\n case \"FILLED\":\n case \"PARTIAL_FILLED\":\n const displayTotalExecutedQuantity =\n base_dp === undefined\n ? total_executed_quantity\n : parseNumber(total_executed_quantity, { dp: base_dp });\n title = \"Order filled\";\n msg = `${displaySide} ${displaySymbol} ${displayTotalExecutedQuantity} / ${displayQuantity}`;\n break;\n case \"CANCELLED\":\n title = \"Order cancelled\";\n msg = `${displaySide} ${displaySymbol} ${displayQuantity}`;\n break;\n case \"REJECTED\":\n title = \"Order rejected\";\n msg = `${displaySide} ${displaySymbol} ${displayQuantity}`;\n break;\n case \"REPLACED\":\n title = \"Order edited\";\n msg = `${side} ${displaySymbol} ${total_executed_quantity} / ${displayQuantity}`;\n break;\n default:\n break;\n }\n\n return {\n title,\n msg,\n };\n}\n","import { AccountStatusEnum } from \"@orderly.network/types\";\nimport { useAppContext } from \"../provider/appContext\";\nimport { useAccount } from \"@orderly.network/hooks\";\n\nexport const useDataTap = <T = any>(\n data: T,\n options?: {\n skip?: false;\n fallbackData?: T;\n accountStatus?: AccountStatusEnum;\n }\n): T | null => {\n const { wrongNetwork } = useAppContext();\n const { state } = useAccount();\n /**\n * ignore\n */\n if (options?.skip) return data;\n\n if (wrongNetwork) {\n return typeof options?.fallbackData !== \"undefined\"\n ? options.fallbackData\n : null;\n }\n\n if (typeof options?.accountStatus !== \"undefined\") {\n if (state.status < options.accountStatus) {\n return typeof options?.fallbackData !== \"undefined\"\n ? options.fallbackData\n : null;\n }\n }\n\n // return wrongNetwork\n // ? typeof options?.fallbackData !== \"undefined\"\n // ? options.fallbackData\n // : null\n // : data;\n //\n return data;\n};\n"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@orderly.network/react-app",
|
|
3
|
-
"version": "2.0.
|
|
3
|
+
"version": "2.0.4-alpha.0",
|
|
4
4
|
"description": "Create React App with Orderly Network components",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"module": "dist/index.mjs",
|
|
@@ -17,10 +17,10 @@
|
|
|
17
17
|
"access": "public"
|
|
18
18
|
},
|
|
19
19
|
"dependencies": {
|
|
20
|
-
"@orderly.network/ui": "2.0.
|
|
21
|
-
"@orderly.network/
|
|
22
|
-
"@orderly.network/
|
|
23
|
-
"@orderly.network/
|
|
20
|
+
"@orderly.network/ui": "2.0.4-alpha.0",
|
|
21
|
+
"@orderly.network/types": "2.0.4-alpha.0",
|
|
22
|
+
"@orderly.network/utils": "2.0.4-alpha.0",
|
|
23
|
+
"@orderly.network/hooks": "2.0.4-alpha.0"
|
|
24
24
|
},
|
|
25
25
|
"devDependencies": {
|
|
26
26
|
"@types/react": "^18.3.2",
|
|
@@ -29,7 +29,7 @@
|
|
|
29
29
|
"react-dom": "^18.2.0",
|
|
30
30
|
"tailwindcss": "^3.4.4",
|
|
31
31
|
"tsup": "^7.3.0",
|
|
32
|
-
"tsconfig": "0.3.
|
|
32
|
+
"tsconfig": "0.3.20-alpha.0"
|
|
33
33
|
},
|
|
34
34
|
"peerDependencies": {
|
|
35
35
|
"react": ">=18",
|