You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

85 lines
2.4 KiB

import React from 'react'
import PropTypes from 'prop-types'
import Form from 'components/Form'
import ChannelForm from 'components/Contacts/ChannelForm'
7 years ago
import Network from 'components/Contacts/Network'
import AddChannel from 'components/Contacts/AddChannel'
import ReceiveModal from 'components/Wallet/ReceiveModal'
import ActivityModal from 'components/Activity/ActivityModal'
import Activity from 'containers/Activity'
import { Box } from 'rebass'
import styles from './App.scss'
class App extends React.Component {
static propTypes = {
form: PropTypes.object.isRequired,
formProps: PropTypes.object.isRequired,
closeForm: PropTypes.func.isRequired,
currentTheme: PropTypes.string.isRequired,
currentTicker: PropTypes.object,
contactsFormProps: PropTypes.object,
networkTabProps: PropTypes.object,
activityModalProps: PropTypes.object,
receiveModalProps: PropTypes.object,
channelFormProps: PropTypes.object,
fetchInfo: PropTypes.func.isRequired,
fetchDescribeNetwork: PropTypes.func.isRequired,
fetchSuggestedNodes: PropTypes.func.isRequired
}
componentDidMount() {
const { currentTicker, fetchInfo, fetchSuggestedNodes, fetchDescribeNetwork } = this.props
// If we don't yet have any ticker information then it must be our first time mounting this component.
if (!currentTicker) {
// fetch node info.
fetchInfo()
// fetch suggested nodes list from zap.jackmallers.com/suggested-peers.
fetchSuggestedNodes()
// fetch LN network from nodes POV.
fetchDescribeNetwork()
}
}
render() {
const {
currentTheme,
currentTicker,
form,
formProps,
closeForm,
contactsFormProps,
networkTabProps,
receiveModalProps,
activityModalProps,
channelFormProps
} = this.props
if (!currentTicker) {
return null
}
return (
<Box width={1} className={`${currentTheme}`}>
<ChannelForm {...channelFormProps} />
<ReceiveModal {...receiveModalProps} />
<ActivityModal {...activityModalProps} />
<Box className={styles.content}>
<Activity />
</Box>
{contactsFormProps.contactsform.isOpen ? (
<AddChannel {...contactsFormProps} />
) : (
<Network {...networkTabProps} />
)}
<Form formType={form.formType} formProps={formProps} closeForm={closeForm} />
</Box>
)
}
}
export default App