From 6f7fcece61b1f6520103fb08f2b6a9f33d45bfc9 Mon Sep 17 00:00:00 2001 From: liangping <18786721@qq.com> Date: Sat, 7 Aug 2021 15:01:01 +0800 Subject: [PATCH] Finish search bar --- .../app-navbar/components/SearchBar.vue | 31 ++++++++++++-- src/views/Block.vue | 40 ++++++++++++------- src/views/Transaction.vue | 15 ++++++- 3 files changed, 68 insertions(+), 18 deletions(-) diff --git a/src/@core/layouts/components/app-navbar/components/SearchBar.vue b/src/@core/layouts/components/app-navbar/components/SearchBar.vue index d13e2575..64aff251 100644 --- a/src/@core/layouts/components/app-navbar/components/SearchBar.vue +++ b/src/@core/layouts/components/app-navbar/components/SearchBar.vue @@ -30,10 +30,11 @@ placeholder="Search Height/Transaction/Address" autofocus autocomplete="off" + @keyup.enter="doQuery" />
@@ -45,7 +46,7 @@ import { BFormInput } from 'bootstrap-vue' import { ref } from '@vue/composition-api' import { title } from '@core/utils/filter' -import searchAndBookmarkData from '../search-and-bookmark-data' +import store from '@/store' export default { components: { @@ -61,10 +62,34 @@ export default { return { showSearchBar, perfectScrollbarSettings, - searchAndBookmarkData, title, } }, + data() { + return { + searchQuery: null, + } + }, + methods: { + doQuery() { + const height = /^\d+$/ + const txhash = /^[A-Z\d]{64}$/ + const addr = /^[a-z]{2,6}1[a-z\d]{38}$/ + const key = this.searchQuery + + const c = store.state.chains.selected + if (!Object.values(this.$route.params).includes(key)) { + if (height.test(key)) { + this.$router.push({ name: 'block', params: { chain: c.chain_name, height: key } }) + } else if (txhash.test(key)) { + this.$router.push({ name: 'transaction', params: { chain: c.chain_name, hash: key } }) + } else if (addr.test(key)) { + // console.log('address', key) + } + } + // this.$router.push('/') + }, + }, } diff --git a/src/views/Block.vue b/src/views/Block.vue index 90c73ee4..d74ee507 100644 --- a/src/views/Block.vue +++ b/src/views/Block.vue @@ -66,24 +66,36 @@ export default { ], } }, + beforeRouteUpdate(to, from, next) { + const { height } = to.params + if (height > 0 && height !== from.params.height) { + this.initData(height) + next() + } + }, created() { const { height } = this.$route.params - this.$http.getBlockByHeight(height).then(res => { - this.block = res - const { txs } = res.block.data - const array = [] - for (let i = 0; i <= txs.length; i += 1) { - try { - const origin = decodeTxRaw(fromBase64(txs[i])) - const tx = Tx.create(origin) - tx.setHash(txs[i]) - array.push(tx) - } catch (e) { + this.initData(height) + }, + methods: { + initData(height) { + this.$http.getBlockByHeight(height).then(res => { + this.block = res + const { txs } = res.block.data + const array = [] + for (let i = 0; i <= txs.length; i += 1) { + try { + const origin = decodeTxRaw(fromBase64(txs[i])) + const tx = Tx.create(origin) + tx.setHash(txs[i]) + array.push(tx) + } catch (e) { // catch errors + } } - } - if (array.length > 0) this.txs = array - }) + if (array.length > 0) this.txs = array + }) + }, }, } diff --git a/src/views/Transaction.vue b/src/views/Transaction.vue index 713ff8ef..20d4f5d1 100644 --- a/src/views/Transaction.vue +++ b/src/views/Transaction.vue @@ -25,7 +25,10 @@ {{ 'height' }} - {{ tx.height }} + + + {{ tx.height }} + @@ -103,6 +106,16 @@ export default { tx: { tx: {} }, } }, + beforeRouteUpdate(to, from, next) { + const { hash } = to.params + console.log(hash !== from.params.hash, hash, from.params) + if (hash !== from.params.hash) { + this.$http.getTxs(hash).then(res => { + this.tx = res + }) + next() + } + }, created() { const { hash } = this.$route.params this.$http.getTxs(hash).then(res => {