add re-import address, default wallet

This commit is contained in:
liangping 2021-11-24 11:40:03 +08:00
parent 7bbf220906
commit 4910319be7
4 changed files with 131 additions and 44 deletions

View File

@ -69,7 +69,7 @@
:to="{ name: 'accounts' }"
>
<feather-icon icon="KeyIcon" />
<span class="align-middle ml-25">Wallet</span>
<span class="align-middle ml-25">{{ walletName }}</span>
</b-button>
<!-- <b-dropdown
class="ml-1"
@ -135,7 +135,7 @@ import Locale from '@core/layouts/components/app-navbar/components/Locale.vue'
import SearchBar from '@core/layouts/components/app-navbar/components/SearchBar.vue'
// import CartDropdown from '@core/layouts/components/app-navbar/components/CartDropdown.vue'
import store from '@/store'
import { timeIn, toDay } from '@/libs/data'
import { getLocalAccounts, timeIn, toDay } from '@/libs/data'
// import UserDropdown from '@core/layouts/components/app-navbar/components/UserDropdown.vue'
export default {
@ -172,6 +172,10 @@ export default {
}
},
computed: {
walletName() {
const key = this.$store.state.chains.defaultWallet
return key || 'Wallet'
},
selected_chain() {
this.block()
return store.state.chains.selected
@ -180,6 +184,12 @@ export default {
return this.variant
},
},
mounted() {
const accounts = Object.keys(getLocalAccounts())
if (!this.$store.state.chains.defaultWallet && accounts.length > 0) {
this.$store.commit('setDefaultWallet', accounts[0])
}
},
methods: {
block() {
store.commit('setHeight', 0)

View File

@ -26,6 +26,7 @@ export default {
height: 0,
ibcChannels: {},
quotes: {},
defaultWallet: localStorage.getItem('default-wallet'),
},
getters: {
getchains: state => state.chains,
@ -50,6 +51,12 @@ export default {
setQuotes(state, quotes) {
state.quotes = quotes
},
setDefaultWallet(state, defaultWallet) {
if (defaultWallet && defaultWallet.length > 0) {
localStorage.setItem('default-wallet', defaultWallet)
state.chains.defaultWallet = defaultWallet
}
},
},
actions: {
async getQuotes(context) {

View File

@ -1,6 +1,7 @@
<template>
<div>
<form-wizard
ref="wizard"
color="#7367F0"
:title="null"
:subtitle="null"
@ -131,6 +132,7 @@
v-model="name"
:state="errors.length > 0 ? false:null"
placeholder="Ping Nano X"
:readonly="edit"
/>
<small class="text-danger">{{ errors[0] }}</small>
</validation-provider>
@ -261,7 +263,9 @@ import {
} from 'bootstrap-vue'
import { required } from '@validations'
import store from '@/store'
import { addressDecode, addressEnCode, getLedgerAddress } from '@/libs/data'
import {
addressDecode, addressEnCode, getLedgerAddress, getLocalAccounts,
} from '@/libs/data'
import { toHex } from '@cosmjs/encoding'
export default {
@ -295,6 +299,7 @@ export default {
selected: [],
accounts: null,
exludes: [], // HD Path is NOT supported,
edit: false,
}
},
computed: {
@ -309,21 +314,43 @@ export default {
if (this.accounts && this.accounts.address) {
const { data } = addressDecode(this.accounts.address)
return this.selected.map(x => {
const { logo, addr_prefix } = this.chains[x]
const addr = addressEnCode(addr_prefix, data)
return {
chain: x, addr, logo, hdpath: this.hdpath,
if (this.chains[x]) {
const { logo, addr_prefix } = this.chains[x]
const addr = addressEnCode(addr_prefix, data)
return {
chain: x, addr, logo, hdpath: this.hdpath,
}
}
})
return null
}).filter(x => x != null)
}
return []
},
},
created() {
mounted() {
const { selected } = store.state.chains
if (selected && selected.chain_name && !this.exludes.includes(selected.chain_name)) {
this.selected.push(selected.chain_name)
}
const name = new URLSearchParams(window.location.search).get('name')
const wallets = getLocalAccounts()
if (name && wallets && wallets[name]) {
const wallet = wallets[name]
this.device = wallet.device
this.name = wallet.name
this.edit = true
if (wallet.address) {
wallet.address.forEach(a => {
if (!this.selected.includes(a.chain)) {
this.selected.push(a.chain)
}
})
this.address = wallet.address[0].addr
if (this.localAddress()) {
this.$refs.wizard.nextTab()
}
}
}
},
methods: {
formatPubkey(v) {
@ -373,6 +400,9 @@ export default {
address: this.addresses,
}
localStorage.setItem('accounts', JSON.stringify(accounts))
if (!this.$store.state.chains.defaultWallet) {
this.$store.commit('setDefaultWallet', this.name)
}
this.$toast({
component: ToastificationContent,
@ -386,31 +416,34 @@ export default {
this.$router.push('./accounts')
},
async validationFormDevice() {
let ok = false
switch (this.device) {
case 'keplr':
await this.cennectKeplr().then(accounts => {
if (accounts) {
let ok = String(this.name).length > 0
if (!ok) { // new import, otherwise it's edit mode.
switch (this.device) {
case 'keplr':
await this.cennectKeplr().then(accounts => {
if (accounts) {
// eslint-disable-next-line prefer-destructuring
this.accounts = accounts[0]
ok = true
}
})
break
case 'ledger':
case 'ledger2':
await this.connect().then(accounts => {
if (accounts) {
this.accounts = accounts[0]
ok = true
}
})
break
case 'ledger':
case 'ledger2':
await this.connect().then(accounts => {
if (accounts) {
// eslint-disable-next-line prefer-destructuring
this.accounts = accounts[0]
ok = true
}
}).catch(e => {
this.debug = e
})
break
default:
ok = this.localAddress()
this.accounts = accounts[0]
ok = true
}
}).catch(e => {
this.debug = e
})
break
default:
ok = this.localAddress()
}
}
return new Promise((resolve, reject) => {
@ -438,5 +471,6 @@ export default {
</script>
<style lang="scss">
// @import '@core/assets/fonts/feather/iconfont.css';
@import '@core/scss/vue/libs/vue-wizard.scss';
</style>

View File

@ -71,16 +71,40 @@
</b-row>
</b-card>
<b-tabs
<div
v-for="item,index in accounts"
:key="index"
active-nav-item-class="font-weight-bolder"
>
<b-tab>
<template #title>
<feather-icon icon="UserIcon" />
<span>{{ item.name }}</span>
</template>
<div>
<div class="d-flex justify-content-between align-items-end mb-1">
<b-button
v-ripple.400="'rgba(255, 255, 255, 0.15)'"
variant="warning"
:to="`/wallet/import?name=${item.name}`"
>
<feather-icon
icon="EditIcon"
class="mr-50"
/>
<span class="align-middle">{{ item.name }}</span>
</b-button>
<b-form-checkbox
v-model="defaultWallet"
v-b-tooltip.hover.v-primary
:value="item.name"
title="Set as default wallet"
variant="outline-warning"
:readonly="item.name===defaultWallet"
>
<span
:class="item.name===defaultWallet ? 'text-primary' : ''"
class="font-weight-bolder pb-0"
style="font-size:16px"
>
Set as default
</span>
</b-form-checkbox>
</div>
<b-row>
<b-col
@ -212,8 +236,8 @@
</b-card>
</b-col>
</b-row>
</b-tab>
</b-tabs>
</div>
</div>
<router-link to="./import">
<b-card class="addzone">
@ -230,7 +254,8 @@
<script>
import {
BCard, BCardHeader, BCardTitle, BCardBody, VBModal, BRow, BCol, BTabs, BTab, BAvatar, BDropdown, BDropdownItem, BDropdownDivider,
BCard, BCardHeader, BCardTitle, BCardBody, VBModal, BRow, BCol, BAvatar, BButton,
BDropdown, BDropdownItem, BDropdownDivider, BFormCheckbox, VBTooltip,
} from 'bootstrap-vue'
import Ripple from 'vue-ripple-directive'
import FeatherIcon from '@/@core/components/feather-icon/FeatherIcon.vue'
@ -252,15 +277,17 @@ export default {
BAvatar,
BCard,
BRow,
BButton,
BCol,
BTabs,
BTab,
BCardHeader,
BCardBody,
BCardTitle,
BDropdown,
BDropdownItem,
BDropdownDivider,
BFormCheckbox,
// eslint-disable-next-line vue/no-unused-components
VBTooltip,
FeatherIcon,
OperationTransferComponent,
// eslint-disable-next-line vue/no-unused-components
@ -272,6 +299,7 @@ export default {
AppCollapseItem,
},
directives: {
'b-tooltip': VBTooltip,
'b-modal': VBModal,
Ripple,
},
@ -337,6 +365,14 @@ export default {
}
},
computed: {
defaultWallet: {
get() {
return this.$store.state.chains.defaultWallet
},
set(value) {
this.$store.commit('setDefaultWallet', value)
},
},
calculateTotal() {
const v = Object.values(this.balances)
let total = 0