65 lines
1.9 KiB
JavaScript
Raw Normal View History

2018-05-13 01:31:01 -03:00
import EmbarkJS from 'Embark/EmbarkJS';
import TestToken from 'Embark/contracts/TestToken';
import React from 'react';
import { Form, FormGroup, FormControl, HelpBlock, Button } from 'react-bootstrap';
2018-05-31 20:38:21 -03:00
import ERC20TokenUI from './erc20token';
import { connect } from 'react-redux';
import { actions as accountActions } from '../reducers/accounts';
2018-05-31 20:38:21 -03:00
2018-05-13 01:31:01 -03:00
class TestTokenUI extends React.Component {
constructor(props) {
super(props);
this.state = {
amountToMint: 100,
}
}
handleMintAmountChange(e){
this.setState({amountToMint: e.target.value});
}
mint(e){
const { addToBalance } = this.props;
2018-05-13 01:31:01 -03:00
e.preventDefault();
var value = parseInt(this.state.amountToMint, 10);
if (EmbarkJS.isNewWeb3()) {
TestToken.methods.mint(value).send({from: web3.eth.defaultAccount})
.then(r => { addToBalance(value) });
2018-05-13 01:31:01 -03:00
} else {
TestToken.mint(value).send({from: web3.eth.defaultAccount})
.then(r => { addToBalance(value) });
2018-05-13 01:31:01 -03:00
}
2018-06-05 11:45:35 -03:00
console.log(TestToken.options.address +".mint("+value+").send({from: " + web3.eth.defaultAccount + "})");
2018-05-13 01:31:01 -03:00
}
2018-05-31 20:38:21 -03:00
2018-05-13 01:31:01 -03:00
render(){
return (<React.Fragment>
2018-05-31 20:38:21 -03:00
<h3> Mint Test Token</h3>
2018-05-13 01:31:01 -03:00
<Form inline>
<FormGroup>
<FormControl
type="text"
defaultValue={this.state.amountToMint}
onChange={(e) => this.handleMintAmountChange(e)} />
<Button bsStyle="primary" onClick={(e) => this.mint(e)}>Mint</Button>
</FormGroup>
</Form>
2018-05-31 20:38:21 -03:00
<ERC20TokenUI address={ TestToken.options.address } />
2018-05-13 01:31:01 -03:00
</React.Fragment>
);
}
}
const mapDispatchToProps = dispatch => ({
addToBalance(amount) {
dispatch(accountActions.addToSntTokenBalance(amount));
},
});
export default connect(null, mapDispatchToProps)(TestTokenUI);