import React from 'react'; import { connect } from 'react-redux'; import { translateRaw, translate } from 'translations'; import { AppState } from 'features/reducers'; import { getLanguageSelection } from 'features/config'; import { transactionBroadcastActions, transactionSelectors } from 'features/transaction'; import { walletSelectors } from 'features/wallet'; import Modal, { IButton } from 'components/ui/Modal'; import Spinner from 'components/ui/Spinner'; import './ConfirmationModalTemplate.scss'; interface DispatchProps { broadcastLocalTransactionRequested: transactionBroadcastActions.TBroadcastLocalTransactionRequested; broadcastWeb3TransactionRequested: transactionBroadcastActions.TBroadcastWeb3TransactionRequested; } interface StateProps { lang: string; walletTypes: walletSelectors.IWalletType; transactionBroadcasting: boolean; } export interface ConfirmButtonCBProps { type: IButton['type']; timeLocked: boolean; timeLeft: number; timePrefix: string; defaultText: string; onConfirm: ConfirmationModalTemplateClass['confirm']; } export interface OwnProps { isOpen?: boolean; Body: React.ReactElement; withConfirmButton?(props: ConfirmButtonCBProps): IButton; onClose(): void; } interface State { timeToRead: number; } type Props = DispatchProps & StateProps & OwnProps; class ConfirmationModalTemplateClass extends React.Component { private readTimer = 0; public constructor(props: Props) { super(props); this.state = { timeToRead: 5 }; } // Count down 5 seconds before allowing them to confirm public componentDidMount() { this.readTimer = window.setInterval(() => { if (this.state.timeToRead > 0) { this.setState({ timeToRead: this.state.timeToRead - 1 }); } else { window.clearInterval(this.readTimer); } }, 1000); } public render() { const { onClose, transactionBroadcasting, isOpen } = this.props; const { timeToRead } = this.state; const buttonPrefix = timeToRead > 0 ? `(${timeToRead}) ` : ''; const defaultConfirmButton = { text: buttonPrefix + translateRaw('ACTION_11'), type: 'primary' as IButton['type'], disabled: timeToRead > 0, onClick: this.confirm }; const confirmButton: IButton = this.props.withConfirmButton ? this.props.withConfirmButton({ onConfirm: defaultConfirmButton.onClick, timeLeft: timeToRead, timePrefix: buttonPrefix, timeLocked: defaultConfirmButton.disabled, defaultText: translateRaw('ACTION_11'), type: defaultConfirmButton.type }) : defaultConfirmButton; const buttons: IButton[] = [ confirmButton, { text: translate('ACTION_2'), type: 'default', onClick: onClose } ]; return ( {transactionBroadcasting ? ( ) : ( {this.props.Body} )} ); } public componentWillUnmount() { window.clearInterval(this.readTimer); } private confirm = () => { if (this.state.timeToRead < 1) { this.props.walletTypes.isWeb3Wallet ? this.props.broadcastWeb3TransactionRequested() : this.props.broadcastLocalTransactionRequested(); } }; } export const ConfirmationModalTemplate = connect( (state: AppState) => ({ transactionBroadcasting: transactionSelectors.currentTransactionBroadcasting(state), lang: getLanguageSelection(state), walletTypes: walletSelectors.getWalletType(state) }), { broadcastLocalTransactionRequested: transactionBroadcastActions.broadcastLocalTransactionRequested, broadcastWeb3TransactionRequested: transactionBroadcastActions.broadcastWeb3TransactionRequested } )(ConfirmationModalTemplateClass);