aboutsummaryrefslogtreecommitdiffstats
path: root/ui/app/components
diff options
context:
space:
mode:
authorDan <danjm.com@gmail.com>2017-10-10 07:17:52 +0800
committerChi Kei Chan <chikeichan@gmail.com>2017-10-10 09:24:14 +0800
commit71d6463984f040b2aa495a13429f6ea3505defaf (patch)
treef10f80e5de5b80f8e9967f1fccb0ab129cf266b2 /ui/app/components
parent80463072b5c0c9e826582e066fbc962b667ee355 (diff)
downloadtangerine-wallet-browser-71d6463984f040b2aa495a13429f6ea3505defaf.tar
tangerine-wallet-browser-71d6463984f040b2aa495a13429f6ea3505defaf.tar.gz
tangerine-wallet-browser-71d6463984f040b2aa495a13429f6ea3505defaf.tar.bz2
tangerine-wallet-browser-71d6463984f040b2aa495a13429f6ea3505defaf.tar.lz
tangerine-wallet-browser-71d6463984f040b2aa495a13429f6ea3505defaf.tar.xz
tangerine-wallet-browser-71d6463984f040b2aa495a13429f6ea3505defaf.tar.zst
tangerine-wallet-browser-71d6463984f040b2aa495a13429f6ea3505defaf.zip
Refactor 'rendersingleidentity' to a stand alone account-list-item component.
Diffstat (limited to 'ui/app/components')
-rw-r--r--ui/app/components/send/account-list-item.js51
-rw-r--r--ui/app/components/send/from-dropdown.js69
2 files changed, 71 insertions, 49 deletions
diff --git a/ui/app/components/send/account-list-item.js b/ui/app/components/send/account-list-item.js
new file mode 100644
index 000000000..b11527d95
--- /dev/null
+++ b/ui/app/components/send/account-list-item.js
@@ -0,0 +1,51 @@
+const Component = require('react').Component
+const h = require('react-hyperscript')
+const inherits = require('util').inherits
+const connect = require('react-redux').connect
+const Identicon = require('../identicon')
+
+inherits(AccountListItem, Component)
+function AccountListItem () {
+ Component.call(this)
+}
+
+module.exports = AccountListItem
+
+AccountListItem.prototype.render = function () {
+ const {
+ account,
+ handleClick,
+ icon = null,
+ } = this.props
+
+ const { identity, balancesToRender } = account
+ const { name, address } = identity
+ const { primary, secondary } = balancesToRender
+
+ return h('div.account-list-item', {
+ onClick: () => handleClick(identity),
+ }, [
+
+ h('div.account-list-item__top-row', {}, [
+
+ h(
+ Identicon,
+ {
+ address,
+ diameter: 18,
+ className: 'account-list-item__identicon',
+ },
+ ),
+
+ h('div.account-list-item__account-name', {}, name),
+
+ icon && h('div.account-list-item__icon', [icon]),
+
+ ]),
+
+ h('div.account-list-item__account-primary-balance', {}, primary),
+
+ h('div.account-list-item__account-secondary-balance', {}, secondary),
+
+ ])
+} \ No newline at end of file
diff --git a/ui/app/components/send/from-dropdown.js b/ui/app/components/send/from-dropdown.js
index c438cefd5..fb0a00cc2 100644
--- a/ui/app/components/send/from-dropdown.js
+++ b/ui/app/components/send/from-dropdown.js
@@ -2,6 +2,7 @@ const Component = require('react').Component
const h = require('react-hyperscript')
const inherits = require('util').inherits
const Identicon = require('../identicon')
+const AccountListItem = require('./account-list-item')
module.exports = FromDropdown
@@ -10,48 +11,15 @@ function FromDropdown () {
Component.call(this)
}
-FromDropdown.prototype.renderSingleIdentity = function (
- account,
- handleClick,
- inList = false,
- selectedIdentity = {}
-) {
- const { identity, balancesToRender } = account
- const { name, address } = identity
- const { primary, secondary } = balancesToRender
+FromDropdown.prototype.getListItemIcon = function (currentAccount, selectedAccount) {
+ const listItemIcon = h(`i.fa.fa-check.fa-lg`, { style: { color: '#02c9b1' } })
- const iconType = inList ? 'check' : 'caret-down'
- const showIcon = !inList || address === selectedIdentity.address
-
- return h('div.send-v2__from-dropdown__account', {
- onClick: () => handleClick(identity),
- }, [
-
- h('div.send-v2__from-dropdown__top-row', {}, [
-
- h(
- Identicon,
- {
- address,
- diameter: 18,
- className: 'send-v2__from-dropdown__identicon',
- },
- ),
-
- h('div.send-v2__from-dropdown__account-name', {}, name),
-
- showIcon && h(`i.fa.fa-${iconType}.fa-lg.send-v2__from-dropdown__${iconType}`),
-
- ]),
-
- h('div.send-v2__from-dropdown__account-primary-balance', {}, primary),
-
- h('div.send-v2__from-dropdown__account-secondary-balance', {}, secondary),
-
- ])
+ return currentAccount.identity.address === selectedAccount.identity.address
+ ? listItemIcon
+ : null
}
-FromDropdown.prototype.renderDropdown = function (identities, selectedIdentity, closeDropdown) {
+FromDropdown.prototype.renderDropdown = function (accounts, selectedAccount, closeDropdown) {
return h('div', {}, [
h('div.send-v2__from-dropdown__close-area', {
@@ -60,12 +28,11 @@ FromDropdown.prototype.renderDropdown = function (identities, selectedIdentity,
h('div.send-v2__from-dropdown__list', {}, [
- ...identities.map(identity => this.renderSingleIdentity(
- identity,
- () => console.log('Select identity'),
- true,
- selectedIdentity
- ))
+ ...accounts.map(account => h(AccountListItem, {
+ account,
+ handleClick: () => console.log('Select identity'),
+ icon: this.getListItemIcon(account, selectedAccount),
+ }))
]),
@@ -74,8 +41,8 @@ FromDropdown.prototype.renderDropdown = function (identities, selectedIdentity,
FromDropdown.prototype.render = function () {
const {
- identities,
- selectedIdentity,
+ accounts,
+ selectedAccount,
setFromField,
openDropdown,
closeDropdown,
@@ -84,9 +51,13 @@ FromDropdown.prototype.render = function () {
return h('div.send-v2__from-dropdown', {}, [
- this.renderSingleIdentity(selectedIdentity, openDropdown),
+ h(AccountListItem, {
+ account: selectedAccount,
+ handleClick: openDropdown,
+ icon: h(`i.fa.fa-caret-down.fa-lg`, { style: { color: '#dedede' } })
+ }),
- dropdownOpen && this.renderDropdown(identities, selectedIdentity.identity, closeDropdown),
+ dropdownOpen && this.renderDropdown(accounts, selectedAccount, closeDropdown),
])