/* @flow */ 'use strict'; import React, { Component } from 'react'; import { bindActionCreators } from 'redux'; import { connect } from 'react-redux'; import { withRouter } from 'react-router-dom'; import { CSSTransition, Transition } from 'react-transition-group'; import { UI } from 'trezor-connect'; import { default as ModalActions } from '../../actions/ModalActions'; import { default as ReceiveActions } from '../../actions/ReceiveActions'; import Pin from './Pin'; import InvalidPin from './InvalidPin'; import Passphrase from './Passphrase'; import PassphraseType from './PassphraseType'; import ConfirmSignTx from './ConfirmSignTx'; import ConfirmAddress, { ConfirmUnverifiedAddress } from './ConfirmAddress'; import RememberDevice, { ForgetDevice, DisconnectDevice } from './RememberDevice'; import DuplicateDevice from './DuplicateDevice'; import * as RECEIVE from '../../actions/constants/receive'; import * as MODAL from '../../actions/constants/modal'; import * as CONNECT from '../../actions/constants/TrezorConnect'; import type { MapStateToProps, MapDispatchToProps } from 'react-redux'; import type { State, Dispatch } from '../../flowtype'; type OwnProps = { } type StateProps = { modal: $ElementType, accounts: $ElementType, devices: $PropertyType<$ElementType, 'devices'>, connect: $ElementType, sendForm: $ElementType, receive: $ElementType, localStorage: $ElementType, } type DispatchProps = { modalActions: typeof ModalActions, receiveActions: typeof ReceiveActions, } export type Props = StateProps & DispatchProps; const duration = 300; const Fade = ({ children, ...props }) => ( { children } ); class Modal extends Component { render() { const { opened, windowType } = this.props.modal; let component = null; switch (windowType) { case UI.REQUEST_PIN : component = (); break; case UI.INVALID_PIN : component = (); break; case UI.REQUEST_PASSPHRASE : component = (); break; case "ButtonRequest_SignTx" : component = () break; case "ButtonRequest_Address" : component = () break; case "ButtonRequest_PassphraseType" : component = () break; case RECEIVE.REQUEST_UNVERIFIED : component = () break; case CONNECT.REMEMBER_REQUEST : component = () break; case CONNECT.FORGET_REQUEST : component = () break; case CONNECT.DISCONNECT_REQUEST : component = () break; case CONNECT.TRY_TO_DUPLICATE : component = () break; } let ch = null; if (opened) { ch = (
{ component }
); } return ch; } } const mapStateToProps: MapStateToProps = (state: State, own: OwnProps): StateProps => { return { modal: state.modal, accounts: state.accounts, devices: state.connect.devices, connect: state.connect, sendForm: state.sendForm, receive: state.receive, localStorage: state.localStorage }; } const mapDispatchToProps: MapDispatchToProps = (dispatch: Dispatch): DispatchProps => { return { modalActions: bindActionCreators(ModalActions, dispatch), receiveActions: bindActionCreators(ReceiveActions, dispatch), }; } // export default connect(mapStateToProps, mapDispatchToProps)(Modal); export default withRouter( connect(mapStateToProps, mapDispatchToProps)(Modal) );