mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
Style dropdown of to-autocomplete.
This commit is contained in:
parent
de3a48ec66
commit
07c4c92db6
@ -27,6 +27,8 @@ AccountListItem.prototype.render = function () {
|
|||||||
icon = null,
|
icon = null,
|
||||||
conversionRate,
|
conversionRate,
|
||||||
currentCurrency,
|
currentCurrency,
|
||||||
|
displayBalance = true,
|
||||||
|
displayAddress = false,
|
||||||
} = this.props
|
} = this.props
|
||||||
|
|
||||||
const { name, address, balance } = account || {}
|
const { name, address, balance } = account || {}
|
||||||
@ -46,13 +48,15 @@ AccountListItem.prototype.render = function () {
|
|||||||
},
|
},
|
||||||
),
|
),
|
||||||
|
|
||||||
h('div.account-list-item__account-name', {}, name),
|
h('div.account-list-item__account-name', {}, name || address),
|
||||||
|
|
||||||
icon && h('div.account-list-item__icon', [icon]),
|
icon && h('div.account-list-item__icon', [icon]),
|
||||||
|
|
||||||
]),
|
]),
|
||||||
|
|
||||||
h(CurrencyDisplay, {
|
displayAddress && name && h('div.account-list-item__account-address', address),
|
||||||
|
|
||||||
|
displayBalance && h(CurrencyDisplay, {
|
||||||
primaryCurrency: 'ETH',
|
primaryCurrency: 'ETH',
|
||||||
convertedCurrency: currentCurrency,
|
convertedCurrency: currentCurrency,
|
||||||
value: balance,
|
value: balance,
|
||||||
|
@ -2,54 +2,126 @@ const Component = require('react').Component
|
|||||||
const h = require('react-hyperscript')
|
const h = require('react-hyperscript')
|
||||||
const inherits = require('util').inherits
|
const inherits = require('util').inherits
|
||||||
const Identicon = require('../identicon')
|
const Identicon = require('../identicon')
|
||||||
|
const AccountListItem = require('./account-list-item')
|
||||||
|
|
||||||
module.exports = ToAutoComplete
|
module.exports = ToAutoComplete
|
||||||
|
|
||||||
inherits(ToAutoComplete, Component)
|
inherits(ToAutoComplete, Component)
|
||||||
function ToAutoComplete () {
|
function ToAutoComplete () {
|
||||||
Component.call(this)
|
Component.call(this)
|
||||||
|
|
||||||
|
this.state = { accountsToRender: [] }
|
||||||
|
}
|
||||||
|
|
||||||
|
ToAutoComplete.prototype.getListItemIcon = function (listItemAddress, toAddress) {
|
||||||
|
const listItemIcon = h(`i.fa.fa-check.fa-lg`, { style: { color: '#02c9b1' } })
|
||||||
|
|
||||||
|
return toAddress && listItemAddress === toAddress
|
||||||
|
? listItemIcon
|
||||||
|
: null
|
||||||
|
}
|
||||||
|
|
||||||
|
ToAutoComplete.prototype.renderDropdown = function () {
|
||||||
|
const {
|
||||||
|
accounts,
|
||||||
|
closeDropdown,
|
||||||
|
onChange,
|
||||||
|
to,
|
||||||
|
} = this.props
|
||||||
|
const { accountsToRender } = this.state
|
||||||
|
|
||||||
|
return accountsToRender.length && h('div', {}, [
|
||||||
|
|
||||||
|
h('div.send-v2__from-dropdown__close-area', {
|
||||||
|
onClick: closeDropdown,
|
||||||
|
}),
|
||||||
|
|
||||||
|
h('div.send-v2__from-dropdown__list', {}, [
|
||||||
|
|
||||||
|
...accountsToRender.map(account => h(AccountListItem, {
|
||||||
|
account,
|
||||||
|
handleClick: () => {
|
||||||
|
onChange(account.address)
|
||||||
|
closeDropdown()
|
||||||
|
},
|
||||||
|
icon: this.getListItemIcon(account.address, to),
|
||||||
|
displayBalance: false,
|
||||||
|
displayAddress: true,
|
||||||
|
}))
|
||||||
|
|
||||||
|
]),
|
||||||
|
|
||||||
|
])
|
||||||
|
}
|
||||||
|
|
||||||
|
ToAutoComplete.prototype.handleInputEvent = function (event = {}, cb) {
|
||||||
|
const {
|
||||||
|
to,
|
||||||
|
accounts,
|
||||||
|
closeDropdown,
|
||||||
|
openDropdown,
|
||||||
|
} = this.props
|
||||||
|
|
||||||
|
const matchingAccounts = accounts.filter(({ address }) => address.match(to))
|
||||||
|
|
||||||
|
if (!to) {
|
||||||
|
this.setState({ accountsToRender: accounts })
|
||||||
|
openDropdown()
|
||||||
|
}
|
||||||
|
else if (matchingAccounts.length === 1 && matchingAccounts[0].address === to) {
|
||||||
|
this.setState({ accountsToRender: [] })
|
||||||
|
event.target && event.target.select()
|
||||||
|
closeDropdown()
|
||||||
|
}
|
||||||
|
else if (matchingAccounts.length) {
|
||||||
|
this.setState({ accountsToRender: matchingAccounts })
|
||||||
|
openDropdown()
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
this.setState({ accountsToRender: [] })
|
||||||
|
event.target && event.target.select()
|
||||||
|
closeDropdown()
|
||||||
|
}
|
||||||
|
cb && cb(event.target.value)
|
||||||
|
}
|
||||||
|
|
||||||
|
ToAutoComplete.prototype.componentDidUpdate = function (nextProps, nextState) {
|
||||||
|
if (this.props.to !== nextProps.to) {
|
||||||
|
this.handleInputEvent()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ToAutoComplete.prototype.render = function () {
|
ToAutoComplete.prototype.render = function () {
|
||||||
const { to, accounts, onChange, inError } = this.props
|
const {
|
||||||
|
to,
|
||||||
|
accounts,
|
||||||
|
openDropdown,
|
||||||
|
closeDropdown,
|
||||||
|
dropdownOpen,
|
||||||
|
onChange,
|
||||||
|
inError,
|
||||||
|
} = this.props
|
||||||
|
|
||||||
return h('div.send-v2__to-autocomplete', [
|
return h('div.to-autocomplete', {}, [
|
||||||
|
|
||||||
h('input.send-v2__to-autocomplete__input', {
|
h('input.send-v2__to-autocomplete__input', {
|
||||||
name: 'address',
|
|
||||||
list: 'addresses',
|
|
||||||
placeholder: 'Recipient Address',
|
placeholder: 'Recipient Address',
|
||||||
className: inError ? `send-v2__error-border` : '',
|
className: inError ? `send-v2__error-border` : '',
|
||||||
value: to,
|
value: to,
|
||||||
onChange,
|
onChange: event => onChange(event.target.value),
|
||||||
onFocus: event => {
|
onFocus: event => this.handleInputEvent(event),
|
||||||
to && event.target.select()
|
|
||||||
},
|
|
||||||
style: {
|
style: {
|
||||||
borderColor: inError ? 'red' : null,
|
borderColor: inError ? 'red' : null,
|
||||||
}
|
}
|
||||||
}),
|
}),
|
||||||
|
|
||||||
h('datalist#addresses', [
|
!to && h(`i.fa.fa-caret-down.fa-lg.send-v2__to-autocomplete__down-caret`, {
|
||||||
// Corresponds to the addresses owned.
|
style: { color: '#dedede' },
|
||||||
...Object.entries(accounts).map(([key, { address, name }]) => {
|
onClick: () => this.handleInputEvent(),
|
||||||
return h('option', {
|
}),
|
||||||
value: address,
|
|
||||||
label: name,
|
dropdownOpen && this.renderDropdown(),
|
||||||
key: address,
|
|
||||||
})
|
|
||||||
}),
|
|
||||||
// Corresponds to previously sent-to addresses.
|
|
||||||
// ...addressBook.map(({ address, name }) => {
|
|
||||||
// return h('option', {
|
|
||||||
// value: address,
|
|
||||||
// label: name,
|
|
||||||
// key: address,
|
|
||||||
// })
|
|
||||||
// }),
|
|
||||||
]),
|
|
||||||
|
|
||||||
])
|
])
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -62,4 +62,11 @@
|
|||||||
&__account-secondary-balance {
|
&__account-secondary-balance {
|
||||||
color: $dusty-gray;
|
color: $dusty-gray;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
&__account-address {
|
||||||
|
margin-left: 35px;
|
||||||
|
width: 80%;
|
||||||
|
overflow: hidden;
|
||||||
|
text-overflow: ellipsis;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -594,6 +594,16 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
&__to-autocomplete {
|
||||||
|
position: relative;
|
||||||
|
|
||||||
|
&__down-caret {
|
||||||
|
position: absolute;
|
||||||
|
top: 18px;
|
||||||
|
right: 12px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
&__to-autocomplete, &__memo-text-area {
|
&__to-autocomplete, &__memo-text-area {
|
||||||
&__input {
|
&__input {
|
||||||
height: 54px;
|
height: 54px;
|
||||||
|
@ -32,7 +32,8 @@ function SendTransactionScreen () {
|
|||||||
PersistentForm.call(this)
|
PersistentForm.call(this)
|
||||||
|
|
||||||
this.state = {
|
this.state = {
|
||||||
dropdownOpen: false,
|
fromDropdownOpen: false,
|
||||||
|
toDropdownOpen: false,
|
||||||
errors: {
|
errors: {
|
||||||
to: null,
|
to: null,
|
||||||
amount: null,
|
amount: null,
|
||||||
@ -157,7 +158,7 @@ SendTransactionScreen.prototype.renderFromRow = function () {
|
|||||||
updateSendFrom,
|
updateSendFrom,
|
||||||
} = this.props
|
} = this.props
|
||||||
|
|
||||||
const { dropdownOpen } = this.state
|
const { fromDropdownOpen } = this.state
|
||||||
|
|
||||||
return h('div.send-v2__form-row', [
|
return h('div.send-v2__form-row', [
|
||||||
|
|
||||||
@ -165,12 +166,12 @@ SendTransactionScreen.prototype.renderFromRow = function () {
|
|||||||
|
|
||||||
h('div.send-v2__form-field', [
|
h('div.send-v2__form-field', [
|
||||||
h(FromDropdown, {
|
h(FromDropdown, {
|
||||||
dropdownOpen,
|
dropdownOpen: fromDropdownOpen,
|
||||||
accounts: fromAccounts,
|
accounts: fromAccounts,
|
||||||
selectedAccount: from,
|
selectedAccount: from,
|
||||||
onSelect: updateSendFrom,
|
onSelect: updateSendFrom,
|
||||||
openDropdown: () => this.setState({ dropdownOpen: true }),
|
openDropdown: () => this.setState({ fromDropdownOpen: true }),
|
||||||
closeDropdown: () => this.setState({ dropdownOpen: false }),
|
closeDropdown: () => this.setState({ fromDropdownOpen: false }),
|
||||||
conversionRate,
|
conversionRate,
|
||||||
}),
|
}),
|
||||||
]),
|
]),
|
||||||
@ -178,9 +179,8 @@ SendTransactionScreen.prototype.renderFromRow = function () {
|
|||||||
])
|
])
|
||||||
}
|
}
|
||||||
|
|
||||||
SendTransactionScreen.prototype.handleToChange = function (event) {
|
SendTransactionScreen.prototype.handleToChange = function (to) {
|
||||||
const { updateSendTo, updateSendErrors } = this.props
|
const { updateSendTo, updateSendErrors } = this.props
|
||||||
const to = event.target.value
|
|
||||||
let toError = null
|
let toError = null
|
||||||
|
|
||||||
if (!to) {
|
if (!to) {
|
||||||
@ -194,8 +194,9 @@ SendTransactionScreen.prototype.handleToChange = function (event) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
SendTransactionScreen.prototype.renderToRow = function () {
|
SendTransactionScreen.prototype.renderToRow = function () {
|
||||||
const { toAccounts, errors } = this.props
|
const { toAccounts, errors, to } = this.props
|
||||||
const { to } = this.state
|
|
||||||
|
const { toDropdownOpen } = this.state
|
||||||
|
|
||||||
return h('div.send-v2__form-row', [
|
return h('div.send-v2__form-row', [
|
||||||
|
|
||||||
@ -210,7 +211,10 @@ SendTransactionScreen.prototype.renderToRow = function () {
|
|||||||
h('div.send-v2__form-field', [
|
h('div.send-v2__form-field', [
|
||||||
h(ToAutoComplete, {
|
h(ToAutoComplete, {
|
||||||
to,
|
to,
|
||||||
accounts: toAccounts,
|
accounts: Object.entries(toAccounts).map(([key, account]) => account),
|
||||||
|
dropdownOpen: toDropdownOpen,
|
||||||
|
openDropdown: () => this.setState({ toDropdownOpen: true }),
|
||||||
|
closeDropdown: () => this.setState({ toDropdownOpen: false }),
|
||||||
onChange: this.handleToChange,
|
onChange: this.handleToChange,
|
||||||
inError: Boolean(errors.to),
|
inError: Boolean(errors.to),
|
||||||
}),
|
}),
|
||||||
|
Loading…
x
Reference in New Issue
Block a user