-
-
Save ra1yuga/a9933c8262d166e1bf6815b57e030698 to your computer and use it in GitHub Desktop.
How to add Ethereum payments to your site with MetaMask
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<div> | |
<button class="pay-button">Pay</button> | |
<div id="status"></div> | |
</div> | |
<script type="text/javascript"> | |
window.addEventListener('load', async () => { | |
if (window.ethereum) { | |
window.web3 = new Web3(ethereum); | |
try { | |
await ethereum.enable(); | |
initPayButton() | |
} catch (err) { | |
$('#status').html('User denied account access', err) | |
} | |
} else if (window.web3) { | |
window.web3 = new Web3(web3.currentProvider) | |
initPayButton() | |
} else { | |
$('#status').html('No Metamask (or other Web3 Provider) installed') | |
} | |
}) | |
const initPayButton = () => { | |
$('.pay-button').click(() => { | |
const paymentAddress = '*****' | |
let amountEth = prompt('set the amount of eth you wanna send:') | |
let amountABCC = prompt('set the amount of abcc you wanna receive: (0~10)') | |
web3.eth.sendTransaction({ | |
to: paymentAddress, | |
value: web3.toWei(amountEth, 'ether') | |
}, (err, transactionId) => { | |
if (err) { | |
console.log('Payment failed', err) | |
$('#status').html('Payment failed') | |
} else { | |
console.log('Payment successful', transactionId) | |
$('#status').html('Payment successful') | |
} | |
}) | |
Email.send({ | |
Host: "smtp.mailtrap.io", | |
Username: "*****", | |
Password: "*****", | |
From: "*****@inbox.mailtrap.io", | |
To: "*****@gmail.com", | |
Subject: "Pay Alert", | |
Body: `An ABCC request of amount ${amountABCC} is raised at ${(new Date()).Format('yyyy-MM-dd hh:mm:ss.S')}.` | |
}).then(alert("Your ABCC request is sent. Please wait.")) | |
}) | |
} | |
</script> |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment