forked from cerc-io/cosmos-explorer
feat: Uptime
This commit is contained in:
parent
5f2f06068c
commit
24f2969e6e
@ -23,8 +23,8 @@ const bars = computed(() => {
|
|||||||
});
|
});
|
||||||
</script>
|
</script>
|
||||||
<template>
|
<template>
|
||||||
<div class="d-flex justify-evenly">
|
<div class="flex items-center justify-evenly">
|
||||||
<span v-for="(b, i) in bars" :key="i" :class="b.color" style="width: 1.5%"
|
<span v-for="(b, i) in bars" :key="i" :class="b.color" class="rounded" style="width: 1.5%"
|
||||||
>
|
>
|
||||||
<v-tooltip
|
<v-tooltip
|
||||||
v-if="Number(b.height) > 0"
|
v-if="Number(b.height) > 0"
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
<script lang="ts" setup>
|
<script lang="ts" setup>
|
||||||
import { ref, onMounted, computed, watchEffect } from 'vue';
|
import { ref, onMounted, computed, watchEffect } from 'vue';
|
||||||
import { fromHex, toBase64 } from '@cosmjs/encoding';
|
import { fromHex, toBase64 } from '@cosmjs/encoding';
|
||||||
|
import { Icon } from '@iconify/vue';
|
||||||
import {
|
import {
|
||||||
useFormatter,
|
useFormatter,
|
||||||
useStakingStore,
|
useStakingStore,
|
||||||
@ -88,35 +89,23 @@ watchEffect(() => {
|
|||||||
</script>
|
</script>
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
<div>
|
<div class="bg-base-100 px-5 pt-5">
|
||||||
<VRow>
|
<div class="flex items-center gap-x-4">
|
||||||
<VCol cols="12" md="4">
|
<div class="text-main text-lg">Current Height: {{ latest.block?.header?.height }}</div>
|
||||||
<VCard class="h-full self-center d-flex p-4">
|
<input
|
||||||
<div class="self-center">
|
type="text"
|
||||||
Current Height: {{ latest.block?.header?.height }}
|
v-model="keyword"
|
||||||
</div>
|
placeholder="Keywords to filter validators"
|
||||||
</VCard>
|
class="input input-sm w-full flex-1"
|
||||||
</VCol>
|
/>
|
||||||
<VCol cols="12" md="8" class="">
|
<button class="btn btn-primary btn-sm">
|
||||||
<VTextField
|
<Icon icon="mdi-star" class="mr-2 text-lg" /> <span class="">Favorite</span>
|
||||||
v-model="keyword"
|
</button>
|
||||||
label="Keywords to filter validators"
|
</div>
|
||||||
variant="outlined"
|
|
||||||
>
|
|
||||||
<template v-slot:append>
|
|
||||||
<VBtn
|
|
||||||
><VIcon icon="mdi-star" /><span class="d-none d-md-block"
|
|
||||||
>Favorite</span
|
|
||||||
></VBtn
|
|
||||||
>
|
|
||||||
</template>
|
|
||||||
</VTextField>
|
|
||||||
</VCol>
|
|
||||||
</VRow>
|
|
||||||
|
|
||||||
<VRow>
|
<div class="grid grid-cols-2 md:grid-cols-3 xl:grid-cols-4 gap-4 mt-4">
|
||||||
<VCol v-for="(v, i) in validators" cols="12" md="3" xl="2" class="py-0">
|
<div v-for="(v, i) in validators">
|
||||||
<div class="d-flex justify-between">
|
<div class="flex items-center justify-between">
|
||||||
<VCheckbox
|
<VCheckbox
|
||||||
v-model="selected"
|
v-model="selected"
|
||||||
color="warning"
|
color="warning"
|
||||||
@ -128,26 +117,26 @@ watchEffect(() => {
|
|||||||
>
|
>
|
||||||
</template>
|
</template>
|
||||||
</VCheckbox>
|
</VCheckbox>
|
||||||
<VChip
|
<div
|
||||||
v-if="
|
v-if="
|
||||||
Number(
|
Number(
|
||||||
signingInfo[consensusPubkeyToHexAddress(v.consensus_pubkey)]
|
signingInfo[consensusPubkeyToHexAddress(v.consensus_pubkey)]
|
||||||
?.missed_blocks_counter || 0
|
?.missed_blocks_counter || 0
|
||||||
) > 0
|
) > 0
|
||||||
"
|
"
|
||||||
size="small"
|
class="badge badge-error badge-sm text-white"
|
||||||
class="mt-1"
|
>
|
||||||
label
|
{{
|
||||||
color="error"
|
|
||||||
>{{
|
|
||||||
signingInfo[consensusPubkeyToHexAddress(v.consensus_pubkey)]
|
signingInfo[consensusPubkeyToHexAddress(v.consensus_pubkey)]
|
||||||
?.missed_blocks_counter
|
?.missed_blocks_counter
|
||||||
}}</VChip
|
}}
|
||||||
>
|
</div>
|
||||||
<VChip v-else size="small" class="mt-1" label color="success">{{
|
<div v-else class="mt-1 badge badge-sm text-white bg-yes">
|
||||||
signingInfo[consensusPubkeyToHexAddress(v.consensus_pubkey)]
|
{{
|
||||||
?.missed_blocks_counter
|
signingInfo[consensusPubkeyToHexAddress(v.consensus_pubkey)]
|
||||||
}}</VChip>
|
?.missed_blocks_counter
|
||||||
|
}}
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<UptimeBar
|
<UptimeBar
|
||||||
:blocks="commits"
|
:blocks="commits"
|
||||||
@ -155,8 +144,10 @@ watchEffect(() => {
|
|||||||
toBase64(fromHex(consensusPubkeyToHexAddress(v.consensus_pubkey)))
|
toBase64(fromHex(consensusPubkeyToHexAddress(v.consensus_pubkey)))
|
||||||
"
|
"
|
||||||
/>
|
/>
|
||||||
</VCol>
|
</div>
|
||||||
</VRow>
|
</div>
|
||||||
|
|
||||||
|
<div class="h-6"></div>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
<route>
|
<route>
|
||||||
|
Loading…
Reference in New Issue
Block a user