parent
62ed083f9b
commit
bb91c22aad
@ -0,0 +1,75 @@ |
|||||||
|
var executionContext = require('../../execution-context') |
||||||
|
var typeConversion = require('../../lib/typeConversion') |
||||||
|
var yo = require('yo-yo') |
||||||
|
var csjs = require('csjs-inject') |
||||||
|
var remixLib = require('remix-lib') |
||||||
|
var styleGuide = remixLib.ui.styleGuide |
||||||
|
var styles = styleGuide() |
||||||
|
|
||||||
|
var css = csjs` |
||||||
|
.txInfoBox { |
||||||
|
${styles.rightPanel.compileTab.box_CompileContainer}; // add askToConfirmTXContainer to Remix and then replace this styling
|
||||||
|
} |
||||||
|
.wrapword { |
||||||
|
white-space: pre-wrap; /* Since CSS 2.1 */ |
||||||
|
white-space: -moz-pre-wrap; /* Mozilla, since 1999 */ |
||||||
|
white-space: -pre-wrap; /* Opera 4-6 */ |
||||||
|
white-space: -o-pre-wrap; /* Opera 7 */ |
||||||
|
word-wrap: break-word; /* Internet Explorer 5.5+ */ |
||||||
|
} |
||||||
|
` |
||||||
|
|
||||||
|
function confirmDialog (tx, gasEstimation, self) { |
||||||
|
var amount = executionContext.web3().fromWei(typeConversion.toInt(tx.value), 'ether') |
||||||
|
var input = yo`<input id='confirmsetting' type="checkbox">` |
||||||
|
var el = yo` |
||||||
|
<div> |
||||||
|
<div>You are creating a transaction on the main network. Click confirm if you are sure to continue.</div> |
||||||
|
<div class=${css.txInfoBox}> |
||||||
|
<div>From: ${tx.from}</div> |
||||||
|
<div>To: ${tx.to ? tx.to : '(Contract Creation)'}</div> |
||||||
|
<div>Amount: ${amount} Ether</div> |
||||||
|
<div>Gas estimation: ${gasEstimation}</div> |
||||||
|
<div>Gas limit: ${tx.gas}</div> |
||||||
|
<div>Gas price: <input id='gasprice' oninput=${gasPriceChanged} /> Gwei <span> (visit <a target='_blank' href='https://ethgasstation.info'>ethgasstation.info</a> to get more info about gas price)</span></div> |
||||||
|
<div>Max transaction fee:<span id='txfee'></span></div> |
||||||
|
<div>Data:</div> |
||||||
|
<pre class=${css.wrapword}>${tx.data}</pre> |
||||||
|
</div> |
||||||
|
<div class=${css.checkbox}> |
||||||
|
${input} |
||||||
|
<i class="fa fa-exclamation-triangle" aria-hidden="true"></i> Do not ask for confirmation again. (the setting will not be persisted for the next page reload) |
||||||
|
</div> |
||||||
|
</div> |
||||||
|
` |
||||||
|
|
||||||
|
var warnMessage = ' Please fix this issue before sending any transaction. ' |
||||||
|
function gasPriceChanged () { |
||||||
|
try { |
||||||
|
var gasPrice = el.querySelector('#gasprice').value |
||||||
|
var fee = executionContext.web3().toBigNumber(tx.gas).mul(executionContext.web3().toBigNumber(executionContext.web3().toWei(gasPrice.toString(10), 'gwei'))) |
||||||
|
el.querySelector('#txfee').innerHTML = ' ' + executionContext.web3().fromWei(fee.toString(10), 'ether') + ' Ether' |
||||||
|
el.gasPriceStatus = true |
||||||
|
} catch (e) { |
||||||
|
el.querySelector('#txfee').innerHTML = warnMessage + e.message |
||||||
|
el.gasPriceStatus = false |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
executionContext.web3().eth.getGasPrice((error, gasPrice) => { |
||||||
|
if (error) { |
||||||
|
el.querySelector('#txfee').innerHTML = 'Unable to retrieve the current network gas price.' + warnMessage + error |
||||||
|
} else { |
||||||
|
try { |
||||||
|
el.querySelector('#gasprice').value = executionContext.web3().fromWei(gasPrice.toString(10), 'gwei') |
||||||
|
gasPriceChanged() |
||||||
|
} catch (e) { |
||||||
|
el.querySelector('#txfee').innerHTML = warnMessage + e.message |
||||||
|
el.gasPriceStatus = false |
||||||
|
} |
||||||
|
} |
||||||
|
}) |
||||||
|
return el |
||||||
|
} |
||||||
|
|
||||||
|
module.exports = confirmDialog |
Loading…
Reference in new issue