blob: bf92b173cf225be19a63d110339e35b016443dc8 [file] [log] [blame]
<template>
<b-modal
id="modal-reset"
ref="modal"
:title="$t(`pageFactoryReset.modal.${resetType}Title`)"
title-tag="h2"
@hidden="resetConfirm"
>
<p class="mb-2">
<strong>{{ $t(`pageFactoryReset.modal.${resetType}Header`) }}</strong>
</p>
<ul class="pl-3 mb-4">
<li
v-for="(item, index) in $t(
`pageFactoryReset.modal.${resetType}SettingsList`
)"
:key="index"
class="mt-1 mb-1"
>
{{ $t(item) }}
</li>
</ul>
<!-- Warning message -->
<template v-if="!isHostOff">
<p class="d-flex mb-2">
<status-icon status="danger" />
<span id="reset-to-default-warning" class="ml-1">
{{ $t(`pageFactoryReset.modal.resetWarningMessage`) }}
</span>
</p>
<b-form-checkbox
v-model="confirm"
aria-describedby="reset-to-default-warning"
@input="$v.confirm.$touch()"
>
{{ $t(`pageFactoryReset.modal.resetWarningCheckLabel`) }}
</b-form-checkbox>
<b-form-invalid-feedback
role="alert"
:state="getValidationState($v.confirm)"
>
{{ $t('global.form.fieldRequired') }}
</b-form-invalid-feedback>
</template>
<template #modal-footer="{ cancel }">
<b-button
variant="secondary"
data-test-id="factoryReset-button-cancel"
@click="cancel()"
>
{{ $t('global.action.cancel') }}
</b-button>
<b-button
type="sumbit"
variant="primary"
data-test-id="factoryReset-button-confirm"
@click="handleConfirm"
>
{{ $t(`pageFactoryReset.modal.${resetType}SubmitText`) }}
</b-button>
</template>
</b-modal>
</template>
<script>
import StatusIcon from '@/components/Global/StatusIcon';
import VuelidateMixin from '@/components/Mixins/VuelidateMixin';
export default {
components: { StatusIcon },
mixins: [VuelidateMixin],
props: {
resetType: {
type: String,
default: null,
},
},
data() {
return {
confirm: false,
};
},
computed: {
hostStatus() {
return this.$store.getters['global/hostStatus'];
},
isHostOff() {
return this.hostStatus === 'off' ? true : false;
},
},
validations: {
confirm: {
mustBeTrue: function (value) {
return this.isHostOff || value === true;
},
},
},
methods: {
handleConfirm() {
this.$v.$touch();
if (this.$v.$invalid) return;
this.$emit('okConfirm');
this.$nextTick(() => this.$refs.modal.hide());
this.resetConfirm();
},
resetConfirm() {
this.confirm = false;
this.$v.$reset();
},
},
};
</script>