2017-11-29 23:14:57 +00:00
|
|
|
import React from 'react';
|
|
|
|
import translate from 'translations';
|
|
|
|
import { ISignedMessage } from 'libs/signing';
|
|
|
|
import { IFullWallet } from 'libs/wallet';
|
|
|
|
import { TShowNotification } from 'actions/notifications';
|
|
|
|
|
|
|
|
interface Props {
|
|
|
|
wallet: IFullWallet;
|
|
|
|
message: string;
|
|
|
|
showNotification: TShowNotification;
|
|
|
|
onSignMessage(msg: ISignedMessage): any;
|
|
|
|
}
|
|
|
|
|
|
|
|
export default class SignMessageButton extends React.Component<Props, {}> {
|
|
|
|
public render() {
|
|
|
|
return (
|
2017-12-18 23:29:26 +00:00
|
|
|
<button className="SignMessage-sign btn btn-primary btn-lg" onClick={this.handleSignMessage}>
|
2018-03-22 03:50:25 +00:00
|
|
|
{translate('NAV_SIGNMSG')}
|
2017-11-29 23:14:57 +00:00
|
|
|
</button>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
private handleSignMessage = async () => {
|
|
|
|
const { wallet, message, showNotification, onSignMessage } = this.props;
|
|
|
|
|
|
|
|
try {
|
|
|
|
const signedMessage: ISignedMessage = {
|
2018-02-21 18:23:04 +00:00
|
|
|
address: wallet.getAddressString(),
|
2018-01-22 20:27:37 +00:00
|
|
|
msg: message,
|
|
|
|
sig: await wallet.signMessage(message),
|
2017-11-29 23:14:57 +00:00
|
|
|
version: '2'
|
|
|
|
};
|
|
|
|
|
|
|
|
onSignMessage(signedMessage);
|
|
|
|
showNotification(
|
|
|
|
'success',
|
2018-03-22 03:50:25 +00:00
|
|
|
translate('SIGN_MSG_SUCCESS', { $address: signedMessage.address })
|
2017-11-29 23:14:57 +00:00
|
|
|
);
|
|
|
|
} catch (err) {
|
2018-03-22 03:50:25 +00:00
|
|
|
showNotification('danger', translate('SIGN_MSG_FAIL', { $err: err.message }));
|
2017-11-29 23:14:57 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|