@ecadlabs/tezosx-mcp 1.0.7 → 1.0.8
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/tools/bridge_execute_withdrawal.d.ts +27 -0
- package/dist/tools/bridge_execute_withdrawal.js +125 -0
- package/dist/tools/bridge_status.d.ts +25 -0
- package/dist/tools/bridge_status.js +155 -0
- package/dist/tools/bridge_to_etherlink.d.ts +25 -0
- package/dist/tools/bridge_to_etherlink.js +116 -0
- package/dist/tools/index.d.ts +68 -0
- package/dist/tools/index.js +6 -0
- package/dist/tools/recover_spender_funds.js +2 -2
- package/frontend/dist/assets/{index-BmltqixB.js → index-BbUbeppO.js} +2 -2
- package/frontend/dist/index.html +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import z from "zod";
|
|
2
|
+
import type { LiveConfig } from "../live-config.js";
|
|
3
|
+
export declare const createBridgeExecuteWithdrawalTool: (config: LiveConfig) => {
|
|
4
|
+
name: string;
|
|
5
|
+
config: {
|
|
6
|
+
title: string;
|
|
7
|
+
description: string;
|
|
8
|
+
inputSchema: z.ZodObject<{
|
|
9
|
+
outboxLevel: z.ZodOptional<z.ZodNumber>;
|
|
10
|
+
messageIndex: z.ZodOptional<z.ZodNumber>;
|
|
11
|
+
cementedCommitment: z.ZodOptional<z.ZodString>;
|
|
12
|
+
outputProof: z.ZodOptional<z.ZodString>;
|
|
13
|
+
}, z.z.core.$strip>;
|
|
14
|
+
annotations: {
|
|
15
|
+
readOnlyHint: boolean;
|
|
16
|
+
destructiveHint: boolean;
|
|
17
|
+
idempotentHint: boolean;
|
|
18
|
+
openWorldHint: boolean;
|
|
19
|
+
};
|
|
20
|
+
};
|
|
21
|
+
handler: (params: any) => Promise<{
|
|
22
|
+
content: {
|
|
23
|
+
type: "text";
|
|
24
|
+
text: string;
|
|
25
|
+
}[];
|
|
26
|
+
}>;
|
|
27
|
+
};
|
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
import axios from "axios";
|
|
2
|
+
import z from "zod";
|
|
3
|
+
import { ensureRevealed } from "./reveal_account.js";
|
|
4
|
+
const CONFIRMATIONS_TO_WAIT = 3;
|
|
5
|
+
const BRIDGE_CONFIG = {
|
|
6
|
+
mainnet: {
|
|
7
|
+
smartRollupAddress: "sr1Ghq66tYK9y3r8CC1Tf8i8m5nxh8nTvZEf",
|
|
8
|
+
},
|
|
9
|
+
shadownet: {
|
|
10
|
+
smartRollupAddress: "sr19fMYrr5C4qqvQqQrDSjtP31GcrWjodzvg",
|
|
11
|
+
},
|
|
12
|
+
};
|
|
13
|
+
// Default rollup node URLs (can be overridden via env)
|
|
14
|
+
const ROLLUP_NODE_URLS = {
|
|
15
|
+
mainnet: process.env.ETHERLINK_ROLLUP_NODE_MAINNET,
|
|
16
|
+
shadownet: process.env.ETHERLINK_ROLLUP_NODE_SHADOWNET,
|
|
17
|
+
};
|
|
18
|
+
const inputSchema = z.object({
|
|
19
|
+
// Option 1: provide outbox level + message index (requires rollup node access)
|
|
20
|
+
outboxLevel: z.number().optional().describe("The Tezos L1 block level of the outbox containing the withdrawal message. " +
|
|
21
|
+
"Used with messageIndex to auto-fetch the proof from the rollup node."),
|
|
22
|
+
messageIndex: z.number().optional().describe("The index of the message within the outbox level. Defaults to 0."),
|
|
23
|
+
// Option 2: provide pre-computed proof directly
|
|
24
|
+
cementedCommitment: z.string().optional().describe("The cemented commitment hash (src1...). Required if outputProof is provided directly."),
|
|
25
|
+
outputProof: z.string().optional().describe("The hex-encoded output proof. If provided along with cementedCommitment, skips rollup node query."),
|
|
26
|
+
});
|
|
27
|
+
async function fetchProofFromRollupNode(rollupNodeUrl, outboxLevel, messageIndex) {
|
|
28
|
+
const url = `${rollupNodeUrl}/global/block/head/helpers/proofs/outbox/${outboxLevel}/messages?index=${messageIndex}`;
|
|
29
|
+
try {
|
|
30
|
+
const { data } = await axios.get(url, { timeout: 30_000 });
|
|
31
|
+
return {
|
|
32
|
+
commitment: data.commitment,
|
|
33
|
+
proof: data.proof,
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
catch (error) {
|
|
37
|
+
const msg = error instanceof Error ? error.message : String(error);
|
|
38
|
+
throw new Error(`Failed to fetch outbox proof from rollup node at ${rollupNodeUrl}: ${msg}\n` +
|
|
39
|
+
`Ensure ETHERLINK_ROLLUP_NODE_MAINNET or ETHERLINK_ROLLUP_NODE_SHADOWNET env var is set to a valid rollup node URL.`);
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
async function getCementedCommitment(tezosRpcUrl, rollupAddress) {
|
|
43
|
+
const url = `${tezosRpcUrl}/chains/main/blocks/head/context/smart_rollups/smart_rollup/${rollupAddress}/last_cemented_commitment_hash_with_level`;
|
|
44
|
+
try {
|
|
45
|
+
const { data } = await axios.get(url, { timeout: 15_000 });
|
|
46
|
+
return { hash: data.hash, level: data.level };
|
|
47
|
+
}
|
|
48
|
+
catch (error) {
|
|
49
|
+
const msg = error instanceof Error ? error.message : String(error);
|
|
50
|
+
throw new Error(`Failed to get cemented commitment: ${msg}`);
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
export const createBridgeExecuteWithdrawalTool = (config) => ({
|
|
54
|
+
name: "tezos_bridge_execute_withdrawal",
|
|
55
|
+
config: {
|
|
56
|
+
title: "Execute Bridge Withdrawal",
|
|
57
|
+
description: "Executes a cemented outbox message on Tezos L1 to finalize a standard bridge withdrawal (Etherlink → Tezos). " +
|
|
58
|
+
"This can only be done after the commitment containing the withdrawal has been cemented (~15 days after initiation). " +
|
|
59
|
+
"Provide either outboxLevel + messageIndex (auto-fetches proof from rollup node) or cementedCommitment + outputProof directly. " +
|
|
60
|
+
"Requires ETHERLINK_ROLLUP_NODE_MAINNET or ETHERLINK_ROLLUP_NODE_SHADOWNET env var for auto-fetch mode.",
|
|
61
|
+
inputSchema,
|
|
62
|
+
annotations: {
|
|
63
|
+
readOnlyHint: false,
|
|
64
|
+
destructiveHint: false,
|
|
65
|
+
idempotentHint: true,
|
|
66
|
+
openWorldHint: true,
|
|
67
|
+
},
|
|
68
|
+
},
|
|
69
|
+
handler: async (params) => {
|
|
70
|
+
params = params;
|
|
71
|
+
const { Tezos, networkName, spendingAddress } = config;
|
|
72
|
+
const bridgeConfig = BRIDGE_CONFIG[networkName];
|
|
73
|
+
if (!bridgeConfig) {
|
|
74
|
+
throw new Error(`Bridge not supported on network: ${networkName}`);
|
|
75
|
+
}
|
|
76
|
+
let commitment;
|
|
77
|
+
let proof;
|
|
78
|
+
if (params.outputProof && params.cementedCommitment) {
|
|
79
|
+
// Direct mode: use provided proof
|
|
80
|
+
commitment = params.cementedCommitment;
|
|
81
|
+
proof = params.outputProof;
|
|
82
|
+
}
|
|
83
|
+
else if (params.outboxLevel !== undefined) {
|
|
84
|
+
// Auto-fetch mode: query rollup node for proof
|
|
85
|
+
const rollupNodeUrl = ROLLUP_NODE_URLS[networkName];
|
|
86
|
+
if (!rollupNodeUrl) {
|
|
87
|
+
throw new Error(`No rollup node URL configured for ${networkName}. ` +
|
|
88
|
+
`Set ETHERLINK_ROLLUP_NODE_${networkName.toUpperCase()} environment variable, ` +
|
|
89
|
+
`or provide cementedCommitment and outputProof directly.`);
|
|
90
|
+
}
|
|
91
|
+
const messageIndex = params.messageIndex ?? 0;
|
|
92
|
+
const proofResult = await fetchProofFromRollupNode(rollupNodeUrl, params.outboxLevel, messageIndex);
|
|
93
|
+
commitment = proofResult.commitment;
|
|
94
|
+
proof = proofResult.proof;
|
|
95
|
+
}
|
|
96
|
+
else {
|
|
97
|
+
throw new Error("Provide either: (1) outboxLevel + messageIndex to auto-fetch proof from rollup node, " +
|
|
98
|
+
"or (2) cementedCommitment + outputProof directly.");
|
|
99
|
+
}
|
|
100
|
+
// Check spender has enough for fees
|
|
101
|
+
const spenderBalance = await Tezos.tz.getBalance(spendingAddress);
|
|
102
|
+
if (spenderBalance.isZero()) {
|
|
103
|
+
throw new Error("Spending account balance is 0. Please fund the spending address to cover transaction fees.");
|
|
104
|
+
}
|
|
105
|
+
await ensureRevealed(Tezos);
|
|
106
|
+
// Execute the outbox message
|
|
107
|
+
const op = await Tezos.contract.smartRollupExecuteOutboxMessage({
|
|
108
|
+
rollup: bridgeConfig.smartRollupAddress,
|
|
109
|
+
cementedCommitment: commitment,
|
|
110
|
+
outputProof: proof,
|
|
111
|
+
});
|
|
112
|
+
await op.confirmation(CONFIRMATIONS_TO_WAIT);
|
|
113
|
+
const tzktBase = config.tzktApi.replace('api.', '').replace('/v1', '');
|
|
114
|
+
const tzktUrl = `${tzktBase}/${op.hash}`;
|
|
115
|
+
return {
|
|
116
|
+
content: [{
|
|
117
|
+
type: "text",
|
|
118
|
+
text: `Outbox message executed successfully.\n` +
|
|
119
|
+
`Commitment: ${commitment}\n` +
|
|
120
|
+
`Operation: ${tzktUrl}\n` +
|
|
121
|
+
`The withdrawal funds have been released to the recipient on Tezos L1.`,
|
|
122
|
+
}],
|
|
123
|
+
};
|
|
124
|
+
},
|
|
125
|
+
});
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import z from "zod";
|
|
2
|
+
import type { LiveConfig } from "../live-config.js";
|
|
3
|
+
export declare const createBridgeStatusTool: (config: LiveConfig) => {
|
|
4
|
+
name: string;
|
|
5
|
+
config: {
|
|
6
|
+
title: string;
|
|
7
|
+
description: string;
|
|
8
|
+
inputSchema: z.ZodObject<{
|
|
9
|
+
address: z.ZodOptional<z.ZodString>;
|
|
10
|
+
limit: z.ZodOptional<z.ZodNumber>;
|
|
11
|
+
}, z.z.core.$strip>;
|
|
12
|
+
annotations: {
|
|
13
|
+
readOnlyHint: boolean;
|
|
14
|
+
destructiveHint: boolean;
|
|
15
|
+
idempotentHint: boolean;
|
|
16
|
+
openWorldHint: boolean;
|
|
17
|
+
};
|
|
18
|
+
};
|
|
19
|
+
handler: (params: any) => Promise<{
|
|
20
|
+
content: {
|
|
21
|
+
type: "text";
|
|
22
|
+
text: string;
|
|
23
|
+
}[];
|
|
24
|
+
}>;
|
|
25
|
+
};
|
|
@@ -0,0 +1,155 @@
|
|
|
1
|
+
import axios from "axios";
|
|
2
|
+
import z from "zod";
|
|
3
|
+
const BRIDGE_CONFIG = {
|
|
4
|
+
mainnet: {
|
|
5
|
+
bridgeContract: "KT1Wj8SUGmnEPFqyahHAcjcNQwe6YGhEXJb5",
|
|
6
|
+
exchangerContract: "KT1CeFqjJRJPNVvhvznQrWfHad2jCiDZ6Lyj",
|
|
7
|
+
fastWithdrawalContract: "KT1BGwyCrnJ6HuEYP7X8Q2UooTdxmEYHiK6j",
|
|
8
|
+
smartRollupAddress: "sr1Ghq66tYK9y3r8CC1Tf8i8m5nxh8nTvZEf",
|
|
9
|
+
},
|
|
10
|
+
shadownet: {
|
|
11
|
+
bridgeContract: "KT19aBsSWvWtvEkbiqReJnD8UzQMWcD8SHUD",
|
|
12
|
+
exchangerContract: "KT1JYZsawXmeArts18nn4uT79tUJc4AGTYgc",
|
|
13
|
+
fastWithdrawalContract: "KT1E1f7ze8FcjbFu4UwnBqNo4kbbS6Zo5Y9W",
|
|
14
|
+
smartRollupAddress: "sr19fMYrr5C4qqvQqQrDSjtP31GcrWjodzvg",
|
|
15
|
+
},
|
|
16
|
+
};
|
|
17
|
+
const MUTEZ_PER_TEZ = 1_000_000;
|
|
18
|
+
const inputSchema = z.object({
|
|
19
|
+
address: z.string().optional().describe("Tezos (tz1/tz2/KT1) or Etherlink (0x) address to check bridge transfers for. Defaults to the spending contract address."),
|
|
20
|
+
limit: z.number().optional().describe("Max results per category. Default: 5"),
|
|
21
|
+
});
|
|
22
|
+
function formatMutez(mutez) {
|
|
23
|
+
return `${(mutez / MUTEZ_PER_TEZ).toFixed(6)} XTZ`;
|
|
24
|
+
}
|
|
25
|
+
function formatEtherlinkAddress(hex) {
|
|
26
|
+
return `0x${hex}`;
|
|
27
|
+
}
|
|
28
|
+
export const createBridgeStatusTool = (config) => ({
|
|
29
|
+
name: "tezos_bridge_status",
|
|
30
|
+
config: {
|
|
31
|
+
title: "Bridge Transfer Status",
|
|
32
|
+
description: "Checks the status of Tezos <-> Etherlink bridge transfers for a given address. " +
|
|
33
|
+
"Shows deposits (Tezos -> Etherlink), standard withdrawals (Etherlink -> Tezos), " +
|
|
34
|
+
"and fast withdrawals. Accepts either a Tezos or Etherlink address.",
|
|
35
|
+
inputSchema,
|
|
36
|
+
annotations: {
|
|
37
|
+
readOnlyHint: true,
|
|
38
|
+
destructiveHint: false,
|
|
39
|
+
idempotentHint: true,
|
|
40
|
+
openWorldHint: true,
|
|
41
|
+
},
|
|
42
|
+
},
|
|
43
|
+
handler: async (params) => {
|
|
44
|
+
params = params;
|
|
45
|
+
const { networkName, spendingContract, tzktApi } = config;
|
|
46
|
+
const bridgeConfig = BRIDGE_CONFIG[networkName];
|
|
47
|
+
if (!bridgeConfig) {
|
|
48
|
+
throw new Error(`Bridge not supported on network: ${networkName}`);
|
|
49
|
+
}
|
|
50
|
+
const limit = params.limit ?? 5;
|
|
51
|
+
const address = params.address ?? spendingContract;
|
|
52
|
+
const isTezosAddress = /^(tz[123]|KT1)[a-zA-Z0-9]{33}$/.test(address);
|
|
53
|
+
const isEtherlinkAddress = /^0x[0-9a-fA-F]{40}$/.test(address);
|
|
54
|
+
if (!isTezosAddress && !isEtherlinkAddress) {
|
|
55
|
+
throw new Error("Invalid address format. Provide a Tezos (tz1/tz2/KT1) or Etherlink (0x) address.");
|
|
56
|
+
}
|
|
57
|
+
const results = [];
|
|
58
|
+
const tzktBase = tzktApi;
|
|
59
|
+
// Query deposits
|
|
60
|
+
try {
|
|
61
|
+
let depositUrl;
|
|
62
|
+
if (isTezosAddress) {
|
|
63
|
+
depositUrl = `${tzktBase}/v1/operations/transactions?target=${bridgeConfig.bridgeContract}&entrypoint=deposit&sender=${address}&limit=${limit}&sort.desc=id`;
|
|
64
|
+
}
|
|
65
|
+
else {
|
|
66
|
+
const l2Hex = address.slice(2).toLowerCase();
|
|
67
|
+
depositUrl = `${tzktBase}/v1/operations/transactions?target=${bridgeConfig.bridgeContract}&entrypoint=deposit¶meter.l2_address=${l2Hex}&limit=${limit}&sort.desc=id`;
|
|
68
|
+
}
|
|
69
|
+
const { data: deposits } = await axios.get(depositUrl);
|
|
70
|
+
if (deposits.length > 0) {
|
|
71
|
+
results.push(`## Deposits (Tezos → Etherlink): ${deposits.length} found\n`);
|
|
72
|
+
for (const dep of deposits) {
|
|
73
|
+
const amount = formatMutez(dep.amount);
|
|
74
|
+
const l2 = dep.parameter?.value?.l2_address
|
|
75
|
+
? formatEtherlinkAddress(dep.parameter.value.l2_address)
|
|
76
|
+
: "unknown";
|
|
77
|
+
const from = dep.sender?.address ?? "unknown";
|
|
78
|
+
results.push(`- **${amount}** → ${l2}\n` +
|
|
79
|
+
` From: ${from} | ${dep.status} | ${dep.timestamp}\n` +
|
|
80
|
+
` Hash: ${dep.hash}`);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
else {
|
|
84
|
+
results.push("## Deposits (Tezos → Etherlink): none found");
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
catch {
|
|
88
|
+
results.push("## Deposits: query failed");
|
|
89
|
+
}
|
|
90
|
+
// Query standard withdrawals (exchanger burn) — only for Tezos addresses
|
|
91
|
+
if (isTezosAddress) {
|
|
92
|
+
try {
|
|
93
|
+
const burnUrl = `${tzktBase}/v1/operations/transactions?target=${bridgeConfig.exchangerContract}&entrypoint=burn¶meter.address=${address}&limit=${limit}&sort.desc=id`;
|
|
94
|
+
const { data: burns } = await axios.get(burnUrl);
|
|
95
|
+
if (burns.length > 0) {
|
|
96
|
+
results.push(`\n## Standard Withdrawals (Etherlink → Tezos): ${burns.length} found\n`);
|
|
97
|
+
for (const burn of burns) {
|
|
98
|
+
const ticketAmount = burn.parameter?.value?.ticket?.amount ?? "?";
|
|
99
|
+
const amount = formatMutez(Number(ticketAmount));
|
|
100
|
+
results.push(`- **${amount}** → ${address}\n` +
|
|
101
|
+
` ${burn.status} | ${burn.timestamp}\n` +
|
|
102
|
+
` Hash: ${burn.hash}`);
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
else {
|
|
106
|
+
results.push("\n## Standard Withdrawals (Etherlink → Tezos): none found");
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
catch {
|
|
110
|
+
results.push("\n## Standard Withdrawals: query failed");
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
// Query fast withdrawals
|
|
114
|
+
try {
|
|
115
|
+
let fastUrl;
|
|
116
|
+
if (isTezosAddress) {
|
|
117
|
+
fastUrl = `${tzktBase}/v1/operations/transactions?target=${bridgeConfig.fastWithdrawalContract}&entrypoint=payout_withdrawal¶meter.withdrawal.base_withdrawer=${address}&limit=${limit}&sort.desc=id`;
|
|
118
|
+
}
|
|
119
|
+
else {
|
|
120
|
+
const l2Hex = address.slice(2).toLowerCase();
|
|
121
|
+
fastUrl = `${tzktBase}/v1/operations/transactions?target=${bridgeConfig.fastWithdrawalContract}&entrypoint=payout_withdrawal¶meter.withdrawal.l2_caller=${l2Hex}&limit=${limit}&sort.desc=id`;
|
|
122
|
+
}
|
|
123
|
+
const { data: fastOps } = await axios.get(fastUrl);
|
|
124
|
+
if (fastOps.length > 0) {
|
|
125
|
+
results.push(`\n## Fast Withdrawals: ${fastOps.length} found\n`);
|
|
126
|
+
for (const fw of fastOps) {
|
|
127
|
+
const w = fw.parameter?.value?.withdrawal;
|
|
128
|
+
const fullAmount = w?.full_amount ? formatMutez(Number(w.full_amount)) : "?";
|
|
129
|
+
const paidAmount = formatMutez(fw.amount);
|
|
130
|
+
const recipient = w?.base_withdrawer ?? "unknown";
|
|
131
|
+
const l2Caller = w?.l2_caller ? formatEtherlinkAddress(w.l2_caller) : "unknown";
|
|
132
|
+
const fee = w?.full_amount
|
|
133
|
+
? formatMutez(Number(w.full_amount) - fw.amount)
|
|
134
|
+
: "?";
|
|
135
|
+
results.push(`- **${fullAmount}** (paid: ${paidAmount}, fee: ${fee})\n` +
|
|
136
|
+
` To: ${recipient} | From L2: ${l2Caller}\n` +
|
|
137
|
+
` ID: ${w?.withdrawal_id ?? "?"} | ${fw.status} | ${fw.timestamp}\n` +
|
|
138
|
+
` Hash: ${fw.hash}`);
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
else {
|
|
142
|
+
results.push("\n## Fast Withdrawals: none found");
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
catch {
|
|
146
|
+
results.push("\n## Fast Withdrawals: query failed");
|
|
147
|
+
}
|
|
148
|
+
return {
|
|
149
|
+
content: [{
|
|
150
|
+
type: "text",
|
|
151
|
+
text: `# Bridge Status for ${address}\nNetwork: ${networkName}\n\n${results.join("\n")}`,
|
|
152
|
+
}],
|
|
153
|
+
};
|
|
154
|
+
},
|
|
155
|
+
});
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import z from "zod";
|
|
2
|
+
import { type LiveConfig } from "../live-config.js";
|
|
3
|
+
export declare const createBridgeToEtherlinkTool: (config: LiveConfig) => {
|
|
4
|
+
name: string;
|
|
5
|
+
config: {
|
|
6
|
+
title: string;
|
|
7
|
+
description: string;
|
|
8
|
+
inputSchema: z.ZodObject<{
|
|
9
|
+
amount: z.ZodNumber;
|
|
10
|
+
etherlinkAddress: z.ZodString;
|
|
11
|
+
}, z.z.core.$strip>;
|
|
12
|
+
annotations: {
|
|
13
|
+
readOnlyHint: boolean;
|
|
14
|
+
destructiveHint: boolean;
|
|
15
|
+
idempotentHint: boolean;
|
|
16
|
+
openWorldHint: boolean;
|
|
17
|
+
};
|
|
18
|
+
};
|
|
19
|
+
handler: (params: any) => Promise<{
|
|
20
|
+
content: {
|
|
21
|
+
type: "text";
|
|
22
|
+
text: string;
|
|
23
|
+
}[];
|
|
24
|
+
}>;
|
|
25
|
+
};
|
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
import z from "zod";
|
|
2
|
+
import { ensureRevealed } from "./reveal_account.js";
|
|
3
|
+
import { calculateFeeRebate } from "../live-config.js";
|
|
4
|
+
// Constants
|
|
5
|
+
const MUTEZ_PER_TEZ = 1_000_000;
|
|
6
|
+
const CONFIRMATIONS_TO_WAIT = 3;
|
|
7
|
+
// Bridge configuration per network
|
|
8
|
+
// bridge contract = the evm_bridge.mligo contract that handles deposits
|
|
9
|
+
// exchanger = the exchanger.mligo contract (not called directly by users)
|
|
10
|
+
// smartRollupAddress = passed as evm_address param to the bridge deposit entrypoint
|
|
11
|
+
const BRIDGE_CONFIG = {
|
|
12
|
+
mainnet: {
|
|
13
|
+
smartRollupAddress: "sr1Ghq66tYK9y3r8CC1Tf8i8m5nxh8nTvZEf",
|
|
14
|
+
bridgeContractAddress: "KT1Wj8SUGmnEPFqyahHAcjcNQwe6YGhEXJb5",
|
|
15
|
+
},
|
|
16
|
+
shadownet: {
|
|
17
|
+
smartRollupAddress: "sr19fMYrr5C4qqvQqQrDSjtP31GcrWjodzvg",
|
|
18
|
+
bridgeContractAddress: "KT19aBsSWvWtvEkbiqReJnD8UzQMWcD8SHUD",
|
|
19
|
+
},
|
|
20
|
+
};
|
|
21
|
+
const inputSchema = z.object({
|
|
22
|
+
amount: z.number().describe("The amount of XTZ to bridge to Etherlink."),
|
|
23
|
+
etherlinkAddress: z.string().describe("The Etherlink (0x) address to receive the bridged XTZ."),
|
|
24
|
+
});
|
|
25
|
+
// Cache the last-verified spender so we only hit the chain when config changes
|
|
26
|
+
let verifiedSpender = null;
|
|
27
|
+
export const createBridgeToEtherlinkTool = (config) => ({
|
|
28
|
+
name: "tezos_bridge_to_etherlink",
|
|
29
|
+
config: {
|
|
30
|
+
title: "Bridge XTZ to Etherlink",
|
|
31
|
+
description: "Bridges XTZ from Tezos to Etherlink via the native bridge. " +
|
|
32
|
+
"Sends XTZ from the spending contract through the Tezos-Etherlink bridge to the specified Etherlink address. " +
|
|
33
|
+
"The bridged XTZ will appear as native tokens on Etherlink after the rollup processes the deposit.",
|
|
34
|
+
inputSchema,
|
|
35
|
+
annotations: {
|
|
36
|
+
readOnlyHint: false,
|
|
37
|
+
destructiveHint: true,
|
|
38
|
+
idempotentHint: false,
|
|
39
|
+
openWorldHint: true,
|
|
40
|
+
},
|
|
41
|
+
},
|
|
42
|
+
handler: async (params) => {
|
|
43
|
+
params = params;
|
|
44
|
+
const { Tezos, spendingContract, spendingAddress, networkName } = config;
|
|
45
|
+
const bridgeConfig = BRIDGE_CONFIG[networkName];
|
|
46
|
+
if (!bridgeConfig) {
|
|
47
|
+
throw new Error(`Bridge not supported on network: ${networkName}`);
|
|
48
|
+
}
|
|
49
|
+
// Validate Etherlink address format
|
|
50
|
+
if (!/^0x[0-9a-fA-F]{40}$/.test(params.etherlinkAddress)) {
|
|
51
|
+
throw new Error("Invalid Etherlink address. Must be a 0x-prefixed, 40 hex character address.");
|
|
52
|
+
}
|
|
53
|
+
const amountMutez = Math.floor(params.amount * MUTEZ_PER_TEZ);
|
|
54
|
+
if (amountMutez <= 0) {
|
|
55
|
+
throw new Error("Amount must be greater than 0.");
|
|
56
|
+
}
|
|
57
|
+
// Verify the server's signer matches the on-chain spender (only when config changes)
|
|
58
|
+
const needsVerify = !verifiedSpender
|
|
59
|
+
|| verifiedSpender.address !== spendingAddress
|
|
60
|
+
|| verifiedSpender.contract !== spendingContract;
|
|
61
|
+
if (needsVerify) {
|
|
62
|
+
const c = await Tezos.contract.at(spendingContract);
|
|
63
|
+
const storage = await c.storage();
|
|
64
|
+
if (storage.spender !== spendingAddress) {
|
|
65
|
+
throw new Error(`Spender mismatch: the server's signing key (${spendingAddress}) does not match ` +
|
|
66
|
+
`the contract's spender (${storage.spender}). ` +
|
|
67
|
+
`Please regenerate the spender key from the dashboard.`);
|
|
68
|
+
}
|
|
69
|
+
verifiedSpender = { address: spendingAddress, contract: spendingContract };
|
|
70
|
+
}
|
|
71
|
+
// Check spending contract has enough for the bridge amount
|
|
72
|
+
const contractBalance = await Tezos.tz.getBalance(spendingContract);
|
|
73
|
+
if (contractBalance.toNumber() < amountMutez) {
|
|
74
|
+
throw new Error(`Insufficient spending contract balance. ` +
|
|
75
|
+
`Requested: ${amountMutez} mutez, Available: ${contractBalance.toNumber()} mutez`);
|
|
76
|
+
}
|
|
77
|
+
// Ensure account is revealed before estimating
|
|
78
|
+
await ensureRevealed(Tezos);
|
|
79
|
+
// Step 1: Fund the spender from the spending contract
|
|
80
|
+
// The spender needs the bridge amount + fees to execute the bridge deposit
|
|
81
|
+
const spenderBalance = await Tezos.tz.getBalance(spendingAddress);
|
|
82
|
+
const spenderMutez = spenderBalance.toNumber();
|
|
83
|
+
const feeRebate = calculateFeeRebate(spenderMutez);
|
|
84
|
+
const spendingContractInstance = await Tezos.contract.at(spendingContract);
|
|
85
|
+
const fundCall = spendingContractInstance.methodsObject.spend({
|
|
86
|
+
recipient: spendingAddress,
|
|
87
|
+
amount: amountMutez,
|
|
88
|
+
fee_rebate: feeRebate,
|
|
89
|
+
});
|
|
90
|
+
const fundOp = await fundCall.send();
|
|
91
|
+
await fundOp.confirmation(CONFIRMATIONS_TO_WAIT);
|
|
92
|
+
// Step 2: Call the bridge contract's deposit entrypoint directly
|
|
93
|
+
// The deposit entrypoint takes:
|
|
94
|
+
// evm_address: the smart rollup address (sr1...)
|
|
95
|
+
// l2_address: the Etherlink receiver as hex bytes (without 0x prefix)
|
|
96
|
+
// XTZ is sent along with the call as the amount to bridge
|
|
97
|
+
const bridgeContract = await Tezos.contract.at(bridgeConfig.bridgeContractAddress);
|
|
98
|
+
const l2AddressBytes = params.etherlinkAddress.slice(2).toLowerCase();
|
|
99
|
+
const depositCall = bridgeContract.methodsObject.deposit({
|
|
100
|
+
evm_address: bridgeConfig.smartRollupAddress,
|
|
101
|
+
l2_address: l2AddressBytes,
|
|
102
|
+
});
|
|
103
|
+
const depositOp = await depositCall.send({ amount: amountMutez, mutez: true });
|
|
104
|
+
await depositOp.confirmation(CONFIRMATIONS_TO_WAIT);
|
|
105
|
+
const tzktBase = config.tzktApi.replace('api.', '').replace('/v1', '');
|
|
106
|
+
const tzktUrl = `${tzktBase}/${depositOp.hash}`;
|
|
107
|
+
return {
|
|
108
|
+
content: [{
|
|
109
|
+
type: "text",
|
|
110
|
+
text: `Bridged ${params.amount} XTZ to Etherlink address ${params.etherlinkAddress}\n` +
|
|
111
|
+
`Tezos operation: ${tzktUrl}\n` +
|
|
112
|
+
`The deposit will appear on Etherlink after the rollup processes it (typically a few minutes).`,
|
|
113
|
+
}],
|
|
114
|
+
};
|
|
115
|
+
},
|
|
116
|
+
});
|
package/dist/tools/index.d.ts
CHANGED
|
@@ -131,4 +131,72 @@ export declare const createTools: (liveConfig: LiveConfig, http: boolean) => ({
|
|
|
131
131
|
text: string;
|
|
132
132
|
}[];
|
|
133
133
|
}>;
|
|
134
|
+
} | {
|
|
135
|
+
name: string;
|
|
136
|
+
config: {
|
|
137
|
+
title: string;
|
|
138
|
+
description: string;
|
|
139
|
+
inputSchema: import("zod").ZodObject<{
|
|
140
|
+
amount: import("zod").ZodNumber;
|
|
141
|
+
etherlinkAddress: import("zod").ZodString;
|
|
142
|
+
}, import("zod/v4/core").$strip>;
|
|
143
|
+
annotations: {
|
|
144
|
+
readOnlyHint: boolean;
|
|
145
|
+
destructiveHint: boolean;
|
|
146
|
+
idempotentHint: boolean;
|
|
147
|
+
openWorldHint: boolean;
|
|
148
|
+
};
|
|
149
|
+
};
|
|
150
|
+
handler: (params: any) => Promise<{
|
|
151
|
+
content: {
|
|
152
|
+
type: "text";
|
|
153
|
+
text: string;
|
|
154
|
+
}[];
|
|
155
|
+
}>;
|
|
156
|
+
} | {
|
|
157
|
+
name: string;
|
|
158
|
+
config: {
|
|
159
|
+
title: string;
|
|
160
|
+
description: string;
|
|
161
|
+
inputSchema: import("zod").ZodObject<{
|
|
162
|
+
address: import("zod").ZodOptional<import("zod").ZodString>;
|
|
163
|
+
limit: import("zod").ZodOptional<import("zod").ZodNumber>;
|
|
164
|
+
}, import("zod/v4/core").$strip>;
|
|
165
|
+
annotations: {
|
|
166
|
+
readOnlyHint: boolean;
|
|
167
|
+
destructiveHint: boolean;
|
|
168
|
+
idempotentHint: boolean;
|
|
169
|
+
openWorldHint: boolean;
|
|
170
|
+
};
|
|
171
|
+
};
|
|
172
|
+
handler: (params: any) => Promise<{
|
|
173
|
+
content: {
|
|
174
|
+
type: "text";
|
|
175
|
+
text: string;
|
|
176
|
+
}[];
|
|
177
|
+
}>;
|
|
178
|
+
} | {
|
|
179
|
+
name: string;
|
|
180
|
+
config: {
|
|
181
|
+
title: string;
|
|
182
|
+
description: string;
|
|
183
|
+
inputSchema: import("zod").ZodObject<{
|
|
184
|
+
outboxLevel: import("zod").ZodOptional<import("zod").ZodNumber>;
|
|
185
|
+
messageIndex: import("zod").ZodOptional<import("zod").ZodNumber>;
|
|
186
|
+
cementedCommitment: import("zod").ZodOptional<import("zod").ZodString>;
|
|
187
|
+
outputProof: import("zod").ZodOptional<import("zod").ZodString>;
|
|
188
|
+
}, import("zod/v4/core").$strip>;
|
|
189
|
+
annotations: {
|
|
190
|
+
readOnlyHint: boolean;
|
|
191
|
+
destructiveHint: boolean;
|
|
192
|
+
idempotentHint: boolean;
|
|
193
|
+
openWorldHint: boolean;
|
|
194
|
+
};
|
|
195
|
+
};
|
|
196
|
+
handler: (params: any) => Promise<{
|
|
197
|
+
content: {
|
|
198
|
+
type: "text";
|
|
199
|
+
text: string;
|
|
200
|
+
}[];
|
|
201
|
+
}>;
|
|
134
202
|
})[];
|
package/dist/tools/index.js
CHANGED
|
@@ -8,6 +8,9 @@ import { createParseX402RequirementsTool } from "./parse_x402_requirements.js";
|
|
|
8
8
|
import { createRevealAccountTool } from "./reveal_account.js";
|
|
9
9
|
import { createRecoverSpenderFundsTool } from "./recover_spender_funds.js";
|
|
10
10
|
import { createSendXtzTool } from "./send_xtz.js";
|
|
11
|
+
import { createBridgeToEtherlinkTool } from "./bridge_to_etherlink.js";
|
|
12
|
+
import { createBridgeStatusTool } from "./bridge_status.js";
|
|
13
|
+
import { createBridgeExecuteWithdrawalTool } from "./bridge_execute_withdrawal.js";
|
|
11
14
|
import { createGetDashboardTool } from "./get_dashboard.js";
|
|
12
15
|
const getNotConfiguredMessage = () => `Wallet not configured.
|
|
13
16
|
|
|
@@ -43,6 +46,9 @@ export const createTools = (liveConfig, http) => {
|
|
|
43
46
|
createRecoverSpenderFundsTool(liveConfig),
|
|
44
47
|
createRevealAccountTool(liveConfig),
|
|
45
48
|
createSendXtzTool(liveConfig),
|
|
49
|
+
createBridgeToEtherlinkTool(liveConfig),
|
|
50
|
+
createBridgeStatusTool(liveConfig),
|
|
51
|
+
createBridgeExecuteWithdrawalTool(liveConfig),
|
|
46
52
|
];
|
|
47
53
|
if (!http) {
|
|
48
54
|
tools.push(createGetDashboardTool(liveConfig));
|
|
@@ -51,7 +51,7 @@ export const createRecoverSpenderFundsTool = (config) => ({
|
|
|
51
51
|
const isContract = destination.startsWith("KT1");
|
|
52
52
|
if (isContract) {
|
|
53
53
|
const contract = await Tezos.contract.at(destination);
|
|
54
|
-
const depositCall = contract.methodsObject
|
|
54
|
+
const depositCall = contract.methodsObject["default"](null);
|
|
55
55
|
const estimate = await Tezos.estimate.contractCall(depositCall);
|
|
56
56
|
const maxAmount = balanceMutez - estimate.suggestedFeeMutez;
|
|
57
57
|
if (maxAmount <= 0) {
|
|
@@ -62,7 +62,7 @@ export const createRecoverSpenderFundsTool = (config) => ({
|
|
|
62
62
|
}],
|
|
63
63
|
};
|
|
64
64
|
}
|
|
65
|
-
const operation = await contract.methodsObject
|
|
65
|
+
const operation = await contract.methodsObject["default"](null).send({
|
|
66
66
|
amount: maxAmount,
|
|
67
67
|
mutez: true,
|
|
68
68
|
fee: estimate.suggestedFeeMutez,
|
|
@@ -125,7 +125,7 @@ Error generating stack: `+h.message+`
|
|
|
125
125
|
/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../components/alert/styles.css","../../components/bug-report-form/styles.css","../../components/info/styles.css","../../components/loader/styles.css","../../components/pair-other/styles.css","../../components/qr/styles.css","../../components/top-wallets/styles.css","../../components/wallet/styles.css","../../components/wallets/styles.css","../../components/button-icon/button-icon.css","components/pairing-alert/components/wc-init-error/styles.css"],"names":[],"mappings":"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","file":"aggregated.css","sourcesContent":[".alert-wrapper-show {\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  position: fixed;\n  height: 100%;\n  width: 100vw;\n  overflow: hidden;\n  top: 0;\n  left: 0;\n  background-color: rgba(0, 0, 0, 0.6);\n  z-index: 99999;\n  /* Trigger fadeIn animation */\n  animation: fadeIn 0.3s ease forwards;\n}\n\n.alert-wrapper-hide {\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  position: fixed;\n  height: 100%;\n  width: 100vw;\n  overflow: hidden;\n  top: 0;\n  left: 0;\n  background-color: rgba(0, 0, 0, 0.6);\n  z-index: 99999;\n  /* Trigger fadeOut animation */\n  animation: fadeOut 0.3s ease forwards;\n}\n\n/* Keyframes for fadeIn and fadeOut */\n@keyframes fadeIn {\n  from { opacity: 0; }\n  to   { opacity: 1; }\n}\n\n@keyframes fadeOut {\n  from { opacity: 1; }\n  to   { opacity: 0; }\n}\n\n\n.theme__dark .alert-modal-show {\n  background-color: #27334c;\n}\n\n.theme__dark .alert-modal-hide {\n  background-color: #27334c;\n}\n\n.theme__dark .alert-footer {\n  color: white;\n  -webkit-box-shadow: 0px -4px 12px rgb(0 0 0 / 20%);\n  -moz-box-shadow: 0px -4px 12px rgb(0 0 0 / 20%);\n  box-shadow: 0px -4px 12px rgb(0 0 0 / 20%);\n}\n\n.theme__dark .alert-logo svg g {\n  fill: white;\n}\n\n.alert-modal-show {\n  background-color: white;\n  border-radius: 32px;\n  opacity: 1;\n  width: 480px;\n}\n\n.alert-modal-hide {\n  background-color: white;\n  border-radius: 32px;\n  opacity: 1;\n  width: 480px;\n}\n\n.alert-modal-loading-wrapper {\n  width: 480px;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  position: relative;\n}\n\n.alert-header {\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  padding: 1.8em;\n  padding-top: 1.2em;\n  padding-bottom: 0px;\n}\n\n.alert-button-icon-empty {\n  width: 24px;\n  height: 24px;\n  padding: 2px;\n}\n\n.alert-logo {\n  margin: 0px 6em;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n}\n\n.alert-logo svg {\n  height: 28px;\n}\n\n.alert-body {\n  padding: 1.8em;\n  padding-bottom: 0px;\n  transition: all ease 0.3s;\n}\n\n.alert-footer {\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  color: grey;\n  cursor: pointer;\n  -webkit-box-shadow: 0px -4px 12px rgb(50 50 50 / 6%);\n  -moz-box-shadow: 0px -4px 12px rgb(50 50 50 / 6%);\n  box-shadow: 0px -4px 12px rgb(50 50 50 / 6%);\n  font-size: 0.938rem;\n  font-weight: bold;\n  height: 64px;\n}\n\n.alert-body-extra-show {\n  transition: all ease 0.3s;\n  overflow: hidden;\n  max-height: 35vh;\n}\n\n.alert-body-extra-hide {\n  transition: all ease 0.3s;\n  overflow: hidden;\n  max-height: 0px;\n}\n\n.alert-divider {\n  border-top: 1px solid #aaaaaa42;\n  width: 100%;\n  border-radius: 6px;\n}\n\n@media only screen and (max-width: 800px) {\n  .alert-logo {\n    margin: 0px 2em;\n  }\n\n  .alert-wrapper-show {\n    align-items: flex-end;\n    width: 100%;\n  }\n\n  .alert-wrapper-hide {\n    align-items: flex-end;\n    width: 100%;\n  }\n\n  .alert-modal-show {\n    border-bottom-left-radius: 0px;\n    border-bottom-right-radius: 0px;\n    padding-bottom: 1.8em;\n    width: 100%;\n  }\n\n  .alert-modal-hide {\n    border-bottom-left-radius: 0px;\n    border-bottom-right-radius: 0px;\n    padding-bottom: 1.8em;\n  }\n}\n\n@media only screen and (max-width: 300px) {\n  .alert-wrapper-show {\n    align-items: flex-end;\n    width: 100vw;\n  }\n\n  .alert-wrapper-hide {\n    align-items: flex-end;\n    width: 100vw;\n  }\n\n  .alert-body {\n    padding: 0.8em;\n  }\n\n  .alert-body {\n    padding: 0.8em;\n    padding-top: 0.4em;\n  }\n\n  .alert-logo {\n    margin: 0px;\n    transform: scale(0.8);\n  }\n}\n",".form-style {\n  display: flex;\n  flex-direction: column;\n  max-width: 500px;\n  min-width: 100%;\n  margin: 0 auto;\n  gap: 20px;\n}\n\n.input-group {\n  display: flex;\n  flex-direction: column;\n  margin-bottom: 15px;\n}\n\n.label-style {\n  margin-bottom: 8px;\n}\n\n.theme__light .label-style {\n  color: black;\n}\n\n.input-style,\n.textarea-style {\n  width: 100%;\n  padding: 10px;\n  box-sizing: border-box;\n  border: 1px solid #ccc;\n  border-radius: 5px;\n  background-color: white;\n  color: black;\n}\n\n.theme__dark .input-style,\n.theme__dark .textarea-style {\n  background-color: #25334b;\n  color: white;\n}\n\n.input-style.invalid,\n.textarea-style.invalid {\n  border-color: #f76b8a;\n  border-width: medium;\n}\n\n.textarea-style {\n  height: 8rem;\n}\n\n.button-style {\n  padding: 10px 20px;\n  color: white;\n  border: none;\n  border-radius: 5px;\n  cursor: pointer;\n  margin-top: 20px;\n}\n\n.button-style.valid {\n  background-color: #007bff;\n}\n\n.button-style.invalid {\n  background-color: #65afff;\n}\n\n.error-label {\n  display: inline;\n  font-size: 0.7rem;\n  color: #f76b8a;\n}\n\n.permissions-group {\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n}\n\n.permissions-group label {\n  flex-grow: 1;\n  font-size: 0.7rem;\n}\n\n.permissions-group input {\n  flex-shrink: 0;\n}\n\n@media screen and (max-height: 700px) {\n  .textarea-style {\n    height: 6rem;\n  }\n}\n\n.button-loading::after {\n  content: '';\n  position: absolute;\n  width: 16px;\n  height: 16px;\n  left: 0;\n  right: 0;\n  margin: auto;\n  border: 4px solid transparent;\n  border-top-color: #ffffff;\n  border-radius: 50%;\n  animation: button-loading-spinner 1s ease infinite;\n}\n\n@keyframes button-loading-spinner {\n  from {\n    transform: rotate(0turn);\n  }\n\n  to {\n    transform: rotate(1turn);\n  }\n}\n\n.icon {\n  display: inline-block;\n  border: 2px solid white;\n  border-radius: 50%;\n  padding: 5px;\n  margin-bottom: 3px;\n  width: 1rem;\n  opacity: 0;\n  transition: opacity 0.3s ease;\n}\n\n.success-icon {\n  animation: successAnimation 0.6s ease forwards;\n}\n\n.error-icon {\n  animation: fadeIn 0.3s ease forwards;\n}\n\n@keyframes successAnimation {\n  0% {\n    transform: rotate(0deg);\n    opacity: 0;\n  }\n  100% {\n    transform: rotate(360deg);\n    opacity: 1;\n  }\n}\n\n@keyframes fadeIn {\n  0% {\n    opacity: 0;\n  }\n  100% {\n    opacity: 1;\n  }\n}\n\n.thank-you-message {\n  display: inline-block;\n  margin-left: 10px;\n}\n\n.thank-you-message span {\n  opacity: 0;\n  animation: fadeInLetter 0.3s ease forwards;\n}\n\n@keyframes fadeInLetter {\n  to {\n    opacity: 1;\n  }\n}\n",".info-wrapper {\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  justify-content: center;\n  gap: 0.5rem;\n  border-radius: 10px;\n  padding: 30px;\n}\n.info-border {\n  border: 1px solid #aaaaaa42;\n}\n.info-icon {\n  width: 40px;\n  height: 40px;\n  border-radius: 6px;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  font-size: 28px;\n  margin-bottom: 0.2rem;\n}\n\n.info-badge {\n  background-color: #3880ff;\n  font-size: 38px;\n  -webkit-box-shadow: 0px 0px 12px -4px rgb(0 0 0 / 30%);\n  -moz-box-shadow: 0px 0px 12px -4px rgb(0 0 0 / 30%);\n  box-shadow: 0px 0px 12px -4px rgb(0 0 0 / 30%);\n}\n.theme__dark .info-title {\n  color: white;\n}\n.theme__dark .info-description {\n  color: #aeaeae;\n}\n.info-title {\n  text-align: center;\n  color: #334155;\n  margin: 0px;\n  font-size: 16px;\n}\n\n.info-description {\n  text-align: center;\n  font-size: 12.8px;\n  font-weight: 300;\n  color: #7c828b;\n  line-height: 1.25rem;\n  margin: 6px 0px 12px 0px;\n  margin: 0px;\n  max-width: 300px;\n}\n\n.info-data {\n  font-size: 12.8px;\n  font-weight: 300;\n  color: #7c828b;\n  line-height: 1.25rem;\n  margin: 6px 0px 12px 0px;\n  margin: 0px;\n  overflow: scroll;\n  max-height: 300px;\n}\n.info-buttons {\n  display: flex;\n  align-items: center;\n  gap: 0.6rem;\n}\n\n.info-button {\n  border-radius: 6px;\n  background-color: #3880ff;\n  border: 1px solid #3880ff;\n  color: white;\n  padding: 0.6rem 1.2rem;\n  width: 180px;\n  transition: all ease 0.2s;\n  cursor: pointer;\n  margin-top: 1rem;\n  font-size: 12.8px;\n}\n\n.info-button:hover {\n  background-color: #166afc;\n}\n.info-button-secondary {\n  border-radius: 6px;\n  background-color: transparent;\n  border: 1px solid #3880ff;\n  color: #3880ff;\n  padding: 0.6em 1.2rem;\n  width: 180px;\n  transition: all ease 0.2s;\n  cursor: pointer;\n  margin-top: 1rem;\n}\n\n.info-button-secondary:hover {\n  background-color: #e8f0ff;\n}\n.downloadLink {\n  text-decoration: none;\n  color: gray;\n  font-size: smaller;\n  padding: 0.5rem;\n}\nbutton#qr-code-icon {\n  background-color: transparent;\n  border: none;\n  min-width: 2.5rem;\n  align-self: self-end;\n  position: absolute;\n  top: 0.3rem;\n  right: 0.3rem;\n  padding: 1.5px;\n}\n\nbutton#qr-code-icon svg {\n  width: 25px;\n}\n\n@media only screen and (max-width: 300px) {\n  button#qr-code-icon {\n    min-width: 1.5rem;\n  }\n}\n\n@media only screen and (max-width: 800px) {\n  .info-title {\n    font-size: 14.4px;\n    line-height: 1rem;\n  }\n\n  .info-description {\n    font-size: 0.65rem;\n  }\n\n  .qr-more-info {\n    font-size: 0.75rem;\n  }\n\n  .info-wrapper {\n    max-height: 180px;\n    padding: 1.2em;\n    position: relative;\n  }\n  .info-icon {\n    width: 40px;\n    height: 40px;\n    font-size: 1.8rem;\n  }\n\n  .info-button {\n    padding: 0.5em 1.6em;\n    font-size: 16px;\n    font-weight: bold;\n  }\n}\n",".loader {\n  height: 3px;\n  position: relative;\n  background-color: #ddd;\n  position: absolute;\n  width: 100%;\n  left: 0px;\n  bottom: 0px;\n  overflow: hidden;\n}\n\n.loader:before {\n  content: '';\n  position: absolute;\n  left: -50%;\n  height: 3px;\n  width: 40%;\n  background-color: #3880ff;\n  -webkit-animation: lineAnim 1s linear infinite;\n  -moz-animation: lineAnim 1s linear infinite;\n  animation: lineAnim 1s linear infinite;\n}\n\n@keyframes lineAnim {\n  0% {\n    left: -40%;\n  }\n  50% {\n    left: 20%;\n    width: 80%;\n  }\n  100% {\n    left: 100%;\n    width: 100%;\n  }\n}\n",".pair-other-info {\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  justify-content: center;\n  color: #b5b8be;\n}\n",".qr-wrapper {\n  display: flex;\n  align-items: flex-start;\n  justify-content: center;\n  gap: 0.5em;\n  border: 1px solid #aaaaaa42;\n  border-radius: 10px;\n  padding: 30px;\n  height: 200px;\n}\n\n.qr-left {\n  display: flex;\n  flex-direction: column;\n  max-width: 16em;\n  height: 100%;\n}\n\n.qr-left h3 {\n  color: #334155;\n  margin: 0px;\n  margin-bottom: 0.4em;\n  font-size: 1em;\n}\n\n.theme__dark .qr-left h3 {\n  color: white;\n}\n\n.theme__dark .qr-left span {\n  color: #aeaeae;\n}\n\n.theme__dark .qr-copy-wrapper p {\n  color: #aeaeae;\n}\n\n.qr-left span {\n  font-size: 0.8rem;\n  font-weight: 300;\n  color: #7c828b;\n  line-height: 1.35em;\n  margin: 0px;\n}\n\n.qr-more-info {\n  font-size: 0.95em !important;\n  text-decoration: underline;\n  margin-left: 6px !important;\n  cursor: pointer;\n}\n\n.qr-right {\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  justify-content: center;\n  border-radius: 6px;\n  transition: all ease 0.2s;\n  cursor: pointer;\n}\n\n.theme__dark .qr-right:hover {\n  background-color: rgba(238, 238, 238, 0.492);\n}\n\n.qr-right:hover {\n  background-color: rgb(238, 238, 238);\n}\n\n.qr-copy-wrapper {\n  display: flex;\n  align-items: center;\n  gap: 0.6em;\n  color: #7c828b;\n  margin-bottom: 8px;\n  margin-top: 18px;\n}\n\n.qr-copy-wrapper svg {\n  font-size: 1em;\n}\n\n.qr-copy-wrapper p {\n  font-size: 0.8em;\n  margin: 0px;\n}\n\n.qr-svg-wrapper {\n  background-color: white;\n  border-radius: 10px;\n}\n\n.qr-svg-wrapper svg rect {\n  fill: transparent !important;\n}\n\n@media only screen and (max-width: 800px) {\n  .qr-wrapper {\n    flex-direction: column;\n    align-items: center;\n    justify-content: center;\n    height: 340px;\n  }\n\n  .qr-left {\n    margin: 0.6em 0px;\n  }\n\n  .qr-left h3 {\n    font-size: 1em;\n    line-height: 1em;\n  }\n\n  .qr-left p {\n    font-size: 0.75em;\n    text-align: center;\n  }\n\n  .qr-left > div {\n    display: flex;\n    align-items: center;\n    justify-content: center;\n  }\n\n  .qr-more-info {\n    font-size: 0.75em;\n  }\n}\n",".top-wallets-wrapper {\n  margin-bottom: 1.8em;\n}\n\n.top-wallets-info {\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  justify-content: center;\n}\n\n.theme__dark .top-wallets-info h3 {\n  color: white;\n}\n\n.theme__dark .top-wallets-info span {\n  color: #b5b8be;\n}\n\n.theme__dark .top-wallets-other-wallets-left h3 {\n  color: white;\n}\n\n.top-wallets-info h3 {\n  text-align: center;\n  color: #334155;\n  margin: 0px;\n  font-size: 0.938rem;\n}\n\n.top-wallets-info span {\n  text-align: center;\n  max-width: 300px;\n  font-size: 0.8em;\n  font-weight: 300;\n  color: #7c828b;\n  line-height: 1.35em;\n  margin: 6px 0px 12px 0px;\n}\n\n.top-wallets-learn-more {\n  text-decoration: underline;\n  cursor: pointer;\n  font-size: 0.95em !important;\n}\n\n.top-wallets-wallets-main {\n  margin-top: 1em;\n  grid-template-columns: repeat(2, 1fr);\n  display: grid;\n  gap: 1em;\n}\n\n.top-wallets-other-wallets {\n  display: flex;\n  gap: 1.25em;\n  justify-content: space-between;\n  border-radius: 12px;\n  padding: 1.25em;\n  cursor: pointer;\n  transition: all ease 0.2s;\n\n  -webkit-box-shadow: 0px 0px 12px -4px rgb(0 0 0 / 30%);\n  -moz-box-shadow: 0px 0px 12px -4px rgb(0 0 0 / 30%);\n  box-shadow: 0px 0px 12px -4px rgb(0 0 0 / 30%);\n}\n\n.top-wallets-other-wallets-left {\n  max-width: 148px;\n}\n\n.top-wallets-other-wallets-left h3 {\n  color: #334155;\n  margin: 0px;\n  font-size: 1em;\n}\n\n.top-wallets-other-wallets-left p {\n  max-width: 400px;\n  font-size: 0.85em;\n  font-weight: 300;\n  color: #94a3b8;\n  line-height: 1.35em;\n  margin: 0px;\n  font-size: 0.75em;\n}\n\n.top-wallets-other-wallets-right {\n  display: flex;\n  justify-content: center;\n  align-items: center;\n}\n\n.top-wallets-other-wallets-right img {\n  border-radius: 8px;\n  width: 2.4em;\n  height: 2.4em;\n  -webkit-box-shadow: 0px 0px 12px -4px rgb(0 0 0 / 30%);\n  -moz-box-shadow: 0px 0px 12px -4px rgb(0 0 0 / 30%);\n  box-shadow: 0px 0px 12px -4px rgb(0 0 0 / 30%);\n}\n\n.top-wallets-other-wallets-center-wallet {\n  transform: perspective(500px) translateZ(100px);\n}\n\n@media only screen and (max-width: 800px) {\n  .top-wallets-info h3 {\n    font-size: 1em;\n  }\n\n  .top-wallets-info p {\n    font-size: 0.75em;\n  }\n\n  .top-wallets-other-wallets {\n    flex-direction: column;\n    text-align: center;\n    justify-content: center;\n    align-items: center;\n  }\n\n  .top-wallets-other-wallets-left {\n    order: 1;\n  }\n\n  .top-wallets-other-wallets-left h3 {\n    font-size: 0.85em;\n  }\n\n  .top-wallets-other-wallets-left p {\n    font-size: 0.65em;\n  }\n}\n\n@media only screen and (max-width: 400px) {\n  .top-wallets-other-wallets-right {\n    max-width: 50px;\n    transform: scale(0.8);\n  }\n}\n",".wallet-main {\n  display: flex;\n  gap: 1.25em;\n  justify-content: space-between;\n  border-radius: 12px;\n  padding: 15px;\n  cursor: pointer;\n  transition: all ease 0.2s;\n\n  -webkit-box-shadow: 0px 0px 12px -4px rgb(0 0 0 / 30%);\n  -moz-box-shadow: 0px 0px 12px -4px rgb(0 0 0 / 30%);\n  box-shadow: 0px 0px 12px -4px rgb(0 0 0 / 30%);\n}\n\n.wallet-disabled {\n  opacity: 0.5;\n}\n\n.wallet-main:hover {\n  transform: scale(1.01);\n}\n\n.wallet-main:active {\n  transform: scale(0.99);\n}\n\n.wallet-main-left {\n  max-width: 148px;\n  flex: 1;\n}\n\n.theme__dark .wallet-main-left h3 {\n  color: white;\n}\n\n.theme__dark .top-wallets-info p {\n  color: #b5b8be;\n}\n\n.theme__dark .wallet-main-right {\n  -webkit-box-shadow: 0px 0px 12px -4px rgb(0 0 0 / 63%);\n  -moz-box-shadow: 0px 0px 12px -4px rgb(0 0 0 / 63%);\n  box-shadow: 0px 0px 12px -4px rgb(0 0 0 / 63%);\n}\n\n.theme__dark .wallet-small img {\n  -webkit-box-shadow: 0px 0px 12px -4px rgb(0 0 0 / 63%);\n  -moz-box-shadow: 0px 0px 12px -4px rgb(0 0 0 / 63%);\n  box-shadow: 0px 0px 12px -4px rgb(0 0 0 / 63%);\n}\n\n.theme__dark .wallet-small h3 {\n  color: white;\n}\n\n.wallet-main-left h3 {\n  color: #1c1e21;\n  margin: 0px;\n  font-size: 1em;\n}\n\n.wallet-main-left p {\n  max-width: 400px;\n  font-weight: 300;\n  color: #7c828b;\n  line-height: 1.35em;\n  margin: 0px;\n  font-size: 0.65em;\n}\n\n.wallet-main-right {\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  border-radius: 8px;\n  overflow: hidden;\n  -webkit-box-shadow: 0px 0px 12px -4px rgb(0 0 0 / 30%);\n  -moz-box-shadow: 0px 0px 12px -4px rgb(0 0 0 / 30%);\n  box-shadow: 0px 0px 12px -4px rgb(0 0 0 / 30%);\n}\n\n.wallet-main-right img {\n  width: 3.2em;\n  height: 3.2em;\n}\n\n.wallet-main-tags {\n  display: flex;\n  gap: 6px;\n}\n\n.wallet-main-tag {\n  color: #3880ff;\n  margin: 0px;\n  font-size: 0.75em;\n  font-weight: 600;\n  margin-top: 6px;\n  text-transform: uppercase;\n}\n\n.wallet-small {\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  flex-direction: column;\n  gap: 0.5em;\n}\n\n.wallet-small img {\n  padding: 0.4em;\n  border-radius: 10px;\n  width: 2.5em;\n  height: 2.5em;\n  cursor: pointer;\n  transition: all ease 0.2s;\n\n  -webkit-box-shadow: 0px 0px 12px -4px rgb(0 0 0 / 30%);\n  -moz-box-shadow: 0px 0px 12px -4px rgb(0 0 0 / 30%);\n  box-shadow: 0px 0px 12px -4px rgb(0 0 0 / 30%);\n}\n\n.wallet-small img:hover {\n  transform: scale(1.01);\n}\n\n.wallet-small img:active {\n  transform: scale(0.99);\n}\n\n.wallet-small h3 {\n  color: #334155;\n  margin: 0px;\n  font-size: 0.8em;\n  text-align: center;\n}\n\n.wallet-main-mobile {\n  flex-direction: column;\n  justify-content: center;\n  align-items: center;\n  gap: 1em;\n}\n\n.wallet-main-left-mobile {\n  order: 1;\n}\n\n.wallet-main-left-mobile h3 {\n  font-size: 0.9em;\n  text-align: center;\n}\n\n.wallet-main-left-mobile p {\n  font-size: 0.65em;\n  text-align: center;\n}\n\n@media only screen and (max-width: 800px) {\n  .wallet-main {\n    padding: 0.65em 15px;\n  }\n\n  .wallet-main-mobile {\n    padding: 1.25em;\n  }\n}\n",".wallets-button {\n  border-radius: 6px;\n  background-color: transparent;\n  border: 1px solid #3880ff;\n  color: #3880ff;\n  width: 100%;\n  padding: 12px 0px;\n  margin-bottom: 1.8em;\n  transition: all ease 0.2s;\n  cursor: pointer;\n  font-size: 0.9em;\n}\n\n.wallets-button:hover {\n  color: white;\n  background-color: #3880ff;\n}\n\n.wallets-list-main-wrapper {\n  position: relative;\n}\n\n.wallets-list-wrapper {\n  display: grid;\n  overflow-y: auto;\n  grid-template-columns: repeat(4, 1fr);\n  padding: 1.8em 0px;\n  gap: 1.2em 0em;\n  max-height: 180px;\n}\n\n@media only screen and (max-width: 800px) {\n  .wallets-list-wrapper {\n    display: flex;\n    flex-direction: column;\n    gap: 12px;\n    max-height: 300px;\n    padding: 1.6em 0.6em;\n    margin-top: 0px;\n  }\n\n  .wallets-list-main-wrapper::before {\n    position: absolute;\n    top: 0px;\n    content: '';\n    left: -24px;\n    width: calc(100% + 48px);\n    background: radial-gradient(\n      circle,\n      rgba(171, 171, 171, 0.7329525560224089) 0%,\n      rgba(193, 193, 193, 0.1279105392156863) 100%\n    );\n    height: 1px;\n  }\n}\n",".button-icon {\n  width: 24px;\n  height: 24px;\n  padding: 2px;\n  border-radius: 100%;\n  border: 1px solid #f0f0f1;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  cursor: pointer;\n  fill: #64748b;\n  transition: all ease 0.2s;\n  margin-left: auto;\n}\n\n.button-icon:hover {\n  background-color: #475569;\n  border: 1px solid #475569;\n  fill: #e2e8f0;\n}\n\n.theme__dark .button-icon {\n  border: 1px solid #475569;\n  fill: #94a3b8;\n}\n\n.theme__dark .button-icon:hover {\n  background-color: #64748b;\n  border: 1px solid #64748b;\n  fill: #f1f5f9;\n}\n",".body-style {\n  color: black;\n}\n\n.theme__dark .body-style {\n  color: white;\n}\n"]} */`,n.appendChild(i);var s=document.createElement("div");n.appendChild(s),setTimeout(function(){return xce.createRoot(s).render(We.jsx(eGe,po({},e)))},50),iX=!0}(t),zj.next(!0)},jj=function(){var t=Promise.resolve("");Lh({title:"",body:"",buttons:[],openBugReport:!0,pairingPayload:{walletConnectSyncCode:t,p2pSyncCode:t,postmessageSyncCode:t,networkType:Ox.MAINNET}})},Fj=function(){zj.next(!1)},eGe=function(t){var e=Zr($t.useState(!0),2),r=e[0],n=e[1],i=Zr($t.useState(!1),2),s=i[0],o=i[1],c=Zr($t.useState(t),2),u=c[0],f=c[1];$t.useEffect(function(){var g=[];return g.push(zj.subscribe(function(m){return n(m)})),g.push(_le.subscribe(function(m){return f(m)})),function(){return g.forEach(function(m){return m.unsubscribe()})}},[]),$t.useEffect(function(){r?o(!0):setTimeout(function(){return o(!1)},300)},[r]);var d=po(po({},u),{},{onClose:function(){Fj(),u.closeButtonCallback&&u.closeButtonCallback()},open:r,closeOnBackdropClick:!0}),p=function(){return u.pairingPayload||u.openBugReport?We.jsx(JWe,po({},d)):We.jsx(_We,po({},d))};return We.jsxs("div",{className:"theme__".concat(Jle()),children:[s&&We.jsx(p,{})," "]})};(function(t){t[t.DESKTOP=0]="DESKTOP",t[t.IOS=1]="IOS",t[t.ANDROID=2]="ANDROID"})(tX||(tX={})),function(t){t.IOS="ios",t.ANDROID="android",t.EXTENSION="extension",t.DESKTOP="desktop",t.WEB="web"}(rX||(rX={}));vce(function t(){yce(this,t)});var s8,tGe=function(t){var e,r,n,i,s,o,c=Zr($t.useState(!0),2),u=c[0],f=c[1],d=t.label.includes("{{wallet}}")&&t.walletInfo,p=t.label.includes("Request sent to"),g=Zr($t.useState([0,0]),2),m=Zr(g[0],2),x=m[0],A=m[1],D=g[1],O=Zr($t.useState(!1),2),z=O[0],j=O[1],Q=(e=function(N){var U=Zr(N.offset,2),M=U[0],y=U[1];D([M,y])},r=$t.useRef({startX:0,startY:0,isDragging:!1}),n=$t.useRef([0,0]),i=function(N){N.preventDefault(),r.current.isDragging=!0,r.current.startX=N.clientX-n.current[0],r.current.startY=N.clientY-n.current[1],document.addEventListener("mousemove",s),document.addEventListener("mouseup",o)},s=function(N){if(r.current.isDragging){var U=N.clientX-r.current.startX,M=N.clientY-r.current.startY;n.current=[U,M],e({offset:[U,M]})}},o=function(){r.current.isDragging=!1,document.removeEventListener("mousemove",s),document.removeEventListener("mouseup",o)},function(){return{onMouseDown:i}}),H=Hd(window);$t.useEffect(function(){p&&(f(!1),setTimeout(function(){f(!0)},3e3))},[p]),$t.useEffect(function(){t.open&&j(!1)},[t.open]);var W,F,b;return We.jsxs("div",po(po({onAnimationEnd:function(){t.open&&j(!0)},style:{position:"absolute",transform:"translate3d(".concat(x,"px, ").concat(A,"px, 0)"),touchAction:"none",minWidth:H?void 0:460,animation:t.open&&z?"none":void 0},className:t.open?"toast-wrapper-show":"toast-wrapper-hide"},H?void 0:Q()),{},{children:[We.jsxs("div",{className:"toast-header",children:[We.jsx(Mce,{}),d&&t.walletInfo&&We.jsx(We.Fragment,{children:(W=t.label,F=t.walletInfo,b=/({{\s*wallet\s*}})/g,W.split(b).map(function(N,U){return N.match(b)?We.jsxs(tPe.Fragment,{children:[We.jsx("img",{draggable:!1,src:F.icon,alt:"".concat(F.name," icon")}),We.jsx("h3",{children:F.name})]},U):We.jsx("p",{className:"toast-label",children:N},U)}))}),!d&&We.jsx("p",{className:"toast-label",children:t.label}),!Hd(window)&&t.openWalletAction&&We.jsx("div",{className:"toast-action-button",onClick:t.openWalletAction,children:"Open Wallet"}),We.jsx(jD,{onClick:t.onClickClose,children:We.jsx(Sce,{})})]}),t.actions&&u&&We.jsx("div",{className:"toast-body",children:t.actions.map(function(N,U){return We.jsxs("div",{className:"toast-action-wrapper",children:[We.jsx("p",{className:"toast-action-label ".concat(N.isBold?"toast-action-bold":""),children:N.text}),N.actionText&&We.jsx("div",{className:"toast-action-button",onClick:N.actionCallback,children:N.actionText})]},U)})})]}))},sX=!1,Bj=new rA,Vj=new rA,aX=0,a8=0,fd=function(t){var e=Date.now();e-aX>2e3?a8=1:a8++,aX=e,sX?setTimeout(function(){return Bj.next(t)},a8===1?0:500+100*(a8-2)):function(r){var n=document.createElement("beacon-toast");document.body.prepend(n);var i=n.attachShadow({mode:"open"}),s=document.createElement("style");s.textContent=`.toast-wrapper-show{animation:toastIn .3s ease forwards}.toast-wrapper-hide,.toast-wrapper-show{background-color:#fff;border-radius:6px;-webkit-box-shadow:0 4px 11px -4px rgba(0,0,0,.45);-moz-box-shadow:0 4px 11px -4px rgba(0,0,0,.45);box-shadow:0 4px 11px -4px rgba(0,0,0,.45);cursor:move;max-width:460px;overflow:hidden;position:fixed;right:12px;top:12px;user-select:none;z-index:1000000}.toast-wrapper-hide{animation:toastOut .3s ease forwards}@keyframes toastIn{0%{opacity:0;transform:translateY(-150px) scale(.2)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes toastOut{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-150px) scale(.2)}}.toast-header{align-items:center;display:flex;gap:6px;overflow:hidden;padding:0 .6em 0 1.2em;position:relative}.toast-header img{width:24px}.toast-header h3{color:#334155;font-size:.8em;font-weight:700;margin:14px auto 13px 0}.toast-label{color:#334155;font-size:.9em;margin:1em 0}.toast-button-icon{margin-left:auto}.toast-body{padding:.6em 1.2em}.toast-action-wrapper{align-items:center;display:flex;justify-content:space-between}.toast-action-label{color:#64748b;font-size:.8em;margin:.8em 0}.toast-action-bold{color:#334155;font-weight:700}.toast-action-button{border-radius:6px;color:#3880ff;cursor:pointer;font-size:.8em;font-weight:600;padding:.4em .8em;transition:all .2s ease}.toast-action-button:hover{background-color:#e4eeff;transition:all .2s ease}@media only screen and (max-width:800px){.toast-wrapper-hide,.toast-wrapper-show{width:calc(100% - 24px)}}.theme__dark .toast-wrapper-hide,.theme__dark .toast-wrapper-show{background-color:#27334c;-webkit-box-shadow:0 4px 11px -4px rgba(0,0,0,.65);-moz-box-shadow:0 4px 11px -4px rgba(0,0,0,.65);box-shadow:0 4px 11px -4px rgba(0,0,0,.65)}.theme__dark .toast-header h3,.theme__dark .toast-label{color:#e2e8f0}.theme__dark .toast-action-label{color:#94a3b8}.theme__dark .toast-action-bold{color:#e2e8f0}.theme__dark .toast-action-button{color:#60a5fa}.theme__dark .toast-action-button:hover{background-color:#1e293b}.loader{background-color:#ddd;bottom:0;left:0;overflow:hidden;position:relative;width:100%}.loader,.loader:before{height:3px;position:absolute}.loader:before{-webkit-animation:lineAnim 1s linear infinite;-moz-animation:lineAnim 1s linear infinite;animation:lineAnim 1s linear infinite;background-color:#3880ff;content:"";left:-50%;width:40%}@keyframes lineAnim{0%{left:-40%}50%{left:20%;width:80%}to{left:100%;width:100%}}.button-icon{fill:#64748b;align-items:center;border:1px solid #f0f0f1;border-radius:100%;cursor:pointer;display:flex;height:24px;justify-content:center;margin-left:auto;padding:2px;transition:all .2s ease;width:24px}.button-icon:hover{fill:#e2e8f0;background-color:#475569;border:1px solid #475569}.theme__dark .button-icon{fill:#94a3b8;border:1px solid #475569}.theme__dark .button-icon:hover{fill:#f1f5f9;background-color:#64748b;border:1px solid #64748b}
|
|
126
126
|
/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../components/toast/styles.css","../../components/loader/styles.css","../../components/button-icon/button-icon.css"],"names":[],"mappings":"AAAA,oBAeE,mCACF,CAEA,wCAbE,qBAAuB,CAIvB,iBAAkB,CAElB,kDAAyD,CACzD,+CAAsD,CACtD,0CAAiD,CAXjD,WAAY,CACZ,eAAgB,CAChB,eAAgB,CAEhB,cAAe,CAEf,UAAW,CADX,QAAS,CANT,gBAAiB,CASjB,eAwBF,CAhBA,oBAeE,oCACF,CAGA,mBACE,GAEE,SAAU,CADV,sCAEF,CACA,GAEE,SAAU,CADV,gCAEF,CACF,CAEA,oBACE,GAEE,SAAU,CADV,gCAEF,CACA,GAEE,SAAU,CADV,sCAEF,CACF,CAEA,cAGE,kBAAmB,CADnB,YAAa,CAEb,OAAQ,CACR,eAAgB,CAJhB,sBAA4B,CAK5B,iBACF,CAEA,kBACE,UACF,CAEA,iBAEE,aAAc,CACd,cAAgB,CAFhB,eAAiB,CAGjB,uBACF,CAEA,aAEE,aAAc,CACd,cAAgB,CAFhB,YAGF,CAEA,mBACE,gBACF,CAEA,YACE,kBACF,CAEA,sBAEE,kBAAmB,CADnB,YAAa,CAEb,6BACF,CAEA,oBAGE,aAAc,CADd,cAAgB,CADhB,aAGF,CAEA,mBAEE,aAAc,CADd,eAEF,CAEA,qBAME,iBAAkB,CAFlB,aAAc,CAHd,cAAe,CACf,cAAgB,CAChB,eAAgB,CAIhB,iBAAoB,CAFpB,uBAGF,CAEA,2BACE,wBAAyB,CACzB,uBACF,CAEA,yCAKE,wCACE,uBACF,CACF,CASA,kEACE,wBAAyB,CACzB,kDAAyD,CACzD,+CAAsD,CACtD,0CACF,CAMA,wDACE,aACF,CAEA,iCACE,aACF,CAEA,gCACE,aACF,CAEA,kCACE,aACF,CAEA,wCACE,wBACF,CC3KA,QAGE,qBAAsB,CAItB,QAAW,CADX,MAAS,CAET,eAAgB,CANhB,iBAAkB,CAGlB,UAIF,CAEA,uBAVE,UAAW,CAGX,iBAiBF,CAVA,eAOE,6CAA8C,CAC9C,0CAA2C,CAC3C,qCAAsC,CAHtC,wBAAyB,CALzB,UAAW,CAEX,SAAU,CAEV,SAKF,CAEA,oBACE,GACE,SACF,CACA,IACE,QAAS,CACT,SACF,CACA,GACE,SAAU,CACV,UACF,CACF,CCnCA,aAUE,YAAa,CAHb,kBAAmB,CAFnB,wBAAyB,CADzB,kBAAmB,CAKnB,cAAe,CAHf,YAAa,CAJb,WAAY,CAMZ,sBAAuB,CAIvB,gBAAiB,CATjB,WAAY,CAQZ,uBAAyB,CAVzB,UAYF,CAEA,mBAGE,YAAa,CAFb,wBAAyB,CACzB,wBAEF,CAEA,0BAEE,YAAa,CADb,wBAEF,CAEA,gCAGE,YAAa,CAFb,wBAAyB,CACzB,wBAEF","file":"aggregated.css","sourcesContent":[".toast-wrapper-show {\n  user-select: none;\n  cursor: move;\n  max-width: 460px;\n  overflow: hidden;\n  background-color: white;\n  position: fixed;\n  top: 12px;\n  right: 12px;\n  border-radius: 6px;\n  z-index: 1000000;\n  -webkit-box-shadow: 0px 4px 11px -4px rgba(0, 0, 0, 0.45);\n  -moz-box-shadow: 0px 4px 11px -4px rgba(0, 0, 0, 0.45);\n  box-shadow: 0px 4px 11px -4px rgba(0, 0, 0, 0.45);\n  /* Apply fade-in animation */\n  animation: toastIn 0.3s ease forwards;\n}\n\n.toast-wrapper-hide {\n  user-select: none;\n  cursor: move;\n  max-width: 460px;\n  overflow: hidden;\n  background-color: white;\n  position: fixed;\n  top: 12px;\n  right: 12px;\n  border-radius: 6px;\n  z-index: 1000000;\n  -webkit-box-shadow: 0px 4px 11px -4px rgba(0, 0, 0, 0.45);\n  -moz-box-shadow: 0px 4px 11px -4px rgba(0, 0, 0, 0.45);\n  box-shadow: 0px 4px 11px -4px rgba(0, 0, 0, 0.45);\n  /* Apply fade-out animation */\n  animation: toastOut 0.3s ease forwards;\n}\n\n/* Keyframes for the toast animations */\n@keyframes toastIn {\n  from {\n    transform: translateY(-150px) scale(0.2);\n    opacity: 0;\n  }\n  to {\n    transform: translateY(0) scale(1);\n    opacity: 1;\n  }\n}\n\n@keyframes toastOut {\n  from {\n    transform: translateY(0) scale(1);\n    opacity: 1;\n  }\n  to {\n    transform: translateY(-150px) scale(0.2);\n    opacity: 0;\n  }\n}\n\n.toast-header {\n  padding: 0px 0.6em 0px 1.2em;\n  display: flex;\n  align-items: center;\n  gap: 6px;\n  overflow: hidden;\n  position: relative;\n}\n\n.toast-header img {\n  width: 24px;\n}\n\n.toast-header h3 {\n  font-weight: bold;\n  color: #334155;\n  font-size: 0.8em;\n  margin: 14px auto 13px 0;\n}\n\n.toast-label {\n  margin: 1em 0em 1em 0em;\n  color: #334155;\n  font-size: 0.9em;\n}\n\n.toast-button-icon {\n  margin-left: auto;\n}\n\n.toast-body {\n  padding: 0.6em 1.2em;\n}\n\n.toast-action-wrapper {\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n}\n\n.toast-action-label {\n  margin: 0.8em 0em;\n  font-size: 0.8em;\n  color: #64748b;\n}\n\n.toast-action-bold {\n  font-weight: bold;\n  color: #334155;\n}\n\n.toast-action-button {\n  cursor: pointer;\n  font-size: 0.8em;\n  font-weight: 600;\n  color: #3880ff;\n  transition: all ease 0.2s;\n  border-radius: 6px;\n  padding: 0.4em 0.8em;\n}\n\n.toast-action-button:hover {\n  background-color: #e4eeff;\n  transition: all ease 0.2s;\n}\n\n@media only screen and (max-width: 800px) {\n  .toast-wrapper-show {\n    width: calc(100% - 24px);\n  }\n\n  .toast-wrapper-hide {\n    width: calc(100% - 24px);\n  }\n}\n\n.theme__dark .toast-wrapper-show {\n  background-color: #27334c;\n  -webkit-box-shadow: 0px 4px 11px -4px rgba(0, 0, 0, 0.65);\n  -moz-box-shadow: 0px 4px 11px -4px rgba(0, 0, 0, 0.65);\n  box-shadow: 0px 4px 11px -4px rgba(0, 0, 0, 0.65);\n}\n\n.theme__dark .toast-wrapper-hide {\n  background-color: #27334c;\n  -webkit-box-shadow: 0px 4px 11px -4px rgba(0, 0, 0, 0.65);\n  -moz-box-shadow: 0px 4px 11px -4px rgba(0, 0, 0, 0.65);\n  box-shadow: 0px 4px 11px -4px rgba(0, 0, 0, 0.65);\n}\n\n.theme__dark .toast-header h3 {\n  color: #e2e8f0;\n}\n\n.theme__dark .toast-label {\n  color: #e2e8f0;\n}\n\n.theme__dark .toast-action-label {\n  color: #94a3b8;\n}\n\n.theme__dark .toast-action-bold {\n  color: #e2e8f0;\n}\n\n.theme__dark .toast-action-button {\n  color: #60a5fa;\n}\n\n.theme__dark .toast-action-button:hover {\n  background-color: #1e293b;\n}\n",".loader {\n  height: 3px;\n  position: relative;\n  background-color: #ddd;\n  position: absolute;\n  width: 100%;\n  left: 0px;\n  bottom: 0px;\n  overflow: hidden;\n}\n\n.loader:before {\n  content: '';\n  position: absolute;\n  left: -50%;\n  height: 3px;\n  width: 40%;\n  background-color: #3880ff;\n  -webkit-animation: lineAnim 1s linear infinite;\n  -moz-animation: lineAnim 1s linear infinite;\n  animation: lineAnim 1s linear infinite;\n}\n\n@keyframes lineAnim {\n  0% {\n    left: -40%;\n  }\n  50% {\n    left: 20%;\n    width: 80%;\n  }\n  100% {\n    left: 100%;\n    width: 100%;\n  }\n}\n",".button-icon {\n  width: 24px;\n  height: 24px;\n  padding: 2px;\n  border-radius: 100%;\n  border: 1px solid #f0f0f1;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  cursor: pointer;\n  fill: #64748b;\n  transition: all ease 0.2s;\n  margin-left: auto;\n}\n\n.button-icon:hover {\n  background-color: #475569;\n  border: 1px solid #475569;\n  fill: #e2e8f0;\n}\n\n.theme__dark .button-icon {\n  border: 1px solid #475569;\n  fill: #94a3b8;\n}\n\n.theme__dark .button-icon:hover {\n  background-color: #64748b;\n  border: 1px solid #64748b;\n  fill: #f1f5f9;\n}\n"]} */`,i.appendChild(s);var o=document.createElement("div");i.appendChild(o),setTimeout(function(){return xce.createRoot(o).render(We.jsx(rGe,po({},r)))},50),sX=!0}(t),s8&&(clearTimeout(s8),s8=void 0),s8=t.timer?setTimeout(function(){return ad()},t.timer):void 0,Vj.next(!0)},ad=function(){Bj.next(void 0),Vj.next(!1)},rGe=function(t){var e=Zr($t.useState(t),2),r=e[0],n=e[1],i=Zr($t.useState(!0),2),s=i[0],o=i[1],c=Zr($t.useState(!1),2),u=c[0],f=c[1];return $t.useEffect(function(){var d=[];return d.push(Bj.subscribe(function(p){n(p)})),d.push(Vj.subscribe(function(p){o(p)})),function(){return d.forEach(function(p){return p.unsubscribe()})}},[]),$t.useEffect(function(){r?s&&f(!0):f(!1)},[s,r]),We.jsx(We.Fragment,{children:We.jsx("div",{className:"theme__".concat(Jle()),children:u&&r&&We.jsx(tGe,{label:r.body,open:s,onClickClose:ad,actions:r.actions,walletInfo:r.walletInfo,openWalletAction:r.openWalletAction})})})};const oA=t=>t.length>=12?`${t.substr(0,5)}...${t.substr(-5)}`:t,Qg=new bj("BeaconEvents"),d1=5*1e3;var It;(function(t){t.PERMISSION_REQUEST_SENT="PERMISSION_REQUEST_SENT",t.PERMISSION_REQUEST_SUCCESS="PERMISSION_REQUEST_SUCCESS",t.PERMISSION_REQUEST_ERROR="PERMISSION_REQUEST_ERROR",t.PROOF_OF_EVENT_CHALLENGE_REQUEST_SENT="PROOF_OF_EVENT_CHALLENGE_REQUEST_SENT",t.PROOF_OF_EVENT_CHALLENGE_REQUEST_SUCCESS="PROOF_OF_EVENT_CHALLENGE_REQUEST_SUCCESS",t.PROOF_OF_EVENT_CHALLENGE_REQUEST_ERROR="PROOF_OF_EVENT_CHALLENGE_REQUEST_ERROR",t.SIMULATED_PROOF_OF_EVENT_CHALLENGE_REQUEST_SENT="SIMULATED_PROOF_OF_EVENT_CHALLENGE_REQUEST_SENT",t.SIMULATED_PROOF_OF_EVENT_CHALLENGE_REQUEST_SUCCESS="SIMULATED_PROOF_OF_EVENT_CHALLENGE_REQUEST_SUCCESS",t.SIMULATED_PROOF_OF_EVENT_CHALLENGE_REQUEST_ERROR="SIMULATED_PROOF_OF_EVENT_CHALLENGE_REQUEST_ERROR",t.OPERATION_REQUEST_SENT="OPERATION_REQUEST_SENT",t.OPERATION_REQUEST_SUCCESS="OPERATION_REQUEST_SUCCESS",t.OPERATION_REQUEST_ERROR="OPERATION_REQUEST_ERROR",t.SIGN_REQUEST_SENT="SIGN_REQUEST_SENT",t.SIGN_REQUEST_SUCCESS="SIGN_REQUEST_SUCCESS",t.SIGN_REQUEST_ERROR="SIGN_REQUEST_ERROR",t.BLOCKCHAIN_REQUEST_SUCCESS="BLOCKCHAIN_REQUEST_SUCCESS",t.BROADCAST_REQUEST_SENT="BROADCAST_REQUEST_SENT",t.BROADCAST_REQUEST_SUCCESS="BROADCAST_REQUEST_SUCCESS",t.BROADCAST_REQUEST_ERROR="BROADCAST_REQUEST_ERROR",t.ACKNOWLEDGE_RECEIVED="ACKNOWLEDGE_RECEIVED",t.LOCAL_RATE_LIMIT_REACHED="LOCAL_RATE_LIMIT_REACHED",t.NO_PERMISSIONS="NO_PERMISSIONS",t.ACTIVE_ACCOUNT_SET="ACTIVE_ACCOUNT_SET",t.ACTIVE_TRANSPORT_SET="ACTIVE_TRANSPORT_SET",t.SHOW_PREPARE="SHOW_PREPARE",t.HIDE_UI="HIDE_UI",t.INVALID_ACTIVE_ACCOUNT_STATE="INVALID_ACTIVE_ACCOUNT_STATE",t.INVALID_ACCOUNT_DEACTIVATED="INVALID_ACCOUNT_DEACTIVATED",t.PAIR_INIT="PAIR_INIT",t.PAIR_SUCCESS="PAIR_SUCCESS",t.CHANNEL_CLOSED="CHANNEL_CLOSED",t.GENERIC_ERROR="GENERIC_ERROR",t.OPEN_BUG_REPORT="OPEN_BUG_REPORT",t.RELAYER_ERROR="RELAYER_ERROR",t.INTERNAL_ERROR="INTERNAL_ERROR",t.UNKNOWN="UNKNOWN"})(It||(It={}));const dv=async t=>{let e;const r=[];if(t.walletInfo.deeplink&&(t.walletInfo.type==="web"||t.walletInfo.type==="mobile"&&zD(window)||t.walletInfo.type==="desktop"&&!zD(window))){const n=t.walletInfo.deeplink;e=async()=>{const i=document.createElement("a");i.setAttribute("rel","noopener"),i.setAttribute("href",n),i.setAttribute("target","_blank"),i.dispatchEvent(new MouseEvent("click",{view:window,bubbles:!0,cancelable:!0}))}}r.push({text:"No answer from your wallet received yet. Please make sure the wallet is open.",isBold:!0}),r.push({text:"Wallet not receiving request?",actionText:"Reset Connection",actionCallback:async()=>{ad();const n=t.extraInfo.resetCallback;n&&(Qg.log("showSentToast","resetCallback invoked"),await n())}}),r.push({text:"Do you wish to report a bug?",actionText:"Open",actionCallback:async()=>{ad(),jj()}}),fd({body:"Request sent to {{wallet}}",walletInfo:t.walletInfo,state:"loading",timer:Hd(window)?d1:0,actions:r,openWalletAction:e})},nGe=async t=>{fd({body:"Awaiting confirmation in {{wallet}}",state:"acknowledge",walletInfo:t.walletInfo})},iGe=async t=>{const e=t.walletInfo?"Preparing Request for {{wallet}}...":"Preparing Request...";fd({body:e,state:"prepare",walletInfo:t.walletInfo})},sGe=t=>{t!=null&&t.includes("alert")&&Fj(),(t!=null&&t.includes("toast")||!t)&&ad()},aGe=async()=>{Lh({title:"No Permission",body:"Please allow the wallet to handle this type of request."})},oGe=async()=>{Lh({title:"Invalid state",body:`An active account has been received, but no active subscription was found for BeaconEvent.ACTIVE_ACCOUNT_SET.
|
|
127
127
|
For more information, visit: https://docs.walletbeacon.io/guides/migration-guide`})},cGe=async()=>{await Lh({title:"Error",body:"Your session has expired. Please pair with your wallet again."})},lGe=async t=>{Lh({title:`${t}`,body:"Please try again. If this problem persists please send us a bug report.",buttons:[{label:"Send Report",type:"primary",onClick:()=>jj()}]})},hv=async(t,e)=>{var i,s,o,c,u;const r=t.errorResponse.errorType?Kqe(t.errorResponse.errorType,t.errorResponse.errorData):new mce,n=[{text:r.title,isBold:!0}];if(t.errorResponse.errorType===Ci.TRANSACTION_INVALID_ERROR&&t.errorResponse.errorData){const f=t.errorResponse.errorData,d=t.errorMessages;let p=!1;if((i=f[0])!=null&&i.contract_handle&&d&&(d!=null&&d[f[0].contract_handle])){const g=((o=(s=f[1])==null?void 0:s.with)==null?void 0:o.int)??((u=(c=f[1])==null?void 0:c.with)==null?void 0:u.string),m=d==null?void 0:d[f[0].contract_handle];g&&(m!=null&&m[g])&&(n.push({text:m==null?void 0:m[g],isBold:!0}),p=!0)}p||n.push({text:r.description}),n.push({text:"",actionText:"Show Details",actionCallback:async()=>{ad(),Lh({title:r.title,body:r.fullDescription.description,data:r.fullDescription.data,buttons:e})}})}fd({body:"{{wallet}} has returned an error",timer:t.errorResponse.errorType===Ci.ABORTED_ERROR?d1:void 0,state:"finished",walletInfo:t.walletInfo,actions:n})},uGe=async()=>{Lh({title:"Error",body:"Rate limit reached. Please slow down",buttons:[{text:"Done",style:"outline"}],timer:3e3})},fGe=()=>{Fj()},dGe=async()=>{await jj()},hGe=async()=>{Lh({title:"Error",body:"Failed to connect to the relayer. Please check that your system time is synchronized with the current time and reload the page.",buttons:[{text:"Done",style:"outline"}],timer:1500})},pGe=async()=>{},gGe=async t=>{const e=[...t.buttons??[]];e.push({text:"Done",style:"outline"});const r={title:"Internal Error",body:t.text,buttons:e};Lh(r)},bGe=async t=>{Qg.log("showPairAlert");const e={title:"Choose your preferred wallet",body:"<p></p>",pairingPayload:{p2pSyncCode:t.p2pPeerInfo,walletConnectSyncCode:t.walletConnectPeerInfo,postmessageSyncCode:t.postmessagePeerInfo,networkType:t.networkType},closeButtonCallback:t.abortedHandler,disclaimerText:t.disclaimerText,analytics:t.analytics,featuredWallets:t.featuredWallets,substratePairing:t.substratePairing};Lh(e)},mGe=async t=>{const{output:e}=t,r=[{text:"Address",actionText:oA(e.address),isBold:!0}];e.network.type!=="substrate"&&(r.push({text:"Network",actionText:`${e.network.type}`}),r.push({text:"Permissions",actionText:e.scopes.join(", ")})),fd({body:"{{wallet}} has granted permission",timer:d1,walletInfo:t.walletInfo,state:"finished",actions:r})},yGe=async t=>{const{output:e}=t;fd({body:`{{wallet}} has ${e.isAccepted?"accepted":"refused"} the challenge`,timer:d1,walletInfo:t.walletInfo,state:"finished",actions:e.isAccepted?[{text:`Payload hash: ${e.payloadHash}`,actionText:"Copy to clipboard",actionCallback:async()=>{navigator.clipboard.writeText(e.payloadHash).then(()=>{Qg.log("showSignSuccessAlert","Copying to clipboard was successful!")},r=>{Qg.error("showSignSuccessAlert","Could not copy text to clipboard: ",r)}),ad()}}]:[]})},vGe=async t=>{const{output:e}=t;fd({body:e.errorMessage?"{{wallet}} has returned an error":"{{wallet}} has returned the list of operation",timer:d1,walletInfo:t.walletInfo,state:"finished",actions:e.errorMessage?[{text:"Error message",actionText:e.errorMessage}]:[{text:"Operation list",actionText:"Copy to clipboard",actionCallback:async()=>{navigator.clipboard.writeText(e.operationsList).then(()=>{Qg.log("showSignSuccessAlert","Copying to clipboard was successful!")},r=>{Qg.error("showSignSuccessAlert","Could not copy text to clipboard: ",r)}),ad()}}]})},EGe=async t=>{const{account:e,output:r,blockExplorer:n}=t;fd({body:"{{wallet}} successfully submitted operation",timer:d1,state:"finished",walletInfo:t.walletInfo,actions:[{text:oA(r.transactionHash),isBold:!0,actionText:"Open Blockexplorer",actionLogo:"external",actionCallback:async()=>{const i=await n.getTransactionLink(r.transactionHash,e.network);window.open(i,"_blank","noopener"),ad()}}]})},wGe=async t=>{const e=t.output;fd({body:"{{wallet}} successfully signed payload",timer:d1,state:"finished",walletInfo:t.walletInfo,actions:[{text:`Signature: ${oA(e.signature)}`,actionText:"Copy to clipboard",actionCallback:async()=>{navigator.clipboard.writeText(e.signature).then(()=>{Qg.log("showSignSuccessAlert","Copying to clipboard was successful!")},r=>{Qg.error("showSignSuccessAlert","Could not copy text to clipboard: ",r)}),ad()}}]})},IGe=async t=>{fd({body:"{{wallet}} request successfully executed",timer:d1,state:"finished",walletInfo:t.walletInfo})},xGe=async t=>{const{network:e,output:r,blockExplorer:n}=t;fd({body:"{{wallet}} successfully injected operation",timer:d1,state:"finished",walletInfo:t.walletInfo,actions:[{text:oA(r.transactionHash),isBold:!0,actionText:"Open Blockexplorer",actionLogo:"external",actionCallback:async()=>{const i=await n.getTransactionLink(r.transactionHash,e);window.open(i,"_blank","noopener"),ad()}}]})},mO=()=>async()=>{};It.PERMISSION_REQUEST_SENT+"",It.PERMISSION_REQUEST_SUCCESS+"",It.PERMISSION_REQUEST_ERROR+"",It.PROOF_OF_EVENT_CHALLENGE_REQUEST_SENT+"",It.PROOF_OF_EVENT_CHALLENGE_REQUEST_SUCCESS+"",It.PROOF_OF_EVENT_CHALLENGE_REQUEST_ERROR+"",It.SIMULATED_PROOF_OF_EVENT_CHALLENGE_REQUEST_SENT+"",It.SIMULATED_PROOF_OF_EVENT_CHALLENGE_REQUEST_SUCCESS+"",It.SIMULATED_PROOF_OF_EVENT_CHALLENGE_REQUEST_ERROR+"",It.OPERATION_REQUEST_SENT+"",It.OPERATION_REQUEST_SUCCESS+"",It.OPERATION_REQUEST_ERROR+"",It.SIGN_REQUEST_SENT+"",It.SIGN_REQUEST_SUCCESS+"",It.SIGN_REQUEST_ERROR+"",It.BROADCAST_REQUEST_SENT+"",It.BROADCAST_REQUEST_SUCCESS+"",It.BROADCAST_REQUEST_ERROR+"",It.ACKNOWLEDGE_RECEIVED+"",It.LOCAL_RATE_LIMIT_REACHED+"",It.NO_PERMISSIONS+"",It.ACTIVE_ACCOUNT_SET+"",mO(),It.ACTIVE_TRANSPORT_SET+"",mO(),It.INVALID_ACTIVE_ACCOUNT_STATE+"",It.GENERIC_ERROR+"",It.INVALID_ACCOUNT_DEACTIVATED+"",It.SHOW_PREPARE+"",It.HIDE_UI+"",It.PAIR_INIT+"",It.PAIR_SUCCESS+"",It.OPEN_BUG_REPORT+"",It.RELAYER_ERROR+"",It.CHANNEL_CLOSED+"",It.INTERNAL_ERROR+"",It.BLOCKCHAIN_REQUEST_SUCCESS+"",It.UNKNOWN+"",mO();Ps.BlockchainRequest+"",It.OPERATION_REQUEST_SENT,It.BLOCKCHAIN_REQUEST_SUCCESS,It.OPERATION_REQUEST_ERROR,Ps.BlockchainResponse+"",It.UNKNOWN,It.UNKNOWN,It.UNKNOWN,Ps.PermissionRequest+"",It.PERMISSION_REQUEST_SENT,It.PERMISSION_REQUEST_SUCCESS,It.PERMISSION_REQUEST_ERROR,Ps.PermissionResponse+"",It.UNKNOWN,It.UNKNOWN,It.UNKNOWN,Ps.ProofOfEventChallengeRequest+"",It.PROOF_OF_EVENT_CHALLENGE_REQUEST_SENT,It.PROOF_OF_EVENT_CHALLENGE_REQUEST_SUCCESS,It.PROOF_OF_EVENT_CHALLENGE_REQUEST_ERROR,Ps.ProofOfEventChallengeResponse+"",It.UNKNOWN,It.UNKNOWN,It.UNKNOWN,Ps.SimulatedProofOfEventChallengeRequest+"",It.SIMULATED_PROOF_OF_EVENT_CHALLENGE_REQUEST_SENT,It.SIMULATED_PROOF_OF_EVENT_CHALLENGE_REQUEST_SUCCESS,It.SIMULATED_PROOF_OF_EVENT_CHALLENGE_REQUEST_ERROR,Ps.SimulatedProofOfEventChallengeResponse+"",It.UNKNOWN,It.UNKNOWN,It.UNKNOWN,Ps.OperationRequest+"",It.OPERATION_REQUEST_SENT,It.OPERATION_REQUEST_SUCCESS,It.OPERATION_REQUEST_ERROR,Ps.OperationResponse+"",It.UNKNOWN,It.UNKNOWN,It.UNKNOWN,Ps.SignPayloadRequest+"",It.SIGN_REQUEST_SENT,It.SIGN_REQUEST_SUCCESS,It.SIGN_REQUEST_ERROR,Ps.SignPayloadResponse+"",It.UNKNOWN,It.UNKNOWN,It.UNKNOWN,Ps.BroadcastRequest+"",It.BROADCAST_REQUEST_SENT,It.BROADCAST_REQUEST_SUCCESS,It.BROADCAST_REQUEST_ERROR,Ps.BroadcastResponse+"",It.UNKNOWN,It.UNKNOWN,It.UNKNOWN,Ps.ChangeAccountRequest+"",It.UNKNOWN,It.UNKNOWN,It.UNKNOWN,Ps.Acknowledge+"",It.UNKNOWN,It.UNKNOWN,It.UNKNOWN,Ps.Disconnect+"",It.UNKNOWN,It.UNKNOWN,It.UNKNOWN,Ps.Error+"",It.UNKNOWN,It.UNKNOWN,It.UNKNOWN;var oX;(function(t){t.GET_ACCOUNTS="tezos_getAccounts",t.OPERATION_REQUEST="tezos_send",t.SIGN="tezos_sign"})(oX||(oX={}));var cX;(function(t){t.CHAIN_CHANGED="chainChanged",t.ACCOUNTS_CHANGED="accountsChanged",t.REQUEST_ACKNOWLEDGED="requestAcknowledged"})(cX||(cX={}));const $le=1e6,Yv={mainnet:{name:"Mainnet",rpcUrl:"https://mainnet.tezos.ecadinfra.com",tzktUrl:"https://tzkt.io",beaconNetwork:"mainnet"},shadownet:{name:"Shadownet",rpcUrl:"https://shadownet.tezos.ecadinfra.com",tzktUrl:"https://shadownet.tzkt.io",beaconNetwork:"custom"}},eue="selectedNetwork",SGe="mainnet";function tue(){const t=localStorage.getItem(eue);return t&&t in Yv?t:SGe}function MGe(t){localStorage.setItem(eue,t)}function NGe(){return Yv[tue()]}function _6(t){return t/$le}function g6(t){return Math.floor(t*$le)}function Zv(t,e=6){return t.toFixed(e).replace(/\.?0+$/,"")}function RGe(t,e=6,r=4){return t?t.length<=e+r?t:`${t.slice(0,e)}...${t.slice(-r)}`:""}async function qj(t){try{return await navigator.clipboard.writeText(t),!0}catch{const e=document.createElement("textarea");e.value=t,e.style.position="fixed",e.style.opacity="0",e.style.pointerEvents="none",document.body.appendChild(e),e.select();try{return document.execCommand("copy"),!0}catch{return!1}finally{document.body.removeChild(e)}}}function AGe(t){const e=NGe();window.open(`${e.tzktUrl}/${t}`,"_blank")}const Uy=SJ("wallet",()=>{const t=IO(null),e=IO(null),r=gr(null),n=gr(!1),i=gr(null),s=gr(tue()),o=Zc(()=>!!r.value),c=Zc(()=>Yv[s.value]);function u(A){return A.beaconNetwork==="mainnet"?{type:$N.MAINNET}:{type:$N.CUSTOM,name:A.name,rpcUrl:A.rpcUrl}}async function f(){if(t.value)return;const A=c.value;t.value=new nq(A.rpcUrl);const D=u(A);e.value=new bqe({name:"TezosX MCP",network:D}),t.value.setWalletProvider(e.value);const O=await e.value.client.getActiveAccount();O&&(r.value=O.address)}async function d(){i.value=null,n.value=!0;try{if(await f(),!e.value)throw new Error("Wallet not initialized");await e.value.requestPermissions();const A=await e.value.getPKH();return r.value=A,A}catch(A){return console.error("Failed to connect wallet:",A),i.value=A instanceof Error?A.message:"Failed to connect wallet",null}finally{n.value=!1}}async function p(){e.value&&await e.value.clearActiveAccount(),r.value=null,t.value=null}async function g(A){if(A===s.value)return;e.value&&await e.value.clearActiveAccount(),r.value=null,s.value=A,MGe(A);const D=c.value;if(!e.value){t.value=null,await f();return}t.value=new nq(D.rpcUrl),e.value.client.network=u(D),t.value.setWalletProvider(e.value)}async function m(A){return t.value||await f(),(await t.value.tz.getBalance(A)).toNumber()/1e6}function x(){return t.value}return{tezos:t,wallet:e,userAddress:r,isConnecting:n,error:i,networkId:s,isConnected:o,currentNetwork:c,init:f,connect:d,disconnect:p,switchNetwork:g,getBalance:m,getTezos:x}}),LGe=`{ parameter
|
|
128
|
-
(or (unit %
|
|
128
|
+
(or (unit %default)
|
|
129
129
|
(or (pair %withdraw (address %recipient) (mutez %amount))
|
|
130
130
|
(or (pair %set_limits (mutez %new_daily_limit) (mutez %new_per_tx_limit))
|
|
131
131
|
(or (address %set_spender)
|
|
@@ -275,4 +275,4 @@ Error generating stack: `+h.message+`
|
|
|
275
275
|
SPENDING_CONTRACT=${r.contractAddress}
|
|
276
276
|
TEZOS_NETWORK=${i.networkId}`}function m(){return`SPENDING_PRIVATE_KEY=${r.spendingKey}
|
|
277
277
|
SPENDING_CONTRACT=${r.contractAddress}
|
|
278
|
-
TEZOS_NETWORK=${i.networkId}`}return(x,A)=>(kt(),Vt("section",ZGe,[A[16]||(A[16]=m6('<div class="text-center mb-5"><div class="inline-flex items-center justify-center w-12 h-12 bg-green-100 rounded-full mb-3"><svg xmlns="http://www.w3.org/2000/svg" class="h-6 w-6 text-green-600" fill="none" viewBox="0 0 24 24" stroke="currentColor"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M5 13l4 4L19 7"></path></svg></div><h2 class="text-lg font-semibold text-text-primary">Contract Deployed Successfully</h2></div>',1)),Yt(s)&&t.configSaveFailed?(kt(),Vt("div",XGe,[A[7]||(A[7]=Oe("div",{class:"flex items-center gap-2 mb-2"},[Oe("svg",{xmlns:"http://www.w3.org/2000/svg",class:"h-5 w-5 text-red-600",viewBox:"0 0 20 20",fill:"currentColor"},[Oe("path",{"fill-rule":"evenodd",d:"M8.257 3.099c.765-1.36 2.722-1.36 3.486 0l5.58 9.92c.75 1.334-.213 2.98-1.742 2.98H4.42c-1.53 0-2.493-1.646-1.743-2.98l5.58-9.92zM11 13a1 1 0 11-2 0 1 1 0 012 0zm-1-8a1 1 0 00-1 1v3a1 1 0 002 0V6a1 1 0 00-1-1z","clip-rule":"evenodd"})]),Oe("span",{class:"font-semibold text-red-800"},"Failed to Save Configuration")],-1)),Oe("p",JGe,[A[5]||(A[5]=_n(" Your contract was deployed on-chain at ",-1)),Oe("code",_Ge,Nr(t.contractAddress),1),A[6]||(A[6]=_n(", but the spending key could not be saved to the MCP server. ",-1))]),Oe("button",{onClick:d,disabled:u.value,class:"btn-primary w-full flex items-center justify-center gap-2"},[u.value?(kt(),Vt("span",eKe)):Oi("",!0),_n(" "+Nr(u.value?"Saving...":"Retry Save"),1)],8,$Ge),f.value?(kt(),Vt("p",tKe,Nr(f.value),1)):Oi("",!0)])):Yt(s)?(kt(),Vt("div",rKe,[A[11]||(A[11]=m6('<div class="flex items-center gap-2 mb-2"><svg xmlns="http://www.w3.org/2000/svg" class="h-5 w-5 text-green-600" viewBox="0 0 20 20" fill="currentColor"><path fill-rule="evenodd" d="M10 18a8 8 0 100-16 8 8 0 000 16zm3.707-9.293a1 1 0 00-1.414-1.414L9 10.586 7.707 9.293a1 1 0 00-1.414 1.414l2 2a1 1 0 001.414 0l4-4z" clip-rule="evenodd"></path></svg><span class="font-semibold text-green-800">MCP Server Configured Automatically</span></div><p class="text-sm text-green-700 mb-4"> Your spending key and contract address have been saved to your MCP server. No manual configuration needed — your MCP tools are ready to use. </p>',2)),t.spendingKey?(kt(),Vt("div",nKe,[Oe("pre",iKe,Nr(g()),1),Oe("div",sKe,[Oe("button",{onClick:A[0]||(A[0]=D=>c.value=!c.value),class:"btn-secondary !py-1.5 !px-2",title:c.value?"Hide spending key":"Show spending key"},[c.value?(kt(),Vt("svg",cKe,[...A[9]||(A[9]=[Oe("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M13.875 18.825A10.05 10.05 0 0112 19c-4.478 0-8.268-2.943-9.543-7a9.97 9.97 0 011.563-3.029m5.858.908a3 3 0 114.243 4.243M9.878 9.878l4.242 4.242M9.88 9.88l-3.29-3.29m7.532 7.532l3.29 3.29M3 3l3.59 3.59m0 0A9.953 9.953 0 0112 5c4.478 0 8.268 2.943 9.543 7a10.025 10.025 0 01-4.132 5.411m0 0L21 21"},null,-1)])])):(kt(),Vt("svg",oKe,[...A[8]||(A[8]=[Oe("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M15 12a3 3 0 11-6 0 3 3 0 016 0z"},null,-1),Oe("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M2.458 12C3.732 7.943 7.523 5 12 5c4.478 0 8.268 2.943 9.542 7-1.274 4.057-5.064 7-9.542 7-4.477 0-8.268-2.943-9.542-7z"},null,-1)])]))],8,aKe),Oe("button",{onClick:A[1]||(A[1]=D=>p(m(),"env")),class:"btn-secondary flex-1 flex items-center justify-center gap-2"},[A[10]||(A[10]=Oe("svg",{xmlns:"http://www.w3.org/2000/svg",class:"h-4 w-4",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor"},[Oe("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M8 16H6a2 2 0 01-2-2V6a2 2 0 012-2h8a2 2 0 012 2v2m-6 12h8a2 2 0 002-2v-8a2 2 0 00-2-2h-8a2 2 0 00-2 2v8a2 2 0 002 2z"})],-1)),_n(" "+Nr(o.value==="env"?"Copied!":"Copy Environment Variables"),1)])])])):Oi("",!0)])):(kt(),Vt("div",lKe,[A[15]||(A[15]=m6('<div class="flex items-center gap-2 mb-2"><svg xmlns="http://www.w3.org/2000/svg" class="h-5 w-5 text-amber-600" viewBox="0 0 20 20" fill="currentColor"><path fill-rule="evenodd" d="M8.257 3.099c.765-1.36 2.722-1.36 3.486 0l5.58 9.92c.75 1.334-.213 2.98-1.742 2.98H4.42c-1.53 0-2.493-1.646-1.743-2.98l5.58-9.92zM11 13a1 1 0 11-2 0 1 1 0 012 0zm-1-8a1 1 0 00-1 1v3a1 1 0 002 0V6a1 1 0 00-1-1z" clip-rule="evenodd"></path></svg><span class="font-semibold text-amber-800">Manual Configuration Required</span></div><p class="text-sm text-amber-700 mb-4"> Set these environment variables on your MCP server. The spending key won't be shown again after you leave this page. </p>',2)),Oe("pre",uKe,Nr(g()),1),Oe("div",fKe,[Oe("button",{onClick:A[2]||(A[2]=D=>c.value=!c.value),class:"btn-secondary !py-1.5 !px-2",title:c.value?"Hide spending key":"Show spending key"},[c.value?(kt(),Vt("svg",pKe,[...A[13]||(A[13]=[Oe("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M13.875 18.825A10.05 10.05 0 0112 19c-4.478 0-8.268-2.943-9.543-7a9.97 9.97 0 011.563-3.029m5.858.908a3 3 0 114.243 4.243M9.878 9.878l4.242 4.242M9.88 9.88l-3.29-3.29m7.532 7.532l3.29 3.29M3 3l3.59 3.59m0 0A9.953 9.953 0 0112 5c4.478 0 8.268 2.943 9.543 7a10.025 10.025 0 01-4.132 5.411m0 0L21 21"},null,-1)])])):(kt(),Vt("svg",hKe,[...A[12]||(A[12]=[Oe("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M15 12a3 3 0 11-6 0 3 3 0 016 0z"},null,-1),Oe("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M2.458 12C3.732 7.943 7.523 5 12 5c4.478 0 8.268 2.943 9.542 7-1.274 4.057-5.064 7-9.542 7-4.477 0-8.268-2.943-9.542-7z"},null,-1)])]))],8,dKe),Oe("button",{onClick:A[3]||(A[3]=D=>p(m(),"env")),class:"btn-secondary flex-1 flex items-center justify-center gap-2"},[A[14]||(A[14]=Oe("svg",{xmlns:"http://www.w3.org/2000/svg",class:"h-4 w-4",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor"},[Oe("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M8 16H6a2 2 0 01-2-2V6a2 2 0 012-2h8a2 2 0 012 2v2m-6 12h8a2 2 0 002-2v-8a2 2 0 00-2-2h-8a2 2 0 00-2 2v8a2 2 0 002 2z"})],-1)),_n(" "+Nr(o.value==="env"?"Copied!":"Copy Environment Variables"),1)])])])),A[17]||(A[17]=m6('<div class="card-subtle p-4 mb-4 border border-amber-200 bg-amber-50/50"><div class="flex items-start gap-2"><svg xmlns="http://www.w3.org/2000/svg" class="h-5 w-5 text-amber-600 flex-shrink-0 mt-0.5" viewBox="0 0 20 20" fill="currentColor"><path fill-rule="evenodd" d="M8.257 3.099c.765-1.36 2.722-1.36 3.486 0l5.58 9.92c.75 1.334-.213 2.98-1.742 2.98H4.42c-1.53 0-2.493-1.646-1.743-2.98l5.58-9.92zM11 13a1 1 0 11-2 0 1 1 0 012 0zm-1-8a1 1 0 00-1 1v3a1 1 0 002 0V6a1 1 0 00-1-1z" clip-rule="evenodd"></path></svg><p class="text-sm text-amber-700"><strong>Next step:</strong> Send some XTZ to your spending contract so the MCP server has funds to work with. You can do this from the dashboard on the next page. </p></div></div>',1)),Oe("button",{onClick:A[4]||(A[4]=D=>n("continue")),class:"btn-primary w-full"}," Continue to Dashboard ")]))}}),bKe={class:"fixed inset-0 z-50 flex items-center justify-center"},mKe={class:"relative bg-white rounded-lg shadow-xl max-w-md w-full mx-4 p-6"},yKe={class:"flex justify-center mb-4"},vKe={key:0,xmlns:"http://www.w3.org/2000/svg",class:"h-6 w-6 text-red-600",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor"},EKe={key:1,xmlns:"http://www.w3.org/2000/svg",class:"h-6 w-6 text-amber-600",viewBox:"0 0 20 20",fill:"currentColor"},wKe={key:2,xmlns:"http://www.w3.org/2000/svg",class:"h-6 w-6 text-primary-600",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor"},IKe={class:"text-lg font-semibold text-center text-text-primary mb-2"},xKe={class:"text-sm text-text-muted text-center mb-6"},SKe={class:"flex gap-3"},MKe=["disabled"],NKe=["disabled"],RKe={key:0,class:"spinner"},iue=Eh({__name:"ConfirmationModal",props:{title:{},message:{},confirmText:{},cancelText:{},isLoading:{type:Boolean},variant:{}},emits:["confirm","cancel"],setup(t,{emit:e}){const r=e;return(n,i)=>(kt(),Vt("div",bKe,[Oe("div",{class:"absolute inset-0 bg-black/50 backdrop-blur-sm",onClick:i[0]||(i[0]=s=>r("cancel"))}),Oe("div",mKe,[Oe("div",yKe,[Oe("div",{class:Tg(["w-12 h-12 rounded-full flex items-center justify-center",t.variant==="danger"?"bg-red-100":t.variant==="warning"?"bg-amber-100":"bg-primary-100"])},[t.variant==="danger"?(kt(),Vt("svg",vKe,[...i[3]||(i[3]=[Oe("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M12 9v2m0 4h.01m-6.938 4h13.856c1.54 0 2.502-1.667 1.732-3L13.732 4c-.77-1.333-2.694-1.333-3.464 0L3.34 16c-.77 1.333.192 3 1.732 3z"},null,-1)])])):t.variant==="warning"?(kt(),Vt("svg",EKe,[...i[4]||(i[4]=[Oe("path",{"fill-rule":"evenodd",d:"M8.257 3.099c.765-1.36 2.722-1.36 3.486 0l5.58 9.92c.75 1.334-.213 2.98-1.742 2.98H4.42c-1.53 0-2.493-1.646-1.743-2.98l5.58-9.92zM11 13a1 1 0 11-2 0 1 1 0 012 0zm-1-8a1 1 0 00-1 1v3a1 1 0 002 0V6a1 1 0 00-1-1z","clip-rule":"evenodd"},null,-1)])])):(kt(),Vt("svg",wKe,[...i[5]||(i[5]=[Oe("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M13 16h-1v-4h-1m1-4h.01M21 12a9 9 0 11-18 0 9 9 0 0118 0z"},null,-1)])]))],2)]),Oe("h3",IKe,Nr(t.title),1),Efe(n.$slots,"default",{},()=>[Oe("p",xKe,Nr(t.message),1)]),Oe("div",SKe,[Oe("button",{onClick:i[1]||(i[1]=s=>r("cancel")),disabled:t.isLoading,class:"btn-secondary flex-1"},Nr(t.cancelText??"Cancel"),9,MKe),Oe("button",{onClick:i[2]||(i[2]=s=>r("confirm")),disabled:t.isLoading,class:Tg(["flex-1 flex items-center justify-center gap-2",t.variant==="danger"?"btn-danger":"btn-primary"])},[t.isLoading?(kt(),Vt("span",RKe)):Oi("",!0),_n(" "+Nr(t.confirmText??"Confirm"),1)],10,NKe)])])]))}}),AKe={class:"card p-5 mb-5"},LKe={class:"flex items-start justify-between mb-4"},TKe={class:"flex items-center gap-2"},UKe={class:"mono text-sm text-text-primary"},CKe=["title"],OKe={key:0,xmlns:"http://www.w3.org/2000/svg",class:"h-3.5 w-3.5",viewBox:"0 0 20 20",fill:"currentColor"},kKe={key:1,xmlns:"http://www.w3.org/2000/svg",class:"h-3.5 w-3.5 text-green-600",viewBox:"0 0 20 20",fill:"currentColor"},DKe={class:"flex items-center gap-2"},zKe={key:0,class:"badge badge-success"},jKe={key:1,class:"badge badge-muted"},FKe={class:"card-subtle p-4 mb-4"},BKe={class:"flex items-center justify-between"},VKe={class:"value-display"},qKe={class:"flex items-center gap-2"},PKe=["disabled"],QKe={key:0,class:"spinner !w-4 !h-4"},WKe={class:"grid grid-cols-1 sm:grid-cols-2 gap-3"},GKe={class:"card-subtle p-3"},KKe={class:"mono text-sm text-text-primary break-all"},HKe={class:"card-subtle p-3"},YKe={class:"flex items-center gap-1.5 mb-1"},ZKe={class:"relative"},XKe={class:"absolute bottom-full left-1/2 -translate-x-1/2 mb-2 w-64 p-3 bg-gray-900 text-white text-xs rounded-lg shadow-lg z-10"},JKe={class:"mono text-sm text-text-primary break-all mb-2"},_Ke={class:"flex items-center justify-between pt-2 border-t border-primary-200"},$Ke={class:"mono text-sm text-text-primary"},eHe={class:"flex items-center gap-2"},tHe=["disabled"],rHe={key:0,class:"spinner spinner-dark !w-3 !h-3"},nHe={class:"mb-6"},iHe={class:"text-sm text-text-muted text-center mb-4"},sHe={class:"space-y-2"},aHe={class:"card-subtle p-3 flex items-start gap-3"},oHe={class:"text-xs text-text-muted"},cHe=Eh({__name:"ContractInfo",setup(t){const e=_E(),r=Uy(),n=gr(""),i=gr(null),s=gr("0.5"),o=gr(!1),c=gr(!1),u=gr("10"),f=gr(!1),d=gr(!1),p=gr(0);async function g(H,W){await qj(H),n.value=W,setTimeout(()=>{n.value=""},2e3)}function m(){e.contractAddress&&AGe(e.contractAddress)}function x(){return e.contractBalance===null?"0":Zv(_6(e.contractBalance))}function A(){return i.value===null?"...":Zv(i.value)}async function D(){var H;if((H=e.storage)!=null&&H.spender)try{i.value=await r.getBalance(e.storage.spender)}catch(W){console.error("Failed to fetch spender balance:",W),i.value=null}}async function O(){var W;if(!((W=e.storage)!=null&&W.spender)||!r.tezos)return;const H=parseFloat(s.value);if(!(isNaN(H)||H<=0)){o.value=!0;try{await(await r.tezos.wallet.transfer({to:e.storage.spender,amount:H}).send()).confirmation(),await D()}catch(F){console.error("Failed to fund spender:",F)}finally{o.value=!1}}}function z(){var H;return!!((H=e.storage)!=null&&H.spender&&i.value!==null&&i.value<.3)}function j(){if(!e.contract||!r.tezos)return;const H=parseFloat(u.value);isNaN(H)||H<=0||(p.value=H,z()?d.value=!0:Q(!1))}async function Q(H){if(!(!e.contract||!r.tezos)){d.value=!1,f.value=!0;try{H?(await(await r.tezos.wallet.batch().withTransfer(e.contract.methodsObject.default_(null).toTransferParams({amount:p.value})).withTransfer({to:e.storage.spender,amount:.5}).send()).confirmation(),await D()):await(await e.contract.methodsObject.default_(null).send({amount:p.value})).confirmation(),await e.refreshStorage()}catch(W){console.error("Failed to fund contract:",W)}finally{f.value=!1}}}return wR(()=>{D()}),k6(()=>{var H;return(H=e.storage)==null?void 0:H.spender},()=>{D()}),(H,W)=>{var F,b;return kt(),Vt("section",AKe,[Oe("div",LKe,[Oe("div",null,[W[13]||(W[13]=Oe("p",{class:"section-label mb-1"},"spending contract",-1)),Oe("div",TKe,[Oe("p",UKe,Nr(Yt(e).contractAddress),1),Oe("button",{onClick:W[0]||(W[0]=N=>g(Yt(e).contractAddress,"contract")),class:"btn-secondary !py-1 !px-2 text-xs",title:n.value==="contract"?"Copied!":"Copy address"},[n.value!=="contract"?(kt(),Vt("svg",OKe,[...W[10]||(W[10]=[Oe("path",{d:"M8 3a1 1 0 011-1h2a1 1 0 110 2H9a1 1 0 01-1-1z"},null,-1),Oe("path",{d:"M6 3a2 2 0 00-2 2v11a2 2 0 002 2h8a2 2 0 002-2V5a2 2 0 00-2-2 3 3 0 01-3 3H9a3 3 0 01-3-3z"},null,-1)])])):(kt(),Vt("svg",kKe,[...W[11]||(W[11]=[Oe("path",{"fill-rule":"evenodd",d:"M16.707 5.293a1 1 0 010 1.414l-8 8a1 1 0 01-1.414 0l-4-4a1 1 0 011.414-1.414L8 12.586l7.293-7.293a1 1 0 011.414 0z","clip-rule":"evenodd"},null,-1)])]))],8,CKe),Oe("button",{onClick:m,class:"btn-secondary !py-1 !px-2 text-xs",title:"View on TzKT"},[...W[12]||(W[12]=[Oe("svg",{xmlns:"http://www.w3.org/2000/svg",class:"h-3.5 w-3.5",viewBox:"0 0 20 20",fill:"currentColor"},[Oe("path",{d:"M11 3a1 1 0 100 2h2.586l-6.293 6.293a1 1 0 101.414 1.414L15 6.414V9a1 1 0 102 0V4a1 1 0 00-1-1h-5z"}),Oe("path",{d:"M5 5a2 2 0 00-2 2v8a2 2 0 002 2h8a2 2 0 002-2v-3a1 1 0 10-2 0v3H5V7h3a1 1 0 000-2H5z"})],-1)])])])]),Oe("div",DKe,[Yt(e).isOwner?(kt(),Vt("span",zKe,"owner")):(kt(),Vt("span",jKe,"not owner")),Oe("button",{onClick:W[1]||(W[1]=N=>Yt(e).clearContractAddress()),class:"btn-secondary !py-1 !px-2 text-xs"}," Disconnect ")])]),Oe("div",FKe,[Oe("div",BKe,[Oe("div",null,[W[15]||(W[15]=Oe("p",{class:"label mb-1"},"balance",-1)),Oe("p",null,[Oe("span",VKe,Nr(x()),1),W[14]||(W[14]=Oe("span",{class:"value-unit"},"XTZ",-1))])]),Oe("div",qKe,[th(Oe("input",{"onUpdate:modelValue":W[2]||(W[2]=N=>u.value=N),type:"number",step:"1",min:"0",placeholder:"10",class:"input-field !py-2 !px-3 w-24 text-sm"},null,512),[[qp,u.value]]),Oe("button",{onClick:j,disabled:f.value||o.value||!u.value,class:"btn-primary flex items-center gap-2 h-[38px] w-fit px-2"},[f.value?(kt(),Vt("span",QKe)):Oi("",!0),W[16]||(W[16]=_n(" Fund ",-1))],8,PKe)])])]),Oe("div",WKe,[Oe("div",GKe,[W[17]||(W[17]=Oe("p",{class:"label"},"owner",-1)),Oe("p",KKe,Nr((F=Yt(e).storage)==null?void 0:F.owner),1)]),Oe("div",HKe,[Oe("div",YKe,[W[20]||(W[20]=Oe("p",{class:"label !mb-0"},"spender",-1)),Oe("div",ZKe,[Oe("button",{onMouseenter:W[3]||(W[3]=N=>c.value=!0),onMouseleave:W[4]||(W[4]=N=>c.value=!1),onFocus:W[5]||(W[5]=N=>c.value=!0),onBlur:W[6]||(W[6]=N=>c.value=!1),class:"text-text-muted hover:text-text-secondary transition-colors"},[...W[18]||(W[18]=[Oe("svg",{xmlns:"http://www.w3.org/2000/svg",class:"h-3.5 w-3.5",viewBox:"0 0 20 20",fill:"currentColor"},[Oe("path",{"fill-rule":"evenodd",d:"M18 10a8 8 0 11-16 0 8 8 0 0116 0zm-7-4a1 1 0 11-2 0 1 1 0 012 0zM9 9a1 1 0 000 2v3a1 1 0 001 1h1a1 1 0 100-2v-3a1 1 0 00-1-1H9z","clip-rule":"evenodd"})],-1)])],32),th(Oe("div",XKe,[...W[19]||(W[19]=[Oe("p",{class:"font-medium mb-1"},"Spender Fee Balance",-1),Oe("p",{class:"text-gray-300"}," The spender address needs a small amount of XTZ to pay for transaction fees. This is automatically topped up from the contract when it drops below 0.25 XTZ. ",-1),Oe("div",{class:"absolute top-full left-1/2 -translate-x-1/2 -mt-1"},[Oe("div",{class:"border-4 border-transparent border-t-gray-900"})],-1)])],512),[[bde,c.value]])])]),Oe("p",JKe,Nr((b=Yt(e).storage)==null?void 0:b.spender),1),Oe("div",_Ke,[Oe("div",null,[W[22]||(W[22]=Oe("p",{class:"text-xs text-text-muted"},"Fee Balance",-1)),Oe("p",$Ke,[_n(Nr(A())+" ",1),W[21]||(W[21]=Oe("span",{class:"text-text-muted"},"XTZ",-1))])]),Oe("div",eHe,[th(Oe("input",{"onUpdate:modelValue":W[7]||(W[7]=N=>s.value=N),type:"number",step:"0.1",min:"0",placeholder:"0.5",class:"input-field !py-1 !px-2 w-20 text-sm"},null,512),[[qp,s.value]]),Oe("button",{onClick:O,disabled:o.value||f.value||!s.value,class:"btn-secondary !py-1 !px-2 text-xs flex items-center gap-1"},[o.value?(kt(),Vt("span",rHe)):Oi("",!0),W[23]||(W[23]=_n(" Fund ",-1))],8,tHe)])])])]),d.value?(kt(),Cp(iue,{key:0,title:"Batched Transaction","confirm-text":"Approve","cancel-text":"Fund Contract Only",onConfirm:W[8]||(W[8]=N=>Q(!0)),onCancel:W[9]||(W[9]=N=>Q(!1))},{default:GX(()=>[Oe("div",nHe,[Oe("p",iHe," Your spender fee balance is low ("+Nr(A())+" XTZ). This will be batched as two operations in a single approval: ",1),Oe("div",sHe,[Oe("div",aHe,[W[25]||(W[25]=Oe("span",{class:"text-xs font-semibold text-primary-600 bg-primary-100 rounded-full w-5 h-5 flex items-center justify-center shrink-0 mt-0.5"},"1",-1)),Oe("div",null,[W[24]||(W[24]=Oe("p",{class:"text-sm font-medium text-text-primary"},"Fund contract",-1)),Oe("p",oHe,"Deposit "+Nr(p.value)+" XTZ into the spending contract",1)])]),W[26]||(W[26]=Oe("div",{class:"card-subtle p-3 flex items-start gap-3"},[Oe("span",{class:"text-xs font-semibold text-primary-600 bg-primary-100 rounded-full w-5 h-5 flex items-center justify-center shrink-0 mt-0.5"},"2"),Oe("div",null,[Oe("p",{class:"text-sm font-medium text-text-primary"},"Top up spender"),Oe("p",{class:"text-xs text-text-muted"},"Send 0.5 XTZ for transaction fees")])],-1))])])]),_:1})):Oi("",!0)])}}}),lHe={class:"card p-5 mb-5"},uHe={class:"mb-5"},fHe={class:"flex items-baseline justify-between mb-2"},dHe={class:"mono text-text-primary text-sm"},hHe={class:"progress-bar"},pHe={class:"flex justify-between mt-1.5"},gHe={class:"text-xs text-text-muted"},bHe={key:0,class:"text-xs text-text-muted mono"},mHe={class:"grid grid-cols-2 gap-3 mb-5"},yHe={class:"card-subtle p-3 text-center"},vHe={class:"value-display text-xl"},EHe={class:"card-subtle p-3 text-center"},wHe={class:"value-display text-xl"},IHe={key:0},xHe={class:"grid grid-cols-2 gap-3 mb-3"},SHe=["placeholder"],MHe=["placeholder"],NHe=["disabled"],RHe={key:0,class:"spinner"},AHe=Eh({__name:"SpendingLimits",setup(t){const e=_E(),r=gr(""),n=gr(""),i=gr(null);let s=null;const o=Zc(()=>e.storage?Zv(_6(e.storage.daily_limit)):"0"),c=Zc(()=>e.storage?Zv(_6(e.storage.per_tx_limit)):"0"),u=Zc(()=>e.storage?Zv(_6(e.storage.spent_today)):"0"),f=Zc(()=>!e.storage||e.storage.daily_limit===0?0:Math.min(100,e.storage.spent_today/e.storage.daily_limit*100));function d(){var Q;if(!((Q=e.storage)!=null&&Q.last_reset)){i.value=null;return}const g=new Date(e.storage.last_reset).getTime(),m=Date.now(),x=g+24*60*60*1e3,A=Math.max(0,x-m);if(A<=0){i.value="00:00:00";return}const D=Math.floor(A/1e3),O=Math.floor(D/3600),z=Math.floor(D%3600/60),j=D%60;i.value=`${O.toString().padStart(2,"0")}:${z.toString().padStart(2,"0")}:${j.toString().padStart(2,"0")}`}async function p(){const g=parseFloat(r.value),m=parseFloat(n.value);isNaN(g)||isNaN(m)||(await e.setLimits(g,m),r.value="",n.value="")}return wR(()=>{s=setInterval(d,1e3),d()}),p3(()=>{s&&clearInterval(s)}),(g,m)=>(kt(),Vt("section",lHe,[m[12]||(m[12]=Oe("p",{class:"section-label mb-4"},"spending limits",-1)),Oe("div",uHe,[Oe("div",fHe,[m[2]||(m[2]=Oe("p",{class:"text-sm text-text-secondary"},"Spent Today",-1)),Oe("p",dHe,Nr(u.value)+" / "+Nr(o.value)+" XTZ ",1)]),Oe("div",hHe,[Oe("div",{class:"progress-bar-fill",style:gR({width:`${f.value}%`})},null,4)]),Oe("div",pHe,[Oe("p",gHe,Nr(Math.round(f.value))+"% used",1),i.value?(kt(),Vt("p",bHe," resets in "+Nr(i.value),1)):Oi("",!0)])]),Oe("div",mHe,[Oe("div",yHe,[m[4]||(m[4]=Oe("p",{class:"label"},"daily limit",-1)),Oe("p",null,[Oe("span",vHe,Nr(o.value),1),m[3]||(m[3]=Oe("span",{class:"value-unit text-xs"},"XTZ",-1))])]),Oe("div",EHe,[m[6]||(m[6]=Oe("p",{class:"label"},"per-tx limit",-1)),Oe("p",null,[Oe("span",wHe,Nr(c.value),1),m[5]||(m[5]=Oe("span",{class:"value-unit text-xs"},"XTZ",-1))])])]),Yt(e).isOwner?(kt(),Vt("div",IHe,[m[10]||(m[10]=Oe("div",{class:"divider"},null,-1)),m[11]||(m[11]=Oe("p",{class:"text-sm font-medium text-text-primary mb-3"},"Update Limits",-1)),Oe("div",xHe,[Oe("div",null,[m[7]||(m[7]=Oe("label",{class:"label"},"new daily limit",-1)),th(Oe("input",{"onUpdate:modelValue":m[0]||(m[0]=x=>r.value=x),type:"number",placeholder:o.value,class:"input-field"},null,8,SHe),[[qp,r.value]])]),Oe("div",null,[m[8]||(m[8]=Oe("label",{class:"label"},"new per-tx limit",-1)),th(Oe("input",{"onUpdate:modelValue":m[1]||(m[1]=x=>n.value=x),type:"number",placeholder:c.value,class:"input-field"},null,8,MHe),[[qp,n.value]])])]),Oe("button",{onClick:p,disabled:Yt(e).isLoading||!r.value||!n.value,class:"btn-primary flex items-center gap-2"},[Yt(e).isLoading?(kt(),Vt("span",RHe)):Oi("",!0),m[9]||(m[9]=_n(" Update Limits ",-1))],8,NHe)])):Oi("",!0)]))}}),LHe={class:"card p-5 mb-5"},THe={key:0,class:"card-subtle p-4 border-2 border-green-200 bg-green-50/50"},UHe={key:0,class:"mb-3"},CHe={key:0},OHe={class:"flex items-stretch gap-2"},kHe={class:"mono bg-white px-2 py-1.5 rounded flex-1 break-all text-sm border border-green-200 flex items-center"},DHe=["title"],zHe={key:0,xmlns:"http://www.w3.org/2000/svg",class:"h-4 w-4",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor"},jHe={key:1,xmlns:"http://www.w3.org/2000/svg",class:"h-4 w-4",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor"},FHe={key:1,class:"mb-3"},BHe={class:"flex items-stretch gap-2"},VHe={class:"mono bg-white px-2 py-1.5 rounded flex-1 break-all text-sm border border-amber-200 flex items-center"},qHe=["title"],PHe={key:0,xmlns:"http://www.w3.org/2000/svg",class:"h-4 w-4",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor"},QHe={key:1,xmlns:"http://www.w3.org/2000/svg",class:"h-4 w-4",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor"},WHe={key:2,class:"p-3 mb-3 rounded border border-amber-200 bg-amber-50/50"},GHe={class:"mb-4"},KHe={class:"mono bg-white px-2 py-1.5 rounded block break-all text-sm border border-green-200"},HHe={key:1,class:"card-subtle p-4 border border-amber-200 bg-amber-50/50"},YHe={class:"flex items-start gap-3 mb-4"},ZHe={class:"text-sm text-amber-700"},XHe=["disabled"],c8=.5,JHe=Eh({__name:"SpenderManagement",setup(t){const e=_E(),{isLocal:r,detectMode:n}=cA(),i=gr(!1),s=gr(!1),o=gr(!1),c=gr(!1),u=gr(""),f=gr(""),d=gr(!1),p=gr("");async function g(){const O=await fetch("/api/generate-keypair",{method:"POST"});if(!O.ok)throw new Error("Failed to generate keypair on server");return O.json()}async function m(){if(!(await fetch("/api/activate-key",{method:"POST"})).ok)throw new Error("Failed to activate key on server")}async function x(O,z){await qj(O),p.value=z,setTimeout(()=>{p.value=""},2e3)}async function A(){s.value=!0;try{await n();let O;if(r.value){const z=await g();O=z.address,f.value=z.secretKey}else{const z=await nue();O=z.address,f.value=z.secretKey}await e.setSpender(O),r.value&&await m();try{await e.withdraw(O,c8)}catch(z){console.warn("Failed to fund new spender (contract balance may be too low):",z),c.value=!0}u.value=O,o.value=!0,i.value=!1}catch(O){console.error("Failed to regenerate spender:",O)}finally{s.value=!1}}function D(){o.value=!1,c.value=!1,u.value="",f.value="",d.value=!1}return(O,z)=>(kt(),Vt("section",LHe,[z[27]||(z[27]=Oe("p",{class:"section-label mb-4"},"spender key management",-1)),o.value?(kt(),Vt("div",THe,[z[16]||(z[16]=m6('<div class="flex items-center gap-2 mb-3"><div class="w-8 h-8 bg-green-100 rounded-full flex items-center justify-center"><svg xmlns="http://www.w3.org/2000/svg" class="h-4 w-4 text-green-600" fill="none" viewBox="0 0 24 24" stroke="currentColor"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M5 13l4 4L19 7"></path></svg></div><span class="font-semibold text-green-800">Spender Updated Successfully</span></div>',1)),Yt(r)?(kt(),Vt("div",UHe,[z[9]||(z[9]=Oe("p",{class:"text-sm text-green-700 mb-3"}," Your MCP server has been automatically updated with the new spending key. No manual configuration needed. ",-1)),f.value?(kt(),Vt("div",CHe,[z[8]||(z[8]=Oe("label",{class:"label"},"new spending key",-1)),Oe("div",OHe,[Oe("code",kHe,Nr(d.value?f.value:f.value.slice(0,4)+"•".repeat(24)),1),Oe("button",{onClick:z[0]||(z[0]=j=>d.value=!d.value),class:"btn-secondary !py-1.5 !px-2 text-xs",title:d.value?"Hide spending key":"Show spending key"},[d.value?(kt(),Vt("svg",jHe,[...z[7]||(z[7]=[Oe("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M13.875 18.825A10.05 10.05 0 0112 19c-4.478 0-8.268-2.943-9.543-7a9.97 9.97 0 011.563-3.029m5.858.908a3 3 0 114.243 4.243M9.878 9.878l4.242 4.242M9.88 9.88l-3.29-3.29m7.532 7.532l3.29 3.29M3 3l3.59 3.59m0 0A9.953 9.953 0 0112 5c4.478 0 8.268 2.943 9.543 7a10.025 10.025 0 01-4.132 5.411m0 0L21 21"},null,-1)])])):(kt(),Vt("svg",zHe,[...z[6]||(z[6]=[Oe("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M15 12a3 3 0 11-6 0 3 3 0 016 0z"},null,-1),Oe("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M2.458 12C3.732 7.943 7.523 5 12 5c4.478 0 8.268 2.943 9.542 7-1.274 4.057-5.064 7-9.542 7-4.477 0-8.268-2.943-9.542-7z"},null,-1)])]))],8,DHe),Oe("button",{onClick:z[1]||(z[1]=j=>x(f.value,"key")),class:"btn-secondary !py-1.5 !px-2 text-xs"},Nr(p.value==="key"?"Copied!":"Copy"),1)])])):Oi("",!0)])):(kt(),Vt("div",FHe,[z[13]||(z[13]=Oe("p",{class:"text-sm text-amber-700 mb-3"},[_n(" Update the "),Oe("code",{class:"mono text-xs bg-amber-100 px-1 py-0.5 rounded"},"SPENDING_PRIVATE_KEY"),_n(" environment variable on your MCP server with the new key below and restart Claude Desktop. The key won't be shown again after you leave this page. ")],-1)),Oe("div",null,[z[12]||(z[12]=Oe("label",{class:"label"},"new spending key",-1)),Oe("div",BHe,[Oe("code",VHe,Nr(d.value?f.value:f.value.slice(0,4)+"•".repeat(24)),1),Oe("button",{onClick:z[2]||(z[2]=j=>d.value=!d.value),class:"btn-secondary !py-1.5 !px-2 text-xs",title:d.value?"Hide spending key":"Show spending key"},[d.value?(kt(),Vt("svg",QHe,[...z[11]||(z[11]=[Oe("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M13.875 18.825A10.05 10.05 0 0112 19c-4.478 0-8.268-2.943-9.543-7a9.97 9.97 0 011.563-3.029m5.858.908a3 3 0 114.243 4.243M9.878 9.878l4.242 4.242M9.88 9.88l-3.29-3.29m7.532 7.532l3.29 3.29M3 3l3.59 3.59m0 0A9.953 9.953 0 0112 5c4.478 0 8.268 2.943 9.543 7a10.025 10.025 0 01-4.132 5.411m0 0L21 21"},null,-1)])])):(kt(),Vt("svg",PHe,[...z[10]||(z[10]=[Oe("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M15 12a3 3 0 11-6 0 3 3 0 016 0z"},null,-1),Oe("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M2.458 12C3.732 7.943 7.523 5 12 5c4.478 0 8.268 2.943 9.542 7-1.274 4.057-5.064 7-9.542 7-4.477 0-8.268-2.943-9.542-7z"},null,-1)])]))],8,qHe),Oe("button",{onClick:z[3]||(z[3]=j=>x(f.value,"key")),class:"btn-secondary !py-1.5 !px-2 text-xs"},Nr(p.value==="key"?"Copied!":"Copy"),1)])])])),c.value?(kt(),Vt("div",WHe,[Oe("div",{class:"flex items-start gap-2"},[z[14]||(z[14]=Oe("svg",{xmlns:"http://www.w3.org/2000/svg",class:"h-5 w-5 text-amber-600 flex-shrink-0 mt-0.5",viewBox:"0 0 20 20",fill:"currentColor"},[Oe("path",{"fill-rule":"evenodd",d:"M8.257 3.099c.765-1.36 2.722-1.36 3.486 0l5.58 9.92c.75 1.334-.213 2.98-1.742 2.98H4.42c-1.53 0-2.493-1.646-1.743-2.98l5.58-9.92zM11 13a1 1 0 11-2 0 1 1 0 012 0zm-1-8a1 1 0 00-1 1v3a1 1 0 002 0V6a1 1 0 00-1-1z","clip-rule":"evenodd"})],-1)),Oe("p",{class:"text-sm text-amber-700"}," Could not fund the new spender with "+Nr(c8)+" XTZ for gas fees — the contract balance may be too low. Send some XTZ to the spender address below or fund the contract from the dashboard. ")])])):Oi("",!0),Oe("div",GHe,[z[15]||(z[15]=Oe("label",{class:"label"},"new spender address",-1)),Oe("code",KHe,Nr(u.value),1)]),Oe("button",{onClick:D,class:"btn-primary w-full"}," Done ")])):(kt(),Vt("div",HHe,[Oe("div",YHe,[z[25]||(z[25]=Oe("svg",{xmlns:"http://www.w3.org/2000/svg",class:"h-5 w-5 text-amber-600 flex-shrink-0 mt-0.5",viewBox:"0 0 20 20",fill:"currentColor"},[Oe("path",{"fill-rule":"evenodd",d:"M8.257 3.099c.765-1.36 2.722-1.36 3.486 0l5.58 9.92c.75 1.334-.213 2.98-1.742 2.98H4.42c-1.53 0-2.493-1.646-1.743-2.98l5.58-9.92zM11 13a1 1 0 11-2 0 1 1 0 012 0zm-1-8a1 1 0 00-1 1v3a1 1 0 002 0V6a1 1 0 00-1-1z","clip-rule":"evenodd"})],-1)),Oe("div",null,[z[24]||(z[24]=Oe("p",{class:"text-sm font-medium text-amber-800 mb-1"},"Regenerate Spender Keypair",-1)),Oe("p",ZHe,[z[20]||(z[20]=_n(" This will generate a new spending keypair and update the contract. ",-1)),Yt(r)?(kt(),Vt(vs,{key:0},[_n(" The new spender will be funded with "+Nr(c8)+" XTZ for gas fees. ")],64)):Oi("",!0),z[21]||(z[21]=_n(" The current spender key will ",-1)),z[22]||(z[22]=Oe("strong",null,"stop working immediately",-1)),z[23]||(z[23]=_n(". ",-1)),Yt(r)?(kt(),Vt(vs,{key:1},[_n(" Your MCP server will be updated automatically. ")],64)):(kt(),Vt(vs,{key:2},[z[17]||(z[17]=_n(" You will need to update the ",-1)),z[18]||(z[18]=Oe("code",{class:"mono text-xs bg-amber-100 px-1 py-0.5 rounded"},"SPENDING_PRIVATE_KEY",-1)),z[19]||(z[19]=_n(" environment variable on your MCP server. ",-1))],64))])])]),Oe("button",{onClick:z[4]||(z[4]=j=>i.value=!0),disabled:Yt(e).isLoading,class:"btn-danger w-full flex items-center justify-center gap-2"},[...z[26]||(z[26]=[Oe("svg",{xmlns:"http://www.w3.org/2000/svg",class:"h-4 w-4",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor"},[Oe("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M4 4v5h.582m15.356 2A8.001 8.001 0 004.582 9m0 0H9m11 11v-5h-.581m0 0a8.003 8.003 0 01-15.357-2m15.357 2H15"})],-1),_n(" Regenerate Spender Key ",-1)])],8,XHe)])),i.value?(kt(),Cp(iue,{key:2,title:"Regenerate Spender Key?",message:Yt(r)?`This action cannot be undone. The current spender key will be invalidated immediately and any services using it will lose access. The new spender will be funded with ${c8} XTZ from the contract for gas fees.`:"This action cannot be undone. The current spender key will be invalidated immediately and any services using it will lose access. You will need to update the SPENDING_PRIVATE_KEY environment variable on your MCP server.","confirm-text":"Regenerate","cancel-text":"Cancel",variant:"danger","is-loading":s.value,onConfirm:A,onCancel:z[5]||(z[5]=j=>i.value=!1)},null,8,["message","is-loading"])):Oi("",!0)]))}}),_He={class:"card p-5 mb-5"},$He={class:"space-y-3"},eYe=["placeholder"],tYe=["placeholder"],rYe=["disabled"],nYe={key:0,class:"spinner"},iYe=Eh({__name:"WithdrawFunds",setup(t){const e=Uy(),r=_E(),n=gr(""),i=gr(""),s=Zc(()=>r.contractBalance===null?"0":Zv(_6(r.contractBalance)));async function o(){const c=parseFloat(i.value);!n.value||isNaN(c)||(await r.withdraw(n.value,c),n.value="",i.value="")}return(c,u)=>(kt(),Vt("section",_He,[u[5]||(u[5]=Oe("p",{class:"section-label mb-4"},"withdraw funds",-1)),u[6]||(u[6]=Oe("p",{class:"text-sm text-text-muted mb-4"}," Withdraw any amount without limits. ",-1)),Oe("div",$He,[Oe("div",null,[u[2]||(u[2]=Oe("label",{class:"label"},"recipient",-1)),th(Oe("input",{"onUpdate:modelValue":u[0]||(u[0]=f=>n.value=f),type:"text",placeholder:Yt(e).userAddress??void 0,class:"input-field mono"},null,8,eYe),[[qp,n.value]])]),Oe("div",null,[u[3]||(u[3]=Oe("label",{class:"label"},"amount (xtz)",-1)),th(Oe("input",{"onUpdate:modelValue":u[1]||(u[1]=f=>i.value=f),type:"number",placeholder:`Max: ${s.value}`,class:"input-field"},null,8,tYe),[[qp,i.value]])]),Oe("button",{onClick:o,disabled:Yt(r).isLoading||!n.value||!i.value,class:"btn-primary w-full flex items-center justify-center gap-2"},[Yt(r).isLoading?(kt(),Vt("span",nYe)):Oi("",!0),u[4]||(u[4]=_n(" Withdraw ",-1))],8,rYe)])]))}}),sYe={class:"card mb-5 overflow-hidden"},aYe={class:"overflow-hidden"},oYe={class:"px-5 pb-5"},cYe={class:"flex items-center gap-2 mb-2"},lYe={class:"label !mb-0 !text-[11px] uppercase tracking-wider text-text-muted font-medium"},uYe={class:"space-y-1.5"},fYe={class:"mono text-xs text-accent-600 truncate"},dYe={class:"text-xs text-text-secondary leading-relaxed"},hYe={class:"text-xs text-text-muted italic hidden sm:block"},pYe=Eh({__name:"ToolGuide",setup(t){const e=gr(!1),r=[{label:"Wallet",tools:[{name:"tezos_get_balance",desc:"Check the balance of your spending contract and spender address.",example:"What's my balance?"},{name:"tezos_send_xtz",desc:"Send XTZ to any Tezos address via your spending contract.",example:"Send 5 XTZ to tz1abc..."},{name:"tezos_get_limits",desc:"View daily and per-transaction spending limits, and how much has been used today.",example:"What are my spending limits?"},{name:"tezos_get_addresses",desc:"Get the contract, owner, and spender addresses.",example:"Show me my Tezos addresses"},{name:"tezos_get_operation_history",desc:"View recent transaction history for the spending contract.",example:"Show my recent transactions"}]},{label:"x402 Payments",tools:[{name:"tezos_fetch_with_x402",desc:"Fetch a URL and automatically pay if it requires an x402 payment.",example:"Fetch https://api.example.com/paid-endpoint with a max of 0.5 XTZ"},{name:"tezos_create_x402_payment",desc:"Create a signed x402 payment header without broadcasting. Internal tool.",example:"Create an x402 payment of 500000 mutez to tz1abc..."},{name:"tezos_parse_x402_requirements",desc:"Parse payment requirements from a 402 response body. Internal tool.",example:"Parse these x402 payment requirements"}]},{label:"Account",tools:[{name:"tezos_recover_spender_funds",desc:"Transfer the spender address's XTZ balance back to the owner.",example:"Drain the spender address to my account"},{name:"tezos_reveal_account",desc:"Reveal the spender account on-chain. Internal tool.",example:"Reveal my account"},{name:"tezos_get_dashboard",desc:"Get a link to the configuration dashboard.",example:"Open the dashboard"}]}];return(n,i)=>(kt(),Vt("section",sYe,[Oe("button",{onClick:i[0]||(i[0]=s=>e.value=!e.value),class:"w-full flex items-center justify-between px-5 py-4 cursor-pointer bg-transparent border-none text-left transition-colors hover:bg-primary-50/50"},[i[2]||(i[2]=Oe("p",{class:"section-label !mb-0"},"tool reference",-1)),(kt(),Vt("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:Tg(["text-text-muted transition-transform duration-200",e.value?"rotate-180":""])},[...i[1]||(i[1]=[Oe("polyline",{points:"6 9 12 15 18 9"},null,-1)])],2))]),Oe("div",{class:Tg(["grid transition-[grid-template-rows] duration-300 ease-[cubic-bezier(0.16,1,0.3,1)]",e.value?"grid-rows-[1fr]":"grid-rows-[0fr]"])},[Oe("div",aYe,[Oe("div",oYe,[i[4]||(i[4]=Oe("p",{class:"text-xs text-text-muted mb-4"}," Call tools by asking your AI agent to do things in plain language. Tools marked as internal are automatically called in conjunction with other tools, but can also be called manually. ",-1)),(kt(),Vt(vs,null,xO(r,(s,o)=>Oe("div",{key:s.label,class:Tg(o>0?"mt-4":"")},[Oe("div",cYe,[Oe("span",lYe,Nr(s.label),1),i[3]||(i[3]=Oe("div",{class:"flex-1 h-px bg-primary-200"},null,-1))]),Oe("div",uYe,[(kt(!0),Vt(vs,null,xO(s.tools,c=>(kt(),Vt("div",{key:c.name,class:"card-subtle px-3 py-2.5 grid grid-cols-[160px_1fr] gap-3 items-baseline sm:grid-cols-[170px_1fr_1fr]"},[Oe("span",fYe,Nr(c.name),1),Oe("span",dYe,Nr(c.desc),1),Oe("span",hYe,'"'+Nr(c.example)+'"',1)]))),128))])],2)),64))])])],2)]))}}),gYe={class:"min-h-screen py-12 px-4 sm:px-6 lg:px-8 relative z-10"},bYe={class:"max-w-2xl mx-auto"},mYe={class:"mb-6 flex items-center justify-between"},yYe=["value"],vYe=["value"],EYe={key:0,class:"mb-4 px-4 py-2.5 rounded-lg bg-warning/10 border border-warning/20 flex items-center gap-2 text-sm text-warning"},wYe={class:"text-warning/70"},IYe={class:"text-center"},xYe=["disabled"],SYe={key:0,class:"spinner spinner-dark"},MYe={key:4,class:"card p-4 mt-5 border border-error/20 bg-error/5"},NYe={class:"text-sm text-error"},RYe={class:"mt-12 text-center"},AYe={class:"text-sm text-text-muted"},LYe=Eh({__name:"App",setup(t){const e=Uy(),r=_E(),{detectMode:n,serverNetwork:i}=cA(),s=Object.entries(Yv).map(([c,u])=>({id:c,name:u.name}));async function o(c){const u=c.target;r.clearContractAddress(),await e.switchNetwork(u.value)}return wR(async()=>{var p;await n();const c=new URLSearchParams(window.location.search),u=(p=c.get("network"))==null?void 0:p.toLowerCase(),f=u&&u in Yv?u:i.value&&i.value in Yv?i.value:null;f&&f!==e.networkId&&await e.switchNetwork(f),await e.init();const d=c.get("contract");if(d){if(await r.setContractAddress(d),r.contractAddress){c.delete("contract"),c.delete("network");const g=c.toString()?`${window.location.pathname}?${c}`:window.location.pathname;window.history.replaceState({},"",g)}}else r.contractAddress&&await r.loadContract()}),(c,u)=>(kt(),Vt(vs,null,[u[8]||(u[8]=Oe("div",{class:"film-grain"},null,-1)),Oe("div",gYe,[Oe("div",bYe,[Oe("header",mYe,[u[3]||(u[3]=Oe("h1",{class:"text-3xl font-semibold tracking-tight text-text-primary"}," TezosX MCP Configuration ",-1)),Oe("select",{value:Yt(e).networkId,onChange:o,class:"text-xs text-text-muted bg-transparent border border-border rounded px-2 py-1 cursor-pointer hover:border-text-muted transition-colors"},[(kt(!0),Vt(vs,null,xO(Yt(s),f=>(kt(),Vt("option",{key:f.id,value:f.id},Nr(f.name),9,vYe))),128))],40,yYe)]),Yt(e).networkId!=="mainnet"?(kt(),Vt("div",EYe,[u[4]||(u[4]=Oe("span",{class:"font-medium"},"Testnet",-1)),Oe("span",wYe,"You're connected to "+Nr(Yt(e).currentNetwork.name)+". Funds on this network have no real value.",1)])):Oi("",!0),Uc(jGe),Yt(r).deploymentResult?(kt(),Cp(gKe,{key:1,"contract-address":Yt(r).deploymentResult.contractAddress,"spending-key":Yt(r).deploymentResult.spendingKey,"config-save-failed":Yt(r).deploymentResult.configSaveFailed,onContinue:u[0]||(u[0]=f=>Yt(r).clearDeploymentResult()),onConfigSaved:u[1]||(u[1]=f=>Yt(r).deploymentResult.configSaveFailed=!1)},null,8,["contract-address","spending-key","config-save-failed"])):Oi("",!0),!Yt(r).contractAddress&&!Yt(r).deploymentResult?(kt(),Cp(YGe,{key:2})):Oi("",!0),Yt(r).contractAddress&&Yt(r).storage?(kt(),Vt(vs,{key:3},[Uc(cHe),Uc(pYe),Uc(AHe),Yt(r).isOwner?(kt(),Cp(JHe,{key:0})):Oi("",!0),Yt(r).isOwner?(kt(),Cp(iYe,{key:1})):Oi("",!0),Oe("div",IYe,[Oe("button",{onClick:u[2]||(u[2]=f=>Yt(r).refreshStorage()),disabled:Yt(r).isLoading,class:"btn-secondary flex items-center gap-2 mx-auto"},[Yt(r).isLoading?(kt(),Vt("span",SYe)):Oi("",!0),u[5]||(u[5]=_n(" Refresh ",-1))],8,xYe)])],64)):Oi("",!0),Yt(r).error?(kt(),Vt("div",MYe,[Oe("p",NYe,Nr(Yt(r).error),1)])):Oi("",!0),Oe("footer",RYe,[Oe("p",AYe,[u[6]||(u[6]=_n(" Built with ",-1)),u[7]||(u[7]=Oe("a",{href:"https://taquito.io",target:"_blank"},"Taquito",-1)),_n(" · "+Nr(Yt(e).currentNetwork.name),1)])])])])],64))}});globalThis.Buffer=vh.Buffer;globalThis.process=globalThis.process||{env:{},browser:!0};const sue=Ode(LYe);sue.use(zde());sue.mount("#app");
|
|
278
|
+
TEZOS_NETWORK=${i.networkId}`}return(x,A)=>(kt(),Vt("section",ZGe,[A[16]||(A[16]=m6('<div class="text-center mb-5"><div class="inline-flex items-center justify-center w-12 h-12 bg-green-100 rounded-full mb-3"><svg xmlns="http://www.w3.org/2000/svg" class="h-6 w-6 text-green-600" fill="none" viewBox="0 0 24 24" stroke="currentColor"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M5 13l4 4L19 7"></path></svg></div><h2 class="text-lg font-semibold text-text-primary">Contract Deployed Successfully</h2></div>',1)),Yt(s)&&t.configSaveFailed?(kt(),Vt("div",XGe,[A[7]||(A[7]=Oe("div",{class:"flex items-center gap-2 mb-2"},[Oe("svg",{xmlns:"http://www.w3.org/2000/svg",class:"h-5 w-5 text-red-600",viewBox:"0 0 20 20",fill:"currentColor"},[Oe("path",{"fill-rule":"evenodd",d:"M8.257 3.099c.765-1.36 2.722-1.36 3.486 0l5.58 9.92c.75 1.334-.213 2.98-1.742 2.98H4.42c-1.53 0-2.493-1.646-1.743-2.98l5.58-9.92zM11 13a1 1 0 11-2 0 1 1 0 012 0zm-1-8a1 1 0 00-1 1v3a1 1 0 002 0V6a1 1 0 00-1-1z","clip-rule":"evenodd"})]),Oe("span",{class:"font-semibold text-red-800"},"Failed to Save Configuration")],-1)),Oe("p",JGe,[A[5]||(A[5]=_n(" Your contract was deployed on-chain at ",-1)),Oe("code",_Ge,Nr(t.contractAddress),1),A[6]||(A[6]=_n(", but the spending key could not be saved to the MCP server. ",-1))]),Oe("button",{onClick:d,disabled:u.value,class:"btn-primary w-full flex items-center justify-center gap-2"},[u.value?(kt(),Vt("span",eKe)):Oi("",!0),_n(" "+Nr(u.value?"Saving...":"Retry Save"),1)],8,$Ge),f.value?(kt(),Vt("p",tKe,Nr(f.value),1)):Oi("",!0)])):Yt(s)?(kt(),Vt("div",rKe,[A[11]||(A[11]=m6('<div class="flex items-center gap-2 mb-2"><svg xmlns="http://www.w3.org/2000/svg" class="h-5 w-5 text-green-600" viewBox="0 0 20 20" fill="currentColor"><path fill-rule="evenodd" d="M10 18a8 8 0 100-16 8 8 0 000 16zm3.707-9.293a1 1 0 00-1.414-1.414L9 10.586 7.707 9.293a1 1 0 00-1.414 1.414l2 2a1 1 0 001.414 0l4-4z" clip-rule="evenodd"></path></svg><span class="font-semibold text-green-800">MCP Server Configured Automatically</span></div><p class="text-sm text-green-700 mb-4"> Your spending key and contract address have been saved to your MCP server. No manual configuration needed — your MCP tools are ready to use. </p>',2)),t.spendingKey?(kt(),Vt("div",nKe,[Oe("pre",iKe,Nr(g()),1),Oe("div",sKe,[Oe("button",{onClick:A[0]||(A[0]=D=>c.value=!c.value),class:"btn-secondary !py-1.5 !px-2",title:c.value?"Hide spending key":"Show spending key"},[c.value?(kt(),Vt("svg",cKe,[...A[9]||(A[9]=[Oe("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M13.875 18.825A10.05 10.05 0 0112 19c-4.478 0-8.268-2.943-9.543-7a9.97 9.97 0 011.563-3.029m5.858.908a3 3 0 114.243 4.243M9.878 9.878l4.242 4.242M9.88 9.88l-3.29-3.29m7.532 7.532l3.29 3.29M3 3l3.59 3.59m0 0A9.953 9.953 0 0112 5c4.478 0 8.268 2.943 9.543 7a10.025 10.025 0 01-4.132 5.411m0 0L21 21"},null,-1)])])):(kt(),Vt("svg",oKe,[...A[8]||(A[8]=[Oe("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M15 12a3 3 0 11-6 0 3 3 0 016 0z"},null,-1),Oe("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M2.458 12C3.732 7.943 7.523 5 12 5c4.478 0 8.268 2.943 9.542 7-1.274 4.057-5.064 7-9.542 7-4.477 0-8.268-2.943-9.542-7z"},null,-1)])]))],8,aKe),Oe("button",{onClick:A[1]||(A[1]=D=>p(m(),"env")),class:"btn-secondary flex-1 flex items-center justify-center gap-2"},[A[10]||(A[10]=Oe("svg",{xmlns:"http://www.w3.org/2000/svg",class:"h-4 w-4",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor"},[Oe("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M8 16H6a2 2 0 01-2-2V6a2 2 0 012-2h8a2 2 0 012 2v2m-6 12h8a2 2 0 002-2v-8a2 2 0 00-2-2h-8a2 2 0 00-2 2v8a2 2 0 002 2z"})],-1)),_n(" "+Nr(o.value==="env"?"Copied!":"Copy Environment Variables"),1)])])])):Oi("",!0)])):(kt(),Vt("div",lKe,[A[15]||(A[15]=m6('<div class="flex items-center gap-2 mb-2"><svg xmlns="http://www.w3.org/2000/svg" class="h-5 w-5 text-amber-600" viewBox="0 0 20 20" fill="currentColor"><path fill-rule="evenodd" d="M8.257 3.099c.765-1.36 2.722-1.36 3.486 0l5.58 9.92c.75 1.334-.213 2.98-1.742 2.98H4.42c-1.53 0-2.493-1.646-1.743-2.98l5.58-9.92zM11 13a1 1 0 11-2 0 1 1 0 012 0zm-1-8a1 1 0 00-1 1v3a1 1 0 002 0V6a1 1 0 00-1-1z" clip-rule="evenodd"></path></svg><span class="font-semibold text-amber-800">Manual Configuration Required</span></div><p class="text-sm text-amber-700 mb-4"> Set these environment variables on your MCP server. The spending key won't be shown again after you leave this page. </p>',2)),Oe("pre",uKe,Nr(g()),1),Oe("div",fKe,[Oe("button",{onClick:A[2]||(A[2]=D=>c.value=!c.value),class:"btn-secondary !py-1.5 !px-2",title:c.value?"Hide spending key":"Show spending key"},[c.value?(kt(),Vt("svg",pKe,[...A[13]||(A[13]=[Oe("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M13.875 18.825A10.05 10.05 0 0112 19c-4.478 0-8.268-2.943-9.543-7a9.97 9.97 0 011.563-3.029m5.858.908a3 3 0 114.243 4.243M9.878 9.878l4.242 4.242M9.88 9.88l-3.29-3.29m7.532 7.532l3.29 3.29M3 3l3.59 3.59m0 0A9.953 9.953 0 0112 5c4.478 0 8.268 2.943 9.543 7a10.025 10.025 0 01-4.132 5.411m0 0L21 21"},null,-1)])])):(kt(),Vt("svg",hKe,[...A[12]||(A[12]=[Oe("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M15 12a3 3 0 11-6 0 3 3 0 016 0z"},null,-1),Oe("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M2.458 12C3.732 7.943 7.523 5 12 5c4.478 0 8.268 2.943 9.542 7-1.274 4.057-5.064 7-9.542 7-4.477 0-8.268-2.943-9.542-7z"},null,-1)])]))],8,dKe),Oe("button",{onClick:A[3]||(A[3]=D=>p(m(),"env")),class:"btn-secondary flex-1 flex items-center justify-center gap-2"},[A[14]||(A[14]=Oe("svg",{xmlns:"http://www.w3.org/2000/svg",class:"h-4 w-4",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor"},[Oe("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M8 16H6a2 2 0 01-2-2V6a2 2 0 012-2h8a2 2 0 012 2v2m-6 12h8a2 2 0 002-2v-8a2 2 0 00-2-2h-8a2 2 0 00-2 2v8a2 2 0 002 2z"})],-1)),_n(" "+Nr(o.value==="env"?"Copied!":"Copy Environment Variables"),1)])])])),A[17]||(A[17]=m6('<div class="card-subtle p-4 mb-4 border border-amber-200 bg-amber-50/50"><div class="flex items-start gap-2"><svg xmlns="http://www.w3.org/2000/svg" class="h-5 w-5 text-amber-600 flex-shrink-0 mt-0.5" viewBox="0 0 20 20" fill="currentColor"><path fill-rule="evenodd" d="M8.257 3.099c.765-1.36 2.722-1.36 3.486 0l5.58 9.92c.75 1.334-.213 2.98-1.742 2.98H4.42c-1.53 0-2.493-1.646-1.743-2.98l5.58-9.92zM11 13a1 1 0 11-2 0 1 1 0 012 0zm-1-8a1 1 0 00-1 1v3a1 1 0 002 0V6a1 1 0 00-1-1z" clip-rule="evenodd"></path></svg><p class="text-sm text-amber-700"><strong>Next step:</strong> Send some XTZ to your spending contract so the MCP server has funds to work with. You can do this from the dashboard on the next page. </p></div></div>',1)),Oe("button",{onClick:A[4]||(A[4]=D=>n("continue")),class:"btn-primary w-full"}," Continue to Dashboard ")]))}}),bKe={class:"fixed inset-0 z-50 flex items-center justify-center"},mKe={class:"relative bg-white rounded-lg shadow-xl max-w-md w-full mx-4 p-6"},yKe={class:"flex justify-center mb-4"},vKe={key:0,xmlns:"http://www.w3.org/2000/svg",class:"h-6 w-6 text-red-600",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor"},EKe={key:1,xmlns:"http://www.w3.org/2000/svg",class:"h-6 w-6 text-amber-600",viewBox:"0 0 20 20",fill:"currentColor"},wKe={key:2,xmlns:"http://www.w3.org/2000/svg",class:"h-6 w-6 text-primary-600",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor"},IKe={class:"text-lg font-semibold text-center text-text-primary mb-2"},xKe={class:"text-sm text-text-muted text-center mb-6"},SKe={class:"flex gap-3"},MKe=["disabled"],NKe=["disabled"],RKe={key:0,class:"spinner"},iue=Eh({__name:"ConfirmationModal",props:{title:{},message:{},confirmText:{},cancelText:{},isLoading:{type:Boolean},variant:{}},emits:["confirm","cancel"],setup(t,{emit:e}){const r=e;return(n,i)=>(kt(),Vt("div",bKe,[Oe("div",{class:"absolute inset-0 bg-black/50 backdrop-blur-sm",onClick:i[0]||(i[0]=s=>r("cancel"))}),Oe("div",mKe,[Oe("div",yKe,[Oe("div",{class:Tg(["w-12 h-12 rounded-full flex items-center justify-center",t.variant==="danger"?"bg-red-100":t.variant==="warning"?"bg-amber-100":"bg-primary-100"])},[t.variant==="danger"?(kt(),Vt("svg",vKe,[...i[3]||(i[3]=[Oe("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M12 9v2m0 4h.01m-6.938 4h13.856c1.54 0 2.502-1.667 1.732-3L13.732 4c-.77-1.333-2.694-1.333-3.464 0L3.34 16c-.77 1.333.192 3 1.732 3z"},null,-1)])])):t.variant==="warning"?(kt(),Vt("svg",EKe,[...i[4]||(i[4]=[Oe("path",{"fill-rule":"evenodd",d:"M8.257 3.099c.765-1.36 2.722-1.36 3.486 0l5.58 9.92c.75 1.334-.213 2.98-1.742 2.98H4.42c-1.53 0-2.493-1.646-1.743-2.98l5.58-9.92zM11 13a1 1 0 11-2 0 1 1 0 012 0zm-1-8a1 1 0 00-1 1v3a1 1 0 002 0V6a1 1 0 00-1-1z","clip-rule":"evenodd"},null,-1)])])):(kt(),Vt("svg",wKe,[...i[5]||(i[5]=[Oe("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M13 16h-1v-4h-1m1-4h.01M21 12a9 9 0 11-18 0 9 9 0 0118 0z"},null,-1)])]))],2)]),Oe("h3",IKe,Nr(t.title),1),Efe(n.$slots,"default",{},()=>[Oe("p",xKe,Nr(t.message),1)]),Oe("div",SKe,[Oe("button",{onClick:i[1]||(i[1]=s=>r("cancel")),disabled:t.isLoading,class:"btn-secondary flex-1"},Nr(t.cancelText??"Cancel"),9,MKe),Oe("button",{onClick:i[2]||(i[2]=s=>r("confirm")),disabled:t.isLoading,class:Tg(["flex-1 flex items-center justify-center gap-2",t.variant==="danger"?"btn-danger":"btn-primary"])},[t.isLoading?(kt(),Vt("span",RKe)):Oi("",!0),_n(" "+Nr(t.confirmText??"Confirm"),1)],10,NKe)])])]))}}),AKe={class:"card p-5 mb-5"},LKe={class:"flex items-start justify-between mb-4"},TKe={class:"flex items-center gap-2"},UKe={class:"mono text-sm text-text-primary"},CKe=["title"],OKe={key:0,xmlns:"http://www.w3.org/2000/svg",class:"h-3.5 w-3.5",viewBox:"0 0 20 20",fill:"currentColor"},kKe={key:1,xmlns:"http://www.w3.org/2000/svg",class:"h-3.5 w-3.5 text-green-600",viewBox:"0 0 20 20",fill:"currentColor"},DKe={class:"flex items-center gap-2"},zKe={key:0,class:"badge badge-success"},jKe={key:1,class:"badge badge-muted"},FKe={class:"card-subtle p-4 mb-4"},BKe={class:"flex items-center justify-between"},VKe={class:"value-display"},qKe={class:"flex items-center gap-2"},PKe=["disabled"],QKe={key:0,class:"spinner !w-4 !h-4"},WKe={class:"grid grid-cols-1 sm:grid-cols-2 gap-3"},GKe={class:"card-subtle p-3"},KKe={class:"mono text-sm text-text-primary break-all"},HKe={class:"card-subtle p-3"},YKe={class:"flex items-center gap-1.5 mb-1"},ZKe={class:"relative"},XKe={class:"absolute bottom-full left-1/2 -translate-x-1/2 mb-2 w-64 p-3 bg-gray-900 text-white text-xs rounded-lg shadow-lg z-10"},JKe={class:"mono text-sm text-text-primary break-all mb-2"},_Ke={class:"flex items-center justify-between pt-2 border-t border-primary-200"},$Ke={class:"mono text-sm text-text-primary"},eHe={class:"flex items-center gap-2"},tHe=["disabled"],rHe={key:0,class:"spinner spinner-dark !w-3 !h-3"},nHe={class:"mb-6"},iHe={class:"text-sm text-text-muted text-center mb-4"},sHe={class:"space-y-2"},aHe={class:"card-subtle p-3 flex items-start gap-3"},oHe={class:"text-xs text-text-muted"},cHe=Eh({__name:"ContractInfo",setup(t){const e=_E(),r=Uy(),n=gr(""),i=gr(null),s=gr("0.5"),o=gr(!1),c=gr(!1),u=gr("10"),f=gr(!1),d=gr(!1),p=gr(0);async function g(H,W){await qj(H),n.value=W,setTimeout(()=>{n.value=""},2e3)}function m(){e.contractAddress&&AGe(e.contractAddress)}function x(){return e.contractBalance===null?"0":Zv(_6(e.contractBalance))}function A(){return i.value===null?"...":Zv(i.value)}async function D(){var H;if((H=e.storage)!=null&&H.spender)try{i.value=await r.getBalance(e.storage.spender)}catch(W){console.error("Failed to fetch spender balance:",W),i.value=null}}async function O(){var W;if(!((W=e.storage)!=null&&W.spender)||!r.tezos)return;const H=parseFloat(s.value);if(!(isNaN(H)||H<=0)){o.value=!0;try{await(await r.tezos.wallet.transfer({to:e.storage.spender,amount:H}).send()).confirmation(),await D()}catch(F){console.error("Failed to fund spender:",F)}finally{o.value=!1}}}function z(){var H;return!!((H=e.storage)!=null&&H.spender&&i.value!==null&&i.value<.3)}function j(){if(!e.contract||!r.tezos)return;const H=parseFloat(u.value);isNaN(H)||H<=0||(p.value=H,z()?d.value=!0:Q(!1))}async function Q(H){if(!(!e.contract||!r.tezos)){d.value=!1,f.value=!0;try{H?(await(await r.tezos.wallet.batch().withTransfer(e.contract.methodsObject.default(null).toTransferParams({amount:p.value})).withTransfer({to:e.storage.spender,amount:.5}).send()).confirmation(),await D()):await(await e.contract.methodsObject.default(null).send({amount:p.value})).confirmation(),await e.refreshStorage()}catch(W){console.error("Failed to fund contract:",W)}finally{f.value=!1}}}return wR(()=>{D()}),k6(()=>{var H;return(H=e.storage)==null?void 0:H.spender},()=>{D()}),(H,W)=>{var F,b;return kt(),Vt("section",AKe,[Oe("div",LKe,[Oe("div",null,[W[13]||(W[13]=Oe("p",{class:"section-label mb-1"},"spending contract",-1)),Oe("div",TKe,[Oe("p",UKe,Nr(Yt(e).contractAddress),1),Oe("button",{onClick:W[0]||(W[0]=N=>g(Yt(e).contractAddress,"contract")),class:"btn-secondary !py-1 !px-2 text-xs",title:n.value==="contract"?"Copied!":"Copy address"},[n.value!=="contract"?(kt(),Vt("svg",OKe,[...W[10]||(W[10]=[Oe("path",{d:"M8 3a1 1 0 011-1h2a1 1 0 110 2H9a1 1 0 01-1-1z"},null,-1),Oe("path",{d:"M6 3a2 2 0 00-2 2v11a2 2 0 002 2h8a2 2 0 002-2V5a2 2 0 00-2-2 3 3 0 01-3 3H9a3 3 0 01-3-3z"},null,-1)])])):(kt(),Vt("svg",kKe,[...W[11]||(W[11]=[Oe("path",{"fill-rule":"evenodd",d:"M16.707 5.293a1 1 0 010 1.414l-8 8a1 1 0 01-1.414 0l-4-4a1 1 0 011.414-1.414L8 12.586l7.293-7.293a1 1 0 011.414 0z","clip-rule":"evenodd"},null,-1)])]))],8,CKe),Oe("button",{onClick:m,class:"btn-secondary !py-1 !px-2 text-xs",title:"View on TzKT"},[...W[12]||(W[12]=[Oe("svg",{xmlns:"http://www.w3.org/2000/svg",class:"h-3.5 w-3.5",viewBox:"0 0 20 20",fill:"currentColor"},[Oe("path",{d:"M11 3a1 1 0 100 2h2.586l-6.293 6.293a1 1 0 101.414 1.414L15 6.414V9a1 1 0 102 0V4a1 1 0 00-1-1h-5z"}),Oe("path",{d:"M5 5a2 2 0 00-2 2v8a2 2 0 002 2h8a2 2 0 002-2v-3a1 1 0 10-2 0v3H5V7h3a1 1 0 000-2H5z"})],-1)])])])]),Oe("div",DKe,[Yt(e).isOwner?(kt(),Vt("span",zKe,"owner")):(kt(),Vt("span",jKe,"not owner")),Oe("button",{onClick:W[1]||(W[1]=N=>Yt(e).clearContractAddress()),class:"btn-secondary !py-1 !px-2 text-xs"}," Disconnect ")])]),Oe("div",FKe,[Oe("div",BKe,[Oe("div",null,[W[15]||(W[15]=Oe("p",{class:"label mb-1"},"balance",-1)),Oe("p",null,[Oe("span",VKe,Nr(x()),1),W[14]||(W[14]=Oe("span",{class:"value-unit"},"XTZ",-1))])]),Oe("div",qKe,[th(Oe("input",{"onUpdate:modelValue":W[2]||(W[2]=N=>u.value=N),type:"number",step:"1",min:"0",placeholder:"10",class:"input-field !py-2 !px-3 w-24 text-sm"},null,512),[[qp,u.value]]),Oe("button",{onClick:j,disabled:f.value||o.value||!u.value,class:"btn-primary flex items-center gap-2 h-[38px] w-fit px-2"},[f.value?(kt(),Vt("span",QKe)):Oi("",!0),W[16]||(W[16]=_n(" Fund ",-1))],8,PKe)])])]),Oe("div",WKe,[Oe("div",GKe,[W[17]||(W[17]=Oe("p",{class:"label"},"owner",-1)),Oe("p",KKe,Nr((F=Yt(e).storage)==null?void 0:F.owner),1)]),Oe("div",HKe,[Oe("div",YKe,[W[20]||(W[20]=Oe("p",{class:"label !mb-0"},"spender",-1)),Oe("div",ZKe,[Oe("button",{onMouseenter:W[3]||(W[3]=N=>c.value=!0),onMouseleave:W[4]||(W[4]=N=>c.value=!1),onFocus:W[5]||(W[5]=N=>c.value=!0),onBlur:W[6]||(W[6]=N=>c.value=!1),class:"text-text-muted hover:text-text-secondary transition-colors"},[...W[18]||(W[18]=[Oe("svg",{xmlns:"http://www.w3.org/2000/svg",class:"h-3.5 w-3.5",viewBox:"0 0 20 20",fill:"currentColor"},[Oe("path",{"fill-rule":"evenodd",d:"M18 10a8 8 0 11-16 0 8 8 0 0116 0zm-7-4a1 1 0 11-2 0 1 1 0 012 0zM9 9a1 1 0 000 2v3a1 1 0 001 1h1a1 1 0 100-2v-3a1 1 0 00-1-1H9z","clip-rule":"evenodd"})],-1)])],32),th(Oe("div",XKe,[...W[19]||(W[19]=[Oe("p",{class:"font-medium mb-1"},"Spender Fee Balance",-1),Oe("p",{class:"text-gray-300"}," The spender address needs a small amount of XTZ to pay for transaction fees. This is automatically topped up from the contract when it drops below 0.25 XTZ. ",-1),Oe("div",{class:"absolute top-full left-1/2 -translate-x-1/2 -mt-1"},[Oe("div",{class:"border-4 border-transparent border-t-gray-900"})],-1)])],512),[[bde,c.value]])])]),Oe("p",JKe,Nr((b=Yt(e).storage)==null?void 0:b.spender),1),Oe("div",_Ke,[Oe("div",null,[W[22]||(W[22]=Oe("p",{class:"text-xs text-text-muted"},"Fee Balance",-1)),Oe("p",$Ke,[_n(Nr(A())+" ",1),W[21]||(W[21]=Oe("span",{class:"text-text-muted"},"XTZ",-1))])]),Oe("div",eHe,[th(Oe("input",{"onUpdate:modelValue":W[7]||(W[7]=N=>s.value=N),type:"number",step:"0.1",min:"0",placeholder:"0.5",class:"input-field !py-1 !px-2 w-20 text-sm"},null,512),[[qp,s.value]]),Oe("button",{onClick:O,disabled:o.value||f.value||!s.value,class:"btn-secondary !py-1 !px-2 text-xs flex items-center gap-1"},[o.value?(kt(),Vt("span",rHe)):Oi("",!0),W[23]||(W[23]=_n(" Fund ",-1))],8,tHe)])])])]),d.value?(kt(),Cp(iue,{key:0,title:"Batched Transaction","confirm-text":"Approve","cancel-text":"Fund Contract Only",onConfirm:W[8]||(W[8]=N=>Q(!0)),onCancel:W[9]||(W[9]=N=>Q(!1))},{default:GX(()=>[Oe("div",nHe,[Oe("p",iHe," Your spender fee balance is low ("+Nr(A())+" XTZ). This will be batched as two operations in a single approval: ",1),Oe("div",sHe,[Oe("div",aHe,[W[25]||(W[25]=Oe("span",{class:"text-xs font-semibold text-primary-600 bg-primary-100 rounded-full w-5 h-5 flex items-center justify-center shrink-0 mt-0.5"},"1",-1)),Oe("div",null,[W[24]||(W[24]=Oe("p",{class:"text-sm font-medium text-text-primary"},"Fund contract",-1)),Oe("p",oHe,"Deposit "+Nr(p.value)+" XTZ into the spending contract",1)])]),W[26]||(W[26]=Oe("div",{class:"card-subtle p-3 flex items-start gap-3"},[Oe("span",{class:"text-xs font-semibold text-primary-600 bg-primary-100 rounded-full w-5 h-5 flex items-center justify-center shrink-0 mt-0.5"},"2"),Oe("div",null,[Oe("p",{class:"text-sm font-medium text-text-primary"},"Top up spender"),Oe("p",{class:"text-xs text-text-muted"},"Send 0.5 XTZ for transaction fees")])],-1))])])]),_:1})):Oi("",!0)])}}}),lHe={class:"card p-5 mb-5"},uHe={class:"mb-5"},fHe={class:"flex items-baseline justify-between mb-2"},dHe={class:"mono text-text-primary text-sm"},hHe={class:"progress-bar"},pHe={class:"flex justify-between mt-1.5"},gHe={class:"text-xs text-text-muted"},bHe={key:0,class:"text-xs text-text-muted mono"},mHe={class:"grid grid-cols-2 gap-3 mb-5"},yHe={class:"card-subtle p-3 text-center"},vHe={class:"value-display text-xl"},EHe={class:"card-subtle p-3 text-center"},wHe={class:"value-display text-xl"},IHe={key:0},xHe={class:"grid grid-cols-2 gap-3 mb-3"},SHe=["placeholder"],MHe=["placeholder"],NHe=["disabled"],RHe={key:0,class:"spinner"},AHe=Eh({__name:"SpendingLimits",setup(t){const e=_E(),r=gr(""),n=gr(""),i=gr(null);let s=null;const o=Zc(()=>e.storage?Zv(_6(e.storage.daily_limit)):"0"),c=Zc(()=>e.storage?Zv(_6(e.storage.per_tx_limit)):"0"),u=Zc(()=>e.storage?Zv(_6(e.storage.spent_today)):"0"),f=Zc(()=>!e.storage||e.storage.daily_limit===0?0:Math.min(100,e.storage.spent_today/e.storage.daily_limit*100));function d(){var Q;if(!((Q=e.storage)!=null&&Q.last_reset)){i.value=null;return}const g=new Date(e.storage.last_reset).getTime(),m=Date.now(),x=g+24*60*60*1e3,A=Math.max(0,x-m);if(A<=0){i.value="00:00:00";return}const D=Math.floor(A/1e3),O=Math.floor(D/3600),z=Math.floor(D%3600/60),j=D%60;i.value=`${O.toString().padStart(2,"0")}:${z.toString().padStart(2,"0")}:${j.toString().padStart(2,"0")}`}async function p(){const g=parseFloat(r.value),m=parseFloat(n.value);isNaN(g)||isNaN(m)||(await e.setLimits(g,m),r.value="",n.value="")}return wR(()=>{s=setInterval(d,1e3),d()}),p3(()=>{s&&clearInterval(s)}),(g,m)=>(kt(),Vt("section",lHe,[m[12]||(m[12]=Oe("p",{class:"section-label mb-4"},"spending limits",-1)),Oe("div",uHe,[Oe("div",fHe,[m[2]||(m[2]=Oe("p",{class:"text-sm text-text-secondary"},"Spent Today",-1)),Oe("p",dHe,Nr(u.value)+" / "+Nr(o.value)+" XTZ ",1)]),Oe("div",hHe,[Oe("div",{class:"progress-bar-fill",style:gR({width:`${f.value}%`})},null,4)]),Oe("div",pHe,[Oe("p",gHe,Nr(Math.round(f.value))+"% used",1),i.value?(kt(),Vt("p",bHe," resets in "+Nr(i.value),1)):Oi("",!0)])]),Oe("div",mHe,[Oe("div",yHe,[m[4]||(m[4]=Oe("p",{class:"label"},"daily limit",-1)),Oe("p",null,[Oe("span",vHe,Nr(o.value),1),m[3]||(m[3]=Oe("span",{class:"value-unit text-xs"},"XTZ",-1))])]),Oe("div",EHe,[m[6]||(m[6]=Oe("p",{class:"label"},"per-tx limit",-1)),Oe("p",null,[Oe("span",wHe,Nr(c.value),1),m[5]||(m[5]=Oe("span",{class:"value-unit text-xs"},"XTZ",-1))])])]),Yt(e).isOwner?(kt(),Vt("div",IHe,[m[10]||(m[10]=Oe("div",{class:"divider"},null,-1)),m[11]||(m[11]=Oe("p",{class:"text-sm font-medium text-text-primary mb-3"},"Update Limits",-1)),Oe("div",xHe,[Oe("div",null,[m[7]||(m[7]=Oe("label",{class:"label"},"new daily limit",-1)),th(Oe("input",{"onUpdate:modelValue":m[0]||(m[0]=x=>r.value=x),type:"number",placeholder:o.value,class:"input-field"},null,8,SHe),[[qp,r.value]])]),Oe("div",null,[m[8]||(m[8]=Oe("label",{class:"label"},"new per-tx limit",-1)),th(Oe("input",{"onUpdate:modelValue":m[1]||(m[1]=x=>n.value=x),type:"number",placeholder:c.value,class:"input-field"},null,8,MHe),[[qp,n.value]])])]),Oe("button",{onClick:p,disabled:Yt(e).isLoading||!r.value||!n.value,class:"btn-primary flex items-center gap-2"},[Yt(e).isLoading?(kt(),Vt("span",RHe)):Oi("",!0),m[9]||(m[9]=_n(" Update Limits ",-1))],8,NHe)])):Oi("",!0)]))}}),LHe={class:"card p-5 mb-5"},THe={key:0,class:"card-subtle p-4 border-2 border-green-200 bg-green-50/50"},UHe={key:0,class:"mb-3"},CHe={key:0},OHe={class:"flex items-stretch gap-2"},kHe={class:"mono bg-white px-2 py-1.5 rounded flex-1 break-all text-sm border border-green-200 flex items-center"},DHe=["title"],zHe={key:0,xmlns:"http://www.w3.org/2000/svg",class:"h-4 w-4",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor"},jHe={key:1,xmlns:"http://www.w3.org/2000/svg",class:"h-4 w-4",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor"},FHe={key:1,class:"mb-3"},BHe={class:"flex items-stretch gap-2"},VHe={class:"mono bg-white px-2 py-1.5 rounded flex-1 break-all text-sm border border-amber-200 flex items-center"},qHe=["title"],PHe={key:0,xmlns:"http://www.w3.org/2000/svg",class:"h-4 w-4",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor"},QHe={key:1,xmlns:"http://www.w3.org/2000/svg",class:"h-4 w-4",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor"},WHe={key:2,class:"p-3 mb-3 rounded border border-amber-200 bg-amber-50/50"},GHe={class:"mb-4"},KHe={class:"mono bg-white px-2 py-1.5 rounded block break-all text-sm border border-green-200"},HHe={key:1,class:"card-subtle p-4 border border-amber-200 bg-amber-50/50"},YHe={class:"flex items-start gap-3 mb-4"},ZHe={class:"text-sm text-amber-700"},XHe=["disabled"],c8=.5,JHe=Eh({__name:"SpenderManagement",setup(t){const e=_E(),{isLocal:r,detectMode:n}=cA(),i=gr(!1),s=gr(!1),o=gr(!1),c=gr(!1),u=gr(""),f=gr(""),d=gr(!1),p=gr("");async function g(){const O=await fetch("/api/generate-keypair",{method:"POST"});if(!O.ok)throw new Error("Failed to generate keypair on server");return O.json()}async function m(){if(!(await fetch("/api/activate-key",{method:"POST"})).ok)throw new Error("Failed to activate key on server")}async function x(O,z){await qj(O),p.value=z,setTimeout(()=>{p.value=""},2e3)}async function A(){s.value=!0;try{await n();let O;if(r.value){const z=await g();O=z.address,f.value=z.secretKey}else{const z=await nue();O=z.address,f.value=z.secretKey}await e.setSpender(O),r.value&&await m();try{await e.withdraw(O,c8)}catch(z){console.warn("Failed to fund new spender (contract balance may be too low):",z),c.value=!0}u.value=O,o.value=!0,i.value=!1}catch(O){console.error("Failed to regenerate spender:",O)}finally{s.value=!1}}function D(){o.value=!1,c.value=!1,u.value="",f.value="",d.value=!1}return(O,z)=>(kt(),Vt("section",LHe,[z[27]||(z[27]=Oe("p",{class:"section-label mb-4"},"spender key management",-1)),o.value?(kt(),Vt("div",THe,[z[16]||(z[16]=m6('<div class="flex items-center gap-2 mb-3"><div class="w-8 h-8 bg-green-100 rounded-full flex items-center justify-center"><svg xmlns="http://www.w3.org/2000/svg" class="h-4 w-4 text-green-600" fill="none" viewBox="0 0 24 24" stroke="currentColor"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M5 13l4 4L19 7"></path></svg></div><span class="font-semibold text-green-800">Spender Updated Successfully</span></div>',1)),Yt(r)?(kt(),Vt("div",UHe,[z[9]||(z[9]=Oe("p",{class:"text-sm text-green-700 mb-3"}," Your MCP server has been automatically updated with the new spending key. No manual configuration needed. ",-1)),f.value?(kt(),Vt("div",CHe,[z[8]||(z[8]=Oe("label",{class:"label"},"new spending key",-1)),Oe("div",OHe,[Oe("code",kHe,Nr(d.value?f.value:f.value.slice(0,4)+"•".repeat(24)),1),Oe("button",{onClick:z[0]||(z[0]=j=>d.value=!d.value),class:"btn-secondary !py-1.5 !px-2 text-xs",title:d.value?"Hide spending key":"Show spending key"},[d.value?(kt(),Vt("svg",jHe,[...z[7]||(z[7]=[Oe("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M13.875 18.825A10.05 10.05 0 0112 19c-4.478 0-8.268-2.943-9.543-7a9.97 9.97 0 011.563-3.029m5.858.908a3 3 0 114.243 4.243M9.878 9.878l4.242 4.242M9.88 9.88l-3.29-3.29m7.532 7.532l3.29 3.29M3 3l3.59 3.59m0 0A9.953 9.953 0 0112 5c4.478 0 8.268 2.943 9.543 7a10.025 10.025 0 01-4.132 5.411m0 0L21 21"},null,-1)])])):(kt(),Vt("svg",zHe,[...z[6]||(z[6]=[Oe("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M15 12a3 3 0 11-6 0 3 3 0 016 0z"},null,-1),Oe("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M2.458 12C3.732 7.943 7.523 5 12 5c4.478 0 8.268 2.943 9.542 7-1.274 4.057-5.064 7-9.542 7-4.477 0-8.268-2.943-9.542-7z"},null,-1)])]))],8,DHe),Oe("button",{onClick:z[1]||(z[1]=j=>x(f.value,"key")),class:"btn-secondary !py-1.5 !px-2 text-xs"},Nr(p.value==="key"?"Copied!":"Copy"),1)])])):Oi("",!0)])):(kt(),Vt("div",FHe,[z[13]||(z[13]=Oe("p",{class:"text-sm text-amber-700 mb-3"},[_n(" Update the "),Oe("code",{class:"mono text-xs bg-amber-100 px-1 py-0.5 rounded"},"SPENDING_PRIVATE_KEY"),_n(" environment variable on your MCP server with the new key below and restart Claude Desktop. The key won't be shown again after you leave this page. ")],-1)),Oe("div",null,[z[12]||(z[12]=Oe("label",{class:"label"},"new spending key",-1)),Oe("div",BHe,[Oe("code",VHe,Nr(d.value?f.value:f.value.slice(0,4)+"•".repeat(24)),1),Oe("button",{onClick:z[2]||(z[2]=j=>d.value=!d.value),class:"btn-secondary !py-1.5 !px-2 text-xs",title:d.value?"Hide spending key":"Show spending key"},[d.value?(kt(),Vt("svg",QHe,[...z[11]||(z[11]=[Oe("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M13.875 18.825A10.05 10.05 0 0112 19c-4.478 0-8.268-2.943-9.543-7a9.97 9.97 0 011.563-3.029m5.858.908a3 3 0 114.243 4.243M9.878 9.878l4.242 4.242M9.88 9.88l-3.29-3.29m7.532 7.532l3.29 3.29M3 3l3.59 3.59m0 0A9.953 9.953 0 0112 5c4.478 0 8.268 2.943 9.543 7a10.025 10.025 0 01-4.132 5.411m0 0L21 21"},null,-1)])])):(kt(),Vt("svg",PHe,[...z[10]||(z[10]=[Oe("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M15 12a3 3 0 11-6 0 3 3 0 016 0z"},null,-1),Oe("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M2.458 12C3.732 7.943 7.523 5 12 5c4.478 0 8.268 2.943 9.542 7-1.274 4.057-5.064 7-9.542 7-4.477 0-8.268-2.943-9.542-7z"},null,-1)])]))],8,qHe),Oe("button",{onClick:z[3]||(z[3]=j=>x(f.value,"key")),class:"btn-secondary !py-1.5 !px-2 text-xs"},Nr(p.value==="key"?"Copied!":"Copy"),1)])])])),c.value?(kt(),Vt("div",WHe,[Oe("div",{class:"flex items-start gap-2"},[z[14]||(z[14]=Oe("svg",{xmlns:"http://www.w3.org/2000/svg",class:"h-5 w-5 text-amber-600 flex-shrink-0 mt-0.5",viewBox:"0 0 20 20",fill:"currentColor"},[Oe("path",{"fill-rule":"evenodd",d:"M8.257 3.099c.765-1.36 2.722-1.36 3.486 0l5.58 9.92c.75 1.334-.213 2.98-1.742 2.98H4.42c-1.53 0-2.493-1.646-1.743-2.98l5.58-9.92zM11 13a1 1 0 11-2 0 1 1 0 012 0zm-1-8a1 1 0 00-1 1v3a1 1 0 002 0V6a1 1 0 00-1-1z","clip-rule":"evenodd"})],-1)),Oe("p",{class:"text-sm text-amber-700"}," Could not fund the new spender with "+Nr(c8)+" XTZ for gas fees — the contract balance may be too low. Send some XTZ to the spender address below or fund the contract from the dashboard. ")])])):Oi("",!0),Oe("div",GHe,[z[15]||(z[15]=Oe("label",{class:"label"},"new spender address",-1)),Oe("code",KHe,Nr(u.value),1)]),Oe("button",{onClick:D,class:"btn-primary w-full"}," Done ")])):(kt(),Vt("div",HHe,[Oe("div",YHe,[z[25]||(z[25]=Oe("svg",{xmlns:"http://www.w3.org/2000/svg",class:"h-5 w-5 text-amber-600 flex-shrink-0 mt-0.5",viewBox:"0 0 20 20",fill:"currentColor"},[Oe("path",{"fill-rule":"evenodd",d:"M8.257 3.099c.765-1.36 2.722-1.36 3.486 0l5.58 9.92c.75 1.334-.213 2.98-1.742 2.98H4.42c-1.53 0-2.493-1.646-1.743-2.98l5.58-9.92zM11 13a1 1 0 11-2 0 1 1 0 012 0zm-1-8a1 1 0 00-1 1v3a1 1 0 002 0V6a1 1 0 00-1-1z","clip-rule":"evenodd"})],-1)),Oe("div",null,[z[24]||(z[24]=Oe("p",{class:"text-sm font-medium text-amber-800 mb-1"},"Regenerate Spender Keypair",-1)),Oe("p",ZHe,[z[20]||(z[20]=_n(" This will generate a new spending keypair and update the contract. ",-1)),Yt(r)?(kt(),Vt(vs,{key:0},[_n(" The new spender will be funded with "+Nr(c8)+" XTZ for gas fees. ")],64)):Oi("",!0),z[21]||(z[21]=_n(" The current spender key will ",-1)),z[22]||(z[22]=Oe("strong",null,"stop working immediately",-1)),z[23]||(z[23]=_n(". ",-1)),Yt(r)?(kt(),Vt(vs,{key:1},[_n(" Your MCP server will be updated automatically. ")],64)):(kt(),Vt(vs,{key:2},[z[17]||(z[17]=_n(" You will need to update the ",-1)),z[18]||(z[18]=Oe("code",{class:"mono text-xs bg-amber-100 px-1 py-0.5 rounded"},"SPENDING_PRIVATE_KEY",-1)),z[19]||(z[19]=_n(" environment variable on your MCP server. ",-1))],64))])])]),Oe("button",{onClick:z[4]||(z[4]=j=>i.value=!0),disabled:Yt(e).isLoading,class:"btn-danger w-full flex items-center justify-center gap-2"},[...z[26]||(z[26]=[Oe("svg",{xmlns:"http://www.w3.org/2000/svg",class:"h-4 w-4",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor"},[Oe("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M4 4v5h.582m15.356 2A8.001 8.001 0 004.582 9m0 0H9m11 11v-5h-.581m0 0a8.003 8.003 0 01-15.357-2m15.357 2H15"})],-1),_n(" Regenerate Spender Key ",-1)])],8,XHe)])),i.value?(kt(),Cp(iue,{key:2,title:"Regenerate Spender Key?",message:Yt(r)?`This action cannot be undone. The current spender key will be invalidated immediately and any services using it will lose access. The new spender will be funded with ${c8} XTZ from the contract for gas fees.`:"This action cannot be undone. The current spender key will be invalidated immediately and any services using it will lose access. You will need to update the SPENDING_PRIVATE_KEY environment variable on your MCP server.","confirm-text":"Regenerate","cancel-text":"Cancel",variant:"danger","is-loading":s.value,onConfirm:A,onCancel:z[5]||(z[5]=j=>i.value=!1)},null,8,["message","is-loading"])):Oi("",!0)]))}}),_He={class:"card p-5 mb-5"},$He={class:"space-y-3"},eYe=["placeholder"],tYe=["placeholder"],rYe=["disabled"],nYe={key:0,class:"spinner"},iYe=Eh({__name:"WithdrawFunds",setup(t){const e=Uy(),r=_E(),n=gr(""),i=gr(""),s=Zc(()=>r.contractBalance===null?"0":Zv(_6(r.contractBalance)));async function o(){const c=parseFloat(i.value);!n.value||isNaN(c)||(await r.withdraw(n.value,c),n.value="",i.value="")}return(c,u)=>(kt(),Vt("section",_He,[u[5]||(u[5]=Oe("p",{class:"section-label mb-4"},"withdraw funds",-1)),u[6]||(u[6]=Oe("p",{class:"text-sm text-text-muted mb-4"}," Withdraw any amount without limits. ",-1)),Oe("div",$He,[Oe("div",null,[u[2]||(u[2]=Oe("label",{class:"label"},"recipient",-1)),th(Oe("input",{"onUpdate:modelValue":u[0]||(u[0]=f=>n.value=f),type:"text",placeholder:Yt(e).userAddress??void 0,class:"input-field mono"},null,8,eYe),[[qp,n.value]])]),Oe("div",null,[u[3]||(u[3]=Oe("label",{class:"label"},"amount (xtz)",-1)),th(Oe("input",{"onUpdate:modelValue":u[1]||(u[1]=f=>i.value=f),type:"number",placeholder:`Max: ${s.value}`,class:"input-field"},null,8,tYe),[[qp,i.value]])]),Oe("button",{onClick:o,disabled:Yt(r).isLoading||!n.value||!i.value,class:"btn-primary w-full flex items-center justify-center gap-2"},[Yt(r).isLoading?(kt(),Vt("span",nYe)):Oi("",!0),u[4]||(u[4]=_n(" Withdraw ",-1))],8,rYe)])]))}}),sYe={class:"card mb-5 overflow-hidden"},aYe={class:"overflow-hidden"},oYe={class:"px-5 pb-5"},cYe={class:"flex items-center gap-2 mb-2"},lYe={class:"label !mb-0 !text-[11px] uppercase tracking-wider text-text-muted font-medium"},uYe={class:"space-y-1.5"},fYe={class:"mono text-xs text-accent-600 truncate"},dYe={class:"text-xs text-text-secondary leading-relaxed"},hYe={class:"text-xs text-text-muted italic hidden sm:block"},pYe=Eh({__name:"ToolGuide",setup(t){const e=gr(!1),r=[{label:"Wallet",tools:[{name:"tezos_get_balance",desc:"Check the balance of your spending contract and spender address.",example:"What's my balance?"},{name:"tezos_send_xtz",desc:"Send XTZ to any Tezos address via your spending contract.",example:"Send 5 XTZ to tz1abc..."},{name:"tezos_get_limits",desc:"View daily and per-transaction spending limits, and how much has been used today.",example:"What are my spending limits?"},{name:"tezos_get_addresses",desc:"Get the contract, owner, and spender addresses.",example:"Show me my Tezos addresses"},{name:"tezos_get_operation_history",desc:"View recent transaction history for the spending contract.",example:"Show my recent transactions"}]},{label:"x402 Payments",tools:[{name:"tezos_fetch_with_x402",desc:"Fetch a URL and automatically pay if it requires an x402 payment.",example:"Fetch https://api.example.com/paid-endpoint with a max of 0.5 XTZ"},{name:"tezos_create_x402_payment",desc:"Create a signed x402 payment header without broadcasting. Internal tool.",example:"Create an x402 payment of 500000 mutez to tz1abc..."},{name:"tezos_parse_x402_requirements",desc:"Parse payment requirements from a 402 response body. Internal tool.",example:"Parse these x402 payment requirements"}]},{label:"Account",tools:[{name:"tezos_recover_spender_funds",desc:"Transfer the spender address's XTZ balance back to the owner.",example:"Drain the spender address to my account"},{name:"tezos_reveal_account",desc:"Reveal the spender account on-chain. Internal tool.",example:"Reveal my account"},{name:"tezos_get_dashboard",desc:"Get a link to the configuration dashboard.",example:"Open the dashboard"}]}];return(n,i)=>(kt(),Vt("section",sYe,[Oe("button",{onClick:i[0]||(i[0]=s=>e.value=!e.value),class:"w-full flex items-center justify-between px-5 py-4 cursor-pointer bg-transparent border-none text-left transition-colors hover:bg-primary-50/50"},[i[2]||(i[2]=Oe("p",{class:"section-label !mb-0"},"tool reference",-1)),(kt(),Vt("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:Tg(["text-text-muted transition-transform duration-200",e.value?"rotate-180":""])},[...i[1]||(i[1]=[Oe("polyline",{points:"6 9 12 15 18 9"},null,-1)])],2))]),Oe("div",{class:Tg(["grid transition-[grid-template-rows] duration-300 ease-[cubic-bezier(0.16,1,0.3,1)]",e.value?"grid-rows-[1fr]":"grid-rows-[0fr]"])},[Oe("div",aYe,[Oe("div",oYe,[i[4]||(i[4]=Oe("p",{class:"text-xs text-text-muted mb-4"}," Call tools by asking your AI agent to do things in plain language. Tools marked as internal are automatically called in conjunction with other tools, but can also be called manually. ",-1)),(kt(),Vt(vs,null,xO(r,(s,o)=>Oe("div",{key:s.label,class:Tg(o>0?"mt-4":"")},[Oe("div",cYe,[Oe("span",lYe,Nr(s.label),1),i[3]||(i[3]=Oe("div",{class:"flex-1 h-px bg-primary-200"},null,-1))]),Oe("div",uYe,[(kt(!0),Vt(vs,null,xO(s.tools,c=>(kt(),Vt("div",{key:c.name,class:"card-subtle px-3 py-2.5 grid grid-cols-[160px_1fr] gap-3 items-baseline sm:grid-cols-[170px_1fr_1fr]"},[Oe("span",fYe,Nr(c.name),1),Oe("span",dYe,Nr(c.desc),1),Oe("span",hYe,'"'+Nr(c.example)+'"',1)]))),128))])],2)),64))])])],2)]))}}),gYe={class:"min-h-screen py-12 px-4 sm:px-6 lg:px-8 relative z-10"},bYe={class:"max-w-2xl mx-auto"},mYe={class:"mb-6 flex items-center justify-between"},yYe=["value"],vYe=["value"],EYe={key:0,class:"mb-4 px-4 py-2.5 rounded-lg bg-warning/10 border border-warning/20 flex items-center gap-2 text-sm text-warning"},wYe={class:"text-warning/70"},IYe={class:"text-center"},xYe=["disabled"],SYe={key:0,class:"spinner spinner-dark"},MYe={key:4,class:"card p-4 mt-5 border border-error/20 bg-error/5"},NYe={class:"text-sm text-error"},RYe={class:"mt-12 text-center"},AYe={class:"text-sm text-text-muted"},LYe=Eh({__name:"App",setup(t){const e=Uy(),r=_E(),{detectMode:n,serverNetwork:i}=cA(),s=Object.entries(Yv).map(([c,u])=>({id:c,name:u.name}));async function o(c){const u=c.target;r.clearContractAddress(),await e.switchNetwork(u.value)}return wR(async()=>{var p;await n();const c=new URLSearchParams(window.location.search),u=(p=c.get("network"))==null?void 0:p.toLowerCase(),f=u&&u in Yv?u:i.value&&i.value in Yv?i.value:null;f&&f!==e.networkId&&await e.switchNetwork(f),await e.init();const d=c.get("contract");if(d){if(await r.setContractAddress(d),r.contractAddress){c.delete("contract"),c.delete("network");const g=c.toString()?`${window.location.pathname}?${c}`:window.location.pathname;window.history.replaceState({},"",g)}}else r.contractAddress&&await r.loadContract()}),(c,u)=>(kt(),Vt(vs,null,[u[8]||(u[8]=Oe("div",{class:"film-grain"},null,-1)),Oe("div",gYe,[Oe("div",bYe,[Oe("header",mYe,[u[3]||(u[3]=Oe("h1",{class:"text-3xl font-semibold tracking-tight text-text-primary"}," TezosX MCP Configuration ",-1)),Oe("select",{value:Yt(e).networkId,onChange:o,class:"text-xs text-text-muted bg-transparent border border-border rounded px-2 py-1 cursor-pointer hover:border-text-muted transition-colors"},[(kt(!0),Vt(vs,null,xO(Yt(s),f=>(kt(),Vt("option",{key:f.id,value:f.id},Nr(f.name),9,vYe))),128))],40,yYe)]),Yt(e).networkId!=="mainnet"?(kt(),Vt("div",EYe,[u[4]||(u[4]=Oe("span",{class:"font-medium"},"Testnet",-1)),Oe("span",wYe,"You're connected to "+Nr(Yt(e).currentNetwork.name)+". Funds on this network have no real value.",1)])):Oi("",!0),Uc(jGe),Yt(r).deploymentResult?(kt(),Cp(gKe,{key:1,"contract-address":Yt(r).deploymentResult.contractAddress,"spending-key":Yt(r).deploymentResult.spendingKey,"config-save-failed":Yt(r).deploymentResult.configSaveFailed,onContinue:u[0]||(u[0]=f=>Yt(r).clearDeploymentResult()),onConfigSaved:u[1]||(u[1]=f=>Yt(r).deploymentResult.configSaveFailed=!1)},null,8,["contract-address","spending-key","config-save-failed"])):Oi("",!0),!Yt(r).contractAddress&&!Yt(r).deploymentResult?(kt(),Cp(YGe,{key:2})):Oi("",!0),Yt(r).contractAddress&&Yt(r).storage?(kt(),Vt(vs,{key:3},[Uc(cHe),Uc(pYe),Uc(AHe),Yt(r).isOwner?(kt(),Cp(JHe,{key:0})):Oi("",!0),Yt(r).isOwner?(kt(),Cp(iYe,{key:1})):Oi("",!0),Oe("div",IYe,[Oe("button",{onClick:u[2]||(u[2]=f=>Yt(r).refreshStorage()),disabled:Yt(r).isLoading,class:"btn-secondary flex items-center gap-2 mx-auto"},[Yt(r).isLoading?(kt(),Vt("span",SYe)):Oi("",!0),u[5]||(u[5]=_n(" Refresh ",-1))],8,xYe)])],64)):Oi("",!0),Yt(r).error?(kt(),Vt("div",MYe,[Oe("p",NYe,Nr(Yt(r).error),1)])):Oi("",!0),Oe("footer",RYe,[Oe("p",AYe,[u[6]||(u[6]=_n(" Built with ",-1)),u[7]||(u[7]=Oe("a",{href:"https://taquito.io",target:"_blank"},"Taquito",-1)),_n(" · "+Nr(Yt(e).currentNetwork.name),1)])])])])],64))}});globalThis.Buffer=vh.Buffer;globalThis.process=globalThis.process||{env:{},browser:!0};const sue=Ode(LYe);sue.use(zde());sue.mount("#app");
|
package/frontend/dist/index.html
CHANGED
|
@@ -7,7 +7,7 @@
|
|
|
7
7
|
<link rel="preconnect" href="https://fonts.googleapis.com" />
|
|
8
8
|
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin />
|
|
9
9
|
<link href="https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap" rel="stylesheet" />
|
|
10
|
-
<script type="module" crossorigin src="/assets/index-
|
|
10
|
+
<script type="module" crossorigin src="/assets/index-BbUbeppO.js"></script>
|
|
11
11
|
<link rel="stylesheet" crossorigin href="/assets/index-BjYU9URm.css">
|
|
12
12
|
</head>
|
|
13
13
|
<body>
|