HenryNguyen5 c84740c4d4 Generic Confirmation Modal (#940)
* Make generic modal

* Allow generic modals to be injected into send button component
2018-01-29 15:38:28 -06:00

77 lines
2.1 KiB
TypeScript

import React, { Component } from 'react';
import { ConfirmationModal } from 'components/ConfirmationModal';
import { getOffline } from 'selectors/config';
import { AppState } from 'reducers';
import { connect } from 'react-redux';
import { CallbackProps } from '../SendButtonFactory';
import { getCurrentTransactionStatus } from 'selectors/transaction';
import { showNotification, TShowNotification } from 'actions/notifications';
import { ITransactionStatus } from 'reducers/transaction/broadcast';
import { reset, TReset } from 'actions/transaction';
interface StateProps {
offline: boolean;
currentTransaction: false | ITransactionStatus | null;
}
interface State {
showModal: boolean;
}
interface DispatchProps {
showNotification: TShowNotification;
reset: TReset;
}
interface OwnProps {
Modal: typeof ConfirmationModal;
withProps(props: CallbackProps): React.ReactElement<any> | null;
}
const INITIAL_STATE: State = {
showModal: false
};
type Props = OwnProps & StateProps & DispatchProps;
class OnlineSendClass extends Component<Props, State> {
public state: State = INITIAL_STATE;
public render() {
const displayModal = this.state.showModal ? (
<this.props.Modal onClose={this.toggleModal} />
) : null;
return !this.props.offline ? (
<React.Fragment>
{this.props.withProps({ onClick: this.openModal })}
{displayModal}
</React.Fragment>
) : null;
}
private openModal = () => {
const { currentTransaction } = this.props;
if (
currentTransaction &&
(currentTransaction.broadcastSuccessful || currentTransaction.isBroadcasting)
) {
return this.props.showNotification(
'warning',
'The current transaction is already broadcasting or has been successfully broadcasted'
);
}
this.toggleModal();
};
private toggleModal = () =>
this.setState((prevState: State) => ({ showModal: !prevState.showModal }));
}
export const OnlineSend = connect(
(state: AppState) => ({
offline: getOffline(state),
currentTransaction: getCurrentTransactionStatus(state)
}),
{ showNotification, reset }
)(OnlineSendClass);