diff options
Diffstat (limited to 'src/views/Settings')
-rw-r--r-- | src/views/Settings/PowerRestorePolicy/PowerRestorePolicy.vue | 35 |
1 files changed, 23 insertions, 12 deletions
diff --git a/src/views/Settings/PowerRestorePolicy/PowerRestorePolicy.vue b/src/views/Settings/PowerRestorePolicy/PowerRestorePolicy.vue index 8589aed3..06e30f3e 100644 --- a/src/views/Settings/PowerRestorePolicy/PowerRestorePolicy.vue +++ b/src/views/Settings/PowerRestorePolicy/PowerRestorePolicy.vue @@ -5,15 +5,11 @@ <b-row> <b-col sm="8" md="6" xl="12"> <b-form-group :label="$t('pagePowerRestorePolicy.powerPoliciesLabel')"> - <b-form-radio - v-for="policy in powerRestorePolicies" - :key="policy.state" + <b-form-radio-group v-model="currentPowerRestorePolicy" - :value="policy.state" + :options="options" name="power-restore-policy" - > - {{ policy.desc }} - </b-form-radio> + ></b-form-radio-group> </b-form-group> </b-col> </b-row> @@ -41,6 +37,7 @@ export default { data() { return { policyValue: null, + options: [], }; }, computed: { @@ -58,12 +55,24 @@ export default { }, created() { this.startLoader(); - Promise.all([ - this.$store.dispatch('powerPolicy/getPowerRestorePolicies'), - this.$store.dispatch('powerPolicy/getPowerRestoreCurrentPolicy'), - ]).finally(() => this.endLoader()); + this.renderPowerRestoreSettings(); }, methods: { + renderPowerRestoreSettings() { + Promise.all([ + this.$store.dispatch('powerPolicy/getPowerRestorePolicies'), + this.$store.dispatch('powerPolicy/getPowerRestoreCurrentPolicy'), + ]).finally(() => { + this.options.length = 0; + this.powerRestorePolicies.map((item) => { + this.options.push({ + text: this.$t(`pagePowerRestorePolicy.policiesDesc.${item.state}`), + value: `${item.state}`, + }); + }); + this.endLoader(); + }); + }, submitForm() { this.startLoader(); this.$store @@ -73,7 +82,9 @@ export default { ) .then((message) => this.successToast(message)) .catch(({ message }) => this.errorToast(message)) - .finally(() => this.endLoader()); + .finally(() => { + this.renderPowerRestoreSettings(); + }); }, }, }; |