Browse Source

Add HookDeviceChange + FreezeDeviceChangeEvents

master
Gaëtan Renaudeau 7 years ago
parent
commit
da9c37e2e5
  1. 2
      src/components/ManagerPage/AppsList.js
  2. 69
      src/components/ManagerPage/HookDeviceChange.js
  3. 23
      src/components/ManagerPage/index.js
  4. 2
      src/components/modals/UpdateFirmware/index.js

2
src/components/ManagerPage/AppsList.js

@ -34,6 +34,7 @@ import Update from 'icons/Update'
import Trash from 'icons/Trash' import Trash from 'icons/Trash'
import CheckCircle from 'icons/CheckCircle' import CheckCircle from 'icons/CheckCircle'
import { FreezeDeviceChangeEvents } from './HookDeviceChange'
import ManagerApp, { Container as FakeManagerAppContainer } from './ManagerApp' import ManagerApp, { Container as FakeManagerAppContainer } from './ManagerApp'
import AppSearchBar from './AppSearchBar' import AppSearchBar from './AppSearchBar'
@ -170,6 +171,7 @@ class AppsList extends PureComponent<Props, State> {
isOpened={status !== 'idle' && status !== 'loading'} isOpened={status !== 'idle' && status !== 'loading'}
render={() => ( render={() => (
<ModalBody align="center" justify="center" style={{ height: 300 }}> <ModalBody align="center" justify="center" style={{ height: 300 }}>
<FreezeDeviceChangeEvents />
{status === 'busy' || status === 'idle' ? ( {status === 'busy' || status === 'idle' ? (
<Fragment> <Fragment>
<ModalTitle> <ModalTitle>

69
src/components/ManagerPage/HookDeviceChange.js

@ -0,0 +1,69 @@
// @flow
import { PureComponent } from 'react'
import { createStructuredSelector } from 'reselect'
import { connect } from 'react-redux'
import { getCurrentDevice } from 'reducers/devices'
import type { Device } from 'types/common'
const hookDeviceChangeInstances = []
let frozen = 0
export class FreezeDeviceChangeEvents extends PureComponent<{}> {
componentDidMount() {
frozen++
}
componentWillUnmount() {
frozen--
if (!frozen) {
hookDeviceChangeInstances.forEach(i => i.onUnfreeze())
}
}
render() {
return null
}
}
/* eslint-disable react/no-multi-comp */
class HookDeviceChange extends PureComponent<{
device: ?Device,
onDeviceDisconnected: () => void,
onDeviceChanges: Device => void,
}> {
componentDidMount() {
const { device, onDeviceDisconnected } = this.props
if (!device && !frozen) {
onDeviceDisconnected()
}
hookDeviceChangeInstances.push(this)
}
componentDidUpdate(prevProps) {
const { device, onDeviceDisconnected, onDeviceChanges } = this.props
if (!device) {
if (frozen) {
this.onUnfreeze = onDeviceDisconnected
} else {
onDeviceDisconnected()
}
} else if (device !== prevProps.device) {
if (frozen) {
this.onUnfreeze = () => onDeviceChanges(device)
} else {
onDeviceChanges(device)
}
}
}
componentWillUnmount() {
const i = hookDeviceChangeInstances.indexOf(this)
if (i !== -1) hookDeviceChangeInstances.splice(i, 1)
}
onUnfreeze = () => {}
render() {
return null
}
}
export default connect(
createStructuredSelector({
device: getCurrentDevice,
}),
)(HookDeviceChange)

23
src/components/ManagerPage/index.js

@ -1,6 +1,6 @@
// @flow // @flow
import React, { PureComponent } from 'react' import React, { PureComponent, Fragment } from 'react'
import invariant from 'invariant' import invariant from 'invariant'
import { openURL } from 'helpers/linking' import { openURL } from 'helpers/linking'
import { urls } from 'config/support' import { urls } from 'config/support'
@ -11,6 +11,7 @@ import type { DeviceInfo } from 'helpers/devices/getDeviceInfo'
import Dashboard from './Dashboard' import Dashboard from './Dashboard'
import ManagerGenuineCheck from './ManagerGenuineCheck' import ManagerGenuineCheck from './ManagerGenuineCheck'
import HookDeviceChange from './HookDeviceChange'
type Props = {} type Props = {}
@ -20,13 +21,15 @@ type State = {
deviceInfo: ?DeviceInfo, deviceInfo: ?DeviceInfo,
} }
class ManagerPage extends PureComponent<Props, State> { const INITIAL_STATE = {
state = {
isGenuine: null, isGenuine: null,
device: null, device: null,
deviceInfo: null, deviceInfo: null,
} }
class ManagerPage extends PureComponent<Props, State> {
state = INITIAL_STATE
// prettier-ignore // prettier-ignore
handleSuccessGenuine = ({ device, deviceInfo }: { device: Device, deviceInfo: DeviceInfo }) => { // eslint-disable-line react/no-unused-prop-types handleSuccessGenuine = ({ device, deviceInfo }: { device: Device, deviceInfo: DeviceInfo }) => { // eslint-disable-line react/no-unused-prop-types
this.setState({ isGenuine: true, device, deviceInfo }) this.setState({ isGenuine: true, device, deviceInfo })
@ -36,6 +39,14 @@ class ManagerPage extends PureComponent<Props, State> {
openURL(urls.managerHelpRequest) openURL(urls.managerHelpRequest)
} }
onDeviceChanges = () => {
this.setState(INITIAL_STATE)
}
onDeviceDisconnected = () => {
this.setState(INITIAL_STATE)
}
render() { render() {
const { isGenuine, device, deviceInfo } = this.state const { isGenuine, device, deviceInfo } = this.state
@ -47,11 +58,17 @@ class ManagerPage extends PureComponent<Props, State> {
invariant(deviceInfo, 'Inexistant device infos for genuine device') invariant(deviceInfo, 'Inexistant device infos for genuine device')
return ( return (
<Fragment>
<HookDeviceChange
onDeviceChanges={this.onDeviceChanges}
onDeviceDisconnected={this.onDeviceDisconnected}
/>
<Dashboard <Dashboard
device={device} device={device}
deviceInfo={deviceInfo} deviceInfo={deviceInfo}
handleHelpRequest={this.handleHelpRequest} handleHelpRequest={this.handleHelpRequest}
/> />
</Fragment>
) )
} }
} }

2
src/components/modals/UpdateFirmware/index.js

@ -12,6 +12,7 @@ import type { StepProps as DefaultStepProps, Step } from 'components/base/Steppe
import type { ModalStatus } from 'components/ManagerPage/FirmwareUpdate' import type { ModalStatus } from 'components/ManagerPage/FirmwareUpdate'
import type { LedgerScriptParams } from 'helpers/common' import type { LedgerScriptParams } from 'helpers/common'
import { FreezeDeviceChangeEvents } from '../../ManagerPage/HookDeviceChange'
import StepFullFirmwareInstall from './steps/01-step-install-full-firmware' import StepFullFirmwareInstall from './steps/01-step-install-full-firmware'
import StepFlashMcu from './steps/02-step-flash-mcu' import StepFlashMcu from './steps/02-step-flash-mcu'
import StepConfirmation, { StepConfirmFooter } from './steps/03-step-confirmation' import StepConfirmation, { StepConfirmFooter } from './steps/03-step-confirmation'
@ -136,6 +137,7 @@ class UpdateModal extends PureComponent<Props, State> {
steps={this.STEPS} steps={this.STEPS}
{...additionalProps} {...additionalProps}
> >
<FreezeDeviceChangeEvents />
<SyncSkipUnderPriority priority={100} /> <SyncSkipUnderPriority priority={100} />
</Stepper> </Stepper>
)} )}

Loading…
Cancel
Save