Files
certd/packages/ui/certd-client/src/views/sys/settings/tabs/mode.vue
T

71 lines
1.9 KiB
Vue
Raw Normal View History

2026-02-04 15:49:01 +08:00
<template>
<div class="sys-settings-form sys-settings-mode">
<a-form :model="formState" name="basic" :label-col="{ span: 8 }" :wrapper-col="{ span: 16 }" autocomplete="off" @finish="onFinish">
<a-form-item :label="t('certd.sys.setting.adminMode')" :name="['public', 'adminMode']">
2026-02-05 19:01:03 +08:00
<fs-dict-radio v-model:value="formState.public.adminMode" :dict="adminModeDict" />
2026-02-04 15:49:01 +08:00
</a-form-item>
<a-form-item label=" " :colon="false" :wrapper-col="{ span: 8 }">
<a-button :loading="saveLoading" type="primary" html-type="submit">{{ t("certd.saveButton") }}</a-button>
</a-form-item>
</a-form>
</div>
</template>
<script setup lang="tsx">
import { reactive, ref } from "vue";
import { SysSettings } from "/@/views/sys/settings/api";
import * as api from "/@/views/sys/settings/api";
import { merge } from "lodash-es";
import { useSettingStore } from "/@/store/settings";
import { notification } from "ant-design-vue";
import { useI18n } from "/src/locales";
2026-02-05 19:01:03 +08:00
import { dict } from "@fast-crud/fast-crud";
2026-02-04 15:49:01 +08:00
const { t } = useI18n();
defineOptions({
name: "SettingMode",
});
2026-02-05 19:01:03 +08:00
const adminModeDict = dict({
data: [
{
label: t("certd.sys.setting.enterpriseMode"),
2026-02-05 19:01:03 +08:00
value: "enterprise",
},
{
label: t("certd.sys.setting.saasMode"),
2026-02-05 19:01:03 +08:00
value: "saas",
},
],
});
2026-02-04 15:49:01 +08:00
const formState = reactive<Partial<SysSettings>>({
public: {},
private: {},
});
async function loadSysSettings() {
const data: any = await api.SysSettingsGet();
merge(formState, data);
}
const saveLoading = ref(false);
loadSysSettings();
const settingsStore = useSettingStore();
const onFinish = async (form: any) => {
try {
saveLoading.value = true;
await api.SysSettingsSave(form);
await settingsStore.loadSysSettings();
notification.success({
message: t("certd.saveSuccess"),
});
} finally {
saveLoading.value = false;
}
};
</script>
<style lang="less"></style>