Browse Source

ui for firmware update

master
Valentin D. Pinkman 7 years ago
parent
commit
67c296e3c3
No known key found for this signature in database GPG Key ID: E7D110669FFB8D3E
  1. 27
      src/components/ManagerPage/AppSearchBar.js
  2. 65
      src/components/ManagerPage/FirmwareUpdate.js
  3. 2
      src/components/ManagerPage/ManagerApp.js
  4. 2
      src/components/ManagerPage/Workflow.js
  5. 56
      src/components/ManagerPage/index.js
  6. 1
      src/helpers/constants.js
  7. 15
      src/icons/CheckFull.js
  8. 5
      static/i18n/en/manager.yml
  9. BIN
      static/images/logos/connectDevice.png

27
src/components/ManagerPage/AppSearchBar.js

@ -1,6 +1,10 @@
// @flow // @flow
import React, { PureComponent } from 'react' import React, { PureComponent } from 'react'
import styled from 'styled-components' import styled from 'styled-components'
import { color, fontSize, space } from 'styled-system'
import fontFamily from 'styles/styled/fontFamily'
import { ff } from 'styles/helpers'
import Box from 'components/base/Box' import Box from 'components/base/Box'
import Search from 'components/base/Search' import Search from 'components/base/Search'
@ -40,16 +44,26 @@ const SearchBarWrapper = styled(Box).attrs({
padding: 0 13px; padding: 0 13px;
` `
const Input = styled.input` const Input = styled.input.attrs({
width: 100%; ff: 'Open Sans|SemiBold',
color: 'dark',
mx: 3,
fontSize: 4,
})`
${space};
${fontFamily};
${fontSize};
${color};
border: 0; border: 0;
margin: 0 13px;
flex: 1; flex: 1;
outline: none; outline: none;
background: transparent; background: transparent;
color: black;
font-family: 'Open Sans'; &::placeholder {
font-weight: 600; color: ${p => p.theme.colors.fog};
${() => ff('Open Sans|Regular')};
}
` `
class AppSearchBar extends PureComponent<Props, State> { class AppSearchBar extends PureComponent<Props, State> {
@ -86,6 +100,7 @@ class AppSearchBar extends PureComponent<Props, State> {
onChange={this.handleChange} onChange={this.handleChange}
onFocus={this.handleFocus(true)} onFocus={this.handleFocus(true)}
onBlur={this.handleFocus(false)} onBlur={this.handleFocus(false)}
placeholder={'Search app'}
/> />
{!!query && <CrossIcon size={16} cursor="pointer" onClick={this.reset} />} {!!query && <CrossIcon size={16} cursor="pointer" onClick={this.reset} />}
</SearchBarWrapper> </SearchBarWrapper>

65
src/components/ManagerPage/FirmwareUpdate.js

@ -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>
) )
} }
} }

2
src/components/ManagerPage/ManagerApp.js

@ -65,7 +65,7 @@ function ManagerApp(props: Props) {
</Text> </Text>
</Box> </Box>
<Button outline onClick={onInstall}> <Button outline onClick={onInstall}>
{t('manager:install')} {t('manager:installApps')}
</Button> </Button>
<Button outline onClick={onUninstall} outlineColor="grey"> <Button outline onClick={onUninstall} outlineColor="grey">
<Trash size={16} fill="grey" /> <Trash size={16} fill="grey" />

2
src/components/ManagerPage/Workflow.js

@ -148,7 +148,7 @@ class Workflow extends PureComponent<Props, State> {
<img <img
src={i('logos/connectDevice.png')} src={i('logos/connectDevice.png')}
alt="connect your device" alt="connect your device"
style={{ marginBottom: 30, maxWidth: 360, width: '100%' }} style={{ marginBottom: 30, maxWidth: 362, width: '100%' }}
/> />
<Text <Text
ff="Museo Sans|Regular" ff="Museo Sans|Regular"

56
src/components/ManagerPage/index.js

@ -34,8 +34,36 @@ type State = {
} }
class ManagerPage extends PureComponent<Props, State> { class ManagerPage extends PureComponent<Props, State> {
render(): Node { renderDashboard = (device: Device, deviceInfo: DeviceInfo) => {
const { t } = this.props const { t } = this.props
return (
<Box flow={4}>
<Box>
<Text ff="Museo Sans|Regular" fontSize={7} color="black">
{t('manager:title')}
</Text>
<Text ff="Museo Sans|Light" fontSize={5}>
{t('manager:subtitle')}
</Text>
</Box>
<Box mt={7}>
<FirmwareUpdate
infos={{
targetId: deviceInfo.targetId,
version: deviceInfo.version,
}}
device={device}
t={t}
/>
</Box>
<Box>
<AppsList device={device} targetId={deviceInfo.targetId} />
</Box>
</Box>
)
}
render(): Node {
return ( return (
<Workflow <Workflow
renderError={(dashboardError: ?Error, genuineError: ?Error) => { renderError={(dashboardError: ?Error, genuineError: ?Error) => {
@ -49,31 +77,7 @@ class ManagerPage extends PureComponent<Props, State> {
renderMcuUpdate={(deviceInfo: DeviceInfo) => ( renderMcuUpdate={(deviceInfo: DeviceInfo) => (
<p>FLASH MCU (TEMPLATE + ACTION WIP) {deviceInfo.mcu}</p> <p>FLASH MCU (TEMPLATE + ACTION WIP) {deviceInfo.mcu}</p>
)} )}
renderDashboard={(device: Device, deviceInfo: DeviceInfo) => ( renderDashboard={this.renderDashboard}
<Box flow={4}>
<Box>
<Text ff="Museo Sans|Regular" fontSize={7} color="black">
{t('manager:title')}
</Text>
<Text ff="Museo Sans|Light" fontSize={5}>
{t('manager:subtitle')}
</Text>
</Box>
<Box mt={7}>
<FirmwareUpdate
infos={{
targetId: deviceInfo.targetId,
version: deviceInfo.version,
}}
device={device}
t={t}
/>
</Box>
<Box>
<AppsList device={device} targetId={deviceInfo.targetId} />
</Box>
</Box>
)}
/> />
) )
} }

1
src/helpers/constants.js

@ -1,6 +1,7 @@
// Socket endpoint // Socket endpoint
export const BASE_SOCKET_URL = 'ws://api.ledgerwallet.com' export const BASE_SOCKET_URL = 'ws://api.ledgerwallet.com'
export const BASE_SOCKET_URL_TEMP = 'ws://manager.ledger.fr:3500'
// If you want to test locally with https://github.com/LedgerHQ/ledger-update-python-api // If you want to test locally with https://github.com/LedgerHQ/ledger-update-python-api
// export const BASE_SOCKET_URL = 'ws://localhost:3001/update' // export const BASE_SOCKET_URL = 'ws://localhost:3001/update'

15
src/icons/CheckFull.js

@ -0,0 +1,15 @@
// @flow
import React from 'react'
const path = (
<path
fill="currentColor"
d="M6.5 13a6.5 6.5 0 1 1 0-13 6.5 6.5 0 0 1 0 13zm2.146-8.702L5.484 7.46l-1.05-1.05a.402.402 0 0 0-.57 0l-.359.36a.402.402 0 0 0 0 .568L5.2 9.032a.402.402 0 0 0 .57 0l3.806-3.806a.402.402 0 0 0 0-.57l-.36-.358a.402.402 0 0 0-.569 0z"
/>
)
export default ({ size, ...p }: { size: number }) => (
<svg viewBox="0 0 13 13" height={size} width={size} {...p}>
{path}
</svg>
)

5
static/i18n/en/manager.yml

@ -1,14 +1,15 @@
tabs: tabs:
apps: Apps apps: Apps
device: My device device: My device
install: Install installApps: Install
installFirmware: Update firmware
allApps: Apps allApps: Apps
apps: apps:
help: To update an app, you have to uninstall the app and re install it. help: To update an app, you have to uninstall the app and re install it.
title: Manager title: Manager
subtitle: Get all your apps here subtitle: Get all your apps here
firmwareUpdate: Firmware update firmwareUpdate: Firmware update
latestFirmware: Firmware latestFirmware: A new firmware {{version}} is available
plugYourDevice: plugYourDevice:
title: Plug your device title: Plug your device
desc: Please connect your Ledger device and follow the steps below to access the manager desc: Please connect your Ledger device and follow the steps below to access the manager

BIN
static/images/logos/connectDevice.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 14 KiB

After

Width:  |  Height:  |  Size: 8.8 KiB

Loading…
Cancel
Save