<template> <div class="column is-half"> <div class="box-stats"> <div class="tab-with-corner is-left-top"> {{ $t('statistics') }} <span class="selected" ><NumberFormat :value="selectedStatistic.amount" /> {{ selectedStatisticCurrency }}</span > </div> <div class="box"> <div class="label"> {{ $t('anonymitySet') }} <b-tooltip :label="$t('anonymitySetTooltip')" size="is-medium" position="is-top" multilined> <button class="button is-primary has-icon"> <span class="icon icon-info"></span> </button> </b-tooltip> </div> <div class="field"> <i18n v-if="anonimitySet" path="equalUserDeposit"> <span v-if="anonimitySet > 1 && anonimitySet < 5" slot="only">{{ $t('only') }}</span> <b v-if="anonimitySet > 1" slot="n">{{ Number(anonimitySet) }}</b> <span slot="equalUserDepositText">{{ $tc('equalUserDepositPlural', Number(anonimitySet)) }}</span> </i18n> <b-skeleton size="is-large" :active="!anonimitySet" width="200"></b-skeleton> </div> <template v-if="anonimitySet != 0"> <div class="label">{{ $t('latestDeposits') }}</div> <div v-if="latestDeposits && latestDeposits.length" class="columns is-small is-multiline"> <div class="column is-half-small"> <div class="deposits"> <div v-for="{ index, depositTime } in latestDeposits.slice(0, 5)" :key="index" class="row"> <div class="value">{{ Number(index) + 1 }}.</div> <div class="data">{{ depositTime }}</div> </div> </div> </div> <div class="column is-half-small"> <div class="deposits"> <div v-for="{ index, depositTime } in latestDeposits.slice(5, 10)" :key="index" class="row"> <div class="value">{{ Number(index) + 1 }}.</div> <div class="data">{{ depositTime }}</div> </div> </div> </div> </div> <div v-else class="columns is-small is-multiline"> <div class="column is-half-small"> <div class="deposits"> <b-skeleton size="is-large"></b-skeleton> <b-skeleton size="is-large"></b-skeleton> <b-skeleton size="is-large"></b-skeleton> <b-skeleton size="is-large"></b-skeleton> <b-skeleton size="is-large"></b-skeleton> </div> </div> <div class="column is-half-small"> <div class="deposits"> <b-skeleton size="is-large"></b-skeleton> <b-skeleton size="is-large"></b-skeleton> <b-skeleton size="is-large"></b-skeleton> <b-skeleton size="is-large"></b-skeleton> <b-skeleton size="is-large"></b-skeleton> </div> </div> </div> </template> </div> </div> </div> </template> <script> /* eslint-disable no-console */ import { mapState, mapGetters } from 'vuex' import NumberFormat from '@/components/NumberFormat' export default { components: { NumberFormat }, data() { return { timer: null } }, computed: { ...mapState('application', ['ip', 'statistic', 'selectedStatistic']), ...mapGetters('metamask', ['networkConfig']), ...mapGetters('application', ['selectedStatisticCurrency', 'latestDeposits']), anonimitySet() { const currency = this.selectedStatistic.currency.toLowerCase() return this.statistic[currency][this.selectedStatistic.amount].anonymitySet } }, mounted() { this.updateEvents() }, beforeDestroy() { clearTimeout(this.timer) }, methods: { updateEvents() { this.$store.dispatch('application/updateSelectEvents') } } } </script>