Loëck Vézien
7 years ago
8 changed files with 110 additions and 42 deletions
@ -0,0 +1,19 @@ |
|||
// eslint-disable import/prefer-default-export
|
|||
|
|||
export const devicesUpdate = payload => dispatch => |
|||
dispatch({ |
|||
type: 'DEVICES_UPDATE', |
|||
payload, |
|||
}) |
|||
|
|||
export const deviceAdd = payload => dispatch => |
|||
dispatch({ |
|||
type: 'DEVICE_ADD', |
|||
payload, |
|||
}) |
|||
|
|||
export const deviceRemove = payload => dispatch => |
|||
dispatch({ |
|||
type: 'DEVICE_REMOVE', |
|||
payload, |
|||
}) |
@ -1,34 +1,48 @@ |
|||
import React, { Component } from 'react' |
|||
// @flow
|
|||
|
|||
import React, { PureComponent } from 'react' |
|||
import { connect } from 'react-redux' |
|||
import { ipcRenderer } from 'electron' |
|||
|
|||
class App extends Component { |
|||
state = { |
|||
devices: [], |
|||
import { devicesUpdate, deviceAdd, deviceRemove } from 'actions/devices' |
|||
|
|||
type Props = { |
|||
devicesUpdate: (devices: Object) => void, |
|||
deviceAdd: (device: Object) => void, |
|||
deviceRemove: (device: Object) => void, |
|||
devices: Object, |
|||
} |
|||
|
|||
componentDidMount() { |
|||
class Home 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') |
|||
} |
|||
|
|||
ipcRenderer.on('addDevice', (e, device) => |
|||
this.setState(prev => ({ |
|||
devices: [...prev.devices, device].filter( |
|||
(v, i, s) => s.findIndex(t => t.path === v.path) === i, |
|||
), |
|||
})), |
|||
) |
|||
|
|||
ipcRenderer.on('removeDevice', (e, device) => |
|||
this.setState(prev => ({ |
|||
devices: prev.devices.filter(d => d.path !== device.path), |
|||
})), |
|||
) |
|||
componentWillUnmount() { |
|||
ipcRenderer.removeAllListeners('updateDevices') |
|||
ipcRenderer.removeAllListeners('addDevice') |
|||
ipcRenderer.removeAllListeners('removeDevice') |
|||
} |
|||
|
|||
render() { |
|||
const { devices } = this.state |
|||
const { devices } = this.props |
|||
|
|||
return <div>{devices.map(device => device.path)}</div> |
|||
} |
|||
} |
|||
|
|||
export default App |
|||
export default connect(({ devices }) => ({ devices }), { |
|||
deviceAdd, |
|||
deviceRemove, |
|||
devicesUpdate, |
|||
})(Home) |
|||
|
@ -0,0 +1,14 @@ |
|||
// @flow
|
|||
|
|||
import { handleActions } from 'redux-actions' |
|||
|
|||
const state = [] |
|||
|
|||
const handlers = { |
|||
DEVICES_UPDATE: (state, { payload: devices }) => devices, |
|||
DEVICE_ADD: (state, { payload: device }) => |
|||
[...state, device].filter((v, i, s) => s.findIndex(t => t.path === v.path) === i), |
|||
DEVICE_REMOVE: (state, { payload: device }) => state.filter(d => d.path !== device.path), |
|||
} |
|||
|
|||
export default handleActions(handlers, state) |
Loading…
Reference in new issue