horse soft 基础框架前端界面
autumnal_wind@yeah.net
2024-05-27 a2b49c059a7afb0ea602b89d371a85d8c845fdb6
src/views/basis/sysParam/config/DetailForm.vue
@@ -1,6 +1,6 @@
<template>
  <div class="p-2">
    <dialog :title="dialog.title" :model="dialog.visible" width="500px">
    <Dialog :title="dialog.title" v-model="dialog.visible" width="600px" :draggable="draggable">
      <el-form ref="formRef" :model="formData" :rules="formRules" label-width="80px" v-loading="formLoading">
        <el-form-item label="参数名称" prop="configName">
          <el-input v-model="formData.configName" placeholder="请输入参数名称"/>
@@ -21,12 +21,10 @@
        </el-form-item>
      </el-form>
      <template #footer>
        <div class="dialog-footer">
          <el-button @click="submitForm" type="primary" :disabled="formLoading">确 定</el-button>
          <el-button @click="dialog.visible = false">取 消</el-button>
        </div>
        <el-button :disabled="formLoading" type="primary" @click="submitForm">确 定</el-button>
        <el-button @click="dialog.visible = false">取 消</el-button>
      </template>
    </dialog>
    </Dialog>
  </div>
</template>
@@ -34,22 +32,32 @@
// 模块导入
import {ConfigForm} from "@/api/system/config/types";
import {addConfig, getConfig, updateConfig} from "@/api/system/config";
import {useI18n} from "vue-i18n";
// 接收父组件传入属性
// const props = defineProps({})
// 当前组件属性
const { proxy } = getCurrentInstance() as ComponentInternalInstance;
const {proxy} = getCurrentInstance() as ComponentInternalInstance;
// 国际化
const { t } = useI18n()
// 数据字典
const {sys_yes_no} = toRefs<any>(proxy?.useDict("sys_yes_no"));
// 对话框
const dialog = reactive<DialogOption>({
  visible: false,
  title: ''
});
// 窗体是否可以拖动
const draggable = ref(true)
// 表单的加载中:1)修改时的数据加载;2)提交的按钮禁用
const formLoading = ref(false)
// 表单的类型:create - 新增;update - 修改
const formType = ref('')
// 表单引用
const formRef = ref<ElFormInstance>();
// 表单数据
const formData = ref<ConfigForm>({
  configId: undefined,
  configName: '',
@@ -58,17 +66,18 @@
  configType: "Y",
  remark: ''
})
// 表单校验规则
const formRules = reactive({
  configName: [{ required: true, message: "参数名称不能为空", trigger: "blur" }],
  configKey: [{ required: true, message: "参数键名不能为空", trigger: "blur" }],
  configValue: [{ required: true, message: "参数键值不能为空", trigger: "blur" }]
  configName: [{required: true, message: "参数名称不能为空", trigger: "blur"}],
  configKey: [{required: true, message: "参数键名不能为空", trigger: "blur"}],
  configValue: [{required: true, message: "参数键值不能为空", trigger: "blur"}]
})
/** 当前组件方法 */
/** 窗体打开事件 */
const open = async (type: string, id?: number) => {
  dialog.visible = true
  dialog.title = type
  dialog.title = t('action.' + type)
  formType.value = type
  resetForm()
  // 修改时,设置数据
@@ -96,7 +105,7 @@
}
// 传回给父组件的属性与方法
// 提供 open 方法,用于打开弹窗
  defineExpose({open})
defineExpose({open})
/** 触发父组件的事件 */
/** 定义 success 事件,用于操作成功后的回调 */