classic-ui/components/settings/SettingsModalBox.vue

74 lines
1.7 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('withdrawalSettings') }}</div>
<button type="button" class="delete" @click="$parent.cancel('escape')" />
</header>
2023-12-25 13:16:32 +00:00
<b-tabs v-if="isRelayersAvailable" v-model="withdrawType" :animated="false" class="is-modal">
2022-04-22 13:05:56 +10:00
<RelayerTab />
</b-tabs>
2023-12-25 13:16:32 +00:00
<b-tabs v-else v-model="withdrawType" :animated="false" class="is-modal">
<RelayerTab />
<WalletTab />
</b-tabs>
2022-04-22 13:05:56 +10:00
</div>
</template>
<script>
/* eslint-disable no-console */
import { mapState, mapMutations } from 'vuex'
2023-12-25 13:16:32 +00:00
import { RelayerTab, WalletTab } from '@/components/settings/tabs'
2022-04-22 13:05:56 +10:00
export default {
components: {
2023-12-25 13:16:32 +00:00
RelayerTab,
WalletTab
2022-04-22 13:05:56 +10:00
},
props: {
currency: {
type: String,
default: 'ETH'
},
title: {
type: String,
default: 'withdrawalSettings'
}
},
provide() {
return {
currency: this.currency,
save: this.save,
reset: this.reset
}
},
data() {
return {
withdrawType: 'relayer'
}
},
computed: {
...mapState('application', {
defaultWithdrawType: 'withdrawType'
2023-12-25 13:16:32 +00:00
}),
...mapState('relayer', ['isLoadingRelayers', 'validRelayers']),
isRelayersAvailable() {
return !this.isLoadingRelayers && this.validRelayers.length > 0
2023-12-25 13:16:32 +00:00
}
2022-04-22 13:05:56 +10:00
},
created() {
this.withdrawType = this.defaultWithdrawType
},
methods: {
...mapMutations('application', ['SET_WITHDRAW_TYPE']),
reset() {
this.withdrawType = 'relayer'
this.$root.$emit('resetSettings')
},
save() {
this.SET_WITHDRAW_TYPE({ withdrawType: this.withdrawType })
this.$emit('close')
}
}
}
</script>