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 => {