classic-ui/components/ApproveModalBox.vue

95 lines
2.9 KiB
Vue
Raw Permalink Normal View History

2022-04-22 13:05:56 +10:00
<template>
<div class="modal-card box box-modal">
<header class="box-modal-header is-spaced">
<div class="box-modal-title">{{ $t('approvalIsRequired') }}</div>
<button type="button" class="delete" @click="$emit('close')" />
</header>
<div class="note">
{{ $t('inOrderToUse', { currency: selectedCurrency }) }}
</div>
<b-field class="withdraw-radio">
<b-radio v-model="approvalAmount" :native-value="defaultApprovalAmount" class="radio-relayer">
{{ defaultApprovalAmount }} {{ selectedCurrency }}
</b-radio>
<b-radio v-model="approvalAmount" :native-value="unlimitedValue" class="radio-metamask">
{{ $t('unlimited') }}
<b-tooltip :label="$t('unlimitedTooltip')" position="is-top" multilined>
<button class="button is-primary has-icon">
<span class="icon icon-info"></span>
</button>
</b-tooltip>
</b-radio>
</b-field>
<b-button type="is-primary is-fullwidth" :disabled="isApproveBtnAlreadyPressed" @click="_approve">
{{ $t('enable') }}
</b-button>
</div>
</template>
<script>
/* eslint-disable no-console */
import { mapActions, mapState, mapGetters } from 'vuex'
export default {
data() {
return {
success: false,
isApproveBtnAlreadyPressed: false,
unlimitedValue: 'unlimited'
}
},
computed: {
...mapState('application', ['selectedInstance']),
...mapState('token', ['allowance']),
...mapGetters('txHashKeeper', ['txExplorerUrl']),
...mapGetters('token', ['fromDecimals']),
...mapGetters('application', ['selectedCurrency']),
approvalAmount: {
get() {
return this.$store.state.token.approvalAmount
},
set(approvalAmount) {
this.$store.commit('token/SET_APPROVAL_AMOUNT', { approvalAmount })
}
},
defaultApprovalAmount() {
return this.selectedInstance.amount.toString()
}
},
mounted() {
this.approvalAmount = this.unlimitedValue
},
methods: {
...mapActions('token', ['approve']),
async _approve() {
this.isApproveBtnAlreadyPressed = true
this.$store.dispatch('loading/enable', { message: this.$t('preparingTransactionData') })
try {
await this.approve()
await this.$store.dispatch('token/fetchTokenAllowance')
this.$store.dispatch('notice/addNoticeWithInterval', {
notice: {
title: 'transactionWasSuccessfullySent',
type: 'success'
},
interval: 3000
})
this.success = true
} catch (e) {
console.error(e)
this.$store.dispatch('notice/addNoticeWithInterval', {
notice: {
untranslatedTitle: e.message,
type: 'danger'
},
interval: 5000
})
this.success = false
}
this.isApproveBtnAlreadyPressed = false
this.$store.dispatch('loading/disable')
this.$parent.close()
}
}
}
</script>