|
@ -5,7 +5,7 @@ import { connect } from 'react-redux' |
|
|
import { ipcRenderer } from 'electron' |
|
|
import { ipcRenderer } from 'electron' |
|
|
|
|
|
|
|
|
import type { MapStateToProps, MapDispatchToProps } from 'react-redux' |
|
|
import type { MapStateToProps, MapDispatchToProps } from 'react-redux' |
|
|
import type { Device, Devices } from 'types/common' |
|
|
import type { Devices } from 'types/common' |
|
|
import type { SetCurrentDevice } from 'actions/devices' |
|
|
import type { SetCurrentDevice } from 'actions/devices' |
|
|
|
|
|
|
|
|
import { getDevices, getCurrentDevice } from 'reducers/devices' |
|
|
import { getDevices, getCurrentDevice } from 'reducers/devices' |
|
@ -14,7 +14,6 @@ import { lock } from 'reducers/application' |
|
|
import { hasPassword } from 'reducers/settings' |
|
|
import { hasPassword } from 'reducers/settings' |
|
|
|
|
|
|
|
|
import Box from 'components/base/Box' |
|
|
import Box from 'components/base/Box' |
|
|
import Overlay from 'components/base/Overlay' |
|
|
|
|
|
|
|
|
|
|
|
const mapStateToProps: MapStateToProps<*, *, *> = state => ({ |
|
|
const mapStateToProps: MapStateToProps<*, *, *> = state => ({ |
|
|
devices: getDevices(state), |
|
|
devices: getDevices(state), |
|
@ -32,21 +31,16 @@ type Props = { |
|
|
lock: Function, |
|
|
lock: Function, |
|
|
hasPassword: boolean, |
|
|
hasPassword: boolean, |
|
|
devices: Devices, |
|
|
devices: Devices, |
|
|
currentDevice: Device, |
|
|
|
|
|
} |
|
|
} |
|
|
type State = { |
|
|
type State = { |
|
|
changeDevice: boolean, |
|
|
|
|
|
sync: { |
|
|
sync: { |
|
|
progress: null | boolean, |
|
|
progress: null | boolean, |
|
|
fail: boolean, |
|
|
fail: boolean, |
|
|
}, |
|
|
}, |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
const hasDevices = props => props.currentDevice === null && props.devices.length > 0 |
|
|
|
|
|
|
|
|
|
|
|
class TopBar extends PureComponent<Props, State> { |
|
|
class TopBar extends PureComponent<Props, State> { |
|
|
state = { |
|
|
state = { |
|
|
changeDevice: hasDevices(this.props), |
|
|
|
|
|
sync: { |
|
|
sync: { |
|
|
progress: null, |
|
|
progress: null, |
|
|
fail: false, |
|
|
fail: false, |
|
@ -57,14 +51,6 @@ class TopBar extends PureComponent<Props, State> { |
|
|
ipcRenderer.on('msg', this.handleAccountSync) |
|
|
ipcRenderer.on('msg', this.handleAccountSync) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
componentWillReceiveProps(nextProps) { |
|
|
|
|
|
if (hasDevices(nextProps) && this.props.currentDevice !== null) { |
|
|
|
|
|
this.setState({ |
|
|
|
|
|
changeDevice: true, |
|
|
|
|
|
}) |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
componentWillUnmount() { |
|
|
componentWillUnmount() { |
|
|
ipcRenderer.removeListener('msg', this.handleAccountSync) |
|
|
ipcRenderer.removeListener('msg', this.handleAccountSync) |
|
|
} |
|
|
} |
|
@ -98,48 +84,20 @@ class TopBar extends PureComponent<Props, State> { |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
handleChangeDevice = () => { |
|
|
|
|
|
const { devices } = this.props |
|
|
|
|
|
|
|
|
|
|
|
if (devices.length > 0) { |
|
|
|
|
|
this.setState({ |
|
|
|
|
|
changeDevice: true, |
|
|
|
|
|
}) |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
handleSelectDevice = device => () => { |
|
|
handleSelectDevice = device => () => { |
|
|
const { setCurrentDevice } = this.props |
|
|
const { setCurrentDevice } = this.props |
|
|
|
|
|
|
|
|
setCurrentDevice(device) |
|
|
setCurrentDevice(device) |
|
|
|
|
|
|
|
|
this.setState({ |
|
|
|
|
|
changeDevice: false, |
|
|
|
|
|
}) |
|
|
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
handleLock = () => this.props.lock() |
|
|
handleLock = () => this.props.lock() |
|
|
|
|
|
|
|
|
render() { |
|
|
render() { |
|
|
const { devices, hasPassword } = this.props |
|
|
const { devices, hasPassword } = this.props |
|
|
const { changeDevice, sync } = this.state |
|
|
const { sync } = this.state |
|
|
|
|
|
|
|
|
return ( |
|
|
return ( |
|
|
<Fragment> |
|
|
<Fragment> |
|
|
{changeDevice && ( |
|
|
|
|
|
<Overlay p={20}> |
|
|
|
|
|
{devices.map(device => ( |
|
|
|
|
|
<Box |
|
|
|
|
|
key={device.path} |
|
|
|
|
|
color="white" |
|
|
|
|
|
bg="night" |
|
|
|
|
|
onClick={this.handleSelectDevice(device)} |
|
|
|
|
|
> |
|
|
|
|
|
{device.path} |
|
|
|
|
|
</Box> |
|
|
|
|
|
))} |
|
|
|
|
|
</Overlay> |
|
|
|
|
|
)} |
|
|
|
|
|
<Box bg="white" noShrink style={{ height: 60, zIndex: 20 }} align="center" horizontal> |
|
|
<Box bg="white" noShrink style={{ height: 60, zIndex: 20 }} align="center" horizontal> |
|
|
<Box grow> |
|
|
<Box grow> |
|
|
{sync.progress === true |
|
|
{sync.progress === true |
|
@ -148,7 +106,7 @@ class TopBar extends PureComponent<Props, State> { |
|
|
</Box> |
|
|
</Box> |
|
|
<Box justify="flex-end" horizontal> |
|
|
<Box justify="flex-end" horizontal> |
|
|
{hasPassword && <LockApplication onLock={this.handleLock} />} |
|
|
{hasPassword && <LockApplication onLock={this.handleLock} />} |
|
|
<CountDevices count={devices.length} onChangeDevice={this.handleChangeDevice} /> |
|
|
<CountDevices count={devices.length} /> |
|
|
</Box> |
|
|
</Box> |
|
|
</Box> |
|
|
</Box> |
|
|
</Fragment> |
|
|
</Fragment> |
|
@ -156,15 +114,8 @@ class TopBar extends PureComponent<Props, State> { |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
const CountDevices = ({ count, onChangeDevice } = { count: Number, onChangeDevice: Function }) => ( |
|
|
const CountDevices = ({ count } = { count: Number }) => ( |
|
|
<Box |
|
|
<Box color="night" mr={20} horizontal flow={10}> |
|
|
color="night" |
|
|
|
|
|
mr={20} |
|
|
|
|
|
horizontal |
|
|
|
|
|
flow={10} |
|
|
|
|
|
onClick={onChangeDevice} |
|
|
|
|
|
style={{ cursor: 'pointer' }} |
|
|
|
|
|
> |
|
|
|
|
|
<Box> |
|
|
<Box> |
|
|
<DeviceIcon height={20} width={20} /> |
|
|
<DeviceIcon height={20} width={20} /> |
|
|
</Box> |
|
|
</Box> |
|
|