Skip to content

Commit

Permalink
rollback account link style && improve search component code style
Browse files Browse the repository at this point in the history
  • Loading branch information
libotony committed Dec 19, 2024
1 parent 517022e commit e14fe87
Show file tree
Hide file tree
Showing 4 changed files with 54 additions and 54 deletions.
6 changes: 4 additions & 2 deletions src/components/AccountLink.vue
Original file line number Diff line number Diff line change
Expand Up @@ -13,9 +13,11 @@
v-if="noLink"
class="text-monospace text-truncate"
>
<template v-if="!!resolvedName">{{ resolvedName }}</template>
<template v-else-if="abbr">{{ address | abbr }}</template>
<template v-if="abbr">{{ address | abbr }}</template>
<template v-else>{{ address | checksum }}</template>

<!-- display the resolved domain name in no link mode(only used in account summary page) -->
<span class="text-black-50 small" v-if="!!resolvedName"> {{ resolvedName }}</span>
</span>
<router-link
class="text-monospace text-truncate"
Expand Down
36 changes: 35 additions & 1 deletion src/resolver.ts
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,25 @@ const getNamesJsonAbi = {
"stateMutability": "view",
"type": "function"
}
const getAddressesJsonAbi = {
"inputs": [
{
"internalType": "string[]",
"name": "names",
"type": "string[]"
}
],
"name": "getAddresses",
"outputs": [
{
"internalType": "address[]",
"name": "addresses",
"type": "address[]"
}
],
"stateMutability": "view",
"type": "function"
}

export const resolveDomainName = async (address: string, connex: Connex) => {
try {
Expand All @@ -33,4 +52,19 @@ export const resolveDomainName = async (address: string, connex: Connex) => {
} catch {
return null
}
}
}

export const resolveAddressByName = async (name: string, connex: Connex) => {
try {
const { decoded: { addresses } } = await connex.thor
.account(vet_domainResolver)
.method(getAddressesJsonAbi)
.cache([vet_domainResolver])
.call([name])

return addresses[0] || null
} catch {
return null
}
}

28 changes: 10 additions & 18 deletions src/views/Account.vue
Original file line number Diff line number Diff line change
Expand Up @@ -4,24 +4,16 @@
<b-card-header class="border-bottom-0 pb-0">
<span class="h4 mr-3">Account</span>
<div class="d-flex">
<div class="d-inline-flex align-items-center mw-100 mt-1">
<Ident
class="mr-2 flex-shrink-0"
:value="address"
style="width: 3.64em; height: 2.6em; border-radius: 0.2em"
/>
<div class="d-flex flex-column">
<div>
<span class="text-monospace text-truncate">{{ address|checksum }}</span>
<Copy
:value="address|checksum"
class="ml-2"
/>
</div>
<span v-if="resolvedName" class="text-monospace text-truncate text-black-50" style="font-size: 75%;">{{ resolvedName }}</span>
</div>
</div>

<AccountLink
no-link
icon
:address="address"
style="min-width:0px"
/>
<Copy
:value="address|checksum"
class="ml-1"
/>
</div>
</b-card-header>
<b-tabs
Expand Down
38 changes: 5 additions & 33 deletions src/views/Search.vue
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@
<script lang="ts">
import Vue from 'vue'
import { genesisIdToNetwork } from '../utils'
import { resolveAddressByName } from '@/resolver'
export default Vue.extend({
data: () => {
Expand Down Expand Up @@ -68,20 +69,12 @@ export default Vue.extend({
}
}
} else if (/\./.test(str) && genesisIdToNetwork(this.$connex.thor.genesis.id) === 'main') {
try {
const { decoded: { addresses } } = await this.$connex.thor
.account(vetResolverUtilsAddress)
.method(getAddressesJsonAbi)
.call([str])
if (!addresses[0] || addresses[0] === '0x0000000000000000000000000000000000000000') {
throw new Error('Name not found')
}
const address = await resolveAddressByName(str, this.$connex)
return this.$router.replace({ name: 'account', params: { address: addresses[0] } })
} catch (err) {
this.error = new Error('Name not found')
if (address && address !== '0x0000000000000000000000000000000000000000') {
return this.$router.replace({ name: 'account', params: { address: address } })
}
this.error = new Error('Name not found')
}
if (!this.error) {
this.error = new Error(`No result for '${str}'`)
Expand All @@ -93,25 +86,4 @@ export default Vue.extend({
}
})
const vetResolverUtilsAddress = '0xA11413086e163e41901bb81fdc5617c975Fa5a1A'
const getAddressesJsonAbi = {
"inputs": [
{
"internalType": "string[]",
"name": "names",
"type": "string[]"
}
],
"name": "getAddresses",
"outputs": [
{
"internalType": "address[]",
"name": "addresses",
"type": "address[]"
}
],
"stateMutability": "view",
"type": "function"
}
</script>

0 comments on commit e14fe87

Please sign in to comment.