This repository has been archived by the owner on Jun 7, 2023. It is now read-only.
/
Addresses.js
63 lines (57 loc) · 2.54 KB
/
Addresses.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
import React, { PureComponent } from 'react';
import PropTypes from 'prop-types';
import { withI18n } from 'react-i18next';
import { formatValue, formatUnit } from 'libs/iota/utils';
import Scrollbar from 'ui/components/Scrollbar';
import Clipboard from 'ui/components/Clipboard';
import css from './addresses.scss';
/**
* Account addresses component
*/
class Addresses extends PureComponent {
static propTypes = {
/** @ignore */
account: PropTypes.object,
/** @ignore */
t: PropTypes.func.isRequired,
};
render() {
const { account, t } = this.props;
const isSpent = ({ spent: { local, remote } }) => local || remote;
return (
<form>
<fieldset>
<ul className={css.addresses}>
<Scrollbar>
{account.addressData
.map((addressData) => {
const address = addressData.address + addressData.checksum;
return (
<li key={address}>
<p className={isSpent(addressData) ? css.spent : null}>
<Clipboard
text={address}
title={t('receive:addressCopied')}
success={t('receive:addressCopiedExplanation')}
>
{addressData.address.match(/.{1,3}/g).join(' ')}{' '}
<mark>
{addressData.checksum.match(/.{1,3}/g).join(' ')}
</mark>
</Clipboard>
</p>
<strong>
{formatValue(addressData.balance)}
{formatUnit(addressData.balance)}
</strong>
</li>
);
})}
</Scrollbar>
</ul>
</fieldset>
</form>
);
}
}
export default withI18n()(Addresses);