2017-10-30 19:10:25 +00:00
|
|
|
import React, { Component } from 'react';
|
|
|
|
import { connect } from 'react-redux';
|
2018-01-01 19:46:28 +00:00
|
|
|
import WalletDecrypt, { DISABLE_WALLETS } from 'components/WalletDecrypt';
|
2018-03-22 03:50:25 +00:00
|
|
|
import translate, { translateRaw } from 'translations';
|
2017-10-30 19:10:25 +00:00
|
|
|
import { showNotification, TShowNotification } from 'actions/notifications';
|
2018-01-01 19:46:28 +00:00
|
|
|
import { resetWallet, TResetWallet } from 'actions/wallet';
|
2017-10-30 19:10:25 +00:00
|
|
|
import { ISignedMessage } from 'libs/signing';
|
2017-11-29 23:14:57 +00:00
|
|
|
import { IFullWallet } from 'libs/wallet';
|
2017-12-11 20:17:44 +00:00
|
|
|
import { AppState } from 'reducers';
|
2017-11-29 23:14:57 +00:00
|
|
|
import SignButton from './SignButton';
|
2017-12-11 20:17:44 +00:00
|
|
|
import { isWalletFullyUnlocked } from 'selectors/wallet';
|
2017-10-30 19:10:25 +00:00
|
|
|
import './index.scss';
|
2018-03-23 16:41:47 +00:00
|
|
|
import { TextArea, CodeBlock } from 'components/ui';
|
2017-10-30 19:10:25 +00:00
|
|
|
|
|
|
|
interface Props {
|
2017-12-11 20:17:44 +00:00
|
|
|
wallet: IFullWallet;
|
|
|
|
unlocked: boolean;
|
2018-01-01 19:46:28 +00:00
|
|
|
showNotification: TShowNotification;
|
|
|
|
resetWallet: TResetWallet;
|
2017-10-30 19:10:25 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
interface State {
|
|
|
|
message: string;
|
|
|
|
signedMessage: ISignedMessage | null;
|
|
|
|
}
|
|
|
|
|
|
|
|
const initialState: State = {
|
|
|
|
message: '',
|
|
|
|
signedMessage: null
|
|
|
|
};
|
|
|
|
|
2018-03-22 03:50:25 +00:00
|
|
|
const messagePlaceholder = translateRaw('SIGN_MSG_PLACEHOLDER');
|
2017-10-30 19:10:25 +00:00
|
|
|
|
|
|
|
export class SignMessage extends Component<Props, State> {
|
|
|
|
public state: State = initialState;
|
|
|
|
|
2018-01-01 19:46:28 +00:00
|
|
|
public componentWillUnmount() {
|
|
|
|
this.props.resetWallet();
|
|
|
|
}
|
|
|
|
|
2017-10-30 19:10:25 +00:00
|
|
|
public render() {
|
2017-12-11 20:17:44 +00:00
|
|
|
const { wallet, unlocked } = this.props;
|
2017-10-30 19:10:25 +00:00
|
|
|
const { message, signedMessage } = this.state;
|
|
|
|
|
|
|
|
return (
|
|
|
|
<div>
|
2018-01-01 19:46:28 +00:00
|
|
|
{unlocked ? (
|
|
|
|
<div className="Tab-content-pane">
|
|
|
|
<button
|
|
|
|
className="SignMessage-reset btn btn-default btn-sm"
|
|
|
|
onClick={this.changeWallet}
|
|
|
|
>
|
|
|
|
<i className="fa fa-refresh" />
|
2018-03-22 03:50:25 +00:00
|
|
|
{translate('CHANGE_WALLET')}
|
2018-01-01 19:46:28 +00:00
|
|
|
</button>
|
2018-03-01 17:53:29 +00:00
|
|
|
|
|
|
|
<div className="input-group-wrapper Deploy-field">
|
|
|
|
<label className="input-group">
|
2018-03-22 03:50:25 +00:00
|
|
|
<div className="input-group-header">{translate('MSG_MESSAGE')}</div>
|
2018-03-01 17:53:29 +00:00
|
|
|
<TextArea
|
|
|
|
className={`SignMessage-inputBox ${message ? 'is-valid' : 'is-invalid'}`}
|
|
|
|
placeholder={messagePlaceholder}
|
|
|
|
value={message}
|
|
|
|
onChange={this.handleMessageChange}
|
|
|
|
/>
|
|
|
|
</label>
|
2018-03-22 03:50:25 +00:00
|
|
|
<div className="SignMessage-help">{translate('MSG_INFO2')}</div>
|
2018-01-01 19:46:28 +00:00
|
|
|
</div>
|
2017-10-30 19:10:25 +00:00
|
|
|
|
2017-12-11 20:17:44 +00:00
|
|
|
<SignButton
|
|
|
|
wallet={wallet}
|
|
|
|
message={this.state.message}
|
|
|
|
showNotification={this.props.showNotification}
|
|
|
|
onSignMessage={this.onSignMessage}
|
|
|
|
/>
|
2017-10-30 19:10:25 +00:00
|
|
|
|
2018-01-01 19:46:28 +00:00
|
|
|
{!!signedMessage && (
|
2018-03-01 17:53:29 +00:00
|
|
|
<div className="input-group-wrapper SignMessage-inputBox">
|
|
|
|
<label className="input-group">
|
2018-03-22 03:50:25 +00:00
|
|
|
<div className="input-group-header">{translate('MSG_SIGNATURE')}</div>
|
2018-03-23 16:41:47 +00:00
|
|
|
<CodeBlock className="SignMessage-inputBox">
|
|
|
|
{JSON.stringify(signedMessage, null, 2)}
|
|
|
|
</CodeBlock>
|
2018-03-01 17:53:29 +00:00
|
|
|
</label>
|
2017-10-30 19:10:25 +00:00
|
|
|
</div>
|
2018-01-01 19:46:28 +00:00
|
|
|
)}
|
|
|
|
</div>
|
|
|
|
) : (
|
|
|
|
<WalletDecrypt hidden={unlocked} disabledWallets={DISABLE_WALLETS.UNABLE_TO_SIGN} />
|
|
|
|
)}
|
2017-10-30 19:10:25 +00:00
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
private handleMessageChange = (e: React.FormEvent<HTMLTextAreaElement>) => {
|
|
|
|
const message = e.currentTarget.value;
|
|
|
|
this.setState({ message });
|
|
|
|
};
|
|
|
|
|
2017-11-29 23:14:57 +00:00
|
|
|
private onSignMessage = (signedMessage: ISignedMessage) => {
|
|
|
|
this.setState({ signedMessage });
|
2017-10-30 19:10:25 +00:00
|
|
|
};
|
2018-01-01 19:46:28 +00:00
|
|
|
|
|
|
|
private changeWallet = () => {
|
|
|
|
this.props.resetWallet();
|
|
|
|
};
|
2017-10-30 19:10:25 +00:00
|
|
|
}
|
|
|
|
|
2017-12-11 20:17:44 +00:00
|
|
|
const mapStateToProps = (state: AppState) => ({
|
|
|
|
wallet: state.wallet.inst,
|
|
|
|
unlocked: isWalletFullyUnlocked(state)
|
|
|
|
});
|
|
|
|
|
2018-01-01 19:46:28 +00:00
|
|
|
export default connect(mapStateToProps, {
|
|
|
|
showNotification,
|
|
|
|
resetWallet
|
|
|
|
})(SignMessage);
|