@xyo-network/react-chain-provider 3.0.0 → 3.0.1
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/browser/contexts/current-block/usePollCurrentBlock.d.ts +2 -2
- package/dist/browser/hooks/account/BalanceHistoryItemFormatted.d.ts +1 -1
- package/dist/browser/hooks/account/BalanceHistoryItemFormatted.d.ts.map +1 -1
- package/dist/browser/hooks/account/helpers/formatAccountBalanceHistory.d.ts +1 -1
- package/dist/browser/hooks/account/helpers/formatAccountBalanceHistory.d.ts.map +1 -1
- package/dist/browser/hooks/account/useAccountBalanceHistory.d.ts +1 -1
- package/dist/browser/hooks/account/useAccountBalanceHistory.d.ts.map +1 -1
- package/dist/browser/index.mjs.map +1 -1
- package/dist/browser/lib/balanceForRange.d.ts +1 -1
- package/dist/browser/lib/balanceForRange.d.ts.map +1 -1
- package/package.json +26 -19
|
@@ -7,7 +7,7 @@ export declare const usePollCurrentBlock: (viewer?: XyoViewer | null, interval?:
|
|
|
7
7
|
readonly __hex: true;
|
|
8
8
|
} & {
|
|
9
9
|
readonly __address: true;
|
|
10
|
-
}) | import("@xyo-network/
|
|
10
|
+
}) | import("@xyo-network/sdk-protocol-js").XyoQuantAddress)[];
|
|
11
11
|
payload_hashes: import("@xylabs/sdk-js").BrandedHash[];
|
|
12
12
|
payload_schemas: import("@xyo-network/sdk-protocol-js").BrandedSchema<string>[];
|
|
13
13
|
previous_hashes: (import("@xylabs/sdk-js").BrandedHash | null)[];
|
|
@@ -16,7 +16,7 @@ export declare const usePollCurrentBlock: (viewer?: XyoViewer | null, interval?:
|
|
|
16
16
|
chain: import("@xylabs/sdk-js").BrandedHex;
|
|
17
17
|
previous: import("@xylabs/sdk-js").BrandedHash | null;
|
|
18
18
|
$epoch: number;
|
|
19
|
-
$destination?: import("@xyo-network/
|
|
19
|
+
$destination?: import("@xyo-network/sdk-protocol-js").XyoQuantAddress | (Lowercase<string> & {
|
|
20
20
|
readonly __hex: true;
|
|
21
21
|
} & {
|
|
22
22
|
readonly __address: true;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import type { Hash } from '@xylabs/sdk-js';
|
|
2
|
-
import type { XyoAddress } from '@xyo-network/
|
|
2
|
+
import type { XyoAddress } from '@xyo-network/sdk-js';
|
|
3
3
|
import type { AccountBalanceHistoryItem } from '@xyo-network/xl1-sdk';
|
|
4
4
|
export type BalanceTransactionType = 'send' | 'receive';
|
|
5
5
|
export interface AccountBalanceHistoryItemFormatted {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BalanceHistoryItemFormatted.d.ts","sourceRoot":"","sources":["../../../../src/hooks/account/BalanceHistoryItemFormatted.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAA;AAC1C,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"BalanceHistoryItemFormatted.d.ts","sourceRoot":"","sources":["../../../../src/hooks/account/BalanceHistoryItemFormatted.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAA;AAC1C,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAA;AACrD,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,sBAAsB,CAAA;AAErE,MAAM,MAAM,sBAAsB,GAAG,MAAM,GAAG,SAAS,CAAA;AAEvD,MAAM,WAAW,kCAAkC;IACjD,MAAM,EAAE,MAAM,CAAA;IACd,SAAS,EAAE,IAAI,CAAA;IACf,WAAW,EAAE,MAAM,CAAA;IACnB,KAAK,EAAE,yBAAyB,CAAA;IAChC,IAAI,EAAE,UAAU,CAAA;IAChB,GAAG,EAAE,MAAM,CAAA;IACX,SAAS,EAAE,MAAM,CAAA;IACjB,EAAE,EAAE,UAAU,CAAA;IACd,YAAY,EAAE,IAAI,CAAA;IAClB,MAAM,EAAE,IAAI,GAAG,SAAS,CAAA;IACxB,IAAI,EAAE,sBAAsB,CAAA;CAC7B"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import type { XyoAddress } from '@xyo-network/
|
|
1
|
+
import type { XyoAddress } from '@xyo-network/sdk-js';
|
|
2
2
|
import type { AccountBalanceHistoryItem } from '@xyo-network/xl1-sdk';
|
|
3
3
|
import type { AccountBalanceHistoryItemFormatted } from '../BalanceHistoryItemFormatted.ts';
|
|
4
4
|
export declare const formatAccountBalanceHistory: (address: XyoAddress, history: AccountBalanceHistoryItem[]) => Promise<AccountBalanceHistoryItemFormatted[]>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"formatAccountBalanceHistory.d.ts","sourceRoot":"","sources":["../../../../../src/hooks/account/helpers/formatAccountBalanceHistory.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"formatAccountBalanceHistory.d.ts","sourceRoot":"","sources":["../../../../../src/hooks/account/helpers/formatAccountBalanceHistory.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAA;AAErD,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,sBAAsB,CAAA;AAErE,OAAO,KAAK,EAAE,kCAAkC,EAAE,MAAM,mCAAmC,CAAA;AAE3F,eAAO,MAAM,2BAA2B,GAAU,SAAS,UAAU,EAAE,SAAS,yBAAyB,EAAE,KAAG,OAAO,CAAC,kCAAkC,EAAE,CAuCzJ,CAAA"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import type { XyoAddress } from '@xyo-network/
|
|
1
|
+
import type { XyoAddress } from '@xyo-network/sdk-js';
|
|
2
2
|
import type { XL1BlockRange, XyoViewer } from '@xyo-network/xl1-sdk';
|
|
3
3
|
export declare const useAccountBalanceHistory: (address?: XyoAddress, viewer?: XyoViewer, maxPage?: number, blockRange?: XL1BlockRange, refresh?: number) => [{
|
|
4
4
|
history: import("./BalanceHistoryItemFormatted.ts").AccountBalanceHistoryItemFormatted[];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useAccountBalanceHistory.d.ts","sourceRoot":"","sources":["../../../../src/hooks/account/useAccountBalanceHistory.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"useAccountBalanceHistory.d.ts","sourceRoot":"","sources":["../../../../src/hooks/account/useAccountBalanceHistory.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAA;AACrD,OAAO,KAAK,EACiB,aAAa,EAAE,SAAS,EACpD,MAAM,sBAAsB,CAAA;AAK7B,eAAO,MAAM,wBAAwB,GAAI,UAAU,UAAU,EAAE,SAAS,SAAS,EAAE,gBAAY,EAAE,aAAa,aAAa,EAAE,UAAU,MAAM;;;;8FAsC5I,CAAA"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../src/components/connected/account/Connected.tsx", "../../src/components/connected/ConnectAccountsStack.tsx", "../../src/contexts/current-block/context.ts", "../../src/contexts/current-block/Provider.tsx", "../../src/contexts/current-block/usePollCurrentBlock.ts", "../../src/contexts/current-block/use.ts", "../../src/contexts/gateway/Provider.tsx", "../../src/contexts/in-page-gateways/context.ts", "../../src/contexts/in-page-gateways/Provider.tsx", "../../src/contexts/in-page-gateways/use.ts", "../../src/hooks/account/helpers/formatAccountBalanceHistory.ts", "../../src/hooks/account/useAccountBalanceHistory.ts", "../../src/lib/balanceForRange.ts", "../../src/lib/buildGateway.ts", "../../src/lib/findMinimumBlock.ts", "../../src/hooks/gateway/useNetwork.ts", "../../src/hooks/gateway/useRunner.ts", "../../src/hooks/gateway/useViewer.ts", "../../src/hooks/helpers/getXyoClient.ts", "../../src/hooks/helpers/transaction/Confirmation.ts", "../../src/hooks/useAddressBalance.ts", "../../src/hooks/useConfirmTransactionBase.ts", "../../src/hooks/useConnectAccount.ts", "../../src/hooks/useCurrentBlock.ts", "../../src/hooks/useNetwork.ts", "../../src/hooks/useSigner.ts", "../../src/hooks/viewer/useCheckRpc.ts", "../../src/hooks/viewer/ViewerWithDataLake.ts"],
|
|
4
|
-
"sourcesContent": ["import {\n Stack, Tooltip, Typography,\n} from '@mui/material'\nimport { EthAddressWrapper } from '@xylabs/eth-address'\nimport { BlockiesAvatarAddress } from '@xyo-network/xl1-blockies'\nimport React from 'react'\n\nexport const ConnectedAccount: React.FC<{ address: string }> = ({ address }) => {\n const shortenedAddress = EthAddressWrapper.fromString(address)?.toShortString(4)\n\n return (\n <Stack\n direction=\"row\"\n spacing={1}\n sx={{ alignItems: 'center' }}\n >\n <BlockiesAvatarAddress address={address} size={21} />\n <Tooltip title={address}>\n <Typography\n variant=\"caption\"\n sx={{\n color: 'text.secondary',\n fontFamily: 'monospace',\n }}\n >\n {shortenedAddress}\n </Typography>\n </Tooltip>\n </Stack>\n )\n}\n", "/**\n * @deprecated Moved to `@xyo-network/xl1-react-client-sdk`. Import from there\n * instead. This re-export exists only for backward compatibility and will be\n * removed in a future release.\n */\n\nexport type { ConnectClientAccountsStackProps } from '@xyo-network/xl1-react-client-sdk'\nexport { ConnectAccountsStack } from '@xyo-network/xl1-react-client-sdk'\n", "import { createContextEx } from '@xylabs/react-shared'\n\nimport type { XL1CurrentBlockState } from './state.ts'\n\nexport const XL1CurrentBlockContext = createContextEx<XL1CurrentBlockState>()\n", "import type { XyoViewer } from '@xyo-network/xl1-sdk'\nimport type { PropsWithChildren } from 'react'\nimport React, { useMemo } from 'react'\n\nimport { XL1CurrentBlockContext } from './context.ts'\nimport type { XL1CurrentBlockPollingConfig, XL1CurrentBlockState } from './state.ts'\nimport { usePollCurrentBlock } from './usePollCurrentBlock.ts'\n\nexport const DEFAULT_POLLING_INTERVAL = 10_000\n\nexport interface XL1CurrentBlockProviderProps extends PropsWithChildren {\n pollingConfig?: XL1CurrentBlockPollingConfig\n viewer?: XyoViewer | null\n}\n\nexport const XL1CurrentBlockProvider: React.FC<XL1CurrentBlockProviderProps> = ({\n pollingConfig, viewer, children,\n}) => {\n const { interval } = useMemo(() => pollingConfig ?? { interval: DEFAULT_POLLING_INTERVAL }, [pollingConfig])\n const [currentBlock, currentBlockError] = usePollCurrentBlock(viewer, interval)\n\n const value: XL1CurrentBlockState = useMemo(() => ({\n block: currentBlock,\n blockNumber: currentBlock?.[0].block,\n chain: currentBlock?.[0].chain,\n error: currentBlockError,\n pollingConfig,\n provided: true,\n }), [currentBlock, currentBlockError, pollingConfig])\n\n return (\n <XL1CurrentBlockContext value={value}>\n {children}\n </XL1CurrentBlockContext>\n )\n}\n", "import { isDefinedNotNull, isUndefinedOrNull } from '@xylabs/sdk-js'\nimport type { SignedHydratedBlock, XyoViewer } from '@xyo-network/xl1-sdk'\nimport {\n startTransition, useEffect, useState,\n} from 'react'\n\nconst DEFAULT_POLL_INTERVAL = 10_000\n\nexport const usePollCurrentBlock = (viewer?: XyoViewer | null, interval = DEFAULT_POLL_INTERVAL, pause = false) => {\n const [currentBlock, setCurrentBlock] = useState<SignedHydratedBlock | null>(null)\n const [error, setError] = useState<Error>()\n\n useEffect(() => {\n let isMounted = true\n // Function to fetch the current block\n const fetchBlock = async () => {\n if (isDefinedNotNull(viewer)) {\n try {\n const block = await viewer.currentBlock()\n // Safety check to ensure component is still mounted before updating state\n if (isMounted) {\n startTransition(() => {\n setCurrentBlock((existingBlock) => {\n if (isUndefinedOrNull(existingBlock)) {\n return block\n }\n if (\n isDefinedNotNull(block) && existingBlock?.[0].block !== block[0].block\n ) {\n return block\n }\n return existingBlock\n })\n })\n }\n } catch (err) {\n startTransition(() => {\n setError(err as Error)\n })\n }\n }\n }\n\n // Initial fetch\n void fetchBlock()\n\n // Polling mechanism\n const id = setInterval(() => {\n if (!pause) {\n void fetchBlock()\n }\n }, interval)\n\n return () => {\n isMounted = false\n clearInterval(id)\n }\n }, [viewer, interval, pause])\n\n return [currentBlock, error] as const\n}\n", "import { useContextEx } from '@xylabs/react-shared'\n\nimport { XL1CurrentBlockContext } from './context.ts'\nimport type { XL1CurrentBlockState } from './state.ts'\n\nexport const useXl1CurrentBlockContext = (required = true) => useContextEx<XL1CurrentBlockState>(XL1CurrentBlockContext, 'XL1CurrentBlock', required)\n", "/**\n * @deprecated Moved to `@xyo-network/xl1-react-client-sdk`. Import\n * `GatewayProvider` from there instead. This re-export exists only for\n * backward compatibility and will be removed in a future release.\n */\n\nexport { GatewayProvider } from '@xyo-network/xl1-react-client-sdk'\n", "/**\n * @deprecated Moved to `@xyo-network/xl1-react-client-sdk`. Import\n * `InPageGatewaysContext` from there instead. This re-export exists only\n * for backward compatibility and will be removed in a future release.\n */\n\nexport { InPageGatewaysContext } from '@xyo-network/xl1-react-client-sdk'\n", "/**\n * @deprecated Moved to `@xyo-network/xl1-react-client-sdk`. Import\n * `InPageGatewaysProvider` and `InPageGatewaysProviderProps` from there\n * instead. This re-export exists only for backward compatibility and\n * will be removed in a future release.\n */\n\nexport type { InPageGatewaysProviderProps } from '@xyo-network/xl1-react-client-sdk'\nexport { InPageGatewaysProvider } from '@xyo-network/xl1-react-client-sdk'\n", "/**\n * @deprecated Moved to `@xyo-network/xl1-react-client-sdk`. Import\n * `useProvidedInPageGateways` from there instead. This re-export exists\n * only for backward compatibility and will be removed in a future\n * release.\n */\n\nexport { useProvidedInPageGateways } from '@xyo-network/xl1-react-client-sdk'\n", "import { hexToBigInt } from '@xylabs/sdk-js'\nimport type { XyoAddress } from '@xyo-network/address'\nimport { PayloadBuilder } from '@xyo-network/sdk-js'\nimport type { AccountBalanceHistoryItem } from '@xyo-network/xl1-sdk'\n\nimport type { AccountBalanceHistoryItemFormatted } from '../BalanceHistoryItemFormatted.ts'\n\nexport const formatAccountBalanceHistory = async (address: XyoAddress, history: AccountBalanceHistoryItem[]): Promise<AccountBalanceHistoryItemFormatted[]> => {\n const results: AccountBalanceHistoryItemFormatted[] = []\n for (const item of history) {\n const [blockBw, txBw, transfer] = item\n const transferHash = await PayloadBuilder.hash(transfer)\n const blockHash = await PayloadBuilder.hash(blockBw)\n if (address === transfer.from) {\n for (const [to, amount] of Object.entries(transfer.transfers)) {\n results.push({\n amount: hexToBigInt(amount),\n blockHash,\n blockNumber: blockBw.block,\n from: transfer.from,\n timestamp: blockBw.$epoch,\n key: crypto.randomUUID(),\n to: to as XyoAddress,\n transferHash,\n txHash: txBw?._hash,\n debug: item,\n type: 'send',\n })\n }\n } else {\n results.push({\n amount: hexToBigInt(transfer.transfers[address]),\n blockHash,\n blockNumber: blockBw.block,\n from: transfer.from,\n key: crypto.randomUUID(),\n timestamp: blockBw.$epoch,\n to: address,\n transferHash,\n txHash: txBw?._hash,\n debug: item,\n type: 'receive',\n })\n }\n }\n return results\n}\n", "import { usePromise } from '@xylabs/react-promise'\nimport { isUndefined } from '@xylabs/sdk-js'\nimport type { XyoAddress } from '@xyo-network/address'\nimport type {\n AccountBalanceHistoryItem, XL1BlockRange, XyoViewer,\n} from '@xyo-network/xl1-sdk'\n\nimport { balanceForRange, findMinimumBlock } from '../../lib/index.ts'\nimport { formatAccountBalanceHistory } from './helpers/index.ts'\n\nexport const useAccountBalanceHistory = (address?: XyoAddress, viewer?: XyoViewer, maxPage = 10, blockRange?: XL1BlockRange, refresh?: number) => {\n return usePromise(async () => {\n if (isUndefined(viewer) || isUndefined(address)) return\n\n // Pagination Values\n let page = 1\n let lastBlock: number\n const pagedHistory: AccountBalanceHistoryItem[] = []\n const resolvedStartBlock = blockRange ? blockRange[0] : 0\n\n // Fetch first page to get starting lastBlock\n // If blockRange is provided, use that for the first fetch, otherwise the API will use [0, currentBlock]\n const history = await viewer.account.balance.accountBalanceHistory(address, blockRange ? { range: blockRange } : {})\n if (history.length > 0) {\n pagedHistory.push(...history)\n // Set lastBlock to one less than the lowest block in the first page\n lastBlock = findMinimumBlock(history)\n while (page < maxPage) {\n // Fetch next page\n const nextHistory = await viewer.account.balance.accountBalanceHistory(address, { range: [resolvedStartBlock, lastBlock] as XL1BlockRange })\n // Break if no more history\n if (nextHistory.length === 0) break\n // Update lastBlock and append to pagedHistory\n lastBlock = findMinimumBlock(nextHistory)\n pagedHistory.push(...nextHistory)\n // Increment page\n // Even if we are going to go over and break the loop, we still want to increment to show the answer was truncated\n page++\n }\n }\n const formattedHistory = await formatAccountBalanceHistory(address, pagedHistory)\n\n return {\n history: formattedHistory,\n balance: balanceForRange(address, pagedHistory),\n truncated: page >= maxPage,\n }\n }, [address, viewer, refresh, blockRange, maxPage])\n}\n", "import {\n hexToBigInt, isHex, toHex,\n} from '@xylabs/sdk-js'\nimport type { XyoAddress } from '@xyo-network/address'\nimport type { AccountBalanceHistoryItem, AttoXL1 } from '@xyo-network/xl1-sdk'\n\nexport const balanceForRange = (address: XyoAddress, results: AccountBalanceHistoryItem[]): [AttoXL1, AttoXL1] => {\n const totalReceivedBalance = results?.reduce((a, [_block, _tx, transfer]) => {\n return a + hexToBigInt(transfer.transfers[address] ?? toHex(0))\n }, 0n)\n // eslint-disable-next-line unicorn/no-array-reduce\n const totalSentBalance = results?.reduce((a, [_block, _tx, transfer]) => {\n return (transfer.from === address) ? a + Object.values(transfer.transfers).reduce((a, v) => a + (isHex(v) ? hexToBigInt(v) : 0n), 0n) : a\n }, 0n)\n return [totalReceivedBalance, totalSentBalance] as [AttoXL1, AttoXL1]\n}\n", "import { assertEx, isDefined } from '@xylabs/sdk-js'\nimport type {\n GatewayName,\n RemoteConfig, RpcTransport, SimpleXyoGateway,\n XyoSignerRpcSchemas,\n} from '@xyo-network/xl1-sdk'\nimport {\n basicRemoteRunnerLocator,\n basicRemoteViewerLocator,\n DefaultNetworks, NetworkDataLakeUrls, XyoGatewayMoniker,\n} from '@xyo-network/xl1-sdk'\n\nexport const buildGateway = async (gatewayName: GatewayName, signerTransport?: RpcTransport<XyoSignerRpcSchemas>) => {\n const network = DefaultNetworks.find(network => network.id === gatewayName)\n const resolvedNetwork = assertEx(network, () => `No network found for id ${gatewayName}`)\n\n const remoteConfig: RemoteConfig = {\n rpc: {\n protocol: 'http',\n url: `${resolvedNetwork.url}/rpc`,\n },\n }\n\n const dataLakeEndpoint = NetworkDataLakeUrls[gatewayName]\n\n const locator = isDefined(signerTransport)\n ? await basicRemoteRunnerLocator(gatewayName, remoteConfig, signerTransport, dataLakeEndpoint)\n : await basicRemoteViewerLocator(gatewayName, remoteConfig, dataLakeEndpoint)\n\n return await locator.getInstance<SimpleXyoGateway>(XyoGatewayMoniker)\n}\n", "import type { AccountBalanceHistoryItem } from '@xyo-network/xl1-sdk'\n\nexport const findMinimumBlock = (history: AccountBalanceHistoryItem[]): number => {\n // since taking Math.min of an empty array returns Infinity\n if (history.length === 0) return 0\n const blockNumbers = history.map(([blockBw]) => blockBw.block)\n const min = Math.min(...blockNumbers)\n return Math.max(min - 1, 0)\n}\n", "import { useProvidedGateway } from '@xyo-network/xl1-react-client-sdk'\nimport type { XyoNetwork } from '@xyo-network/xl1-sdk'\n\nexport const useNetworkFromGateway = (): XyoNetwork | undefined => {\n const { defaultGateway } = useProvidedGateway()\n return defaultGateway?.connection?.network\n}\n", "import { useProvidedGateway } from '@xyo-network/xl1-react-client-sdk'\nimport type { XyoRunner } from '@xyo-network/xl1-sdk'\n\nexport const useRunnerFromGateway = (): XyoRunner | undefined => {\n const { defaultGateway } = useProvidedGateway()\n return defaultGateway?.connection?.runner\n}\n", "import { useProvidedGateway } from '@xyo-network/xl1-react-client-sdk'\nimport type { XyoViewer } from '@xyo-network/xl1-sdk'\n\nexport const useViewerFromGateway = (): XyoViewer | undefined => {\n const { defaultGateway } = useProvidedGateway()\n return defaultGateway?.connection?.viewer\n}\n", "/** @deprecated Import from `@xyo-network/xl1-react-client-sdk` instead */\nexport { getXyoClient, listenForClientInjection } from '@xyo-network/xl1-react-client-sdk'\n", "import type { Hash, Promisable } from '@xylabs/sdk-js'\nimport {\n assertEx, delay, forget, isDefined, isNull,\n} from '@xylabs/sdk-js'\nimport type { SignedHydratedTransaction, XyoViewer } from '@xyo-network/xl1-sdk'\n\nexport interface ConfirmationStatusUpdate {\n blockNumber: number\n confirmed: boolean\n error?: Error\n progress?: number\n remainingBlocks?: number\n}\n\nexport interface TransactionConfirmationParams {\n onStatusUpdate?: (status: ConfirmationStatusUpdate) => void\n transaction: SignedHydratedTransaction\n txHash: Hash\n viewer: XyoViewer\n}\n\nexport class TransactionConfirmationStatus {\n private readonly _params: TransactionConfirmationParams\n private active = false\n\n constructor(params: TransactionConfirmationParams) {\n this._params = params\n }\n\n get exp(): number {\n return assertEx(this.transaction[0].exp, () => 'exp is not found, transaction is not set')\n }\n\n get nbf(): number {\n return assertEx(this.transaction[0].nbf, () => 'nbf is not found, transaction is not set')\n }\n\n get onStatusUpdate(): TransactionConfirmationParams['onStatusUpdate'] {\n return this._params.onStatusUpdate\n }\n\n get params(): TransactionConfirmationParams {\n return this._params\n }\n\n get transaction(): SignedHydratedTransaction {\n return this.params.transaction\n }\n\n get txHash(): Hash {\n return this.params.txHash\n }\n\n get viewer(): XyoViewer {\n return this.params.viewer\n }\n\n static create(params: TransactionConfirmationParams): Promisable<TransactionConfirmationStatus> {\n return new TransactionConfirmationStatus(params)\n }\n\n async start(): Promise<void> {\n this.active = true\n try {\n const currentBlockNumber = await this.viewer.currentBlockNumber()\n while (isDefined(currentBlockNumber) && this.active) {\n await this.checkBlock(currentBlockNumber)\n // check block every second to see if the transaction is confirmed\n await delay(1000)\n }\n } catch (error) {\n await this.stop()\n forget(this.onStatusUpdate?.({\n error: error instanceof Error ? error : new Error('Unknown error occurred'),\n confirmed: false,\n blockNumber: 0,\n progress: 0,\n remainingBlocks: 0,\n }))\n }\n }\n\n stop(): Promisable<void> {\n this.active = false\n }\n\n private async checkBlock(blockNumber: number): Promise<void> {\n if (blockNumber < this.nbf) {\n await this.stop()\n forget(this.onStatusUpdate?.({\n error: new Error(`Block number: ${blockNumber} is before ${this.nbf}`),\n confirmed: false,\n blockNumber,\n progress: 0,\n remainingBlocks: this.exp - blockNumber,\n }))\n }\n if (blockNumber > this.exp) {\n forget(this.onStatusUpdate?.({\n confirmed: false, blockNumber, progress: 100, remainingBlocks: 0,\n }))\n return\n }\n if (blockNumber < this.exp) {\n await this.checkConfirmation(blockNumber)\n }\n }\n\n private async checkConfirmation(blockNumber: number): Promise<void> {\n const remainingBlocks = this.exp - blockNumber\n const progress = Math.round(((blockNumber - this.nbf) / (this.exp - this.nbf)) * 100)\n\n const tx = await this.viewer.transaction.byHash?.(this.txHash)\n if (isNull(tx)) {\n this.onStatusUpdate?.({\n confirmed: false, blockNumber, progress, remainingBlocks,\n })\n } else {\n this.onStatusUpdate?.({\n confirmed: true, blockNumber, progress, remainingBlocks,\n })\n await this.stop()\n }\n }\n}\n", "import { usePromise } from '@xylabs/react-promise'\nimport type { Address } from '@xylabs/sdk-js'\nimport { isUndefined, isUndefinedOrNull } from '@xylabs/sdk-js'\nimport type { AttoXL1, XyoViewer } from '@xyo-network/xl1-sdk'\nimport { ShiftedBigInt } from '@xyo-network/xl1-sdk'\nimport {\n useMemo, useRef, useState,\n} from 'react'\n\nexport const useAddressBalance = (\n // address to get balance for\n address?: Address,\n // viewer to use for fetching balance\n viewer?: XyoViewer,\n // refresh balance trigger\n refresh?: number,\n // reset balance trigger - clears state immediately\n reset?: number,\n) => {\n const [balancesResult, setBalancesResult] = useState<AttoXL1 | null>()\n const [loading, setLoading] = useState(false)\n const [balancesError, setBalancesError] = useState<Error>()\n\n const [previousReset, setPreviousReset] = useState<number | undefined>(reset)\n if (reset !== previousReset) {\n setPreviousReset(reset)\n setBalancesResult(undefined)\n setBalancesError(undefined)\n setLoading(false)\n }\n\n const balancePromiseRef = useRef<Promise<AttoXL1> | null>(null)\n usePromise(async () => {\n if (isUndefined(viewer) || isUndefined(address)) return\n\n setLoading(true)\n setBalancesError(undefined)\n\n // Create and store the current promise\n const currentPromise = viewer.account.balance.accountBalance(address) as Promise<AttoXL1>\n balancePromiseRef.current = currentPromise\n\n try {\n const result = await currentPromise\n // Only update state if this is still the latest promise\n if (balancePromiseRef.current === currentPromise) {\n setBalancesResult(result)\n setLoading(false)\n }\n } catch (err) {\n // Only update state if this is still the latest promise\n if (balancePromiseRef.current === currentPromise) {\n console.error('Error in queued call:', err)\n setBalancesResult(undefined)\n setBalancesError(err as Error)\n setLoading(false)\n }\n }\n }, [address, viewer, refresh])\n\n const shiftedBigInt = useMemo(() => {\n if (typeof balancesResult !== 'bigint') return\n return new ShiftedBigInt(balancesResult, {\n places: 18, maxDecimal: 18, maxCharacters: 9, minDecimals: 1, locale: navigator.language,\n })\n }, [balancesResult])\n\n const balanceIntlFriendly = useMemo(() => {\n return shiftedBigInt?.toFullString()\n }, [shiftedBigInt])\n\n const shortBalanceIntlFriendly = useMemo(() => {\n return isUndefinedOrNull(balancesResult)\n ? undefined\n : (balancesResult < 1_000_000_000_000n && balancesResult > 0n) ? '<0.00001' : shiftedBigInt?.toShortString()\n }, [balancesResult, shiftedBigInt])\n\n return {\n address,\n balanceForAddress: balancesResult,\n balanceIntlFriendly,\n shortBalanceIntlFriendly,\n error: balancesError,\n loading,\n }\n}\n", "import { usePromise } from '@xylabs/react-promise'\nimport type { Hash } from '@xylabs/sdk-js'\nimport {\n forget, isDefined, isHash,\n} from '@xylabs/sdk-js'\nimport { PayloadBuilder } from '@xyo-network/sdk-js'\nimport type {\n SignedHydratedTransaction, XyoRunner, XyoViewer,\n} from '@xyo-network/xl1-sdk'\nimport { useEffect, useState } from 'react'\n\nimport type { ConfirmationStatusUpdate, TransactionConfirmationParams } from './helpers/index.ts'\nimport { TransactionConfirmationStatus } from './helpers/index.ts'\n\nexport const useConfirmTransactionBase = (\n // The transaction to confirm\n transaction?: SignedHydratedTransaction,\n // Callback for when the transaction is broadcast to the network\n onBroadcast?: (hash: Hash) => void,\n // Optional callback for status updates during confirmation\n onStatusUpdate?: TransactionConfirmationParams['onStatusUpdate'],\n // Runner to use for broadcasting transactions\n runner?: XyoRunner,\n // Viewer to use for checking transaction status\n viewer?: XyoViewer,\n) => {\n const [status, setStatus] = useState<ConfirmationStatusUpdate>()\n const onStatusUpdateLocal = (newStatus: ConfirmationStatusUpdate) => {\n setStatus(newStatus)\n onStatusUpdate?.(newStatus)\n }\n\n const [transactionConfirmationStatus, transactionConfirmationError] = usePromise(async () => {\n const hasRunner = isDefined(runner)\n if (transaction && viewer) {\n const hash = hasRunner ? (await runner.broadcastTransaction(transaction)) : await PayloadBuilder.hash(transaction[0])\n if (isHash(hash)) {\n if (hasRunner && isDefined(onBroadcast)) onBroadcast(hash)\n const params: TransactionConfirmationParams = {\n onStatusUpdate: onStatusUpdateLocal,\n transaction,\n txHash: hash,\n viewer,\n }\n const instance = await TransactionConfirmationStatus.create(params)\n await instance.start()\n return instance\n }\n throw new Error('unexpected return type from broadcast transaction')\n }\n }, [transaction, runner, viewer])\n\n useEffect(() => {\n return () => {\n if (transactionConfirmationStatus) {\n // Stop the transaction confirmation status instance when the component unmounts\n forget(transactionConfirmationStatus.stop())\n }\n }\n }, [transactionConfirmationStatus])\n\n return { status, transactionConfirmationError }\n}\n", "/**\n * @deprecated Moved to `@xyo-network/xl1-react-client-sdk`. Import from there\n * instead. This re-export exists only for backward compatibility and will be\n * removed in a future release.\n */\n\nexport { useConnectAccount } from '@xyo-network/xl1-react-client-sdk'\n", "import type { UsePromiseState } from '@xylabs/react-promise'\nimport { usePromise } from '@xylabs/react-promise'\nimport { isDefinedNotNull } from '@xylabs/sdk-js'\nimport type { HydratedBlockWithHashMeta, XyoViewer } from '@xyo-network/xl1-sdk'\n\nimport { useViewerFromGateway } from './gateway/index.ts'\n\n/* @deprecated - use useCurrentBlockFromGateway instead */\nexport const useCurrentBlock = (refresh = 1, viewer?: XyoViewer | null): [HydratedBlockWithHashMeta | undefined,\n Error | undefined, UsePromiseState | undefined] => {\n return usePromise(async () => {\n if (!isDefinedNotNull(viewer) || refresh <= 0) {\n return\n }\n return await viewer.currentBlock()\n }, [viewer, refresh])\n}\n\nexport const useCurrentBlockFromGateway = (refresh = 1): [HydratedBlockWithHashMeta | undefined,\n Error | undefined, UsePromiseState | undefined] => {\n const viewer = useViewerFromGateway()\n return usePromise(async () => {\n if (!isDefinedNotNull(viewer) || refresh <= 0) {\n return\n }\n return await viewer.currentBlock()\n }, [viewer, refresh])\n}\n", "import { isUndefined } from '@xylabs/sdk-js'\nimport type { DefaultNetworkIds } from '@xyo-network/xl1-sdk'\nimport { SimpleXyoNetwork } from '@xyo-network/xl1-sdk'\nimport { useMemo } from 'react'\n\nexport const useNetwork = (id?: DefaultNetworkIds) => {\n const network = useMemo(() => {\n if (isUndefined(id)) return\n return new SimpleXyoNetwork(id)\n }, [id])\n\n return network\n}\n", "import { usePromise } from '@xylabs/react-promise'\nimport type { AccountInstance } from '@xyo-network/sdk-js'\nimport {\n SimpleXyoSigner, type XyoConnection, type XyoSigner,\n} from '@xyo-network/xl1-sdk'\n\nexport const useSigner = (_provider?: XyoConnection, account?: AccountInstance) => {\n return usePromise<XyoSigner | undefined>(async () => account ? await SimpleXyoSigner.create({ account }) : undefined, [account])\n}\n", "import { usePromise } from '@xylabs/react-promise'\nimport {\n delay, isDefined, isUndefined,\n} from '@xylabs/sdk-js'\nimport type { JsonRpcXyoViewer } from '@xyo-network/xl1-sdk'\nimport {\n basicRemoteViewerLocator,\n LocalNetwork,\n SequenceNetwork,\n XyoViewerMoniker,\n} from '@xyo-network/xl1-sdk'\nimport { useEffect, useState } from 'react'\n\nconst INTERVAL = 5000 // 5 seconds\n\nconst localRpcEndpoint = `${LocalNetwork.url}/rpc`\nconst sequenceRpcEndpoint = `${SequenceNetwork.url}/rpc`\n\nexport const useCheckLocalRpc = () => {\n const isLocalProducer = useCheckRpc(localRpcEndpoint)\n return isLocalProducer\n}\n\nexport const useCheckSequenceRpc = () => {\n const isSequenceRpc = useCheckRpc(sequenceRpcEndpoint)\n return isSequenceRpc\n}\n\nexport const useCheckRpc = (endpoint?: string) => {\n const [isLocalProducer, setIsLocalProducer] = useState(false)\n const [error, setError] = useState<Error>()\n\n const [viewer] = usePromise(async () => {\n if (isUndefined(endpoint)) return\n\n const locator = await basicRemoteViewerLocator(endpoint, { rpc: { protocol: 'http', url: endpoint } })\n\n const viewer = await locator.getInstance<JsonRpcXyoViewer>(XyoViewerMoniker)\n return viewer\n }, [endpoint])\n\n useEffect(() => {\n if (isUndefined(viewer)) return\n\n void (async () => {\n setError(undefined)\n while (!isLocalProducer) {\n try {\n const block = await viewer.currentBlock()\n setIsLocalProducer(isDefined(block))\n } catch (err) {\n setError(err as Error)\n setIsLocalProducer(false)\n }\n await delay(INTERVAL)\n }\n })()\n }, [isLocalProducer, viewer])\n\n return { isLocalProducer, error }\n}\n", "import { type Hash, isNull } from '@xylabs/sdk-js'\nimport { PayloadBuilder } from '@xyo-network/sdk-js'\nimport type {\n DataLakeViewer, SignedHydratedBlockWithHashMeta, SignedHydratedTransactionWithHashMeta, XL1BlockNumber,\n} from '@xyo-network/xl1-sdk'\nimport {\n addDataLakePayloads,\n addDataLakePayloadsToPayloads, DataLakeViewerMoniker, JsonRpcXyoViewer,\n} from '@xyo-network/xl1-sdk'\n\n/**\n * A Viewer with data lake capabilities, it will attempt to fill in missing payloads from the\n * data lake viewer if available.\n *\n * THIS IS AN EXPERIMENTAL CLASS! Only intended to prove the data lake viewer functionality works.\n * In the future, it should be refactored to augment any viewer with data lake capabilities,\n * and not rely on inheritance from JsonRpcXyoViewer which has the 'creatable' pattern baked in.\n */\nexport class ViewerWithDataLake extends JsonRpcXyoViewer {\n protected dataLakeViewer: DataLakeViewer | undefined\n\n override async blocksByHash(hash: Hash, limit?: number): Promise<SignedHydratedBlockWithHashMeta[]> {\n const blocks = await super.blocksByHash(hash, limit)\n return await Promise.all(blocks.map(async (block) => {\n const augmented = await addDataLakePayloads(block, this.dataLakeViewer)\n return augmented[0]\n }))\n }\n\n override async blocksByNumber(blockNumber: XL1BlockNumber, limit?: number): Promise<SignedHydratedBlockWithHashMeta[]> {\n const blocks = await super.blocksByNumber(blockNumber, limit)\n return await Promise.all(blocks.map(async (block) => {\n const augmented = await addDataLakePayloads(block, this.dataLakeViewer)\n return augmented[0]\n }))\n }\n\n override async createHandler() {\n await super.createHandler()\n this.dataLakeViewer = await this.locator.tryGetInstance<DataLakeViewer>(DataLakeViewerMoniker)\n }\n\n override async payloadsByHash(hashes: Hash[]) {\n const payloads = await super.payloadsByHash(hashes)\n const augmented = await addDataLakePayloadsToPayloads(hashes, payloads, this.dataLakeViewer)\n return augmented[0]\n }\n\n override async transactionByHash(hash: Hash): Promise<SignedHydratedTransactionWithHashMeta | null> {\n const transaction = await super.transaction.byHash(hash)\n if (!this.dataLakeViewer) {\n return transaction\n ? [await PayloadBuilder.addHashMeta(transaction[0]), await PayloadBuilder.addHashMeta(transaction[1])]\n : null\n }\n\n if (isNull(transaction)) {\n return transaction\n }\n\n const boundWitness = await PayloadBuilder.addHashMeta(transaction[0])\n const payload = await PayloadBuilder.addHashMeta(transaction[1])\n const augmented = await addDataLakePayloads([boundWitness, payload], this.dataLakeViewer)\n return augmented[0]\n }\n}\n"],
|
|
4
|
+
"sourcesContent": ["import {\n Stack, Tooltip, Typography,\n} from '@mui/material'\nimport { EthAddressWrapper } from '@xylabs/eth-address'\nimport { BlockiesAvatarAddress } from '@xyo-network/xl1-blockies'\nimport React from 'react'\n\nexport const ConnectedAccount: React.FC<{ address: string }> = ({ address }) => {\n const shortenedAddress = EthAddressWrapper.fromString(address)?.toShortString(4)\n\n return (\n <Stack\n direction=\"row\"\n spacing={1}\n sx={{ alignItems: 'center' }}\n >\n <BlockiesAvatarAddress address={address} size={21} />\n <Tooltip title={address}>\n <Typography\n variant=\"caption\"\n sx={{\n color: 'text.secondary',\n fontFamily: 'monospace',\n }}\n >\n {shortenedAddress}\n </Typography>\n </Tooltip>\n </Stack>\n )\n}\n", "/**\n * @deprecated Moved to `@xyo-network/xl1-react-client-sdk`. Import from there\n * instead. This re-export exists only for backward compatibility and will be\n * removed in a future release.\n */\n\nexport type { ConnectClientAccountsStackProps } from '@xyo-network/xl1-react-client-sdk'\nexport { ConnectAccountsStack } from '@xyo-network/xl1-react-client-sdk'\n", "import { createContextEx } from '@xylabs/react-shared'\n\nimport type { XL1CurrentBlockState } from './state.ts'\n\nexport const XL1CurrentBlockContext = createContextEx<XL1CurrentBlockState>()\n", "import type { XyoViewer } from '@xyo-network/xl1-sdk'\nimport type { PropsWithChildren } from 'react'\nimport React, { useMemo } from 'react'\n\nimport { XL1CurrentBlockContext } from './context.ts'\nimport type { XL1CurrentBlockPollingConfig, XL1CurrentBlockState } from './state.ts'\nimport { usePollCurrentBlock } from './usePollCurrentBlock.ts'\n\nexport const DEFAULT_POLLING_INTERVAL = 10_000\n\nexport interface XL1CurrentBlockProviderProps extends PropsWithChildren {\n pollingConfig?: XL1CurrentBlockPollingConfig\n viewer?: XyoViewer | null\n}\n\nexport const XL1CurrentBlockProvider: React.FC<XL1CurrentBlockProviderProps> = ({\n pollingConfig, viewer, children,\n}) => {\n const { interval } = useMemo(() => pollingConfig ?? { interval: DEFAULT_POLLING_INTERVAL }, [pollingConfig])\n const [currentBlock, currentBlockError] = usePollCurrentBlock(viewer, interval)\n\n const value: XL1CurrentBlockState = useMemo(() => ({\n block: currentBlock,\n blockNumber: currentBlock?.[0].block,\n chain: currentBlock?.[0].chain,\n error: currentBlockError,\n pollingConfig,\n provided: true,\n }), [currentBlock, currentBlockError, pollingConfig])\n\n return (\n <XL1CurrentBlockContext value={value}>\n {children}\n </XL1CurrentBlockContext>\n )\n}\n", "import { isDefinedNotNull, isUndefinedOrNull } from '@xylabs/sdk-js'\nimport type { SignedHydratedBlock, XyoViewer } from '@xyo-network/xl1-sdk'\nimport {\n startTransition, useEffect, useState,\n} from 'react'\n\nconst DEFAULT_POLL_INTERVAL = 10_000\n\nexport const usePollCurrentBlock = (viewer?: XyoViewer | null, interval = DEFAULT_POLL_INTERVAL, pause = false) => {\n const [currentBlock, setCurrentBlock] = useState<SignedHydratedBlock | null>(null)\n const [error, setError] = useState<Error>()\n\n useEffect(() => {\n let isMounted = true\n // Function to fetch the current block\n const fetchBlock = async () => {\n if (isDefinedNotNull(viewer)) {\n try {\n const block = await viewer.currentBlock()\n // Safety check to ensure component is still mounted before updating state\n if (isMounted) {\n startTransition(() => {\n setCurrentBlock((existingBlock) => {\n if (isUndefinedOrNull(existingBlock)) {\n return block\n }\n if (\n isDefinedNotNull(block) && existingBlock?.[0].block !== block[0].block\n ) {\n return block\n }\n return existingBlock\n })\n })\n }\n } catch (err) {\n startTransition(() => {\n setError(err as Error)\n })\n }\n }\n }\n\n // Initial fetch\n void fetchBlock()\n\n // Polling mechanism\n const id = setInterval(() => {\n if (!pause) {\n void fetchBlock()\n }\n }, interval)\n\n return () => {\n isMounted = false\n clearInterval(id)\n }\n }, [viewer, interval, pause])\n\n return [currentBlock, error] as const\n}\n", "import { useContextEx } from '@xylabs/react-shared'\n\nimport { XL1CurrentBlockContext } from './context.ts'\nimport type { XL1CurrentBlockState } from './state.ts'\n\nexport const useXl1CurrentBlockContext = (required = true) => useContextEx<XL1CurrentBlockState>(XL1CurrentBlockContext, 'XL1CurrentBlock', required)\n", "/**\n * @deprecated Moved to `@xyo-network/xl1-react-client-sdk`. Import\n * `GatewayProvider` from there instead. This re-export exists only for\n * backward compatibility and will be removed in a future release.\n */\n\nexport { GatewayProvider } from '@xyo-network/xl1-react-client-sdk'\n", "/**\n * @deprecated Moved to `@xyo-network/xl1-react-client-sdk`. Import\n * `InPageGatewaysContext` from there instead. This re-export exists only\n * for backward compatibility and will be removed in a future release.\n */\n\nexport { InPageGatewaysContext } from '@xyo-network/xl1-react-client-sdk'\n", "/**\n * @deprecated Moved to `@xyo-network/xl1-react-client-sdk`. Import\n * `InPageGatewaysProvider` and `InPageGatewaysProviderProps` from there\n * instead. This re-export exists only for backward compatibility and\n * will be removed in a future release.\n */\n\nexport type { InPageGatewaysProviderProps } from '@xyo-network/xl1-react-client-sdk'\nexport { InPageGatewaysProvider } from '@xyo-network/xl1-react-client-sdk'\n", "/**\n * @deprecated Moved to `@xyo-network/xl1-react-client-sdk`. Import\n * `useProvidedInPageGateways` from there instead. This re-export exists\n * only for backward compatibility and will be removed in a future\n * release.\n */\n\nexport { useProvidedInPageGateways } from '@xyo-network/xl1-react-client-sdk'\n", "import { hexToBigInt } from '@xylabs/sdk-js'\nimport type { XyoAddress } from '@xyo-network/sdk-js'\nimport { PayloadBuilder } from '@xyo-network/sdk-js'\nimport type { AccountBalanceHistoryItem } from '@xyo-network/xl1-sdk'\n\nimport type { AccountBalanceHistoryItemFormatted } from '../BalanceHistoryItemFormatted.ts'\n\nexport const formatAccountBalanceHistory = async (address: XyoAddress, history: AccountBalanceHistoryItem[]): Promise<AccountBalanceHistoryItemFormatted[]> => {\n const results: AccountBalanceHistoryItemFormatted[] = []\n for (const item of history) {\n const [blockBw, txBw, transfer] = item\n const transferHash = await PayloadBuilder.hash(transfer)\n const blockHash = await PayloadBuilder.hash(blockBw)\n if (address === transfer.from) {\n for (const [to, amount] of Object.entries(transfer.transfers)) {\n results.push({\n amount: hexToBigInt(amount),\n blockHash,\n blockNumber: blockBw.block,\n from: transfer.from,\n timestamp: blockBw.$epoch,\n key: crypto.randomUUID(),\n to: to as XyoAddress,\n transferHash,\n txHash: txBw?._hash,\n debug: item,\n type: 'send',\n })\n }\n } else {\n results.push({\n amount: hexToBigInt(transfer.transfers[address]),\n blockHash,\n blockNumber: blockBw.block,\n from: transfer.from,\n key: crypto.randomUUID(),\n timestamp: blockBw.$epoch,\n to: address,\n transferHash,\n txHash: txBw?._hash,\n debug: item,\n type: 'receive',\n })\n }\n }\n return results\n}\n", "import { usePromise } from '@xylabs/react-promise'\nimport { isUndefined } from '@xylabs/sdk-js'\nimport type { XyoAddress } from '@xyo-network/sdk-js'\nimport type {\n AccountBalanceHistoryItem, XL1BlockRange, XyoViewer,\n} from '@xyo-network/xl1-sdk'\n\nimport { balanceForRange, findMinimumBlock } from '../../lib/index.ts'\nimport { formatAccountBalanceHistory } from './helpers/index.ts'\n\nexport const useAccountBalanceHistory = (address?: XyoAddress, viewer?: XyoViewer, maxPage = 10, blockRange?: XL1BlockRange, refresh?: number) => {\n return usePromise(async () => {\n if (isUndefined(viewer) || isUndefined(address)) return\n\n // Pagination Values\n let page = 1\n let lastBlock: number\n const pagedHistory: AccountBalanceHistoryItem[] = []\n const resolvedStartBlock = blockRange ? blockRange[0] : 0\n\n // Fetch first page to get starting lastBlock\n // If blockRange is provided, use that for the first fetch, otherwise the API will use [0, currentBlock]\n const history = await viewer.account.balance.accountBalanceHistory(address, blockRange ? { range: blockRange } : {})\n if (history.length > 0) {\n pagedHistory.push(...history)\n // Set lastBlock to one less than the lowest block in the first page\n lastBlock = findMinimumBlock(history)\n while (page < maxPage) {\n // Fetch next page\n const nextHistory = await viewer.account.balance.accountBalanceHistory(address, { range: [resolvedStartBlock, lastBlock] as XL1BlockRange })\n // Break if no more history\n if (nextHistory.length === 0) break\n // Update lastBlock and append to pagedHistory\n lastBlock = findMinimumBlock(nextHistory)\n pagedHistory.push(...nextHistory)\n // Increment page\n // Even if we are going to go over and break the loop, we still want to increment to show the answer was truncated\n page++\n }\n }\n const formattedHistory = await formatAccountBalanceHistory(address, pagedHistory)\n\n return {\n history: formattedHistory,\n balance: balanceForRange(address, pagedHistory),\n truncated: page >= maxPage,\n }\n }, [address, viewer, refresh, blockRange, maxPage])\n}\n", "import {\n hexToBigInt, isHex, toHex,\n} from '@xylabs/sdk-js'\nimport type { XyoAddress } from '@xyo-network/sdk-js'\nimport type { AccountBalanceHistoryItem, AttoXL1 } from '@xyo-network/xl1-sdk'\n\nexport const balanceForRange = (address: XyoAddress, results: AccountBalanceHistoryItem[]): [AttoXL1, AttoXL1] => {\n const totalReceivedBalance = results?.reduce((a, [_block, _tx, transfer]) => {\n return a + hexToBigInt(transfer.transfers[address] ?? toHex(0))\n }, 0n)\n // eslint-disable-next-line unicorn/no-array-reduce\n const totalSentBalance = results?.reduce((a, [_block, _tx, transfer]) => {\n return (transfer.from === address) ? a + Object.values(transfer.transfers).reduce((a, v) => a + (isHex(v) ? hexToBigInt(v) : 0n), 0n) : a\n }, 0n)\n return [totalReceivedBalance, totalSentBalance] as [AttoXL1, AttoXL1]\n}\n", "import { assertEx, isDefined } from '@xylabs/sdk-js'\nimport type {\n GatewayName,\n RemoteConfig, RpcTransport, SimpleXyoGateway,\n XyoSignerRpcSchemas,\n} from '@xyo-network/xl1-sdk'\nimport {\n basicRemoteRunnerLocator,\n basicRemoteViewerLocator,\n DefaultNetworks, NetworkDataLakeUrls, XyoGatewayMoniker,\n} from '@xyo-network/xl1-sdk'\n\nexport const buildGateway = async (gatewayName: GatewayName, signerTransport?: RpcTransport<XyoSignerRpcSchemas>) => {\n const network = DefaultNetworks.find(network => network.id === gatewayName)\n const resolvedNetwork = assertEx(network, () => `No network found for id ${gatewayName}`)\n\n const remoteConfig: RemoteConfig = {\n rpc: {\n protocol: 'http',\n url: `${resolvedNetwork.url}/rpc`,\n },\n }\n\n const dataLakeEndpoint = NetworkDataLakeUrls[gatewayName]\n\n const locator = isDefined(signerTransport)\n ? await basicRemoteRunnerLocator(gatewayName, remoteConfig, signerTransport, dataLakeEndpoint)\n : await basicRemoteViewerLocator(gatewayName, remoteConfig, dataLakeEndpoint)\n\n return await locator.getInstance<SimpleXyoGateway>(XyoGatewayMoniker)\n}\n", "import type { AccountBalanceHistoryItem } from '@xyo-network/xl1-sdk'\n\nexport const findMinimumBlock = (history: AccountBalanceHistoryItem[]): number => {\n // since taking Math.min of an empty array returns Infinity\n if (history.length === 0) return 0\n const blockNumbers = history.map(([blockBw]) => blockBw.block)\n const min = Math.min(...blockNumbers)\n return Math.max(min - 1, 0)\n}\n", "import { useProvidedGateway } from '@xyo-network/xl1-react-client-sdk'\nimport type { XyoNetwork } from '@xyo-network/xl1-sdk'\n\nexport const useNetworkFromGateway = (): XyoNetwork | undefined => {\n const { defaultGateway } = useProvidedGateway()\n return defaultGateway?.connection?.network\n}\n", "import { useProvidedGateway } from '@xyo-network/xl1-react-client-sdk'\nimport type { XyoRunner } from '@xyo-network/xl1-sdk'\n\nexport const useRunnerFromGateway = (): XyoRunner | undefined => {\n const { defaultGateway } = useProvidedGateway()\n return defaultGateway?.connection?.runner\n}\n", "import { useProvidedGateway } from '@xyo-network/xl1-react-client-sdk'\nimport type { XyoViewer } from '@xyo-network/xl1-sdk'\n\nexport const useViewerFromGateway = (): XyoViewer | undefined => {\n const { defaultGateway } = useProvidedGateway()\n return defaultGateway?.connection?.viewer\n}\n", "/** @deprecated Import from `@xyo-network/xl1-react-client-sdk` instead */\nexport { getXyoClient, listenForClientInjection } from '@xyo-network/xl1-react-client-sdk'\n", "import type { Hash, Promisable } from '@xylabs/sdk-js'\nimport {\n assertEx, delay, forget, isDefined, isNull,\n} from '@xylabs/sdk-js'\nimport type { SignedHydratedTransaction, XyoViewer } from '@xyo-network/xl1-sdk'\n\nexport interface ConfirmationStatusUpdate {\n blockNumber: number\n confirmed: boolean\n error?: Error\n progress?: number\n remainingBlocks?: number\n}\n\nexport interface TransactionConfirmationParams {\n onStatusUpdate?: (status: ConfirmationStatusUpdate) => void\n transaction: SignedHydratedTransaction\n txHash: Hash\n viewer: XyoViewer\n}\n\nexport class TransactionConfirmationStatus {\n private readonly _params: TransactionConfirmationParams\n private active = false\n\n constructor(params: TransactionConfirmationParams) {\n this._params = params\n }\n\n get exp(): number {\n return assertEx(this.transaction[0].exp, () => 'exp is not found, transaction is not set')\n }\n\n get nbf(): number {\n return assertEx(this.transaction[0].nbf, () => 'nbf is not found, transaction is not set')\n }\n\n get onStatusUpdate(): TransactionConfirmationParams['onStatusUpdate'] {\n return this._params.onStatusUpdate\n }\n\n get params(): TransactionConfirmationParams {\n return this._params\n }\n\n get transaction(): SignedHydratedTransaction {\n return this.params.transaction\n }\n\n get txHash(): Hash {\n return this.params.txHash\n }\n\n get viewer(): XyoViewer {\n return this.params.viewer\n }\n\n static create(params: TransactionConfirmationParams): Promisable<TransactionConfirmationStatus> {\n return new TransactionConfirmationStatus(params)\n }\n\n async start(): Promise<void> {\n this.active = true\n try {\n const currentBlockNumber = await this.viewer.currentBlockNumber()\n while (isDefined(currentBlockNumber) && this.active) {\n await this.checkBlock(currentBlockNumber)\n // check block every second to see if the transaction is confirmed\n await delay(1000)\n }\n } catch (error) {\n await this.stop()\n forget(this.onStatusUpdate?.({\n error: error instanceof Error ? error : new Error('Unknown error occurred'),\n confirmed: false,\n blockNumber: 0,\n progress: 0,\n remainingBlocks: 0,\n }))\n }\n }\n\n stop(): Promisable<void> {\n this.active = false\n }\n\n private async checkBlock(blockNumber: number): Promise<void> {\n if (blockNumber < this.nbf) {\n await this.stop()\n forget(this.onStatusUpdate?.({\n error: new Error(`Block number: ${blockNumber} is before ${this.nbf}`),\n confirmed: false,\n blockNumber,\n progress: 0,\n remainingBlocks: this.exp - blockNumber,\n }))\n }\n if (blockNumber > this.exp) {\n forget(this.onStatusUpdate?.({\n confirmed: false, blockNumber, progress: 100, remainingBlocks: 0,\n }))\n return\n }\n if (blockNumber < this.exp) {\n await this.checkConfirmation(blockNumber)\n }\n }\n\n private async checkConfirmation(blockNumber: number): Promise<void> {\n const remainingBlocks = this.exp - blockNumber\n const progress = Math.round(((blockNumber - this.nbf) / (this.exp - this.nbf)) * 100)\n\n const tx = await this.viewer.transaction.byHash?.(this.txHash)\n if (isNull(tx)) {\n this.onStatusUpdate?.({\n confirmed: false, blockNumber, progress, remainingBlocks,\n })\n } else {\n this.onStatusUpdate?.({\n confirmed: true, blockNumber, progress, remainingBlocks,\n })\n await this.stop()\n }\n }\n}\n", "import { usePromise } from '@xylabs/react-promise'\nimport type { Address } from '@xylabs/sdk-js'\nimport { isUndefined, isUndefinedOrNull } from '@xylabs/sdk-js'\nimport type { AttoXL1, XyoViewer } from '@xyo-network/xl1-sdk'\nimport { ShiftedBigInt } from '@xyo-network/xl1-sdk'\nimport {\n useMemo, useRef, useState,\n} from 'react'\n\nexport const useAddressBalance = (\n // address to get balance for\n address?: Address,\n // viewer to use for fetching balance\n viewer?: XyoViewer,\n // refresh balance trigger\n refresh?: number,\n // reset balance trigger - clears state immediately\n reset?: number,\n) => {\n const [balancesResult, setBalancesResult] = useState<AttoXL1 | null>()\n const [loading, setLoading] = useState(false)\n const [balancesError, setBalancesError] = useState<Error>()\n\n const [previousReset, setPreviousReset] = useState<number | undefined>(reset)\n if (reset !== previousReset) {\n setPreviousReset(reset)\n setBalancesResult(undefined)\n setBalancesError(undefined)\n setLoading(false)\n }\n\n const balancePromiseRef = useRef<Promise<AttoXL1> | null>(null)\n usePromise(async () => {\n if (isUndefined(viewer) || isUndefined(address)) return\n\n setLoading(true)\n setBalancesError(undefined)\n\n // Create and store the current promise\n const currentPromise = viewer.account.balance.accountBalance(address) as Promise<AttoXL1>\n balancePromiseRef.current = currentPromise\n\n try {\n const result = await currentPromise\n // Only update state if this is still the latest promise\n if (balancePromiseRef.current === currentPromise) {\n setBalancesResult(result)\n setLoading(false)\n }\n } catch (err) {\n // Only update state if this is still the latest promise\n if (balancePromiseRef.current === currentPromise) {\n console.error('Error in queued call:', err)\n setBalancesResult(undefined)\n setBalancesError(err as Error)\n setLoading(false)\n }\n }\n }, [address, viewer, refresh])\n\n const shiftedBigInt = useMemo(() => {\n if (typeof balancesResult !== 'bigint') return\n return new ShiftedBigInt(balancesResult, {\n places: 18, maxDecimal: 18, maxCharacters: 9, minDecimals: 1, locale: navigator.language,\n })\n }, [balancesResult])\n\n const balanceIntlFriendly = useMemo(() => {\n return shiftedBigInt?.toFullString()\n }, [shiftedBigInt])\n\n const shortBalanceIntlFriendly = useMemo(() => {\n return isUndefinedOrNull(balancesResult)\n ? undefined\n : (balancesResult < 1_000_000_000_000n && balancesResult > 0n) ? '<0.00001' : shiftedBigInt?.toShortString()\n }, [balancesResult, shiftedBigInt])\n\n return {\n address,\n balanceForAddress: balancesResult,\n balanceIntlFriendly,\n shortBalanceIntlFriendly,\n error: balancesError,\n loading,\n }\n}\n", "import { usePromise } from '@xylabs/react-promise'\nimport type { Hash } from '@xylabs/sdk-js'\nimport {\n forget, isDefined, isHash,\n} from '@xylabs/sdk-js'\nimport { PayloadBuilder } from '@xyo-network/sdk-js'\nimport type {\n SignedHydratedTransaction, XyoRunner, XyoViewer,\n} from '@xyo-network/xl1-sdk'\nimport { useEffect, useState } from 'react'\n\nimport type { ConfirmationStatusUpdate, TransactionConfirmationParams } from './helpers/index.ts'\nimport { TransactionConfirmationStatus } from './helpers/index.ts'\n\nexport const useConfirmTransactionBase = (\n // The transaction to confirm\n transaction?: SignedHydratedTransaction,\n // Callback for when the transaction is broadcast to the network\n onBroadcast?: (hash: Hash) => void,\n // Optional callback for status updates during confirmation\n onStatusUpdate?: TransactionConfirmationParams['onStatusUpdate'],\n // Runner to use for broadcasting transactions\n runner?: XyoRunner,\n // Viewer to use for checking transaction status\n viewer?: XyoViewer,\n) => {\n const [status, setStatus] = useState<ConfirmationStatusUpdate>()\n const onStatusUpdateLocal = (newStatus: ConfirmationStatusUpdate) => {\n setStatus(newStatus)\n onStatusUpdate?.(newStatus)\n }\n\n const [transactionConfirmationStatus, transactionConfirmationError] = usePromise(async () => {\n const hasRunner = isDefined(runner)\n if (transaction && viewer) {\n const hash = hasRunner ? (await runner.broadcastTransaction(transaction)) : await PayloadBuilder.hash(transaction[0])\n if (isHash(hash)) {\n if (hasRunner && isDefined(onBroadcast)) onBroadcast(hash)\n const params: TransactionConfirmationParams = {\n onStatusUpdate: onStatusUpdateLocal,\n transaction,\n txHash: hash,\n viewer,\n }\n const instance = await TransactionConfirmationStatus.create(params)\n await instance.start()\n return instance\n }\n throw new Error('unexpected return type from broadcast transaction')\n }\n }, [transaction, runner, viewer])\n\n useEffect(() => {\n return () => {\n if (transactionConfirmationStatus) {\n // Stop the transaction confirmation status instance when the component unmounts\n forget(transactionConfirmationStatus.stop())\n }\n }\n }, [transactionConfirmationStatus])\n\n return { status, transactionConfirmationError }\n}\n", "/**\n * @deprecated Moved to `@xyo-network/xl1-react-client-sdk`. Import from there\n * instead. This re-export exists only for backward compatibility and will be\n * removed in a future release.\n */\n\nexport { useConnectAccount } from '@xyo-network/xl1-react-client-sdk'\n", "import type { UsePromiseState } from '@xylabs/react-promise'\nimport { usePromise } from '@xylabs/react-promise'\nimport { isDefinedNotNull } from '@xylabs/sdk-js'\nimport type { HydratedBlockWithHashMeta, XyoViewer } from '@xyo-network/xl1-sdk'\n\nimport { useViewerFromGateway } from './gateway/index.ts'\n\n/* @deprecated - use useCurrentBlockFromGateway instead */\nexport const useCurrentBlock = (refresh = 1, viewer?: XyoViewer | null): [HydratedBlockWithHashMeta | undefined,\n Error | undefined, UsePromiseState | undefined] => {\n return usePromise(async () => {\n if (!isDefinedNotNull(viewer) || refresh <= 0) {\n return\n }\n return await viewer.currentBlock()\n }, [viewer, refresh])\n}\n\nexport const useCurrentBlockFromGateway = (refresh = 1): [HydratedBlockWithHashMeta | undefined,\n Error | undefined, UsePromiseState | undefined] => {\n const viewer = useViewerFromGateway()\n return usePromise(async () => {\n if (!isDefinedNotNull(viewer) || refresh <= 0) {\n return\n }\n return await viewer.currentBlock()\n }, [viewer, refresh])\n}\n", "import { isUndefined } from '@xylabs/sdk-js'\nimport type { DefaultNetworkIds } from '@xyo-network/xl1-sdk'\nimport { SimpleXyoNetwork } from '@xyo-network/xl1-sdk'\nimport { useMemo } from 'react'\n\nexport const useNetwork = (id?: DefaultNetworkIds) => {\n const network = useMemo(() => {\n if (isUndefined(id)) return\n return new SimpleXyoNetwork(id)\n }, [id])\n\n return network\n}\n", "import { usePromise } from '@xylabs/react-promise'\nimport type { AccountInstance } from '@xyo-network/sdk-js'\nimport {\n SimpleXyoSigner, type XyoConnection, type XyoSigner,\n} from '@xyo-network/xl1-sdk'\n\nexport const useSigner = (_provider?: XyoConnection, account?: AccountInstance) => {\n return usePromise<XyoSigner | undefined>(async () => account ? await SimpleXyoSigner.create({ account }) : undefined, [account])\n}\n", "import { usePromise } from '@xylabs/react-promise'\nimport {\n delay, isDefined, isUndefined,\n} from '@xylabs/sdk-js'\nimport type { JsonRpcXyoViewer } from '@xyo-network/xl1-sdk'\nimport {\n basicRemoteViewerLocator,\n LocalNetwork,\n SequenceNetwork,\n XyoViewerMoniker,\n} from '@xyo-network/xl1-sdk'\nimport { useEffect, useState } from 'react'\n\nconst INTERVAL = 5000 // 5 seconds\n\nconst localRpcEndpoint = `${LocalNetwork.url}/rpc`\nconst sequenceRpcEndpoint = `${SequenceNetwork.url}/rpc`\n\nexport const useCheckLocalRpc = () => {\n const isLocalProducer = useCheckRpc(localRpcEndpoint)\n return isLocalProducer\n}\n\nexport const useCheckSequenceRpc = () => {\n const isSequenceRpc = useCheckRpc(sequenceRpcEndpoint)\n return isSequenceRpc\n}\n\nexport const useCheckRpc = (endpoint?: string) => {\n const [isLocalProducer, setIsLocalProducer] = useState(false)\n const [error, setError] = useState<Error>()\n\n const [viewer] = usePromise(async () => {\n if (isUndefined(endpoint)) return\n\n const locator = await basicRemoteViewerLocator(endpoint, { rpc: { protocol: 'http', url: endpoint } })\n\n const viewer = await locator.getInstance<JsonRpcXyoViewer>(XyoViewerMoniker)\n return viewer\n }, [endpoint])\n\n useEffect(() => {\n if (isUndefined(viewer)) return\n\n void (async () => {\n setError(undefined)\n while (!isLocalProducer) {\n try {\n const block = await viewer.currentBlock()\n setIsLocalProducer(isDefined(block))\n } catch (err) {\n setError(err as Error)\n setIsLocalProducer(false)\n }\n await delay(INTERVAL)\n }\n })()\n }, [isLocalProducer, viewer])\n\n return { isLocalProducer, error }\n}\n", "import { type Hash, isNull } from '@xylabs/sdk-js'\nimport { PayloadBuilder } from '@xyo-network/sdk-js'\nimport type {\n DataLakeViewer, SignedHydratedBlockWithHashMeta, SignedHydratedTransactionWithHashMeta, XL1BlockNumber,\n} from '@xyo-network/xl1-sdk'\nimport {\n addDataLakePayloads,\n addDataLakePayloadsToPayloads, DataLakeViewerMoniker, JsonRpcXyoViewer,\n} from '@xyo-network/xl1-sdk'\n\n/**\n * A Viewer with data lake capabilities, it will attempt to fill in missing payloads from the\n * data lake viewer if available.\n *\n * THIS IS AN EXPERIMENTAL CLASS! Only intended to prove the data lake viewer functionality works.\n * In the future, it should be refactored to augment any viewer with data lake capabilities,\n * and not rely on inheritance from JsonRpcXyoViewer which has the 'creatable' pattern baked in.\n */\nexport class ViewerWithDataLake extends JsonRpcXyoViewer {\n protected dataLakeViewer: DataLakeViewer | undefined\n\n override async blocksByHash(hash: Hash, limit?: number): Promise<SignedHydratedBlockWithHashMeta[]> {\n const blocks = await super.blocksByHash(hash, limit)\n return await Promise.all(blocks.map(async (block) => {\n const augmented = await addDataLakePayloads(block, this.dataLakeViewer)\n return augmented[0]\n }))\n }\n\n override async blocksByNumber(blockNumber: XL1BlockNumber, limit?: number): Promise<SignedHydratedBlockWithHashMeta[]> {\n const blocks = await super.blocksByNumber(blockNumber, limit)\n return await Promise.all(blocks.map(async (block) => {\n const augmented = await addDataLakePayloads(block, this.dataLakeViewer)\n return augmented[0]\n }))\n }\n\n override async createHandler() {\n await super.createHandler()\n this.dataLakeViewer = await this.locator.tryGetInstance<DataLakeViewer>(DataLakeViewerMoniker)\n }\n\n override async payloadsByHash(hashes: Hash[]) {\n const payloads = await super.payloadsByHash(hashes)\n const augmented = await addDataLakePayloadsToPayloads(hashes, payloads, this.dataLakeViewer)\n return augmented[0]\n }\n\n override async transactionByHash(hash: Hash): Promise<SignedHydratedTransactionWithHashMeta | null> {\n const transaction = await super.transaction.byHash(hash)\n if (!this.dataLakeViewer) {\n return transaction\n ? [await PayloadBuilder.addHashMeta(transaction[0]), await PayloadBuilder.addHashMeta(transaction[1])]\n : null\n }\n\n if (isNull(transaction)) {\n return transaction\n }\n\n const boundWitness = await PayloadBuilder.addHashMeta(transaction[0])\n const payload = await PayloadBuilder.addHashMeta(transaction[1])\n const augmented = await addDataLakePayloads([boundWitness, payload], this.dataLakeViewer)\n return augmented[0]\n }\n}\n"],
|
|
5
5
|
"mappings": ";AAAA;AAAA,EACE;AAAA,EAAO;AAAA,EAAS;AAAA,OACX;AACP,SAAS,yBAAyB;AAClC,SAAS,6BAA6B;AAOlC,SAKE,KALF;AAJG,IAAM,mBAAkD,CAAC,EAAE,QAAQ,MAAM;AAC9E,QAAM,mBAAmB,kBAAkB,WAAW,OAAO,GAAG,cAAc,CAAC;AAE/E,SACE;AAAA,IAAC;AAAA;AAAA,MACC,WAAU;AAAA,MACV,SAAS;AAAA,MACT,IAAI,EAAE,YAAY,SAAS;AAAA,MAE3B;AAAA,4BAAC,yBAAsB,SAAkB,MAAM,IAAI;AAAA,QACnD,oBAAC,WAAQ,OAAO,SACd;AAAA,UAAC;AAAA;AAAA,YACC,SAAQ;AAAA,YACR,IAAI;AAAA,cACF,OAAO;AAAA,cACP,YAAY;AAAA,YACd;AAAA,YAEC;AAAA;AAAA,QACH,GACF;AAAA;AAAA;AAAA,EACF;AAEJ;;;ACvBA,SAAS,4BAA4B;;;ACPrC,SAAS,uBAAuB;AAIzB,IAAM,yBAAyB,gBAAsC;;;ACF5E,SAAgB,eAAe;;;ACF/B,SAAS,kBAAkB,yBAAyB;AAEpD;AAAA,EACE;AAAA,EAAiB;AAAA,EAAW;AAAA,OACvB;AAEP,IAAM,wBAAwB;AAEvB,IAAM,sBAAsB,CAAC,QAA2B,WAAW,uBAAuB,QAAQ,UAAU;AACjH,QAAM,CAAC,cAAc,eAAe,IAAI,SAAqC,IAAI;AACjF,QAAM,CAAC,OAAO,QAAQ,IAAI,SAAgB;AAE1C,YAAU,MAAM;AACd,QAAI,YAAY;AAEhB,UAAM,aAAa,YAAY;AAC7B,UAAI,iBAAiB,MAAM,GAAG;AAC5B,YAAI;AACF,gBAAM,QAAQ,MAAM,OAAO,aAAa;AAExC,cAAI,WAAW;AACb,4BAAgB,MAAM;AACpB,8BAAgB,CAAC,kBAAkB;AACjC,oBAAI,kBAAkB,aAAa,GAAG;AACpC,yBAAO;AAAA,gBACT;AACA,oBACE,iBAAiB,KAAK,KAAK,gBAAgB,CAAC,EAAE,UAAU,MAAM,CAAC,EAAE,OACjE;AACA,yBAAO;AAAA,gBACT;AACA,uBAAO;AAAA,cACT,CAAC;AAAA,YACH,CAAC;AAAA,UACH;AAAA,QACF,SAAS,KAAK;AACZ,0BAAgB,MAAM;AACpB,qBAAS,GAAY;AAAA,UACvB,CAAC;AAAA,QACH;AAAA,MACF;AAAA,IACF;AAGA,SAAK,WAAW;AAGhB,UAAM,KAAK,YAAY,MAAM;AAC3B,UAAI,CAAC,OAAO;AACV,aAAK,WAAW;AAAA,MAClB;AAAA,IACF,GAAG,QAAQ;AAEX,WAAO,MAAM;AACX,kBAAY;AACZ,oBAAc,EAAE;AAAA,IAClB;AAAA,EACF,GAAG,CAAC,QAAQ,UAAU,KAAK,CAAC;AAE5B,SAAO,CAAC,cAAc,KAAK;AAC7B;;;AD7BI,gBAAAA,YAAA;AAvBG,IAAM,2BAA2B;AAOjC,IAAM,0BAAkE,CAAC;AAAA,EAC9E;AAAA,EAAe;AAAA,EAAQ;AACzB,MAAM;AACJ,QAAM,EAAE,SAAS,IAAI,QAAQ,MAAM,iBAAiB,EAAE,UAAU,yBAAyB,GAAG,CAAC,aAAa,CAAC;AAC3G,QAAM,CAAC,cAAc,iBAAiB,IAAI,oBAAoB,QAAQ,QAAQ;AAE9E,QAAM,QAA8B,QAAQ,OAAO;AAAA,IACjD,OAAO;AAAA,IACP,aAAa,eAAe,CAAC,EAAE;AAAA,IAC/B,OAAO,eAAe,CAAC,EAAE;AAAA,IACzB,OAAO;AAAA,IACP;AAAA,IACA,UAAU;AAAA,EACZ,IAAI,CAAC,cAAc,mBAAmB,aAAa,CAAC;AAEpD,SACE,gBAAAA,KAAC,0BAAuB,OACrB,UACH;AAEJ;;;AEnCA,SAAS,oBAAoB;AAKtB,IAAM,4BAA4B,CAAC,WAAW,SAAS,aAAmC,wBAAwB,mBAAmB,QAAQ;;;ACCpJ,SAAS,uBAAuB;;;ACAhC,SAAS,6BAA6B;;;ACEtC,SAAS,8BAA8B;;;ACDvC,SAAS,iCAAiC;;;ACP1C,SAAS,mBAAmB;AAE5B,SAAS,sBAAsB;AAKxB,IAAM,8BAA8B,OAAO,SAAqB,YAAwF;AAC7J,QAAM,UAAgD,CAAC;AACvD,aAAW,QAAQ,SAAS;AAC1B,UAAM,CAAC,SAAS,MAAM,QAAQ,IAAI;AAClC,UAAM,eAAe,MAAM,eAAe,KAAK,QAAQ;AACvD,UAAM,YAAY,MAAM,eAAe,KAAK,OAAO;AACnD,QAAI,YAAY,SAAS,MAAM;AAC7B,iBAAW,CAAC,IAAI,MAAM,KAAK,OAAO,QAAQ,SAAS,SAAS,GAAG;AAC7D,gBAAQ,KAAK;AAAA,UACX,QAAQ,YAAY,MAAM;AAAA,UAC1B;AAAA,UACA,aAAa,QAAQ;AAAA,UACrB,MAAM,SAAS;AAAA,UACf,WAAW,QAAQ;AAAA,UACnB,KAAK,OAAO,WAAW;AAAA,UACvB;AAAA,UACA;AAAA,UACA,QAAQ,MAAM;AAAA,UACd,OAAO;AAAA,UACP,MAAM;AAAA,QACR,CAAC;AAAA,MACH;AAAA,IACF,OAAO;AACL,cAAQ,KAAK;AAAA,QACX,QAAQ,YAAY,SAAS,UAAU,OAAO,CAAC;AAAA,QAC/C;AAAA,QACA,aAAa,QAAQ;AAAA,QACrB,MAAM,SAAS;AAAA,QACf,KAAK,OAAO,WAAW;AAAA,QACvB,WAAW,QAAQ;AAAA,QACnB,IAAI;AAAA,QACJ;AAAA,QACA,QAAQ,MAAM;AAAA,QACd,OAAO;AAAA,QACP,MAAM;AAAA,MACR,CAAC;AAAA,IACH;AAAA,EACF;AACA,SAAO;AACT;;;AC9CA,SAAS,kBAAkB;AAC3B,SAAS,mBAAmB;;;ACD5B;AAAA,EACE,eAAAC;AAAA,EAAa;AAAA,EAAO;AAAA,OACf;AAIA,IAAM,kBAAkB,CAAC,SAAqB,YAA6D;AAChH,QAAM,uBAAuB,SAAS,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,QAAQ,MAAM;AAC3E,WAAO,IAAIA,aAAY,SAAS,UAAU,OAAO,KAAK,MAAM,CAAC,CAAC;AAAA,EAChE,GAAG,EAAE;AAEL,QAAM,mBAAmB,SAAS,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,QAAQ,MAAM;AACvE,WAAQ,SAAS,SAAS,UAAW,IAAI,OAAO,OAAO,SAAS,SAAS,EAAE,OAAO,CAACC,IAAG,MAAMA,MAAK,MAAM,CAAC,IAAID,aAAY,CAAC,IAAI,KAAK,EAAE,IAAI;AAAA,EAC1I,GAAG,EAAE;AACL,SAAO,CAAC,sBAAsB,gBAAgB;AAChD;;;ACfA,SAAS,UAAU,iBAAiB;AAMpC;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EAAiB;AAAA,EAAqB;AAAA,OACjC;AAEA,IAAM,eAAe,OAAO,aAA0B,oBAAwD;AACnH,QAAM,UAAU,gBAAgB,KAAK,CAAAE,aAAWA,SAAQ,OAAO,WAAW;AAC1E,QAAM,kBAAkB,SAAS,SAAS,MAAM,2BAA2B,WAAW,EAAE;AAExF,QAAM,eAA6B;AAAA,IACjC,KAAK;AAAA,MACH,UAAU;AAAA,MACV,KAAK,GAAG,gBAAgB,GAAG;AAAA,IAC7B;AAAA,EACF;AAEA,QAAM,mBAAmB,oBAAoB,WAAW;AAExD,QAAM,UAAU,UAAU,eAAe,IACrC,MAAM,yBAAyB,aAAa,cAAc,iBAAiB,gBAAgB,IAC3F,MAAM,yBAAyB,aAAa,cAAc,gBAAgB;AAE9E,SAAO,MAAM,QAAQ,YAA8B,iBAAiB;AACtE;;;AC5BO,IAAM,mBAAmB,CAAC,YAAiD;AAEhF,MAAI,QAAQ,WAAW,EAAG,QAAO;AACjC,QAAM,eAAe,QAAQ,IAAI,CAAC,CAAC,OAAO,MAAM,QAAQ,KAAK;AAC7D,QAAM,MAAM,KAAK,IAAI,GAAG,YAAY;AACpC,SAAO,KAAK,IAAI,MAAM,GAAG,CAAC;AAC5B;;;AHEO,IAAM,2BAA2B,CAAC,SAAsB,QAAoB,UAAU,IAAI,YAA4B,YAAqB;AAChJ,SAAO,WAAW,YAAY;AAC5B,QAAI,YAAY,MAAM,KAAK,YAAY,OAAO,EAAG;AAGjD,QAAI,OAAO;AACX,QAAI;AACJ,UAAM,eAA4C,CAAC;AACnD,UAAM,qBAAqB,aAAa,WAAW,CAAC,IAAI;AAIxD,UAAM,UAAU,MAAM,OAAO,QAAQ,QAAQ,sBAAsB,SAAS,aAAa,EAAE,OAAO,WAAW,IAAI,CAAC,CAAC;AACnH,QAAI,QAAQ,SAAS,GAAG;AACtB,mBAAa,KAAK,GAAG,OAAO;AAE5B,kBAAY,iBAAiB,OAAO;AACpC,aAAO,OAAO,SAAS;AAErB,cAAM,cAAc,MAAM,OAAO,QAAQ,QAAQ,sBAAsB,SAAS,EAAE,OAAO,CAAC,oBAAoB,SAAS,EAAmB,CAAC;AAE3I,YAAI,YAAY,WAAW,EAAG;AAE9B,oBAAY,iBAAiB,WAAW;AACxC,qBAAa,KAAK,GAAG,WAAW;AAGhC;AAAA,MACF;AAAA,IACF;AACA,UAAM,mBAAmB,MAAM,4BAA4B,SAAS,YAAY;AAEhF,WAAO;AAAA,MACL,SAAS;AAAA,MACT,SAAS,gBAAgB,SAAS,YAAY;AAAA,MAC9C,WAAW,QAAQ;AAAA,IACrB;AAAA,EACF,GAAG,CAAC,SAAS,QAAQ,SAAS,YAAY,OAAO,CAAC;AACpD;;;AIhDA,SAAS,0BAA0B;AAG5B,IAAM,wBAAwB,MAA8B;AACjE,QAAM,EAAE,eAAe,IAAI,mBAAmB;AAC9C,SAAO,gBAAgB,YAAY;AACrC;;;ACNA,SAAS,sBAAAC,2BAA0B;AAG5B,IAAM,uBAAuB,MAA6B;AAC/D,QAAM,EAAE,eAAe,IAAIA,oBAAmB;AAC9C,SAAO,gBAAgB,YAAY;AACrC;;;ACNA,SAAS,sBAAAC,2BAA0B;AAG5B,IAAM,uBAAuB,MAA6B;AAC/D,QAAM,EAAE,eAAe,IAAIA,oBAAmB;AAC9C,SAAO,gBAAgB,YAAY;AACrC;;;ACLA,SAAS,cAAc,gCAAgC;;;ACAvD;AAAA,EACE,YAAAC;AAAA,EAAU;AAAA,EAAO;AAAA,EAAQ,aAAAC;AAAA,EAAW;AAAA,OAC/B;AAkBA,IAAM,gCAAN,MAAM,+BAA8B;AAAA,EACxB;AAAA,EACT,SAAS;AAAA,EAEjB,YAAY,QAAuC;AACjD,SAAK,UAAU;AAAA,EACjB;AAAA,EAEA,IAAI,MAAc;AAChB,WAAOD,UAAS,KAAK,YAAY,CAAC,EAAE,KAAK,MAAM,0CAA0C;AAAA,EAC3F;AAAA,EAEA,IAAI,MAAc;AAChB,WAAOA,UAAS,KAAK,YAAY,CAAC,EAAE,KAAK,MAAM,0CAA0C;AAAA,EAC3F;AAAA,EAEA,IAAI,iBAAkE;AACpE,WAAO,KAAK,QAAQ;AAAA,EACtB;AAAA,EAEA,IAAI,SAAwC;AAC1C,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,IAAI,cAAyC;AAC3C,WAAO,KAAK,OAAO;AAAA,EACrB;AAAA,EAEA,IAAI,SAAe;AACjB,WAAO,KAAK,OAAO;AAAA,EACrB;AAAA,EAEA,IAAI,SAAoB;AACtB,WAAO,KAAK,OAAO;AAAA,EACrB;AAAA,EAEA,OAAO,OAAO,QAAkF;AAC9F,WAAO,IAAI,+BAA8B,MAAM;AAAA,EACjD;AAAA,EAEA,MAAM,QAAuB;AAC3B,SAAK,SAAS;AACd,QAAI;AACF,YAAM,qBAAqB,MAAM,KAAK,OAAO,mBAAmB;AAChE,aAAOC,WAAU,kBAAkB,KAAK,KAAK,QAAQ;AACnD,cAAM,KAAK,WAAW,kBAAkB;AAExC,cAAM,MAAM,GAAI;AAAA,MAClB;AAAA,IACF,SAAS,OAAO;AACd,YAAM,KAAK,KAAK;AAChB,aAAO,KAAK,iBAAiB;AAAA,QAC3B,OAAO,iBAAiB,QAAQ,QAAQ,IAAI,MAAM,wBAAwB;AAAA,QAC1E,WAAW;AAAA,QACX,aAAa;AAAA,QACb,UAAU;AAAA,QACV,iBAAiB;AAAA,MACnB,CAAC,CAAC;AAAA,IACJ;AAAA,EACF;AAAA,EAEA,OAAyB;AACvB,SAAK,SAAS;AAAA,EAChB;AAAA,EAEA,MAAc,WAAW,aAAoC;AAC3D,QAAI,cAAc,KAAK,KAAK;AAC1B,YAAM,KAAK,KAAK;AAChB,aAAO,KAAK,iBAAiB;AAAA,QAC3B,OAAO,IAAI,MAAM,iBAAiB,WAAW,cAAc,KAAK,GAAG,EAAE;AAAA,QACrE,WAAW;AAAA,QACX;AAAA,QACA,UAAU;AAAA,QACV,iBAAiB,KAAK,MAAM;AAAA,MAC9B,CAAC,CAAC;AAAA,IACJ;AACA,QAAI,cAAc,KAAK,KAAK;AAC1B,aAAO,KAAK,iBAAiB;AAAA,QAC3B,WAAW;AAAA,QAAO;AAAA,QAAa,UAAU;AAAA,QAAK,iBAAiB;AAAA,MACjE,CAAC,CAAC;AACF;AAAA,IACF;AACA,QAAI,cAAc,KAAK,KAAK;AAC1B,YAAM,KAAK,kBAAkB,WAAW;AAAA,IAC1C;AAAA,EACF;AAAA,EAEA,MAAc,kBAAkB,aAAoC;AAClE,UAAM,kBAAkB,KAAK,MAAM;AACnC,UAAM,WAAW,KAAK,OAAQ,cAAc,KAAK,QAAQ,KAAK,MAAM,KAAK,OAAQ,GAAG;AAEpF,UAAM,KAAK,MAAM,KAAK,OAAO,YAAY,SAAS,KAAK,MAAM;AAC7D,QAAI,OAAO,EAAE,GAAG;AACd,WAAK,iBAAiB;AAAA,QACpB,WAAW;AAAA,QAAO;AAAA,QAAa;AAAA,QAAU;AAAA,MAC3C,CAAC;AAAA,IACH,OAAO;AACL,WAAK,iBAAiB;AAAA,QACpB,WAAW;AAAA,QAAM;AAAA,QAAa;AAAA,QAAU;AAAA,MAC1C,CAAC;AACD,YAAM,KAAK,KAAK;AAAA,IAClB;AAAA,EACF;AACF;;;AC5HA,SAAS,cAAAC,mBAAkB;AAE3B,SAAS,eAAAC,cAAa,qBAAAC,0BAAyB;AAE/C,SAAS,qBAAqB;AAC9B;AAAA,EACE,WAAAC;AAAA,EAAS;AAAA,EAAQ,YAAAC;AAAA,OACZ;AAEA,IAAM,oBAAoB,CAE/B,SAEA,QAEA,SAEA,UACG;AACH,QAAM,CAAC,gBAAgB,iBAAiB,IAAIA,UAAyB;AACrE,QAAM,CAAC,SAAS,UAAU,IAAIA,UAAS,KAAK;AAC5C,QAAM,CAAC,eAAe,gBAAgB,IAAIA,UAAgB;AAE1D,QAAM,CAAC,eAAe,gBAAgB,IAAIA,UAA6B,KAAK;AAC5E,MAAI,UAAU,eAAe;AAC3B,qBAAiB,KAAK;AACtB,sBAAkB,MAAS;AAC3B,qBAAiB,MAAS;AAC1B,eAAW,KAAK;AAAA,EAClB;AAEA,QAAM,oBAAoB,OAAgC,IAAI;AAC9D,EAAAJ,YAAW,YAAY;AACrB,QAAIC,aAAY,MAAM,KAAKA,aAAY,OAAO,EAAG;AAEjD,eAAW,IAAI;AACf,qBAAiB,MAAS;AAG1B,UAAM,iBAAiB,OAAO,QAAQ,QAAQ,eAAe,OAAO;AACpE,sBAAkB,UAAU;AAE5B,QAAI;AACF,YAAM,SAAS,MAAM;AAErB,UAAI,kBAAkB,YAAY,gBAAgB;AAChD,0BAAkB,MAAM;AACxB,mBAAW,KAAK;AAAA,MAClB;AAAA,IACF,SAAS,KAAK;AAEZ,UAAI,kBAAkB,YAAY,gBAAgB;AAChD,gBAAQ,MAAM,yBAAyB,GAAG;AAC1C,0BAAkB,MAAS;AAC3B,yBAAiB,GAAY;AAC7B,mBAAW,KAAK;AAAA,MAClB;AAAA,IACF;AAAA,EACF,GAAG,CAAC,SAAS,QAAQ,OAAO,CAAC;AAE7B,QAAM,gBAAgBE,SAAQ,MAAM;AAClC,QAAI,OAAO,mBAAmB,SAAU;AACxC,WAAO,IAAI,cAAc,gBAAgB;AAAA,MACvC,QAAQ;AAAA,MAAI,YAAY;AAAA,MAAI,eAAe;AAAA,MAAG,aAAa;AAAA,MAAG,QAAQ,UAAU;AAAA,IAClF,CAAC;AAAA,EACH,GAAG,CAAC,cAAc,CAAC;AAEnB,QAAM,sBAAsBA,SAAQ,MAAM;AACxC,WAAO,eAAe,aAAa;AAAA,EACrC,GAAG,CAAC,aAAa,CAAC;AAElB,QAAM,2BAA2BA,SAAQ,MAAM;AAC7C,WAAOD,mBAAkB,cAAc,IACnC,SACC,iBAAiB,kBAAsB,iBAAiB,KAAM,aAAa,eAAe,cAAc;AAAA,EAC/G,GAAG,CAAC,gBAAgB,aAAa,CAAC;AAElC,SAAO;AAAA,IACL;AAAA,IACA,mBAAmB;AAAA,IACnB;AAAA,IACA;AAAA,IACA,OAAO;AAAA,IACP;AAAA,EACF;AACF;;;ACrFA,SAAS,cAAAG,mBAAkB;AAE3B;AAAA,EACE,UAAAC;AAAA,EAAQ,aAAAC;AAAA,EAAW;AAAA,OACd;AACP,SAAS,kBAAAC,uBAAsB;AAI/B,SAAS,aAAAC,YAAW,YAAAC,iBAAgB;AAK7B,IAAM,4BAA4B,CAEvC,aAEA,aAEA,gBAEA,QAEA,WACG;AACH,QAAM,CAAC,QAAQ,SAAS,IAAIC,UAAmC;AAC/D,QAAM,sBAAsB,CAAC,cAAwC;AACnE,cAAU,SAAS;AACnB,qBAAiB,SAAS;AAAA,EAC5B;AAEA,QAAM,CAAC,+BAA+B,4BAA4B,IAAIC,YAAW,YAAY;AAC3F,UAAM,YAAYC,WAAU,MAAM;AAClC,QAAI,eAAe,QAAQ;AACzB,YAAM,OAAO,YAAa,MAAM,OAAO,qBAAqB,WAAW,IAAK,MAAMC,gBAAe,KAAK,YAAY,CAAC,CAAC;AACpH,UAAI,OAAO,IAAI,GAAG;AAChB,YAAI,aAAaD,WAAU,WAAW,EAAG,aAAY,IAAI;AACzD,cAAM,SAAwC;AAAA,UAC5C,gBAAgB;AAAA,UAChB;AAAA,UACA,QAAQ;AAAA,UACR;AAAA,QACF;AACA,cAAM,WAAW,MAAM,8BAA8B,OAAO,MAAM;AAClE,cAAM,SAAS,MAAM;AACrB,eAAO;AAAA,MACT;AACA,YAAM,IAAI,MAAM,mDAAmD;AAAA,IACrE;AAAA,EACF,GAAG,CAAC,aAAa,QAAQ,MAAM,CAAC;AAEhC,EAAAE,WAAU,MAAM;AACd,WAAO,MAAM;AACX,UAAI,+BAA+B;AAEjC,QAAAC,QAAO,8BAA8B,KAAK,CAAC;AAAA,MAC7C;AAAA,IACF;AAAA,EACF,GAAG,CAAC,6BAA6B,CAAC;AAElC,SAAO,EAAE,QAAQ,6BAA6B;AAChD;;;ACxDA,SAAS,yBAAyB;;;ACLlC,SAAS,cAAAC,mBAAkB;AAC3B,SAAS,oBAAAC,yBAAwB;AAM1B,IAAM,kBAAkB,CAAC,UAAU,GAAG,WACQ;AACnD,SAAOC,YAAW,YAAY;AAC5B,QAAI,CAACC,kBAAiB,MAAM,KAAK,WAAW,GAAG;AAC7C;AAAA,IACF;AACA,WAAO,MAAM,OAAO,aAAa;AAAA,EACnC,GAAG,CAAC,QAAQ,OAAO,CAAC;AACtB;AAEO,IAAM,6BAA6B,CAAC,UAAU,MACA;AACnD,QAAM,SAAS,qBAAqB;AACpC,SAAOD,YAAW,YAAY;AAC5B,QAAI,CAACC,kBAAiB,MAAM,KAAK,WAAW,GAAG;AAC7C;AAAA,IACF;AACA,WAAO,MAAM,OAAO,aAAa;AAAA,EACnC,GAAG,CAAC,QAAQ,OAAO,CAAC;AACtB;;;AC3BA,SAAS,eAAAC,oBAAmB;AAE5B,SAAS,wBAAwB;AACjC,SAAS,WAAAC,gBAAe;AAEjB,IAAM,aAAa,CAAC,OAA2B;AACpD,QAAM,UAAUA,SAAQ,MAAM;AAC5B,QAAID,aAAY,EAAE,EAAG;AACrB,WAAO,IAAI,iBAAiB,EAAE;AAAA,EAChC,GAAG,CAAC,EAAE,CAAC;AAEP,SAAO;AACT;;;ACZA,SAAS,cAAAE,mBAAkB;AAE3B;AAAA,EACE;AAAA,OACK;AAEA,IAAM,YAAY,CAAC,WAA2B,YAA8B;AACjF,SAAOA,YAAkC,YAAY,UAAU,MAAM,gBAAgB,OAAO,EAAE,QAAQ,CAAC,IAAI,QAAW,CAAC,OAAO,CAAC;AACjI;;;ACRA,SAAS,cAAAC,mBAAkB;AAC3B;AAAA,EACE,SAAAC;AAAA,EAAO,aAAAC;AAAA,EAAW,eAAAC;AAAA,OACb;AAEP;AAAA,EACE,4BAAAC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AACP,SAAS,aAAAC,YAAW,YAAAC,iBAAgB;AAEpC,IAAM,WAAW;AAEjB,IAAM,mBAAmB,GAAG,aAAa,GAAG;AAC5C,IAAM,sBAAsB,GAAG,gBAAgB,GAAG;AAE3C,IAAM,mBAAmB,MAAM;AACpC,QAAM,kBAAkB,YAAY,gBAAgB;AACpD,SAAO;AACT;AAEO,IAAM,sBAAsB,MAAM;AACvC,QAAM,gBAAgB,YAAY,mBAAmB;AACrD,SAAO;AACT;AAEO,IAAM,cAAc,CAAC,aAAsB;AAChD,QAAM,CAAC,iBAAiB,kBAAkB,IAAIA,UAAS,KAAK;AAC5D,QAAM,CAAC,OAAO,QAAQ,IAAIA,UAAgB;AAE1C,QAAM,CAAC,MAAM,IAAIN,YAAW,YAAY;AACtC,QAAIG,aAAY,QAAQ,EAAG;AAE3B,UAAM,UAAU,MAAMC,0BAAyB,UAAU,EAAE,KAAK,EAAE,UAAU,QAAQ,KAAK,SAAS,EAAE,CAAC;AAErG,UAAMG,UAAS,MAAM,QAAQ,YAA8B,gBAAgB;AAC3E,WAAOA;AAAA,EACT,GAAG,CAAC,QAAQ,CAAC;AAEb,EAAAF,WAAU,MAAM;AACd,QAAIF,aAAY,MAAM,EAAG;AAEzB,UAAM,YAAY;AAChB,eAAS,MAAS;AAClB,aAAO,CAAC,iBAAiB;AACvB,YAAI;AACF,gBAAM,QAAQ,MAAM,OAAO,aAAa;AACxC,6BAAmBD,WAAU,KAAK,CAAC;AAAA,QACrC,SAAS,KAAK;AACZ,mBAAS,GAAY;AACrB,6BAAmB,KAAK;AAAA,QAC1B;AACA,cAAMD,OAAM,QAAQ;AAAA,MACtB;AAAA,IACF,GAAG;AAAA,EACL,GAAG,CAAC,iBAAiB,MAAM,CAAC;AAE5B,SAAO,EAAE,iBAAiB,MAAM;AAClC;;;AC5DA,SAAoB,UAAAO,eAAc;AAClC,SAAS,kBAAAC,uBAAsB;AAI/B;AAAA,EACE;AAAA,EACA;AAAA,EAA+B;AAAA,EAAuB;AAAA,OACjD;AAUA,IAAM,qBAAN,cAAiC,iBAAiB;AAAA,EAC7C;AAAA,EAEV,MAAe,aAAa,MAAY,OAA4D;AAClG,UAAM,SAAS,MAAM,MAAM,aAAa,MAAM,KAAK;AACnD,WAAO,MAAM,QAAQ,IAAI,OAAO,IAAI,OAAO,UAAU;AACnD,YAAM,YAAY,MAAM,oBAAoB,OAAO,KAAK,cAAc;AACtE,aAAO,UAAU,CAAC;AAAA,IACpB,CAAC,CAAC;AAAA,EACJ;AAAA,EAEA,MAAe,eAAe,aAA6B,OAA4D;AACrH,UAAM,SAAS,MAAM,MAAM,eAAe,aAAa,KAAK;AAC5D,WAAO,MAAM,QAAQ,IAAI,OAAO,IAAI,OAAO,UAAU;AACnD,YAAM,YAAY,MAAM,oBAAoB,OAAO,KAAK,cAAc;AACtE,aAAO,UAAU,CAAC;AAAA,IACpB,CAAC,CAAC;AAAA,EACJ;AAAA,EAEA,MAAe,gBAAgB;AAC7B,UAAM,MAAM,cAAc;AAC1B,SAAK,iBAAiB,MAAM,KAAK,QAAQ,eAA+B,qBAAqB;AAAA,EAC/F;AAAA,EAEA,MAAe,eAAe,QAAgB;AAC5C,UAAM,WAAW,MAAM,MAAM,eAAe,MAAM;AAClD,UAAM,YAAY,MAAM,8BAA8B,QAAQ,UAAU,KAAK,cAAc;AAC3F,WAAO,UAAU,CAAC;AAAA,EACpB;AAAA,EAEA,MAAe,kBAAkB,MAAmE;AAClG,UAAM,cAAc,MAAM,MAAM,YAAY,OAAO,IAAI;AACvD,QAAI,CAAC,KAAK,gBAAgB;AACxB,aAAO,cACH,CAAC,MAAMA,gBAAe,YAAY,YAAY,CAAC,CAAC,GAAG,MAAMA,gBAAe,YAAY,YAAY,CAAC,CAAC,CAAC,IACnG;AAAA,IACN;AAEA,QAAID,QAAO,WAAW,GAAG;AACvB,aAAO;AAAA,IACT;AAEA,UAAM,eAAe,MAAMC,gBAAe,YAAY,YAAY,CAAC,CAAC;AACpE,UAAM,UAAU,MAAMA,gBAAe,YAAY,YAAY,CAAC,CAAC;AAC/D,UAAM,YAAY,MAAM,oBAAoB,CAAC,cAAc,OAAO,GAAG,KAAK,cAAc;AACxF,WAAO,UAAU,CAAC;AAAA,EACpB;AACF;",
|
|
6
6
|
"names": ["jsx", "hexToBigInt", "a", "network", "useProvidedGateway", "useProvidedGateway", "assertEx", "isDefined", "usePromise", "isUndefined", "isUndefinedOrNull", "useMemo", "useState", "usePromise", "forget", "isDefined", "PayloadBuilder", "useEffect", "useState", "useState", "usePromise", "isDefined", "PayloadBuilder", "useEffect", "forget", "usePromise", "isDefinedNotNull", "usePromise", "isDefinedNotNull", "isUndefined", "useMemo", "usePromise", "usePromise", "delay", "isDefined", "isUndefined", "basicRemoteViewerLocator", "useEffect", "useState", "viewer", "isNull", "PayloadBuilder"]
|
|
7
7
|
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import type { XyoAddress } from '@xyo-network/
|
|
1
|
+
import type { XyoAddress } from '@xyo-network/sdk-js';
|
|
2
2
|
import type { AccountBalanceHistoryItem, AttoXL1 } from '@xyo-network/xl1-sdk';
|
|
3
3
|
export declare const balanceForRange: (address: XyoAddress, results: AccountBalanceHistoryItem[]) => [AttoXL1, AttoXL1];
|
|
4
4
|
//# sourceMappingURL=balanceForRange.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"balanceForRange.d.ts","sourceRoot":"","sources":["../../../src/lib/balanceForRange.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"balanceForRange.d.ts","sourceRoot":"","sources":["../../../src/lib/balanceForRange.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAA;AACrD,OAAO,KAAK,EAAE,yBAAyB,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAA;AAE9E,eAAO,MAAM,eAAe,GAAI,SAAS,UAAU,EAAE,SAAS,yBAAyB,EAAE,KAAG,CAAC,OAAO,EAAE,OAAO,CAS5G,CAAA"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@xyo-network/react-chain-provider",
|
|
3
|
-
"version": "3.0.
|
|
3
|
+
"version": "3.0.1",
|
|
4
4
|
"description": "XYO Layer One API",
|
|
5
5
|
"homepage": "https://xylabs.com",
|
|
6
6
|
"bugs": {
|
|
@@ -60,41 +60,45 @@
|
|
|
60
60
|
"@xylabs/react-error": "^9.1.2",
|
|
61
61
|
"@xylabs/react-promise": "^9.1.2",
|
|
62
62
|
"@xylabs/react-shared": "^9.1.2",
|
|
63
|
-
"@xylabs/react-theme": "^9.1.2",
|
|
64
63
|
"@xylabs/sdk-js": "^6.1.3",
|
|
64
|
+
"@xylabs/sdk-react": "^9.1.2",
|
|
65
65
|
"@xylabs/threads": "^6.1.3",
|
|
66
|
-
"@xylabs/toolchain": "~8.
|
|
67
|
-
"@xylabs/tsconfig": "~8.
|
|
68
|
-
"@xylabs/tsconfig-dom": "~8.
|
|
69
|
-
"@xylabs/tsconfig-react": "~8.
|
|
70
|
-
"@xyo-network/address": "^6.1.1",
|
|
66
|
+
"@xylabs/toolchain": "~8.3.0",
|
|
67
|
+
"@xylabs/tsconfig": "~8.3.0",
|
|
68
|
+
"@xylabs/tsconfig-dom": "~8.3.0",
|
|
69
|
+
"@xylabs/tsconfig-react": "~8.3.0",
|
|
71
70
|
"@xyo-network/sdk-js": "^6.1.0",
|
|
72
71
|
"@xyo-network/sdk-protocol-js": "~6.1.1",
|
|
73
|
-
"@xyo-network/xl1-blockies": "~3.0",
|
|
74
|
-
"@xyo-network/xl1-react-client-sdk": "~3.0",
|
|
75
|
-
"@xyo-network/xl1-sdk": "
|
|
72
|
+
"@xyo-network/xl1-blockies": "~3.0.6",
|
|
73
|
+
"@xyo-network/xl1-react-client-sdk": "~3.0.6",
|
|
74
|
+
"@xyo-network/xl1-sdk": "^3.0.6",
|
|
76
75
|
"ajv": "^8.20.0",
|
|
77
76
|
"async-mutex": "^0.5.0",
|
|
77
|
+
"clsx": "^2.1.1",
|
|
78
78
|
"cosmiconfig": "^9.0.2",
|
|
79
79
|
"debug": "~4.4.3",
|
|
80
80
|
"eslint": "^10.5.0",
|
|
81
|
-
"ethers": "^6.
|
|
81
|
+
"ethers": "^6.17.0",
|
|
82
82
|
"hash-wasm": "~4.12.0",
|
|
83
83
|
"idb": "^8.0.3",
|
|
84
84
|
"lru-cache": "^11.5.1",
|
|
85
|
+
"md5": "^2.3.0",
|
|
86
|
+
"numeral": "^2.0.6",
|
|
85
87
|
"observable-fns": "~0.6.1",
|
|
86
|
-
"query-string": "
|
|
88
|
+
"query-string": "^9.4.0",
|
|
87
89
|
"react": "^19.2.7",
|
|
88
90
|
"react-dom": "^19.2.7",
|
|
89
91
|
"react-router-dom": "^7.18.0",
|
|
90
92
|
"storybook": "^10.4.6",
|
|
91
93
|
"typescript": "~6.0.3",
|
|
92
|
-
"uuid": "~14.0.
|
|
94
|
+
"uuid": "~14.0.1",
|
|
95
|
+
"viem": "^2.53.1",
|
|
93
96
|
"vite": "^8.0.16",
|
|
94
97
|
"vitest": "^4.1.9",
|
|
95
98
|
"webextension-polyfill": "^0.12.0",
|
|
96
99
|
"zod": "~4.4.3",
|
|
97
|
-
"
|
|
100
|
+
"zustand": "^5.0.14",
|
|
101
|
+
"@xyo-network/react-chain-shared": "~3.0.1"
|
|
98
102
|
},
|
|
99
103
|
"peerDependencies": {
|
|
100
104
|
"@bitauth/libauth": "~3.0",
|
|
@@ -112,14 +116,12 @@
|
|
|
112
116
|
"@xylabs/eth-address": "^6.1",
|
|
113
117
|
"@xylabs/geo": "^6.0",
|
|
114
118
|
"@xylabs/pixel": "^6.1",
|
|
115
|
-
"@xylabs/react-button": "^9.1",
|
|
116
119
|
"@xylabs/react-error": "^9.1",
|
|
117
120
|
"@xylabs/react-promise": "^9.1",
|
|
118
121
|
"@xylabs/react-shared": "^9.1",
|
|
119
|
-
"@xylabs/react-theme": "^9.1",
|
|
120
122
|
"@xylabs/sdk-js": "^6.0",
|
|
123
|
+
"@xylabs/sdk-react": "^9.1",
|
|
121
124
|
"@xylabs/threads": "^6.1",
|
|
122
|
-
"@xyo-network/address": "^6.0",
|
|
123
125
|
"@xyo-network/sdk-js": "^6.0",
|
|
124
126
|
"@xyo-network/sdk-protocol-js": "~6.1",
|
|
125
127
|
"@xyo-network/xl1-blockies": "^3.0",
|
|
@@ -127,20 +129,25 @@
|
|
|
127
129
|
"@xyo-network/xl1-sdk": "^3.0",
|
|
128
130
|
"ajv": "^8.20",
|
|
129
131
|
"async-mutex": "^0.5",
|
|
132
|
+
"clsx": "^2.1",
|
|
130
133
|
"cosmiconfig": "^9.0",
|
|
131
134
|
"debug": "~4.4",
|
|
132
135
|
"ethers": "^6.16",
|
|
133
136
|
"hash-wasm": "~4.12",
|
|
134
137
|
"idb": "^8.0",
|
|
135
138
|
"lru-cache": "^11.3",
|
|
139
|
+
"md5": "^2.3",
|
|
140
|
+
"numeral": "^2.0",
|
|
136
141
|
"observable-fns": "~0.6",
|
|
137
|
-
"query-string": "
|
|
142
|
+
"query-string": "^9.3",
|
|
138
143
|
"react": "^19.2",
|
|
139
144
|
"react-dom": "^19.2",
|
|
140
145
|
"react-router-dom": "^7.15",
|
|
141
146
|
"uuid": "~14.0",
|
|
147
|
+
"viem": "^2.48",
|
|
142
148
|
"webextension-polyfill": "^0.12",
|
|
143
|
-
"zod": "~4.4"
|
|
149
|
+
"zod": "~4.4",
|
|
150
|
+
"zustand": "^5.0"
|
|
144
151
|
},
|
|
145
152
|
"engines": {
|
|
146
153
|
"node": ">=24"
|