add accounts and supply

This commit is contained in:
liangping 2023-06-09 18:32:25 +08:00
parent 32e8c26d04
commit 551816e0ed
8 changed files with 164 additions and 12 deletions

View File

@ -35,7 +35,7 @@
"md-editor-v3": "^2.8.1", "md-editor-v3": "^2.8.1",
"numeral": "^2.0.6", "numeral": "^2.0.6",
"osmojs": "^14.0.0-rc.0", "osmojs": "^14.0.0-rc.0",
"ping-widget": "^0.0.38", "ping-widget": "^0.0.39",
"pinia": "^2.0.28", "pinia": "^2.0.28",
"postcss": "^8.4.23", "postcss": "^8.4.23",
"qrcode": "^1.5.3", "qrcode": "^1.5.3",

View File

@ -108,7 +108,7 @@ const tipMsg = computed(() => {
<ping-connect-wallet <ping-connect-wallet
:chain-id="baseStore.currentChainId" :chain-id="baseStore.currentChainId"
:hd-path="chainStore.defaultHDPath" :hd-path="chainStore.defaultHDPath"
:prefix="chainStore.current?.bech32Prefix" :addr-prefix="chainStore.current?.bech32Prefix||'cosmos'"
@connect="walletStateChange" @connect="walletStateChange"
@keplr-config="walletStore.suggestChain()" @keplr-config="walletStore.suggestChain()"
/> />

View File

@ -31,8 +31,10 @@ export class CosmosRestClient extends BaseRestClient<RequestRegistry> {
return new CosmosRestClient(endpoint, DEFAULT) return new CosmosRestClient(endpoint, DEFAULT)
} }
// Auth Module // Auth Module
async getAuthAccounts() { async getAuthAccounts(page?: PageRequest) {
return this.request(this.registry.auth_accounts, {}); if(!page) page = new PageRequest()
const query =`?${page.toQueryString()}`;
return this.request(this.registry.auth_accounts, {}, query);
} }
async getAuthAccount(address: string) { async getAuthAccount(address: string) {
return this.request(this.registry.auth_account_address, { address }); return this.request(this.registry.auth_account_address, { address });
@ -47,8 +49,9 @@ export class CosmosRestClient extends BaseRestClient<RequestRegistry> {
async getBankDenomMetadata() { async getBankDenomMetadata() {
return this.request(this.registry.bank_denoms_metadata, {}); return this.request(this.registry.bank_denoms_metadata, {});
} }
async getBankSupply() { async getBankSupply(page?: PageRequest) { if(!page) page = new PageRequest()
return this.request(this.registry.bank_supply, {}); const query =`?${page.toQueryString()}`;
return this.request(this.registry.bank_supply, {}, query);
} }
async getBankSupplyByDenom(denom: string) { async getBankSupplyByDenom(denom: string) {
return this.request(this.registry.bank_supply_by_denom, { denom }); return this.request(this.registry.bank_supply_by_denom, { denom });

View File

@ -0,0 +1,86 @@
<script lang="ts" setup>
import { computed, ref } from '@vue/reactivity';
import { useBaseStore, useBlockchain, useFormatter } from '@/stores';
import { PageRequest, type AuthAccount, type Pagination } from '@/types';
import { onMounted } from 'vue';
import PaginationBar from '@/components/PaginationBar.vue';
const props = defineProps(['chain']);
const chainStore = useBlockchain()
const accounts = ref([] as AuthAccount[])
const pageRequest = ref(new PageRequest())
const pageResponse = ref({} as Pagination)
onMounted(() => {
pageload(1)
});
function pageload(p: number) {
pageRequest.value.setPage(p)
chainStore.rpc.getAuthAccounts(pageRequest.value).then(x => {
accounts.value = x.accounts
pageResponse.value = x.pagination
});
}
function showType(v: string) {
return v.replace("/cosmos.auth.v1beta1.", "")
}
function findField(v: any, field: string) {
if(!v || Array.isArray(v) || typeof v === 'string') return null
const fields = Object.keys(v)
if(fields.includes(field)) {
return v[field]
}
for(let i= 0; i < fields.length; i++) {
const re: any = findField(v[fields[i]], field)
if(re) return re
}
}
function showAddress(v: any) {
return findField(v, 'address')
}
function showAccountNumber(v: any) {
return findField(v, 'account_number')
}
function showSequence(v: any) {
return findField(v, 'sequence')
}
function showPubkey(v: any) {
return findField(v, 'pub_key')
}
</script>
<template>
<div class=" overflow-x-auto">
<table class="table table-compact">
<thead>
<tr>
<td>Type</td>
<td>Address</td>
<td>Account Number</td>
<td>Sequence</td>
<td>Public Key</td>
</tr>
</thead>
<tr v-for="acc in accounts">
<td>{{ showType(acc['@type']) }}</td>
<td><RouterLink :to="`/${chain}/account/${showAddress(acc)}`">{{ showAddress(acc) }}</RouterLink></td>
<td>{{ showAccountNumber(acc) }}</td>
<td>{{ showSequence(acc) }}</td>
<td>{{ showPubkey(acc) }}</td>
</tr>
</table>
<PaginationBar :limit="pageRequest.limit" :total="pageResponse.total" :callback="pageload" />
</div>
</template>
<route>
{
meta: {
i18n: 'account',
order: 16
}
}
</route>

View File

@ -0,0 +1,59 @@
<script lang="ts" setup>
import { computed, ref } from '@vue/reactivity';
import { useBaseStore, useBlockchain, useFormatter } from '@/stores';
import { PageRequest, type AuthAccount, type Pagination, type Coin } from '@/types';
import { onMounted } from 'vue';
import PaginationBar from '@/components/PaginationBar.vue';
const props = defineProps(['chain']);
const format = useFormatter();
const chainStore = useBlockchain()
const list = ref([] as Coin[])
function showType(v: string) {
return v.replace("/cosmos.auth.v1beta1.", "")
}
const pageRequest = ref(new PageRequest())
const pageResponse = ref({} as Pagination)
onMounted(() => {
pageload(1)
});
function pageload(p: number) {
pageRequest.value.setPage(p)
chainStore.rpc.getBankSupply(pageRequest.value).then(x => {
list.value = x.supply
pageResponse.value = x.pagination
});
}
</script>
<template>
<div>
<table class="table">
<thead>
<tr>
<td>Token</td>
<td>Amount</td>
</tr>
</thead>
<tr v-for="item in list">
<td>{{ item.denom }}</td>
<td>{{ item.amount }}</td>
</tr>
</table>
<PaginationBar :limit="pageRequest.limit" :total="pageResponse.total" :callback="pageload" />
</div>
</template>
<route>
{
meta: {
i18n: 'supply',
order: 17
}
}
</route>

View File

@ -6,7 +6,9 @@
"governance": "社区治理", "governance": "社区治理",
"parameters": "参数", "parameters": "参数",
"uptime": "状态", "uptime": "状态",
"consensus": "Consensus" "consensus": "共识引擎",
"supply": "资产供应量",
"account": "账户列表"
}, },
"index": { "index": {
"slogan": "Ping Dashboard 是一个区块链浏览器,也是一个网页钱包,还有更多 ... 🛠", "slogan": "Ping Dashboard 是一个区块链浏览器,也是一个网页钱包,还有更多 ... 🛠",

View File

@ -10,7 +10,9 @@
"cosmwasm": "Cosmwasm", "cosmwasm": "Cosmwasm",
"widget": "Widgets", "widget": "Widgets",
"ibc": "IBC", "ibc": "IBC",
"consensus": "Consensus" "consensus": "Consensus",
"supply": "Supply",
"account": "Accounts"
}, },
"index": { "index": {
"slogan": "Ping Dashboard is not just an explorer but also a wallet and more ... 🛠", "slogan": "Ping Dashboard is not just an explorer but also a wallet and more ... 🛠",

View File

@ -5675,10 +5675,10 @@ ping-widget@^0.0.33:
vue "^3.2.47" vue "^3.2.47"
vue3-webcomponent-wrapper "^0.2.0" vue3-webcomponent-wrapper "^0.2.0"
ping-widget@^0.0.38: ping-widget@^0.0.39:
version "0.0.38" version "0.0.39"
resolved "https://registry.yarnpkg.com/ping-widget/-/ping-widget-0.0.38.tgz#ab25e3f24d1b53002c552a181431a96f4340a1e8" resolved "https://registry.yarnpkg.com/ping-widget/-/ping-widget-0.0.39.tgz#53e8807186f363c08c4921e50aa972a8be0b7a7c"
integrity sha512-x1VwKvV71Ds7BW1U4RiGCYVVb45XU4M/b09j2wpt8MdMZ8uo5y1eFnwsABJfGVQV2MuBSgXg626uhfCIBkH3TQ== integrity sha512-2PRXs+CNOA5G6Qq3bQeIENctj9h1v9ZBNfP1GQJYHfsFcAXAW0JcKcdPwbX7kEyx9gYNctUIB6NkUflHeLWAsg==
dependencies: dependencies:
"@cosmjs/amino" "^0.30.1" "@cosmjs/amino" "^0.30.1"
"@cosmjs/cosmwasm-stargate" "^0.30.1" "@cosmjs/cosmwasm-stargate" "^0.30.1"