feat: progress voter status add

This commit is contained in:
Alisa | Side.one 2023-05-16 23:42:02 +08:00
parent bbd408393a
commit ea4fed9b4f
4 changed files with 85 additions and 15 deletions

View File

@ -1,14 +1,19 @@
<script lang="ts" setup> <script lang="ts" setup>
import { useBlockchain, useFormatter, useStakingStore } from '@/stores'; import {
useBlockchain,
useFormatter,
useStakingStore,
useWalletStore,
useTxDialog
} from '@/stores';
import { select } from '@/components/dynamic/index'; import { select } from '@/components/dynamic/index';
import type { PaginatedProposals } from '@/types'; import type { PaginatedProposals } from '@/types';
import ProposalProcess from './ProposalProcess.vue'; import ProposalProcess from './ProposalProcess.vue';
import type { PropType } from 'vue'; import type { PropType } from 'vue';
import { ref } from 'vue'; import { ref } from 'vue';
const dialog = useTxDialog();
defineProps({ defineProps({
proposals: { type: Object as PropType<PaginatedProposals> }, proposals: { type: Object as PropType<PaginatedProposals> },
votable: { type: Boolean, default: false }
}); });
const format = useFormatter(); const format = useFormatter();
@ -26,17 +31,23 @@ const statusMap: Record<string, string> = {
PROPOSAL_STATUS_PASSED: 'PASSED', PROPOSAL_STATUS_PASSED: 'PASSED',
PROPOSAL_STATUS_REJECTED: 'REJECTED', PROPOSAL_STATUS_REJECTED: 'REJECTED',
}; };
const voterStatusMap: Record<string, string> = {
No_With_Veto: '',
VOTE_OPTION_YES: 'success',
VOTE_OPTION_NO: 'error',
VOTE_OPTION_ABSTAIN: 'warning',
};
const proposalInfo = ref(); const proposalInfo = ref();
</script> </script>
<template> <template>
<div class="bg-white dark:bg-[#28334e] rounded text-sm"> <div class="bg-white dark:bg-[#28334e] rounded text-sm">
<table class="table-compact w-full table-fixed lg:table"> <table class="table-compact w-full table-fixed hidden lg:table">
<tbody> <tbody>
<tr v-for="(item, index) in proposals?.proposals" :key="index"> <tr v-for="(item, index) in proposals?.proposals" :key="index">
<td class="px-4 w-20"> <td class="px-4 w-20">
<label <label
for="" for="proposal-detail-modal"
class="text-main text-base hover:text-indigo-400 cursor-pointer" class="text-main text-base hover:text-indigo-400 cursor-pointer"
@click="proposalInfo = item" @click="proposalInfo = item"
> >
@ -98,9 +109,25 @@ const proposalInfo = ref();
</div> </div>
</td> </td>
<td v-if="votable"> <td v-if="statusMap?.[item?.status] === 'VOTING'">
<div> <div class="" v-show="item?.voterStatus === 'No With Veto'">
<button class="btn btn-xs btn-primary rounded-sm">Vote</button> <label
for="vote"
class="btn btn-xs btn-primary rounded-sm"
@click="dialog.open('vote', { proposal_id: item?.proposal_id })"
>Vote</label
>
<div
class="text-xs truncate relative py-1 px-3 rounded-full w-fit"
:class="`text-${voterStatusMap?.[item?.voterStatus]}`"
v-show="item?.voterStatus !== 'No With Veto'"
>
<span
class="inset-x-0 inset-y-0 opacity-10 absolute"
:class="`bg-${voterStatusMap?.[item?.voterStatus]}`"
></span>
{{ item?.voterStatus }}
</div>
</div> </div>
</td> </td>
</tr> </tr>
@ -176,8 +203,26 @@ const proposalInfo = ref();
></ProposalProcess> ></ProposalProcess>
</div> </div>
<div class="mt-4"> <div class="mt-4" v-if="statusMap?.[item?.status] === 'VOTING'">
<button class="btn btn-xs btn-primary rounded-sm px-4">Vote</button> <div class="" v-show="item?.voterStatus === 'No With Veto'">
<label
for="vote"
class="btn btn-xs btn-primary rounded-sm"
@click="dialog.open('vote', { proposal_id: item?.proposal_id })"
>Vote</label
>
<div
class="text-xs truncate relative py-1 px-3 rounded-full w-fit"
:class="`text-${voterStatusMap?.[item?.voterStatus]}`"
v-show="item?.voterStatus !== 'No With Veto'"
>
<span
class="inset-x-0 inset-y-0 opacity-10 absolute"
:class="`bg-${voterStatusMap?.[item?.voterStatus]}`"
></span>
{{ item?.voterStatus }}
</div>
</div>
</div> </div>
</div> </div>
</div> </div>

View File

@ -41,7 +41,7 @@ const changeTab = (val: '2' | '3' | '4') => {
>Rejected</a >Rejected</a
> >
</div> </div>
<ProposalListItem :proposals="store?.proposals[tab]" :votable="tab === '2'" /> <ProposalListItem :proposals="store?.proposals[tab]"/>
</div> </div>
</template> </template>
<route> <route>

View File

@ -2,6 +2,7 @@ import { defineStore } from 'pinia';
import { useBlockchain } from './useBlockchain'; import { useBlockchain } from './useBlockchain';
import type { PageRequest, PaginatedProposals } from '@/types'; import type { PageRequest, PaginatedProposals } from '@/types';
import { LoadingStatus } from './useDashboard'; import { LoadingStatus } from './useDashboard';
import { useWalletStore } from './useWalletStore'
import { reactive } from 'vue'; import { reactive } from 'vue';
export const useGovStore = defineStore('govStore', { export const useGovStore = defineStore('govStore', {
@ -20,6 +21,9 @@ export const useGovStore = defineStore('govStore', {
blockchain() { blockchain() {
return useBlockchain(); return useBlockchain();
}, },
walletstore() {
return useWalletStore();
}
}, },
actions: { actions: {
initial() { initial() {
@ -34,12 +38,29 @@ export const useGovStore = defineStore('govStore', {
await this.blockchain.rpc?.getGovProposals(status) await this.blockchain.rpc?.getGovProposals(status)
); );
if (status === '2') { if (status === '2') {
proposals?.proposals?.forEach(async (x1) => { proposals?.proposals?.forEach(async (item) => {
await this.fetchTally(x1.proposal_id).then((res) => { await this.fetchTally(item.proposal_id).then((res) => {
x1.final_tally_result = res?.tally; item.final_tally_result = res?.tally;
//
}); });
if (this.walletstore.connectedWallet?.cosmosAddress) {
try {
await this.fetchProposalVotesVoter(item.proposal_id,this.walletstore.currentAddress).then((res) => {
console.log(res, 'fdfsds')
// VOTE_OPTION_YES VOTE_OPTION_NO VOTE_OPTION_ABSTAIN
item.voterStatus = res?.vote?.option || 'No With Veto'
});
} catch (error) {
item.voterStatus = 'No With Veto'
}
console.log(this.walletstore.connectedWallet, 'this.walletstore.connectedWallet')
} else {
item.voterStatus = 'No With Veto'
}
}); });
} }
this.loading[status] = LoadingStatus.Loaded; this.loading[status] = LoadingStatus.Loaded;
this.proposals[status] = proposals; this.proposals[status] = proposals;
} }
@ -62,5 +83,8 @@ export const useGovStore = defineStore('govStore', {
async fetchProposalVotes(proposalId: string, next_key?: string) { async fetchProposalVotes(proposalId: string, next_key?: string) {
return this.blockchain.rpc.getGovProposalVotes(proposalId, next_key); return this.blockchain.rpc.getGovProposalVotes(proposalId, next_key);
}, },
async fetchProposalVotesVoter(proposalId: string, voter: string) {
return this.blockchain.rpc.getGovProposalVotesVoter(proposalId, voter);
},
}, },
}); });

View File

@ -44,7 +44,8 @@ export interface GovProposal {
"total_deposit": Coin[], "total_deposit": Coin[],
"voting_start_time": string, "voting_start_time": string,
"voting_end_time": string, "voting_end_time": string,
"is_expedited": boolean "is_expedited": boolean,
"voterStatus"?: string,
} }
export interface Tally { export interface Tally {