|
@ -8,6 +8,7 @@ import styled from 'styled-components' |
|
|
import moment from 'moment' |
|
|
import moment from 'moment' |
|
|
import { getOperationAmountNumber } from '@ledgerhq/live-common/lib/helpers/operation' |
|
|
import { getOperationAmountNumber } from '@ledgerhq/live-common/lib/helpers/operation' |
|
|
import { getAccountOperationExplorer } from '@ledgerhq/live-common/lib/explorers' |
|
|
import { getAccountOperationExplorer } from '@ledgerhq/live-common/lib/explorers' |
|
|
|
|
|
import uniq from 'lodash/uniq' |
|
|
|
|
|
|
|
|
import TrackPage from 'analytics/TrackPage' |
|
|
import TrackPage from 'analytics/TrackPage' |
|
|
import type { Account, Operation } from '@ledgerhq/live-common/lib/types' |
|
|
import type { Account, Operation } from '@ledgerhq/live-common/lib/types' |
|
@ -126,6 +127,7 @@ const OperationDetails = connect(mapStateToProps)((props: Props) => { |
|
|
const isConfirmed = confirmations >= currencySettings.confirmationsNb |
|
|
const isConfirmed = confirmations >= currencySettings.confirmationsNb |
|
|
|
|
|
|
|
|
const url = getAccountOperationExplorer(account, operation) |
|
|
const url = getAccountOperationExplorer(account, operation) |
|
|
|
|
|
const uniqueSenders = uniq(senders) |
|
|
|
|
|
|
|
|
return ( |
|
|
return ( |
|
|
<ModalBody onClose={onClose}> |
|
|
<ModalBody onClose={onClose}> |
|
@ -217,12 +219,12 @@ const OperationDetails = connect(mapStateToProps)((props: Props) => { |
|
|
<B /> |
|
|
<B /> |
|
|
<Box> |
|
|
<Box> |
|
|
<OpDetailsTitle>{t('app:operationDetails.from')}</OpDetailsTitle> |
|
|
<OpDetailsTitle>{t('app:operationDetails.from')}</OpDetailsTitle> |
|
|
<Recipients recipients={senders} t={t} /> |
|
|
<DataList lines={uniqueSenders} t={t} /> |
|
|
</Box> |
|
|
</Box> |
|
|
<B /> |
|
|
<B /> |
|
|
<Box> |
|
|
<Box> |
|
|
<OpDetailsTitle>{t('app:operationDetails.to')}</OpDetailsTitle> |
|
|
<OpDetailsTitle>{t('app:operationDetails.to')}</OpDetailsTitle> |
|
|
<Recipients recipients={recipients} t={t} /> |
|
|
<DataList lines={recipients} t={t} /> |
|
|
</Box> |
|
|
</Box> |
|
|
</Box> |
|
|
</Box> |
|
|
</GrowScroll> |
|
|
</GrowScroll> |
|
@ -271,7 +273,7 @@ const More = styled(Text).attrs({ |
|
|
outline: none; |
|
|
outline: none; |
|
|
` |
|
|
` |
|
|
|
|
|
|
|
|
export class Recipients extends Component<{ recipients: Array<*>, t: T }, *> { |
|
|
export class DataList extends Component<{ lines: string[], t: T }, *> { |
|
|
state = { |
|
|
state = { |
|
|
showMore: false, |
|
|
showMore: false, |
|
|
} |
|
|
} |
|
@ -279,18 +281,18 @@ export class Recipients extends Component<{ recipients: Array<*>, t: T }, *> { |
|
|
this.setState(({ showMore }) => ({ showMore: !showMore })) |
|
|
this.setState(({ showMore }) => ({ showMore: !showMore })) |
|
|
} |
|
|
} |
|
|
render() { |
|
|
render() { |
|
|
const { recipients, t } = this.props |
|
|
const { lines, t } = this.props |
|
|
const { showMore } = this.state |
|
|
const { showMore } = this.state |
|
|
// Hardcoded for now
|
|
|
// Hardcoded for now
|
|
|
const numToShow = 2 |
|
|
const numToShow = 2 |
|
|
const shouldShowMore = recipients.length > 3 |
|
|
const shouldShowMore = lines.length > 3 |
|
|
return ( |
|
|
return ( |
|
|
<Box> |
|
|
<Box> |
|
|
{(shouldShowMore ? recipients.slice(0, numToShow) : recipients).map(recipient => ( |
|
|
{(shouldShowMore ? lines.slice(0, numToShow) : lines).map(line => ( |
|
|
<OpDetailsData key={recipient}> |
|
|
<OpDetailsData key={line}> |
|
|
{recipient} |
|
|
{line} |
|
|
<GradientHover> |
|
|
<GradientHover> |
|
|
<CopyWithFeedback text={recipient} /> |
|
|
<CopyWithFeedback text={line} /> |
|
|
</GradientHover> |
|
|
</GradientHover> |
|
|
</OpDetailsData> |
|
|
</OpDetailsData> |
|
|
))} |
|
|
))} |
|
@ -299,14 +301,12 @@ export class Recipients extends Component<{ recipients: Array<*>, t: T }, *> { |
|
|
<Box onClick={this.onClick} py={1}> |
|
|
<Box onClick={this.onClick} py={1}> |
|
|
<More fontSize={4} color="wallet" ff="Open Sans|SemiBold" mt={1}> |
|
|
<More fontSize={4} color="wallet" ff="Open Sans|SemiBold" mt={1}> |
|
|
<IconChevronRight size={12} style={{ marginRight: 5 }} /> |
|
|
<IconChevronRight size={12} style={{ marginRight: 5 }} /> |
|
|
{t('app:operationDetails.showMore', { recipients: recipients.length - numToShow })} |
|
|
{t('app:operationDetails.showMore', { recipients: lines.length - numToShow })} |
|
|
</More> |
|
|
</More> |
|
|
</Box> |
|
|
</Box> |
|
|
)} |
|
|
)} |
|
|
{showMore && |
|
|
{showMore && |
|
|
recipients |
|
|
lines.slice(numToShow).map(line => <OpDetailsData key={line}>{line}</OpDetailsData>)} |
|
|
.slice(numToShow) |
|
|
|
|
|
.map(recipient => <OpDetailsData key={recipient}>{recipient}</OpDetailsData>)} |
|
|
|
|
|
{shouldShowMore && |
|
|
{shouldShowMore && |
|
|
showMore && ( |
|
|
showMore && ( |
|
|
<Box onClick={this.onClick} py={1}> |
|
|
<Box onClick={this.onClick} py={1}> |
|
|