-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathinteract.html
96 lines (85 loc) · 3.96 KB
/
interact.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Interaction</title>
<link rel="stylesheet" href="style.css">
</head>
<body>
<h1 id="title">Interact with something</h1>
<form>
<label for="address">Address</label>
<input autocomplete="false" name="address" id="address" type="text" placeholder="0x">
<label for="artifact">Artifact</label>
<textarea autocomplete="false" name="artifact" id="artifact" rows="25" style="resize: vertical;" placeholder="{ "abi": [{}], "bytecode": "0x" }"></textarea>
<label for="method">Method</label>
<input autocomplete="false" name="method" id="method" type="text">
<label for="args">Arguments</label>
<input autocomplete="false" name="args" id="args" type="text" placeholder="[]">
<button type="submit" disabled>Deploy</button>
</form>
<script src="https://cdnjs.cloudflare.com/ajax/libs/ethers/5.2.0/ethers.umd.min.js" type="application/javascript"></script>
<script>
const FIELDS = ["address", "artifact", "method", "args"];
function getFormData(form) {
const data = new FormData(form);
const address = data.get("address");
const artifact = data.get("artifact");
const method = data.get("method");
const args = data.get("args");
return { address, artifact, method, args };
}
function updateTitle(input) {
try {
const { contractName = "something" } = JSON.parse(input);
document.getElementById("title").innerText = `Interact with ${contractName}`;
} catch (_) {
document.getElementById("title").innerText = "Interact with something";
}
}
const form = document.querySelector("form");
const button = form.querySelector("button");
const addressInput = document.getElementById("address");
const artifactInput = document.getElementById("artifact");
const methodInput = document.getElementById("method");
const argsInput = document.getElementById("args");
try {
const base64 = decodeURIComponent(window.location.hash.substr(1));
const { address, artifact, method, args } = JSON.parse(atob(base64));
addressInput.value = address;
artifactInput.value = artifact;
methodInput.value = method;
argsInput.value = args;
updateTitle(artifact);
} catch (_) {
console.error(_);
}
artifactInput.addEventListener("input", (event) => updateTitle(event.currentTarget.value));
form.addEventListener("change", event => {
const data = getFormData(event.currentTarget);
const base64 = btoa(JSON.stringify(data));
window.location.hash = `#${encodeURIComponent(base64)}`;
});
const disableForm = event => {
event.preventDefault();
};
form.addEventListener("submit", disableForm);
const provider = new ethers.providers.Web3Provider(window.ethereum);
provider.send("eth_requestAccounts", []).then(() => {
const signer = provider.getSigner();
button.disabled = false;
form.removeEventListener(form, disableForm);
form.addEventListener("submit", event => {
event.preventDefault();
const { address, artifact, method, args } = getFormData(event.currentTarget);
const { abi, bytecode } = JSON.parse(artifact);
const contract = new ethers.Contract(address, abi, signer);
button.disabled = true;
contract[method](...JSON.parse(args)).then(console.log);
});
});
</script>
</body>
</html>