Please try again", "danger"); return; } toastMsg('Almost There', "You are ready to download your keystore file and receive your private key", "success"); $('.createWallet').hide(); $('.saveKeystore').show(); } function downloadKeystore(){ var userWallet = generateAddress($('#password').val()) localStorage.setItem('lastAddress', userWallet.address) localStorage.setItem('lastKey', userWallet.privKey) $('#newPrivKey').val(userWallet.privKey) $('.iUnderstandButton').attr('disabled', false) } function printPaperWallet(){ var win = window.open("about:blank", "_blank"); var data = '
Paper Wallet
Bitcoin Address
Private Key
' win.document.write(data); } function clearPreviousData(){ localStorage.setItem('lastAddress', '') localStorage.setItem('lastKey', '') } function iUnderstand(){ $('.createWallet').hide(); $('.saveKeystore').hide(); $('.privateSection').show(); } function restart(){ $('.createWallet').show(); $('.saveKeystore').hide(); $('.privateSection').hide(); $('#password').val(''); localStorage.setItem('lastAddress', '') localStorage.setItem('lastKey', '') } function encryptScreen(){ $('.createSection').hide(); $('.sendSection').hide(); $('.encryptSection').show(); $('.page-title').html('Encrypt Existing Key') $('.breadcrumb-item:nth(1)').html('Encrypt Existing') $('#privKeyArea').show() $('#passCodeArea').hide() $('#addPassButton').show(); $('#encryptProgress').hide() $('#encryptedText').hide() $('.faqSection').hide(); restart() } function faqScreen(){ if($('#faqCreate').attr('aria-expanded') == "false"){ $('#faqCreate').click() } $('.createSection').hide(); $('.sendSection').hide(); $('.encryptSection').hide(); $('.page-title').html('FAQ') $('.breadcrumb-item:nth(1)').html('FAQ') $('#privKeyArea').hide() $('#passCodeArea').hide() $('#addPassButton').hide(); $('#encryptProgress').hide() $('#encryptedText').hide() $('.faqSection').show(); restart() } function faqAbout(){ faqScreen() if($('#aboutFaq').attr('aria-expanded') == "false"){ $('#aboutFaq').click() } } function sendScreen(){ $('.createSection').hide(); $('.encryptSection').hide(); $('.sendSection').show(); $('.page-title').html('Send Bitcoin') $('.breadcrumb-item:nth(1)').html('Send Bitcoin') $('.howAccess').show() $('.generateTransaction').hide() $('.faqSection').hide(); restart() } function createScreen(){ $('.createSection').show(); $('.encryptSection').hide(); $('.sendSection').hide(); $('.page-title').html('Create New Bitcoin Address') $('.breadcrumb-item:nth(1)').html('Create Address') $('.faqSection').hide(); restart() } function fileUploadListen(){ $('#walletFileButton').on('change', function(){ selectedFile = document.getElementById('walletFileButton').files[0] var reader = new FileReader() reader.onload = function(event){ validateUpload(event.target.result);} reader.onerror = function(event){} reader.readAsText(selectedFile) }) } function validateUpload(fileContent){ try{ var encKey= $.parseJSON(fileContent) cypherText = encKey.Crypto.cyphertext; $('#unlockCode').show(); $('#unlockButton').show() return true; } catch(err){ toastMsg("Incorrect Format", "Please upload an encrypted JSON file that is the correct format", "danger") return false; } } function unlockMethodListen(){ $('.howAccess input[type=radio]').on('click', function(){ $('.credentials').show() if($(this).val() == "private"){ $('.accessAction').html("Paste Your Private Key") $('.accessInstruct').html('This is not a recommended way to access your wallet.
Entering your private key on a website is dangerous. If our website is compromised or you accidentally visit a different website, your funds will be stolen.') $('#privKey').show() $('#walletFileButton').hide() $('#privKeyButton').show() $('#unlockCode').hide(); $('#unlockButton').hide() } else{ $('.accessAction').html("Select Your Wallet File") $('.accessInstruct').html('Entering your private key on a website dangerous. If you accidentally visit a website other than CreateSendBitcoin.com (less you are running this open-source code locally), your funds will be stolen.') $('#privKey').hide() $('#walletFileButton').show() $('#privKeyButton').hide() $('#unlockCode').hide(); $('#unlockButton').hide() } }) } function unlockEncrypted(){ var decryptResult = decryptWallet(cypherText, $('#unlockCode').val()); if(decryptResult == false){ toastMsg("Error", "Your passphrase does not unlock this", "danger") return; } else{ userAddress = privKeyToAddress(decryptResult); currentPriv = decryptResult; toastMsg("Success", "You have unlocked this wallet", "success") getWalletInfo(userAddress); } $('.howAccess').hide() $('.generateTransaction').show() $('#transactions').hide(); } function getWalletInfo(userAddress){ $('#userAddress').html(userAddress) $.ajax({ url:'https://avocado.proofsuite.com/cloud/api/beta/blockchain.php?address='+userAddress, complete:function(transport){ walletData = $.parseJSON(transport.responseText); $('#userBalance').html((walletData.final_balance / 100000000).toFixed(5) + " BTC"); $('#transHistory').html('https://www.blockchain.com/btc/address/'+userAddress+'') } }) } function broadcastTransaction(hash){ $('#sendTransProgress').show() $('#sendTransactionButton').attr('disabled', true); $.ajax({ 'url':'https://avocado.proofsuite.com/cloud/api/beta/broadcast.php', data: {transHash:hash}, complete:function(transport){ try{ txHash = $.parseJSON(transport.responseText); $('#successTrans').show().html('Transaction ID: https://www.blockchain.com/btc/tx/'+txHash.txid+'') $('#sendTransactionButton').attr('disabled', false); $('#sendTransProgress').hide() } catch(err){ toastMsg("Error", "There was an issue submitting your transaction to the blockchain. Please try again later. Or broadcast this transaction has on Coinb.in. ", "danger") $('#sendTransactionButton').attr('disabled', false); $('#sendTransProgress').hide() return; } toastMsg("Success", "Your transaction has been submitted to the blockchain", "success"); } }) } function unlockPrivate(){ var isValidKey= privKeyToAddress($('#privKey').val().trim()); currentPriv = $('#privKey').val().trim(); if(isValidKey == false){ toastMsg("Error", "This is not a valid private key", "danger") return; } else{ userAddress = isValidKey; toastMsg("Success", "You have unlocked this wallet", "success") getWalletInfo(userAddress); } $('.howAccess').hide() $('.generateTransaction').show() $('#transactions').hide(); } function sendTransaction(){ $('#sendTransactionButton').attr('disabled', true); var signedHash = $('#signedTrans').val(); if($('#toAddress').val().trim().length < 33){ toastMsg("Error", "Invalid Recepient Address", 'danger'); $('#sendTransactionButton').attr('disabled', false); $('#transactions').hide() return; } if(isNaN($('#amountToSend').val().trim())){ toastMsg("Error", "Amount you are sending is not a number", 'danger'); $('#sendTransactionButton').attr('disabled', false); $('#transactions').hide() return; } if(isNaN($('#feePer100').val().trim())){ toastMsg("Error", "Your fee is not a number. Please send a valid number", 'danger'); $('#sendTransactionButton').attr('disabled', false); $('#transactions').hide() return; } //TODO: give user a dialogue asking them if they want to send whole balance minus fee because they dont have enough. right now it defaults to sending whole balance - mine fee if their amount to send is too great if(finalFee + parseFloat($('#amountToSend').val().trim()) > (walletData.final_balance / 100000000).toFixed(5)){ toastMsg("Error", "You do not have enough balance + the miner fee ("+finalFee.toFixed(5)+") to send this transaction.
Please reduce amount to send", 'warning'); $('#sendTransactionButton').attr('disabled', false); $('#transactions').hide() return; } broadcastTransaction(signedHash.trim()); } function getWalletDataThenGenerate(){ $('#userAddress').html(userAddress) $.ajax({ url:'https://avocado.proofsuite.com/cloud/api/beta/blockchain.php?address='+userAddress, complete:function(transport){ walletData = $.parseJSON(transport.responseText); $('#userBalance').html((walletData.final_balance / 100000000).toFixed(5) + " BTC"); $('#transHistory').html('https://www.blockchain.com/btc/address/'+userAddress+'') generateTransaction() }, error:function(transport){ toastMsg("Connection Error", "Internet connection is required to get your input data from the blockchain and craft the transaction. You can also do this manually offline on Coinb.in.", "warning"); } }) } function generateTransaction(){ if(typeof walletData == "undefined" ){ getWalletDataThenGenerate(); return; } if($('#toAddress').val().trim().length < 33){ toastMsg("Error", "Invalid Recepient Address", 'danger'); return; } if(isNaN($('#amountToSend').val().trim()) || $('#amountToSend').val().trim() == ""){ toastMsg("Error", "Amount you are sending is not a number", 'danger'); return; } if(isNaN($('#feePer100').val().trim()) || $('#feePer100').val().trim() ==""){ toastMsg("Error", "Your fee is not a number. Please send a valid number", 'danger'); return; } $('#transactions').show(); generateAndSignTransaction(userAddress, currentPriv, $('#toAddress').val(), parseFloat($('#amountToSend').val()), walletData, parseFloat($('#feePer100').val()) ); $('#signedTrans').val(response[1]) $('#rawTrans').val(response[0]) } function addPasscode(){ if($('#toEncryptPriv').val().length < 40){ toastMsg('Not Valid', "The private key you entered is not a valid Bitcoin key", 'danger'); return; } isValidAddress = privKeyToAddress( $('#toEncryptPriv').val().trim()) if(isValidAddress == false){ toastMsg('Not Valid', "The private key you entered is not a valid Bitcoin key that converts into bitcoin address", 'danger'); return; } $('#passCodeArea').show() $('#addPassButton').hide(); } function encryptPriv(){ var textToShow = generateEncryptedFromKey($('#toEncryptPriv').val().trim(), privKeyToAddress($('#toEncryptPriv').val().trim()),$('#toEncryptPass').val().trim()) $('.encText').val(textToShow); $('.encProgress').css({'width':'40%'}) $('#encryptProgress').show() setTimeout(function(){ $('.encProgress').css({'width':'75%'}) }, 1000) setTimeout(function(){ $('#encryptProgress').hide() $('#encryptedText').show() $('.encProgress').css({'width':'10%'}) $('#privKeyArea').hide() $('#passCodeArea').hide() },2000) } function setupNotification(){ NotificationApp = function() { }; /** * Send Notification * @param {*} heading heading text * @param {*} body body text * @param {*} position position e.g top-right, top-left, bottom-left, etc * @param {*} loaderBgColor loader background color * @param {*} icon icon which needs to be displayed * @param {*} hideAfter automatically hide after seconds * @param {*} stack */ NotificationApp.prototype.send = function(heading, body, position, loaderBgColor, icon, hideAfter, stack, showHideTransition) { // default if (!hideAfter) hideAfter = 6500; if (!stack) stack = 1; var options = { heading: heading, text: body, position: position, loaderBg: loaderBgColor, icon: icon, hideAfter: hideAfter, stack: stack }; if(showHideTransition) options.showHideTransition = showHideTransition; // console.log(options); $.toast().reset('all'); $.toast(options); }, $.NotificationApp = new NotificationApp, $.NotificationApp.Constructor = NotificationApp } function toastMsg(title, msg, msgType="success"){ if(typeof title !="string"){ title= "hello" } if(typeof msg !="string"){ msg= "example message" } if(msgType== "success"){ $.NotificationApp.send(title, msg, 'top-right', '#5ba035', 'success'); } else if(msgType =="info"){ $.NotificationApp.send(title, msg, 'bottom-right', '#3b98b5', 'info'); } else if(msgType=="warning"){ $.NotificationApp.send(title, msg, 'top-center', '#da8609', 'warning'); } else{ $.NotificationApp.send(title, msg, 'top-right', '#bf441d', 'error'); } } function downloadEncryptedFile(){ download(fileName, fileText); } function stickyFoot(){ stickyFooter.init(); } function feeChangeListen(){ $('#feePer100').on('change keyup', function(){ $('#recommendedFee').hide() }) } $(document).ready(function(){ unlockMethodListen() fileUploadListen() setupNotification() clearPreviousData(); stickyFoot() feeChangeListen() }) setTimeout(function(){ try{ (function(e,a){if(!a.__SV){var b=window;try{var c,l,i,j=b.location,g=j.hash;c=function(a,b){return(l=a.match(RegExp(b+"=([^&]*)")))?l[1]:null};g&&c(g,"state")&&(i=JSON.parse(decodeURIComponent(c(g,"state"))),"mpeditor"===i.action&&(b.sessionStorage.setItem("_mpcehash",g),history.replaceState(i.desiredHash||"",e.title,j.pathname+j.search)))}catch(m){}var k,h;window.mixpanel=a;a._i=[];a.init=function(b,c,f){function e(b,a){var c=a.split(".");2==c.length&&(b=b[c[0]],a=c[1]);b[a]=function(){b.push([a].concat(Array.prototype.slice.call(arguments, 0)))}}var d=a;"undefined"!==typeof f?d=a[f]=[]:f="mixpanel";d.people=d.people||[];d.toString=function(b){var a="mixpanel";"mixpanel"!==f&&(a+="."+f);b||(a+=" (stub)");return a};d.people.toString=function(){return d.toString(1)+".people (stub)"};k="disable time_event track track_pageview track_links track_forms register register_once alias unregister identify name_tag set_config reset opt_in_tracking opt_out_tracking has_opted_in_tracking has_opted_out_tracking clear_opt_in_out_tracking people.set people.set_once people.unset people.increment people.append people.union people.track_charge people.clear_charges people.delete_user".split(" "); for(h=0;h
No comments:
Post a Comment