forked from cerc-io/cosmos-explorer
52 lines
1.4 KiB
Vue
52 lines
1.4 KiB
Vue
<script lang="ts" setup>
|
|
import { fromBase64, toBase64 } from '@cosmjs/encoding';
|
|
import { decodeTxRaw } from '@cosmjs/proto-signing';
|
|
import { computed } from '@vue/reactivity';
|
|
import { hashTx } from '@/libs';
|
|
import { useBlockchain, useFormatter } from '@/stores';
|
|
const props = defineProps({
|
|
value: { type: Array<string> },
|
|
});
|
|
|
|
const txs = computed(() => {
|
|
return props.value?.map((x) => ({
|
|
hash: hashTx(fromBase64(x)),
|
|
tx: decodeTxRaw(fromBase64(x)),
|
|
})) || []
|
|
});
|
|
|
|
const format = useFormatter();
|
|
const chain = useBlockchain();
|
|
</script>
|
|
<template>
|
|
<div class="overflow-x-auto mt-4">
|
|
<table class="table w-full" density="compact" v-if="txs.length > 0">
|
|
<thead>
|
|
<tr>
|
|
<th style="position: relative; z-index: 2;">Hash</th>
|
|
<th>Msgs</th>
|
|
<th>Memo</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody class="text-sm">
|
|
<tr v-for="item in txs">
|
|
<td>
|
|
<RouterLink :to="`/${chain.chainName}/tx/${item.hash}`" class="text-primary dark:invert">{{
|
|
item.hash
|
|
}}</RouterLink>
|
|
</td>
|
|
<td>
|
|
{{
|
|
format.messages(
|
|
item.tx.body.messages.map((x) => ({ '@type': x.typeUrl }))
|
|
)
|
|
}}
|
|
</td>
|
|
<td>{{ item.tx.body.memo }}</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
<div v-else class="text-center">No Transactions</div>
|
|
</div>
|
|
</template>
|