|
@ -1,7 +1,7 @@ |
|
|
// @flow
|
|
|
// @flow
|
|
|
|
|
|
|
|
|
import logger from 'logger' |
|
|
import logger from 'logger' |
|
|
import React, { PureComponent } from 'react' |
|
|
import React, { PureComponent, Fragment } from 'react' |
|
|
import isEqual from 'lodash/isEqual' |
|
|
import isEqual from 'lodash/isEqual' |
|
|
import isEmpty from 'lodash/isEmpty' |
|
|
import isEmpty from 'lodash/isEmpty' |
|
|
|
|
|
|
|
@ -14,6 +14,9 @@ import Box, { Card } from 'components/base/Box' |
|
|
import Button from 'components/base/Button' |
|
|
import Button from 'components/base/Button' |
|
|
import Text from 'components/base/Text' |
|
|
import Text from 'components/base/Text' |
|
|
|
|
|
|
|
|
|
|
|
import NanoS from 'icons/device/NanoS' |
|
|
|
|
|
import CheckFull from 'icons/CheckFull' |
|
|
|
|
|
|
|
|
let CACHED_LATEST_FIRMWARE = null |
|
|
let CACHED_LATEST_FIRMWARE = null |
|
|
|
|
|
|
|
|
type FirmwareInfos = { |
|
|
type FirmwareInfos = { |
|
@ -89,31 +92,49 @@ class FirmwareUpdate extends PureComponent<Props, State> { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
render() { |
|
|
render() { |
|
|
const { t, ...props } = this.props |
|
|
const { t, infos } = this.props |
|
|
const { latestFirmware } = this.state |
|
|
const { latestFirmware } = this.state |
|
|
|
|
|
|
|
|
if (!latestFirmware) { |
|
|
|
|
|
return null |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
return ( |
|
|
return ( |
|
|
<Box flow={4} {...props}> |
|
|
<Card px={4} py={25}> |
|
|
<Card flow={2} {...props}> |
|
|
<Box horizontal align="center" flow={2}> |
|
|
<Box horizontal align="center" flow={2}> |
|
|
<Box color="dark"> |
|
|
<Text ff="Open Sans|Regular" fontSize={4}>{`${t('manager:latestFirmware')}: ${ |
|
|
<NanoS size={30} /> |
|
|
latestFirmware.name |
|
|
</Box> |
|
|
}`}</Text>
|
|
|
<Box> |
|
|
<Button outline onClick={this.installFirmware(latestFirmware)}> |
|
|
<Box horizontal align="center"> |
|
|
{t('manager:install')} |
|
|
<Text ff="Open Sans|SemiBold" fontSize={4} color="dark"> |
|
|
</Button> |
|
|
Ledger Nano S |
|
|
|
|
|
</Text> |
|
|
|
|
|
<Box color="wallet" style={{ marginLeft: 10 }}> |
|
|
|
|
|
<CheckFull size={13} color="wallet" /> |
|
|
|
|
|
</Box> |
|
|
|
|
|
</Box> |
|
|
|
|
|
<Text ff="Open Sans|SemiBold" fontSize={2}> |
|
|
|
|
|
Firmware {infos.version} |
|
|
|
|
|
</Text> |
|
|
</Box> |
|
|
</Box> |
|
|
<Box |
|
|
{latestFirmware && ( |
|
|
fontSize={3} |
|
|
<Fragment> |
|
|
style={{ whiteSpace: 'pre' }} |
|
|
<Text |
|
|
dangerouslySetInnerHTML={{ __html: latestFirmware.notes }} |
|
|
ff="Open Sans|Regular" |
|
|
/> |
|
|
fontSize={4} |
|
|
</Card> |
|
|
style={{ marginLeft: 'auto', marginRight: 15 }} |
|
|
</Box> |
|
|
> |
|
|
|
|
|
{t('manager:latestFirmware', { version: latestFirmware.name })} |
|
|
|
|
|
</Text> |
|
|
|
|
|
<Button primary onClick={this.installFirmware(latestFirmware)}> |
|
|
|
|
|
{t('manager:installFirmware')} |
|
|
|
|
|
</Button> |
|
|
|
|
|
</Fragment> |
|
|
|
|
|
)} |
|
|
|
|
|
</Box> |
|
|
|
|
|
{/* <Box |
|
|
|
|
|
fontSize={3} |
|
|
|
|
|
style={{ whiteSpace: 'pre' }} |
|
|
|
|
|
dangerouslySetInnerHTML={{ __html: latestFirmware.notes }} |
|
|
|
|
|
/> */} |
|
|
|
|
|
</Card> |
|
|
) |
|
|
) |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|