|
|
|
<template>
|
|
|
|
<div class="modify-form">
|
|
|
|
<el-form label-position="right" :class="class" :label-width="width ? width + 'px' : ''" :model="param"
|
|
|
|
ref="modifyForm" :rules="rules">
|
|
|
|
<el-form-item v-for="item in items" :label="item.name || t(item.i18n)" :prop="item.code">
|
|
|
|
<NoobSelect v-if="item.dict || item.maxValue" v-model="param[item.code]" :dict="item.dict"
|
|
|
|
:max-value="item.maxValue" full :placeholder="t('rule.pleaseSelect') + (item.name || t(item.i18n))"
|
|
|
|
:disabled="item.disabled" />
|
|
|
|
<NoobDate v-else-if="item.date" v-model="param[item.code]" :formater="item.formater" full
|
|
|
|
:placeholder="t('rule.pleaseSelect') + (item.name || t(item.i18n))" :disabled="item.disabled" />
|
|
|
|
<slot v-else-if="item.slot" :name="item.code" />
|
|
|
|
<NoobInput v-else v-model="param[item.code]" full :type="item.type"
|
|
|
|
:placeholder="t('rule.pleaseEnter') + (item.name || t(item.i18n))" :disabled="item.disabled" />
|
|
|
|
</el-form-item>
|
|
|
|
<slot></slot>
|
|
|
|
<el-form-item class="form-btns">
|
|
|
|
<NoobButton type="primary" @click="formConfirm">{{ t('base.confirm') }}</NoobButton>
|
|
|
|
<NoobButton type="info" @click="emit('cancel')">{{ t('base.cancel') }}</NoobButton>
|
|
|
|
</el-form-item>
|
|
|
|
</el-form>
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script lang="ts" setup>
|
|
|
|
import { onMounted, ref, watch } from "vue";
|
|
|
|
import { FormInstance } from "element-plus";
|
|
|
|
import { useI18n } from 'vue3-i18n';
|
|
|
|
import { NoobSelect, NoobInput, NoobDate, NoobButton } from "noob-mengyxu";
|
|
|
|
const { t } = useI18n();
|
|
|
|
|
|
|
|
const prop = defineProps({
|
|
|
|
width: {
|
|
|
|
type: Number,
|
|
|
|
default: 80,
|
|
|
|
},
|
|
|
|
param: {
|
|
|
|
type: Object,
|
|
|
|
default: {},
|
|
|
|
},
|
|
|
|
rules: {
|
|
|
|
type: Object,
|
|
|
|
default: {},
|
|
|
|
},
|
|
|
|
class: {
|
|
|
|
type: String,
|
|
|
|
default: '',
|
|
|
|
},
|
|
|
|
type: {
|
|
|
|
type: String,
|
|
|
|
default: null,
|
|
|
|
},
|
|
|
|
items: {
|
|
|
|
type: Array<any>(),
|
|
|
|
default: [],
|
|
|
|
},
|
|
|
|
});
|
|
|
|
const emit = defineEmits(["confirm", "cancel"]);
|
|
|
|
const modifyForm = ref<FormInstance>();
|
|
|
|
|
|
|
|
const formConfirm = () => {
|
|
|
|
if (!modifyForm.value) return;
|
|
|
|
modifyForm.value?.validate((valid, fields) => {
|
|
|
|
if (valid) {
|
|
|
|
emit("confirm");
|
|
|
|
modifyForm.value?.clearValidate();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
const clearValidate = () => {
|
|
|
|
modifyForm.value?.clearValidate();
|
|
|
|
}
|
|
|
|
|
|
|
|
watch(() => prop.param, () => {
|
|
|
|
modifyForm.value?.clearValidate();
|
|
|
|
});
|
|
|
|
|
|
|
|
defineExpose({ clearValidate })
|
|
|
|
|
|
|
|
onMounted(() => {
|
|
|
|
});
|
|
|
|
</script>
|
|
|
|
<style lang="scss" scoped>
|
|
|
|
//@import url(); 引入公共css类
|
|
|
|
::v-deep .el-select {
|
|
|
|
width: 100%;
|
|
|
|
}
|
|
|
|
|
|
|
|
::v-deep .el-date-editor {
|
|
|
|
width: 100% !important;
|
|
|
|
}
|
|
|
|
|
|
|
|
::v-deep .el-autocomplete {
|
|
|
|
width: 100%;
|
|
|
|
}
|
|
|
|
</style>
|