@fivenorth/loop-sdk 0.9.0 → 0.11.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/README.md +16 -7
- package/dist/connection.d.ts +40 -0
- package/dist/connection.d.ts.map +1 -0
- package/dist/errors.d.ts +13 -0
- package/dist/errors.d.ts.map +1 -0
- package/dist/extensions/usdc/index.d.ts +11 -0
- package/dist/extensions/usdc/index.d.ts.map +1 -0
- package/dist/extensions/usdc/types.d.ts +25 -0
- package/dist/extensions/usdc/types.d.ts.map +1 -0
- package/dist/index.d.ts +53 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +391 -260
- package/dist/provider.d.ts +61 -0
- package/dist/provider.d.ts.map +1 -0
- package/dist/server/index.d.ts +23 -0
- package/dist/server/index.d.ts.map +1 -0
- package/dist/server/index.js +35344 -0
- package/dist/server/signer.d.ts +15 -0
- package/dist/server/signer.d.ts.map +1 -0
- package/dist/server.d.ts +2 -0
- package/dist/server.d.ts.map +1 -0
- package/dist/session.d.ts +39 -0
- package/dist/session.d.ts.map +1 -0
- package/dist/types.d.ts +116 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/wallet.d.ts +10 -0
- package/dist/wallet.d.ts.map +1 -0
- package/package.json +17 -3
package/README.md
CHANGED
|
@@ -142,6 +142,7 @@ try {
|
|
|
142
142
|
const result = await provider.submitTransaction(damlCommand, {
|
|
143
143
|
// Optional: show a custom message in the wallet prompt
|
|
144
144
|
message: 'Transfer 10 CC to RetailStore',
|
|
145
|
+
estimateTraffic: true, // optional: return estimated traffic in submission response
|
|
145
146
|
});
|
|
146
147
|
console.log('Transaction successful:', result);
|
|
147
148
|
} catch (error) {
|
|
@@ -186,19 +187,19 @@ try {
|
|
|
186
187
|
```javascript
|
|
187
188
|
await loop.wallet.transfer(
|
|
188
189
|
'receiver::fingerprint',
|
|
189
|
-
'5',
|
|
190
|
+
'5',
|
|
190
191
|
{
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
instrument_id: 'Amulet', // optional
|
|
192
|
+
instrument_admin: 'issuer::fingerprint', // optional: DSO (default)
|
|
193
|
+
instrument_id: 'Amulet', // optional: Amulet (default)
|
|
194
194
|
},
|
|
195
195
|
{
|
|
196
|
-
//
|
|
197
|
-
|
|
196
|
+
message: 'Send 5 CC to Alice', // optional: show a custom message in the wallet prompt
|
|
197
|
+
memo: 'optional memo for the transfer', // optional: stored as transfer metadata
|
|
198
198
|
executionMode: 'wait', // optional: 'async' (default) or 'wait'
|
|
199
199
|
requestedAt: new Date().toISOString(), // optional
|
|
200
200
|
executeBefore: new Date(Date.now() + 24*60*60*1000).toISOString(), // optional
|
|
201
201
|
requestTimeout: 5 * 60 * 1000, // optional (ms), defaults to 5 minutes
|
|
202
|
+
estimateTraffic: true, // optional: return estimated traffic in submission response
|
|
202
203
|
},
|
|
203
204
|
);
|
|
204
205
|
```
|
|
@@ -206,7 +207,6 @@ await loop.wallet.transfer(
|
|
|
206
207
|
Notes:
|
|
207
208
|
- You must have spendable holdings for the specified instrument (admin + id). If left blank, the SDK defaults to the native token.
|
|
208
209
|
- The helper handles fetching holdings, building the transfer factory payload, and submitting via Wallet Connect.
|
|
209
|
-
- Requests time out after 5 minutes by default; override with `requestTimeout` in milliseconds.
|
|
210
210
|
|
|
211
211
|
Common instrument overrides (pass into the `instrument` argument above):
|
|
212
212
|
|
|
@@ -237,6 +237,15 @@ Notes:
|
|
|
237
237
|
|
|
238
238
|
Coming soon
|
|
239
239
|
|
|
240
|
+
## Loop Server Signing API
|
|
241
|
+
|
|
242
|
+
Loop SDK also supports a server-side signing flow. Instead of a wallet popup, your backend signs and submits transactions directly using the user's private key.
|
|
243
|
+
|
|
244
|
+
Example ideas:
|
|
245
|
+
- List pending transfers
|
|
246
|
+
- Accept a pending transfer
|
|
247
|
+
|
|
248
|
+
|
|
240
249
|
# Development Guide
|
|
241
250
|
|
|
242
251
|
This section is only if you want to actively develop the SDK itself. To use the SDK, follow the `#Usage Guide` section
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import type { Network, Account, Holding, TransferRequest, PreparedTransferPayload, ExchangeApiKeyResponse, TransactionPayload, PreparedSubmissionResponse, ExecuteSubmissionResquest } from './types';
|
|
2
|
+
import { SessionInfo } from './session';
|
|
3
|
+
export declare class Connection {
|
|
4
|
+
walletUrl: string;
|
|
5
|
+
apiUrl: string;
|
|
6
|
+
ws: WebSocket | null;
|
|
7
|
+
private network;
|
|
8
|
+
private ticketId;
|
|
9
|
+
private onMessageHandler;
|
|
10
|
+
private reconnectPromise;
|
|
11
|
+
private status;
|
|
12
|
+
constructor({ network, walletUrl, apiUrl }: {
|
|
13
|
+
network?: Network;
|
|
14
|
+
walletUrl?: string;
|
|
15
|
+
apiUrl?: string;
|
|
16
|
+
});
|
|
17
|
+
connectInProgress(): boolean;
|
|
18
|
+
getTicket(appName: string, sessionId: string, version: string): Promise<{
|
|
19
|
+
ticket_id: string;
|
|
20
|
+
}>;
|
|
21
|
+
getHolding(authToken: string): Promise<Holding[]>;
|
|
22
|
+
getActiveContracts(authToken: string, params?: {
|
|
23
|
+
templateId?: string;
|
|
24
|
+
interfaceId?: string;
|
|
25
|
+
}): Promise<any[]>;
|
|
26
|
+
prepareTransfer(authToken: string, params: TransferRequest): Promise<PreparedTransferPayload>;
|
|
27
|
+
verifySession(authToken: string): Promise<Account>;
|
|
28
|
+
connectWebSocket(ticketId: string, onMessage: (event: MessageEvent) => void): void;
|
|
29
|
+
reconnect(): Promise<void>;
|
|
30
|
+
exchangeApiKey({ publicKey, signature, epoch }: {
|
|
31
|
+
publicKey: string;
|
|
32
|
+
signature: string;
|
|
33
|
+
epoch: number;
|
|
34
|
+
}): Promise<ExchangeApiKeyResponse>;
|
|
35
|
+
prepareTransaction(session: SessionInfo, params: TransactionPayload): Promise<PreparedSubmissionResponse>;
|
|
36
|
+
executeTransaction(session: SessionInfo, params: ExecuteSubmissionResquest): Promise<PreparedSubmissionResponse>;
|
|
37
|
+
private websocketUrl;
|
|
38
|
+
private attachWebSocket;
|
|
39
|
+
}
|
|
40
|
+
//# sourceMappingURL=connection.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"connection.d.ts","sourceRoot":"","sources":["../src/connection.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACR,OAAO,EACP,OAAO,EACP,OAAO,EACP,eAAe,EACf,uBAAuB,EAEvB,sBAAsB,EACtB,kBAAkB,EAClB,0BAA0B,EAC1B,yBAAyB,EAC5B,MAAM,SAAS,CAAC;AAEjB,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AAGxC,qBAAa,UAAU;IACZ,SAAS,EAAE,MAAM,CAA4B;IAC7C,MAAM,EAAE,MAAM,CAA4B;IAC1C,EAAE,EAAE,SAAS,GAAG,IAAI,CAAQ;IACnC,OAAO,CAAC,OAAO,CAAmB;IAClC,OAAO,CAAC,QAAQ,CAAuB;IACvC,OAAO,CAAC,gBAAgB,CAAgD;IACxE,OAAO,CAAC,gBAAgB,CAA8B;IACtD,OAAO,CAAC,MAAM,CAA+D;gBAEjE,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,EAAE;QAAE,OAAO,CAAC,EAAE,OAAO,CAAC;QAAC,SAAS,CAAC,EAAE,MAAM,CAAC;QAAC,MAAM,CAAC,EAAE,MAAM,CAAA;KAAE;IAmCtG,iBAAiB,IAAI,OAAO;IAItB,SAAS,CAAC,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC;QAAE,SAAS,EAAE,MAAM,CAAA;KAAE,CAAC;IAoB9F,UAAU,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAgBjD,kBAAkB,CAAC,SAAS,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE;QAAE,UAAU,CAAC,EAAE,MAAM,CAAC;QAAC,WAAW,CAAC,EAAE,MAAM,CAAA;KAAE,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC;IAwB7G,eAAe,CAAC,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,eAAe,GAAG,OAAO,CAAC,uBAAuB,CAAC;IA4C7F,aAAa,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAmCxD,gBAAgB,CAAC,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC,KAAK,EAAE,YAAY,KAAK,IAAI;IAwB3E,SAAS,IAAI,OAAO,CAAC,IAAI,CAAC;IA+BpB,cAAc,CAAC,EAAC,SAAS,EAAE,SAAS,EAAE,KAAK,EAAC,EAAE;QAAC,SAAS,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAC,GAAG,OAAO,CAAC,sBAAsB,CAAC;IAqB3I,kBAAkB,CAAC,OAAO,EAAE,WAAW,EAAE,MAAM,EAAE,kBAAkB,GAAG,OAAO,CAAC,0BAA0B,CAAC;IAenG,kBAAkB,CAAC,OAAO,EAAE,WAAW,EAAE,MAAM,EAAE,yBAAyB,GAAG,OAAO,CAAC,0BAA0B,CAAC;IAwBtH,OAAO,CAAC,YAAY;IAKpB,OAAO,CAAC,eAAe;CAqC1B"}
|
package/dist/errors.d.ts
ADDED
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export declare class RequestTimeoutError extends Error {
|
|
2
|
+
constructor(timeout: number);
|
|
3
|
+
}
|
|
4
|
+
export declare class RejectRequestError extends Error {
|
|
5
|
+
constructor();
|
|
6
|
+
}
|
|
7
|
+
export declare class UnauthorizedError extends Error {
|
|
8
|
+
code?: string;
|
|
9
|
+
constructor(code?: string);
|
|
10
|
+
}
|
|
11
|
+
export declare function extractErrorCode(message: any): string | null;
|
|
12
|
+
export declare function isUnauthCode(code: string | null | undefined): code is string;
|
|
13
|
+
//# sourceMappingURL=errors.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../src/errors.ts"],"names":[],"mappings":"AAAA,qBAAa,mBAAoB,SAAQ,KAAK;gBAC9B,OAAO,EAAE,MAAM;CAG9B;AAED,qBAAa,kBAAmB,SAAQ,KAAK;;CAI5C;AAED,qBAAa,iBAAkB,SAAQ,KAAK;IACjC,IAAI,CAAC,EAAE,MAAM,CAAC;gBACT,IAAI,CAAC,EAAE,MAAM;CAI5B;AAID,wBAAgB,gBAAgB,CAAC,OAAO,EAAE,GAAG,GAAG,MAAM,GAAG,IAAI,CAQ5D;AAED,wBAAgB,YAAY,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,GAAG,IAAI,IAAI,MAAM,CAK5E"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { WithdrawOptions, UsdcBridgeExtension, WithdrawUsdcRequest, PreparedWithdrawPayload } from './types';
|
|
2
|
+
import type { Provider } from '../../provider';
|
|
3
|
+
import type { Connection } from '../../connection';
|
|
4
|
+
export declare class UsdcBridge implements UsdcBridgeExtension {
|
|
5
|
+
private getProvider;
|
|
6
|
+
constructor(getProvider: () => Provider | null);
|
|
7
|
+
private requireProvider;
|
|
8
|
+
withdrawalUSDCxToEthereum(recipient: string, amount: string | number, options?: WithdrawOptions): Promise<any>;
|
|
9
|
+
}
|
|
10
|
+
export declare function prepareUsdcWithdraw(connection: Connection, authToken: string, params: WithdrawUsdcRequest): Promise<PreparedWithdrawPayload>;
|
|
11
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/extensions/usdc/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,mBAAmB,EAAE,mBAAmB,EAAE,uBAAuB,EAA2B,MAAM,SAAS,CAAC;AAC3I,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAC/C,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAEnD,qBAAa,UAAW,YAAW,mBAAmB;IACpD,OAAO,CAAC,WAAW,CAAwB;gBAE/B,WAAW,EAAE,MAAM,QAAQ,GAAG,IAAI;IAI9C,OAAO,CAAC,eAAe;IAQvB,yBAAyB,CAAC,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,OAAO,CAAC,EAAE,eAAe,GAAG,OAAO,CAAC,GAAG,CAAC;CAwB/G;AAED,wBAAsB,mBAAmB,CAAC,UAAU,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,mBAAmB,GAAG,OAAO,CAAC,uBAAuB,CAAC,CAyBlJ"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
export type WithdrawUsdcRequest = {
|
|
2
|
+
recipient: string;
|
|
3
|
+
amount: string;
|
|
4
|
+
reference?: string;
|
|
5
|
+
};
|
|
6
|
+
export type PreparedWithdrawPayload = {
|
|
7
|
+
actAs: string[];
|
|
8
|
+
readAs: string[];
|
|
9
|
+
synchronizerId: string;
|
|
10
|
+
commands: any[];
|
|
11
|
+
disclosedContracts: any[];
|
|
12
|
+
packageIdSelectionPreference: string[];
|
|
13
|
+
};
|
|
14
|
+
export type ConnectWithdrawResponse = {
|
|
15
|
+
payload: PreparedWithdrawPayload;
|
|
16
|
+
};
|
|
17
|
+
export type WithdrawOptions = {
|
|
18
|
+
reference?: string;
|
|
19
|
+
requestTimeout?: number;
|
|
20
|
+
message?: string;
|
|
21
|
+
};
|
|
22
|
+
export interface UsdcBridgeExtension {
|
|
23
|
+
withdrawalUSDCxToEthereum(recipient: string, amount: string | number, options?: WithdrawOptions): Promise<any>;
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/extensions/usdc/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,mBAAmB,GAAG;IAChC,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,MAAM,MAAM,uBAAuB,GAAG;IACpC,KAAK,EAAE,MAAM,EAAE,CAAC;IAChB,MAAM,EAAE,MAAM,EAAE,CAAC;IACjB,cAAc,EAAE,MAAM,CAAC;IACvB,QAAQ,EAAE,GAAG,EAAE,CAAC;IAChB,kBAAkB,EAAE,GAAG,EAAE,CAAC;IAC1B,4BAA4B,EAAE,MAAM,EAAE,CAAC;CACxC,CAAC;AAEF,MAAM,MAAM,uBAAuB,GAAG;IACpC,OAAO,EAAE,uBAAuB,CAAC;CAClC,CAAC;AAEF,MAAM,MAAM,eAAe,GAAG;IAC5B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB,CAAC;AAEF,MAAM,WAAW,mBAAmB;IAClC,yBAAyB,CAAC,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,OAAO,CAAC,EAAE,eAAe,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;CAChH"}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { Provider } from "./provider";
|
|
2
|
+
import type { Network, Wallet, RunTransactionResponse } from "./types";
|
|
3
|
+
declare class LoopSDK {
|
|
4
|
+
private version;
|
|
5
|
+
private appName;
|
|
6
|
+
private connection;
|
|
7
|
+
private session;
|
|
8
|
+
private provider;
|
|
9
|
+
private openMode;
|
|
10
|
+
private requestSigningMode;
|
|
11
|
+
private popupWindow;
|
|
12
|
+
private redirectUrl?;
|
|
13
|
+
private onAccept;
|
|
14
|
+
private onReject;
|
|
15
|
+
private onTransactionUpdate;
|
|
16
|
+
private overlay;
|
|
17
|
+
wallet: Wallet;
|
|
18
|
+
constructor();
|
|
19
|
+
init({ appName, network, walletUrl, apiUrl, onAccept, onReject, onTransactionUpdate, options, }: {
|
|
20
|
+
appName: string;
|
|
21
|
+
network?: Network;
|
|
22
|
+
walletUrl?: string;
|
|
23
|
+
apiUrl?: string;
|
|
24
|
+
onAccept?: (provider: Provider) => void;
|
|
25
|
+
onReject?: () => void;
|
|
26
|
+
onTransactionUpdate?: (payload: RunTransactionResponse, message: any) => void;
|
|
27
|
+
options?: {
|
|
28
|
+
openMode?: "popup" | "tab";
|
|
29
|
+
requestSigningMode?: "popup" | "tab";
|
|
30
|
+
redirectUrl?: string;
|
|
31
|
+
};
|
|
32
|
+
}): void;
|
|
33
|
+
private loadSessionInfo;
|
|
34
|
+
autoConnect(): Promise<void>;
|
|
35
|
+
connect(): Promise<void>;
|
|
36
|
+
private handleWebSocketMessage;
|
|
37
|
+
getConnectUrl(): string;
|
|
38
|
+
private buildConnectUrl;
|
|
39
|
+
private buildDashboardUrl;
|
|
40
|
+
private openRequestUi;
|
|
41
|
+
private closePopupIfExists;
|
|
42
|
+
private openWallet;
|
|
43
|
+
private injectModalStyles;
|
|
44
|
+
private showQrCode;
|
|
45
|
+
private hideQrCode;
|
|
46
|
+
logout(): void;
|
|
47
|
+
private requireProvider;
|
|
48
|
+
private createProviderHooks;
|
|
49
|
+
}
|
|
50
|
+
export declare const loop: LoopSDK;
|
|
51
|
+
export * from "./extensions/usdc/types";
|
|
52
|
+
export * from "./types";
|
|
53
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAIA,OAAO,EAAqB,QAAQ,EAAE,MAAM,YAAY,CAAC;AAEzD,OAAO,KAAK,EAGX,OAAO,EAEP,MAAM,EACN,sBAAsB,EACtB,MAAM,SAAS,CAAC;AAIjB,cAAM,OAAO;IACZ,OAAO,CAAC,OAAO,CAAmB;IAElC,OAAO,CAAC,OAAO,CAAqB;IACpC,OAAO,CAAC,UAAU,CAA2B;IAC7C,OAAO,CAAC,OAAO,CAA4B;IAC3C,OAAO,CAAC,QAAQ,CAAyB;IACzC,OAAO,CAAC,QAAQ,CAA4B;IAC5C,OAAO,CAAC,kBAAkB,CAA4B;IACtD,OAAO,CAAC,WAAW,CAAuB;IAC1C,OAAO,CAAC,WAAW,CAAC,CAAS;IAE7B,OAAO,CAAC,QAAQ,CAA+C;IAC/D,OAAO,CAAC,QAAQ,CAA6B;IAC3C,OAAO,CAAC,mBAAmB,CAA0E;IACvG,OAAO,CAAC,OAAO,CAA+B;IACvC,MAAM,EAAE,MAAM,CAAC;;IAMtB,IAAI,CAAC,EACJ,OAAO,EACP,OAAO,EACP,SAAS,EACT,MAAM,EACN,QAAQ,EACR,QAAQ,EACR,mBAAmB,EACnB,OAAO,GACP,EAAE;QACF,OAAO,EAAE,MAAM,CAAC;QAChB,OAAO,CAAC,EAAE,OAAO,CAAC;QAClB,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,QAAQ,CAAC,EAAE,CAAC,QAAQ,EAAE,QAAQ,KAAK,IAAI,CAAC;QACxC,QAAQ,CAAC,EAAE,MAAM,IAAI,CAAC;QACtB,mBAAmB,CAAC,EAAE,CAAC,OAAO,EAAE,sBAAsB,EAAE,OAAO,EAAE,GAAG,KAAK,IAAI,CAAC;QAC9E,OAAO,CAAC,EAAE;YACT,QAAQ,CAAC,EAAE,OAAO,GAAG,KAAK,CAAC;YAC3B,kBAAkB,CAAC,EAAE,OAAO,GAAG,KAAK,CAAC;YACrC,WAAW,CAAC,EAAE,MAAM,CAAC;SACrB,CAAC;KACF;YAiCa,eAAe;IA6CvB,WAAW,IAAI,OAAO,CAAC,IAAI,CAAC;IA8B5B,OAAO;IA2Cb,OAAO,CAAC,sBAAsB;IA8DvB,aAAa,IAAI,MAAM;IAO9B,OAAO,CAAC,eAAe;IASvB,OAAO,CAAC,iBAAiB;IAOzB,OAAO,CAAC,aAAa;IAqBrB,OAAO,CAAC,kBAAkB;IAW1B,OAAO,CAAC,UAAU;IAuClB,OAAO,CAAC,iBAAiB;IAyIzB,OAAO,CAAC,UAAU;IAoFlB,OAAO,CAAC,UAAU;IAOlB,MAAM;IAQN,OAAO,CAAC,eAAe;IASvB,OAAO,CAAC,mBAAmB;CAe3B;AAED,eAAO,MAAM,IAAI,SAAgB,CAAC;AAClC,cAAc,yBAAyB,CAAC;AACxC,cAAc,SAAS,CAAC"}
|