mirror of
https://github.com/FH-Complete/FHC-Core.git
synced 2026-06-01 12:19:28 +00:00
136 lines
3.2 KiB
JavaScript
136 lines
3.2 KiB
JavaScript
/**
|
|
* Copyright (C) 2025 fhcomplete.org
|
|
*
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
import BsModal from "./Bootstrap/Modal.js";
|
|
import FhcForm from "./Form/Form.js";
|
|
import FormInput from "./Form/Input.js";
|
|
|
|
|
|
export default {
|
|
name: 'AppConfig',
|
|
components: {
|
|
BsModal,
|
|
FhcForm,
|
|
FormInput
|
|
},
|
|
emits: [
|
|
'update:modelValue'
|
|
],
|
|
props: {
|
|
modelValue: {
|
|
type: Object,
|
|
required: true
|
|
},
|
|
endpoints: {
|
|
type: Object,
|
|
required: true
|
|
}
|
|
},
|
|
data() {
|
|
return {
|
|
setup: {},
|
|
tempValues: {}
|
|
};
|
|
},
|
|
watch: {
|
|
'$p.user_language.value'(n, o) {
|
|
if (n !== o && o !== undefined && Object.keys(this.setup).length) {
|
|
this.$api
|
|
.call(this.endpoints.get())
|
|
.then(res => {
|
|
this.setup = {};
|
|
Object.keys(res.data).forEach(key => {
|
|
const binding = { ...res.data[key] };
|
|
delete binding.value;
|
|
delete binding.options;
|
|
const options = res.data[key].options;
|
|
this.setup[key] = {
|
|
binding,
|
|
options
|
|
};
|
|
});
|
|
})
|
|
.catch(this.$fhcAlert.handleSystemErrors);
|
|
}
|
|
}
|
|
|
|
},
|
|
methods: {
|
|
update() {
|
|
this.$refs.form
|
|
.call(this.endpoints.set(this.tempValues))
|
|
.then(() => {
|
|
this.$emit('update:modelValue', { ...this.tempValues });
|
|
this.$refs.modal.hide();
|
|
this.$fhcAlert.alertSuccess(this.$p.t('ui/settings_saved'));
|
|
})
|
|
.catch(this.$fhcAlert.handleSystemErrors);
|
|
}
|
|
},
|
|
created() {
|
|
this.$api
|
|
.call(this.endpoints.get())
|
|
.then(res => {
|
|
Object.keys(res.data).forEach(key => {
|
|
const binding = { ...res.data[key] };
|
|
delete binding.value;
|
|
delete binding.options;
|
|
const options = res.data[key].options;
|
|
this.tempValues[key] = res.data[key].value;
|
|
this.setup[key] = {
|
|
binding,
|
|
options
|
|
};
|
|
});
|
|
this.$emit('update:modelValue', { ...this.tempValues });
|
|
})
|
|
.catch(this.$fhcAlert.handleSystemErrors);
|
|
},
|
|
template: /* html */`
|
|
<fhc-form class="stv-config" ref="form" @submit.prevent="update">
|
|
<bs-modal
|
|
ref="modal"
|
|
class="fade"
|
|
id="configModal"
|
|
dialog-class="modal-lg"
|
|
@hidden-bs-modal="tempValues = { ...modelValue }"
|
|
>
|
|
<template #title>{{ $p.t('ui/settings') }}</template>
|
|
<template #default>
|
|
<div class="d-flex flex-column gap-5">
|
|
<form-input
|
|
v-for="(value, key) in setup"
|
|
v-model="tempValues[key]"
|
|
v-bind="value.binding"
|
|
>
|
|
<option
|
|
v-for="(label, val) in value.options"
|
|
:key="val"
|
|
:value="val"
|
|
>{{ label }}</option>
|
|
</form-input>
|
|
</div>
|
|
</template>
|
|
<template #footer>
|
|
<button class="btn btn-primary" type="submit">
|
|
{{ $p.t('ui/speichern') }}
|
|
</button>
|
|
</template>
|
|
</bs-modal>
|
|
</fhc-form>`
|
|
};
|