forked from cerc-io/cosmos-explorer
improve loading strategy
This commit is contained in:
parent
332c0416a9
commit
6b31a47969
@ -252,23 +252,33 @@ export default class ChainFetch {
|
|||||||
return this.get(`/cosmos/gov/v1beta1/proposals/${pid}/votes?pagination.key=${encodeURIComponent(next)}&pagination.limit=${limit}`)
|
return this.get(`/cosmos/gov/v1beta1/proposals/${pid}/votes?pagination.key=${encodeURIComponent(next)}&pagination.limit=${limit}`)
|
||||||
}
|
}
|
||||||
|
|
||||||
async getGovernanceList() {
|
async getGovernanceListByStatus(status) {
|
||||||
const url = this.config.chain_name === 'certik' ? '/shentu/gov/v1alpha1/proposals?pagination.limit=500' : '/cosmos/gov/v1beta1/proposals?pagination.limit=500'
|
const url = this.config.chain_name === 'certik' ? `/shentu/gov/v1alpha1/proposals?pagination.limit=100&proposal_status=${status}` : `/cosmos/gov/v1beta1/proposals?pagination.limit=100&proposal_status=${status}`
|
||||||
return Promise.all([this.get(url), this.get('/staking/pool')]).then(data => {
|
return this.get(url)
|
||||||
const pool = new StakingPool().init(commonProcess(data[1]))
|
}
|
||||||
let proposals = commonProcess(data[0])
|
|
||||||
|
async getGovernanceList(next = '') {
|
||||||
|
const url = this.config.chain_name === 'certik'
|
||||||
|
? `/shentu/gov/v1alpha1/proposals?pagination.limit=50&pagination.reverse=true&pagination.key=${next}`
|
||||||
|
: `/cosmos/gov/v1beta1/proposals?pagination.limit=50&pagination.reverse=true&pagination.key=${next}`
|
||||||
|
return this.get(url).then(data => {
|
||||||
|
// const pool = new StakingPool().init(commonProcess(data[1]))
|
||||||
|
let proposals = commonProcess(data)
|
||||||
if (Array.isArray(proposals.proposals)) {
|
if (Array.isArray(proposals.proposals)) {
|
||||||
proposals = proposals.proposals
|
proposals = proposals.proposals
|
||||||
}
|
}
|
||||||
const ret = []
|
const ret = []
|
||||||
if (proposals) {
|
if (proposals) {
|
||||||
proposals.forEach(e => {
|
proposals.forEach(e => {
|
||||||
const g = new Proposal().init(e, pool.bondedToken)
|
const g = new Proposal().init(e, 0)
|
||||||
g.versionFixed(this.config.sdk_version)
|
g.versionFixed(this.config.sdk_version)
|
||||||
ret.push(g)
|
ret.push(g)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
return ret
|
return {
|
||||||
|
proposals: ret,
|
||||||
|
pagination: data.pagination,
|
||||||
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -51,6 +51,14 @@
|
|||||||
</router-link></b-card-title>
|
</router-link></b-card-title>
|
||||||
<b-card-body md="12">
|
<b-card-body md="12">
|
||||||
<div class="gov-wrapper d-flex flex-wrap">
|
<div class="gov-wrapper d-flex flex-wrap">
|
||||||
|
<div class="gov">
|
||||||
|
<p class="card-text mb-25">
|
||||||
|
Type
|
||||||
|
</p>
|
||||||
|
<h6 class="mb-0">
|
||||||
|
{{ formatType(p.contents['@type']) }}
|
||||||
|
</h6>
|
||||||
|
</div>
|
||||||
<div class="gov">
|
<div class="gov">
|
||||||
<p class="card-text mb-25">
|
<p class="card-text mb-25">
|
||||||
Start Date
|
Start Date
|
||||||
@ -75,14 +83,6 @@
|
|||||||
{{ formatToken(p.total_deposit) || '-' }}
|
{{ formatToken(p.total_deposit) || '-' }}
|
||||||
</h6>
|
</h6>
|
||||||
</div>
|
</div>
|
||||||
<div class="gov">
|
|
||||||
<p class="card-text mb-25">
|
|
||||||
Turnout
|
|
||||||
</p>
|
|
||||||
<h6 class="mb-0">
|
|
||||||
{{ percent(p.tally.turnout) }}%
|
|
||||||
</h6>
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
</b-card-body>
|
</b-card-body>
|
||||||
|
|
||||||
@ -177,6 +177,18 @@
|
|||||||
</b-card>
|
</b-card>
|
||||||
</b-col>
|
</b-col>
|
||||||
</b-row>
|
</b-row>
|
||||||
|
<b-row v-if="next">
|
||||||
|
<b-col>
|
||||||
|
<b-button
|
||||||
|
block
|
||||||
|
variant="outline-primary"
|
||||||
|
:disabled="loading"
|
||||||
|
@click="getList()"
|
||||||
|
>
|
||||||
|
Load More
|
||||||
|
</b-button>
|
||||||
|
</b-col>
|
||||||
|
</b-row>
|
||||||
<operation-modal
|
<operation-modal
|
||||||
:type="operationModalType"
|
:type="operationModalType"
|
||||||
:proposal-id="selectedProposalId"
|
:proposal-id="selectedProposalId"
|
||||||
@ -190,7 +202,6 @@ import {
|
|||||||
BCard, BCardTitle, BCardBody, BCardFooter, BButton, BProgressBar, BProgress, BBadge, BTooltip, BRow, BCol, VBModal,
|
BCard, BCardTitle, BCardBody, BCardFooter, BButton, BProgressBar, BProgress, BBadge, BTooltip, BRow, BCol, VBModal,
|
||||||
} from 'bootstrap-vue'
|
} from 'bootstrap-vue'
|
||||||
import Ripple from 'vue-ripple-directive'
|
import Ripple from 'vue-ripple-directive'
|
||||||
import { Proposal } from '@/libs/data'
|
|
||||||
import { percent, tokenFormatter } from '@/libs/utils'
|
import { percent, tokenFormatter } from '@/libs/utils'
|
||||||
import dayjs from 'dayjs'
|
import dayjs from 'dayjs'
|
||||||
import OperationModal from '@/views/components/OperationModal/index.vue'
|
import OperationModal from '@/views/components/OperationModal/index.vue'
|
||||||
@ -218,15 +229,21 @@ export default {
|
|||||||
return {
|
return {
|
||||||
selectedProposalId: 0,
|
selectedProposalId: 0,
|
||||||
selectedTitle: '',
|
selectedTitle: '',
|
||||||
proposals: [new Proposal()],
|
proposals: [],
|
||||||
max: 1,
|
max: 1,
|
||||||
operationModalType: '',
|
operationModalType: '',
|
||||||
|
next: null,
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
mounted() {
|
mounted() {
|
||||||
this.getList()
|
this.getList()
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
|
formatType(v) {
|
||||||
|
const txt = String(v).replace('Proposal', '')
|
||||||
|
const index = txt.lastIndexOf('.')
|
||||||
|
return index > 0 ? txt.substring(index + 1) : txt
|
||||||
|
},
|
||||||
percent: v => percent(v),
|
percent: v => percent(v),
|
||||||
formatDate: v => dayjs(v).format('YYYY-MM-DD'),
|
formatDate: v => dayjs(v).format('YYYY-MM-DD'),
|
||||||
formatToken: v => tokenFormatter(v, {}),
|
formatToken: v => tokenFormatter(v, {}),
|
||||||
@ -236,25 +253,31 @@ export default {
|
|||||||
this.selectedTitle = title
|
this.selectedTitle = title
|
||||||
},
|
},
|
||||||
getList() {
|
getList() {
|
||||||
this.$http.getGovernanceList().then(res => {
|
this.loading = true
|
||||||
const voting = res.filter(i => i.status === 2)
|
this.$http.getGovernanceList(this.next).then(res => {
|
||||||
if (voting.length > 0) {
|
this.proposals = this.proposals.concat(res.proposals)
|
||||||
let i = 0
|
this.updateTally(this.proposals)
|
||||||
Promise.all(voting.reverse().map(p => this.$http.getGovernanceTally(p.id, p.tally.total))).then(update => {
|
this.next = res.pagination.next_key
|
||||||
this.proposals.map(x => {
|
this.loading = false
|
||||||
if (x.status === 2) {
|
|
||||||
const xh = x
|
|
||||||
xh.tally = update[i]
|
|
||||||
i += 1
|
|
||||||
return xh
|
|
||||||
}
|
|
||||||
return x
|
|
||||||
})
|
|
||||||
})
|
|
||||||
}
|
|
||||||
this.proposals = res.reverse()
|
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
|
updateTally(res) {
|
||||||
|
const voting = res.filter(i => i.status === 2)
|
||||||
|
if (voting.length > 0) {
|
||||||
|
let i = 0
|
||||||
|
Promise.all(voting.reverse().map(p => this.$http.getGovernanceTally(p.id, 0))).then(update => {
|
||||||
|
this.proposals.map(x => {
|
||||||
|
if (x.status === 2) {
|
||||||
|
const xh = x
|
||||||
|
xh.tally = update[i]
|
||||||
|
i += 1
|
||||||
|
return xh
|
||||||
|
}
|
||||||
|
return x
|
||||||
|
})
|
||||||
|
})
|
||||||
|
}
|
||||||
|
},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
Loading…
Reference in New Issue
Block a user