|
@ -1,11 +1,12 @@ |
|
|
// @flow
|
|
|
// @flow
|
|
|
import React, { Component } from 'react' |
|
|
import React, { Fragment, Component } from 'react' |
|
|
import { translate } from 'react-i18next' |
|
|
import { translate } from 'react-i18next' |
|
|
import LRU from 'lru-cache' |
|
|
import LRU from 'lru-cache' |
|
|
import type { Currency } from '@ledgerhq/live-common/lib/types' |
|
|
import type { Currency } from '@ledgerhq/live-common/lib/types' |
|
|
import type { Exchange } from '@ledgerhq/live-common/lib/countervalues/types' |
|
|
import type { Exchange } from '@ledgerhq/live-common/lib/countervalues/types' |
|
|
import logger from 'logger' |
|
|
import logger from 'logger' |
|
|
|
|
|
|
|
|
|
|
|
import Track from 'analytics/Track' |
|
|
import Select from 'components/base/Select' |
|
|
import Select from 'components/base/Select' |
|
|
import Text from 'components/base/Text' |
|
|
import Text from 'components/base/Text' |
|
|
import CounterValues from 'helpers/countervalues' |
|
|
import CounterValues from 'helpers/countervalues' |
|
@ -91,27 +92,37 @@ class SelectExchange extends Component< |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
render() { |
|
|
render() { |
|
|
const { onChange, exchangeId, style, t, ...props } = this.props |
|
|
const { onChange, exchangeId, style, t, from, to, ...props } = this.props |
|
|
const { exchanges, error } = this.state |
|
|
const { exchanges, error } = this.state |
|
|
|
|
|
|
|
|
const options = exchanges ? exchanges.map(e => ({ value: e.id, label: e.name, ...e })) : [] |
|
|
const options = exchanges ? exchanges.map(e => ({ value: e.id, label: e.name, ...e })) : [] |
|
|
|
|
|
const value = options.find(e => e.id === exchangeId) |
|
|
|
|
|
|
|
|
return error ? ( |
|
|
return error ? ( |
|
|
<Text ff="Open Sans|SemiBold" color="dark" fontSize={4}> |
|
|
<Text ff="Open Sans|SemiBold" color="dark" fontSize={4}> |
|
|
{t('app:common.error.load')} |
|
|
{t('app:common.error.load')} |
|
|
</Text> |
|
|
</Text> |
|
|
) : ( |
|
|
) : ( |
|
|
<Select |
|
|
<Fragment> |
|
|
value={options.find(e => e.id === exchangeId)} |
|
|
<Track |
|
|
options={options} |
|
|
onUpdate |
|
|
onChange={onChange} |
|
|
event="SelectExchange" |
|
|
isLoading={options.length === 0} |
|
|
exchangeName={value && value.id} |
|
|
placeholder={t('app:common.selectExchange')} |
|
|
fromCurrency={from.ticker} |
|
|
noOptionsMessage={({ inputValue }) => |
|
|
toCurrency={to.ticker} |
|
|
t('app:common.selectExchangeNoOption', { exchangeName: inputValue }) |
|
|
/> |
|
|
} |
|
|
<Select |
|
|
{...props} |
|
|
value={value} |
|
|
/> |
|
|
options={options} |
|
|
|
|
|
onChange={onChange} |
|
|
|
|
|
isLoading={options.length === 0} |
|
|
|
|
|
placeholder={t('app:common.selectExchange')} |
|
|
|
|
|
noOptionsMessage={({ inputValue }) => |
|
|
|
|
|
t('app:common.selectExchangeNoOption', { exchangeName: inputValue }) |
|
|
|
|
|
} |
|
|
|
|
|
{...props} |
|
|
|
|
|
/> |
|
|
|
|
|
</Fragment> |
|
|
) |
|
|
) |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|