Browse Source

Merge pull request #311 from gre/flow

Fix flow for react-redux
master
Gaëtan Renaudeau 7 years ago
committed by GitHub
parent
commit
a5029ca5e8
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
  1. 1
      .eslintrc
  2. 3
      package.json
  3. 2
      scripts/postinstall.sh
  4. 32
      src/components/CounterValue/index.js
  5. 22
      src/components/DeviceMonit/index.js
  6. 47
      src/components/DeviceMonitNew/index.js
  7. 20
      src/components/base/FormattedVal/index.js
  8. 2
      src/components/modals/StepConnectDevice.js
  9. 2723
      yarn.lock

1
.eslintrc

@ -42,6 +42,7 @@
"no-return-assign": 0, "no-return-assign": 0,
"no-shadow": 0, "no-shadow": 0,
"no-underscore-dangle": 0, "no-underscore-dangle": 0,
"no-unused-vars": ["error", { "argsIgnorePattern": "^_", "vars": "all", "args": "after-used", "ignoreRestSiblings": true }],
"no-use-before-define": 0, "no-use-before-define": 0,
"no-restricted-syntax": 0, "no-restricted-syntax": 0,
"no-prototype-builtins": 0, "no-prototype-builtins": 0,

3
package.json

@ -39,7 +39,7 @@
"@ledgerhq/hw-app-eth": "^4.7.3", "@ledgerhq/hw-app-eth": "^4.7.3",
"@ledgerhq/hw-transport": "^4.7.3", "@ledgerhq/hw-transport": "^4.7.3",
"@ledgerhq/hw-transport-node-hid": "^4.7.6", "@ledgerhq/hw-transport-node-hid": "^4.7.6",
"@ledgerhq/live-common": "^2.0.0-rc4", "@ledgerhq/live-common": "^2.0.0",
"axios": "^0.18.0", "axios": "^0.18.0",
"babel-runtime": "^6.26.0", "babel-runtime": "^6.26.0",
"bcryptjs": "^2.4.3", "bcryptjs": "^2.4.3",
@ -56,6 +56,7 @@
"history": "^4.7.2", "history": "^4.7.2",
"i18next": "^11.2.2", "i18next": "^11.2.2",
"i18next-node-fs-backend": "^1.0.0", "i18next-node-fs-backend": "^1.0.0",
"invariant": "^2.2.4",
"ledger-test-library": "KhalilBellakrid/ledger-test-library-nodejs#7d37482", "ledger-test-library": "KhalilBellakrid/ledger-test-library-nodejs#7d37482",
"lodash": "^4.17.5", "lodash": "^4.17.5",
"moment": "^2.22.1", "moment": "^2.22.1",

2
scripts/postinstall.sh

@ -1,5 +1,5 @@
#/bin/bash #/bin/bash
flow-typed install -s --overwrite flow-typed install -s --overwrite
rm flow-typed/npm/{react-i18next_v7.x.x.js,react-redux_v5.x.x.js,styled-components_v3.x.x.js} rm flow-typed/npm/{react-i18next_v7.x.x.js,styled-components_v3.x.x.js}
electron-builder install-app-deps electron-builder install-app-deps

32
src/components/CounterValue/index.js

@ -2,35 +2,44 @@
import React, { PureComponent } from 'react' import React, { PureComponent } from 'react'
import { connect } from 'react-redux' import { connect } from 'react-redux'
import type { CryptoCurrency } from '@ledgerhq/live-common/lib/types' import type { Currency } from '@ledgerhq/live-common/lib/types'
import { counterValueCurrencySelector } from 'reducers/settings' import { counterValueCurrencySelector } from 'reducers/settings'
import { calculateCounterValueSelector } from 'reducers/counterValues' import { calculateCounterValueSelector } from 'reducers/counterValues'
import FormattedVal from 'components/base/FormattedVal' import FormattedVal from 'components/base/FormattedVal'
type Props = { import type { State } from 'reducers'
type OwnProps = {
// wich market to query // wich market to query
// FIXME drop ticker in favor of currency
ticker: string, ticker: string,
currency?: Currency,
// when? if not given: take latest // when? if not given: take latest
date?: Date, date?: Date,
value: number,
}
type Props = OwnProps & {
// from reducers // from reducers
counterValueCurrency: CryptoCurrency, counterValueCurrency: Currency,
value: number, value: number,
} }
const mapStateToProps = (state, props) => { const mapStateToProps = (state: State, props: OwnProps) => {
const { ticker, value, date } = props const { ticker, value, date } = props
// TODO: in wallet-common, stop using currency. if (ticker) {
// always use ticker and remove that hack // FIXME actually ticker should be deprecated, not currency!!
console.warn('CounterValue: `currency` should be passed instead of `ticker`') // eslint-disable-line no-console
}
let { currency } = props let { currency } = props
if (!currency && ticker) { if (!currency && ticker) {
currency = generateFakeCurrency(ticker) currency = generateFakeCurrency(ticker)
} else if (currency) {
console.warn('`currency` is deprecated in CounterValue. use `ticker` instead.') // eslint-disable-line no-console
} }
const counterValueCurrency = counterValueCurrencySelector(state) const counterValueCurrency = counterValueCurrencySelector(state)
@ -46,11 +55,6 @@ const mapStateToProps = (state, props) => {
} }
class CounterValue extends PureComponent<Props> { class CounterValue extends PureComponent<Props> {
static defaultProps = {
value: 0,
date: undefined,
}
render() { render() {
const { value, counterValueCurrency, date, ...props } = this.props const { value, counterValueCurrency, date, ...props } = this.props
return ( return (
@ -79,7 +83,7 @@ function generateFakeCurrency(ticker) {
], ],
// unused // unused
coinType: 0, id: '',
color: '#000', color: '#000',
name: 'fake-coin', name: 'fake-coin',
scheme: 'bitcoin', scheme: 'bitcoin',

22
src/components/DeviceMonit/index.js

@ -9,23 +9,29 @@ import { sendEvent } from 'renderer/events'
import { getCurrentDevice } from 'reducers/devices' import { getCurrentDevice } from 'reducers/devices'
import type { Device } from 'types/common' import type { Device } from 'types/common'
const mapStateToProps = state => ({ import type { State as StoreState } from 'reducers'
currentDevice: getCurrentDevice(state),
})
type DeviceStatus = 'unconnected' | 'connected' | 'appOpened' type DeviceStatus = 'unconnected' | 'connected' | 'appOpened'
type Props = { type OwnProps = {
currentDevice: Device | null,
account?: Account, account?: Account,
onStatusChange?: DeviceStatus => void, onStatusChange?: DeviceStatus => void,
render?: Function, // FIXME prefer use of children function
render?: DeviceStatus => React$Element<*>,
}
type Props = OwnProps & {
currentDevice: ?Device,
} }
type State = { type State = {
status: DeviceStatus, status: DeviceStatus,
} }
const mapStateToProps = (state: StoreState, _props: OwnProps) => ({
currentDevice: getCurrentDevice(state),
})
class DeviceMonit extends PureComponent<Props, State> { class DeviceMonit extends PureComponent<Props, State> {
state = { state = {
status: this.props.currentDevice ? 'connected' : 'unconnected', status: this.props.currentDevice ? 'connected' : 'unconnected',
@ -70,7 +76,7 @@ class DeviceMonit extends PureComponent<Props, State> {
checkAppOpened = () => { checkAppOpened = () => {
const { currentDevice, account } = this.props const { currentDevice, account } = this.props
if (currentDevice === null || !account || account.currency === null) { if (!currentDevice || !account) {
return return
} }
@ -83,7 +89,7 @@ class DeviceMonit extends PureComponent<Props, State> {
_timeout: any = null _timeout: any = null
handleStatusChange = status => { handleStatusChange = (status: DeviceStatus) => {
const { onStatusChange } = this.props const { onStatusChange } = this.props
this.setState({ status }) this.setState({ status })
onStatusChange && onStatusChange(status) onStatusChange && onStatusChange(status)

47
src/components/DeviceMonitNew/index.js

@ -1,5 +1,5 @@
// @flow // @flow
import invariant from 'invariant'
import { PureComponent } from 'react' import { PureComponent } from 'react'
import { connect } from 'react-redux' import { connect } from 'react-redux'
import { ipcRenderer } from 'electron' import { ipcRenderer } from 'electron'
@ -9,29 +9,40 @@ import type { Device, Devices } from 'types/common'
import { sendEvent } from 'renderer/events' import { sendEvent } from 'renderer/events'
import { getDevices } from 'reducers/devices' import { getDevices } from 'reducers/devices'
import type { State as StoreState } from 'reducers/index'
const mapStateToProps = state => ({ type OwnProps = {
devices: getDevices(state), currency: ?CryptoCurrency,
}) deviceSelected: ?Device,
account: ?Account,
onStatusChange?: (DeviceStatus, AppStatus) => void,
// TODO prefer children function
render?: ({
appStatus: AppStatus,
currency: CryptoCurrency,
devices: Devices,
deviceSelected: ?Device,
deviceStatus: DeviceStatus,
}) => React$Element<*>,
}
type Props = OwnProps & {
devices: Devices,
}
type DeviceStatus = 'unconnected' | 'connected' type DeviceStatus = 'unconnected' | 'connected'
type AppStatus = 'success' | 'fail' | 'progress' type AppStatus = 'success' | 'fail' | 'progress'
type Props = {
currency: ?CryptoCurrency,
devices: Devices,
deviceSelected: Device | null,
account?: Account,
onStatusChange?: (DeviceStatus, AppStatus) => void,
render?: Function,
}
type State = { type State = {
deviceStatus: DeviceStatus, deviceStatus: DeviceStatus,
appStatus: AppStatus, appStatus: AppStatus,
} }
const mapStateToProps = (state: StoreState) => ({
devices: getDevices(state),
})
class DeviceMonit extends PureComponent<Props, State> { class DeviceMonit extends PureComponent<Props, State> {
state = { state = {
appStatus: 'progress', appStatus: 'progress',
@ -80,7 +91,7 @@ class DeviceMonit extends PureComponent<Props, State> {
checkAppOpened = () => { checkAppOpened = () => {
const { deviceSelected, account, currency } = this.props const { deviceSelected, account, currency } = this.props
if (deviceSelected === null) { if (!deviceSelected) {
return return
} }
@ -105,7 +116,7 @@ class DeviceMonit extends PureComponent<Props, State> {
}) })
} }
_timeout: any = null _timeout: *
handleStatusChange = (deviceStatus, appStatus) => { handleStatusChange = (deviceStatus, appStatus) => {
const { onStatusChange } = this.props const { onStatusChange } = this.props
@ -118,7 +129,7 @@ class DeviceMonit extends PureComponent<Props, State> {
const { deviceStatus } = this.state const { deviceStatus } = this.state
const { deviceSelected } = this.props const { deviceSelected } = this.props
if (deviceSelected === null) { if (!deviceSelected) {
return return
} }
@ -138,9 +149,11 @@ class DeviceMonit extends PureComponent<Props, State> {
const { appStatus, deviceStatus } = this.state const { appStatus, deviceStatus } = this.state
if (render) { if (render) {
const cur = account ? account.currency : currency
invariant(cur, 'currency is either provided or taken from account')
return render({ return render({
appStatus, appStatus,
currency: account ? account.currency : currency, currency: cur,
devices, devices,
deviceSelected: deviceStatus === 'connected' ? deviceSelected : null, deviceSelected: deviceStatus === 'connected' ? deviceSelected : null,
deviceStatus, deviceStatus,

20
src/components/base/FormattedVal/index.js

@ -8,6 +8,7 @@ import isUndefined from 'lodash/isUndefined'
import type { Settings } from 'types/common' import type { Settings } from 'types/common'
import type { Unit } from '@ledgerhq/live-common/lib/types' import type { Unit } from '@ledgerhq/live-common/lib/types'
import type { State } from 'reducers'
import { import {
formatCurrencyUnit, formatCurrencyUnit,
@ -39,7 +40,7 @@ I.defaultProps = {
color: undefined, color: undefined,
} }
const mapStateToProps = state => ({ const mapStateToProps = (state: State) => ({
settings: state.settings, settings: state.settings,
}) })
@ -48,11 +49,11 @@ type Props = {
animateTicker?: boolean, animateTicker?: boolean,
color?: string, color?: string,
disableRounding?: boolean, disableRounding?: boolean,
fiat?: string | null, fiat?: string,
isPercent?: boolean, isPercent?: boolean,
settings?: Settings, settings?: Settings,
showCode?: boolean, showCode?: boolean,
unit?: Unit | null, unit?: Unit,
val: number, val: number,
withIcon?: boolean, withIcon?: boolean,
} }
@ -136,17 +137,4 @@ export function FormattedVal(props: Props) {
) )
} }
FormattedVal.defaultProps = {
alwaysShowSign: false,
animateTicker: false,
color: undefined,
disableRounding: false,
fiat: null,
isPercent: false,
settings: undefined,
showCode: false,
unit: null,
withIcon: false,
}
export default connect(mapStateToProps)(FormattedVal) export default connect(mapStateToProps)(FormattedVal)

2
src/components/modals/StepConnectDevice.js

@ -12,7 +12,7 @@ type Props = {
accountName?: string, accountName?: string,
account?: ?Account, account?: ?Account,
currency?: ?CryptoCurrency, currency?: ?CryptoCurrency,
deviceSelected: ?Device, deviceSelected?: ?Device,
onChangeDevice: Function, onChangeDevice: Function,
onStatusChange: Function, onStatusChange: Function,
} }

2723
yarn.lock

File diff suppressed because it is too large
Loading…
Cancel
Save