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.

79 lines
2.1 KiB

7 years ago
// @flow
import React, { PureComponent } from 'react'
7 years ago
import { ThemeProvider } from 'styled-components'
import { ConnectedRouter } from 'react-router-redux'
import { Provider, connect } from 'react-redux'
7 years ago
import { Route } from 'react-router'
import { ipcRenderer } from 'electron'
7 years ago
import { I18nextProvider } from 'react-i18next'
import { devicesUpdate, deviceAdd, deviceRemove } from 'actions/devices'
7 years ago
import theme from 'styles/theme'
7 years ago
import Box from 'components/base/Box'
import SideBar from 'components/SideBar'
import TopBar from 'components/TopBar'
7 years ago
import Home from 'components/Home'
7 years ago
7 years ago
import i18n from '../renderer/i18n'
type Props = {
deviceAdd: (device: Object) => void,
deviceRemove: (device: Object) => void,
devicesUpdate: (devices: Object) => void,
history: Object,
store: Object,
}
class App extends PureComponent<Props> {
componentWillMount() {
const { devicesUpdate, deviceAdd, deviceRemove } = this.props
ipcRenderer.on('updateDevices', (e, devices) => devicesUpdate(devices))
ipcRenderer.on('addDevice', (e, device) => deviceAdd(device))
ipcRenderer.on('removeDevice', (e, device) => deviceRemove(device))
// First renderer, we get all devices
ipcRenderer.send('getDevices')
// Start detection when we plug/unplug devices
ipcRenderer.send('listenDevices')
}
componentWillUnmount() {
ipcRenderer.removeAllListeners('updateDevices')
ipcRenderer.removeAllListeners('addDevice')
ipcRenderer.removeAllListeners('removeDevice')
}
render() {
const { history, store } = this.props
return (
<Provider store={store}>
7 years ago
<I18nextProvider i18n={i18n}>
<ThemeProvider theme={theme}>
<ConnectedRouter history={history}>
<Box grow horizontal>
<SideBar />
<Box grow bg="cream">
<TopBar />
<Route path="/" component={Home} />
</Box>
</Box>
7 years ago
</ConnectedRouter>
</ThemeProvider>
</I18nextProvider>
</Provider>
)
}
}
export default connect(null, {
deviceAdd,
deviceRemove,
devicesUpdate,
})(App)