|
@ -1,4 +1,5 @@ |
|
|
import React from 'react'; |
|
|
import React from 'react'; |
|
|
|
|
|
import ReactDOM from 'react-dom'; |
|
|
import Config from '../../config'; |
|
|
import Config from '../../config'; |
|
|
import { translate } from '../../translate/translate'; |
|
|
import { translate } from '../../translate/translate'; |
|
|
import { |
|
|
import { |
|
@ -31,6 +32,7 @@ import io from 'socket.io-client'; |
|
|
const socket = io.connect('http://127.0.0.1:' + Config.agamaPort); |
|
|
const socket = io.connect('http://127.0.0.1:' + Config.agamaPort); |
|
|
|
|
|
|
|
|
// TODO: prevent any cache updates rather than utxo while on send coin form
|
|
|
// TODO: prevent any cache updates rather than utxo while on send coin form
|
|
|
|
|
|
// fix a bug - total amount is incorrect when switching between steps
|
|
|
|
|
|
|
|
|
class SendCoin extends React.Component { |
|
|
class SendCoin extends React.Component { |
|
|
constructor(props) { |
|
|
constructor(props) { |
|
@ -57,9 +59,28 @@ class SendCoin extends React.Component { |
|
|
this.getOAdress = this.getOAdress.bind(this); |
|
|
this.getOAdress = this.getOAdress.bind(this); |
|
|
this.toggleSendAPIType = this.toggleSendAPIType.bind(this); |
|
|
this.toggleSendAPIType = this.toggleSendAPIType.bind(this); |
|
|
this._fetchNewUTXOData = this._fetchNewUTXOData.bind(this); |
|
|
this._fetchNewUTXOData = this._fetchNewUTXOData.bind(this); |
|
|
|
|
|
this.handleClickOutside = this.handleClickOutside.bind(this); |
|
|
socket.on('messages', msg => this.updateSocketsData(msg)); |
|
|
socket.on('messages', msg => this.updateSocketsData(msg)); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
componentWillMount() { |
|
|
|
|
|
document.addEventListener('click', this.handleClickOutside, false); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
componentWillUnmount() { |
|
|
|
|
|
document.removeEventListener('click', this.handleClickOutside, false); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
handleClickOutside(e) { |
|
|
|
|
|
if (e.srcElement.className !== 'btn dropdown-toggle btn-info' && |
|
|
|
|
|
(e.srcElement.offsetParent && e.srcElement.offsetParent.className !== 'btn dropdown-toggle btn-info') && |
|
|
|
|
|
(e.path && e.path[4] && e.path[4].className.indexOf('showkmdwalletaddrs') === -1)) { |
|
|
|
|
|
this.setState({ |
|
|
|
|
|
addressSelectorOpen: false, |
|
|
|
|
|
}); |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
componentWillReceiveProps(props) { |
|
|
componentWillReceiveProps(props) { |
|
|
if (!this.state.sendFrom && this.props.ActiveCoin.activeAddress) { |
|
|
if (!this.state.sendFrom && this.props.ActiveCoin.activeAddress) { |
|
|
this.setState(Object.assign({}, this.state, { |
|
|
this.setState(Object.assign({}, this.state, { |
|
@ -270,7 +291,7 @@ class SendCoin extends React.Component { |
|
|
|
|
|
|
|
|
renderAddressList() { |
|
|
renderAddressList() { |
|
|
return ( |
|
|
return ( |
|
|
<div className={ 'btn-group bootstrap-select form-control form-material showkmdwalletaddrs show-tick ' + (this.state.addressSelectorOpen ? 'open' : '') }> |
|
|
<div id="showkmdwalletaddrs" className={ 'btn-group bootstrap-select form-control form-material showkmdwalletaddrs show-tick ' + (this.state.addressSelectorOpen ? 'open' : '') }> |
|
|
<button |
|
|
<button |
|
|
type="button" |
|
|
type="button" |
|
|
className="btn dropdown-toggle btn-info" |
|
|
className="btn dropdown-toggle btn-info" |
|
|