4 changed files with 187 additions and 61 deletions
@ -0,0 +1,121 @@ |
|||
<template> |
|||
<a-modal v-model:open="visible" :title="title" @ok="handleOk" @cancel="closeModal" width="50%"> |
|||
<div style="margin: 20px"> |
|||
<a-form :model="form" layout="vertical" ref="formRef" :rules="rules"> |
|||
<a-row :gutter="[16, 16]"> |
|||
<a-col :span="24"> |
|||
<a-form-item label="考核名称" name="name"> |
|||
<a-input v-model:value="form.name" placeholder="请输入" /> |
|||
</a-form-item> |
|||
</a-col> |
|||
</a-row> |
|||
<a-row :gutter="[16, 16]"> |
|||
<a-col :span="24"> |
|||
<a-form-item label="上级指导处" name="superLeader"> |
|||
<a-input v-model:value="form.superLeader" placeholder="请输入" /> |
|||
</a-form-item> |
|||
</a-col> |
|||
</a-row> |
|||
<a-row :gutter="[16, 16]"> |
|||
<a-col :span="24"> |
|||
<a-form-item label="责任单位" name="dutyWorkplace"> |
|||
<a-input v-model:value="form.dutyWorkplace" placeholder="请输入" /> |
|||
</a-form-item> |
|||
</a-col> |
|||
</a-row> |
|||
<a-row :gutter="[16, 16]"> |
|||
<a-col :span="24"> |
|||
<a-form-item label="模板" name="file"> |
|||
<a-upload v-model:file-list="fileLists" :before-upload="beforeUpload" :multiple="false" :maxCount="1"> |
|||
<a-button type="primary"> 上传 </a-button> |
|||
</a-upload> |
|||
</a-form-item> |
|||
</a-col> |
|||
</a-row> |
|||
</a-form> |
|||
</div> |
|||
</a-modal> |
|||
</template> |
|||
|
|||
<script> |
|||
import { reactive, ref } from 'vue'; |
|||
import { message } from 'ant-design-vue'; |
|||
import { addPerformance } from './templateContent.api'; |
|||
import { useGlobSetting } from '@/hooks/setting'; |
|||
import { getToken } from '@/utils/auth'; |
|||
export default { |
|||
setup(props, { emit }) { |
|||
const title = ref('新增'); |
|||
const formRef = ref(); |
|||
const visible = ref(false); |
|||
const form = reactive({ |
|||
file: '', |
|||
name: '', |
|||
superLeader: '', |
|||
dutyWorkplace: '', |
|||
}); |
|||
const fileLists = ref([]); |
|||
const showModal = () => { |
|||
visible.value = true; |
|||
}; |
|||
const rules = { |
|||
name: [{ required: true, message: '请输入' }], |
|||
superLeader: [{ required: true, message: '请输入' }], |
|||
dutyWorkplace: [{ required: true, message: '请输入' }], |
|||
}; |
|||
const beforeUpload = async (file) => { |
|||
console.log(file); |
|||
form.file = file; |
|||
return false; |
|||
}; |
|||
const handleOk = () => { |
|||
formRef.value.validate().then((valid) => { |
|||
if (valid) { |
|||
if(fileLists.value.length>0){ |
|||
let params = {}; |
|||
params.file = form.file; |
|||
params.performance = { |
|||
name: form.name, |
|||
superLeader: form.superLeader, |
|||
dutyWorkplace: form.dutyWorkplace, |
|||
}; |
|||
params.name = params.name |
|||
addPerformance(params).then((_) => { |
|||
message.success('新增成功'); |
|||
emit('success'); |
|||
closeModal(); |
|||
}); |
|||
}else{ |
|||
message.warning('请上传模板') |
|||
} |
|||
} |
|||
}); |
|||
}; |
|||
const closeModal = () => { |
|||
formRef.value.resetFields(); |
|||
fileLists.value = []; |
|||
visible.value = false; |
|||
}; |
|||
return { |
|||
visible, |
|||
title, |
|||
form, |
|||
showModal, |
|||
handleOk, |
|||
formRef, |
|||
closeModal, |
|||
rules, |
|||
fileLists, |
|||
beforeUpload, |
|||
}; |
|||
}, |
|||
}; |
|||
</script> |
|||
|
|||
<style scoped> |
|||
/* 可选样式调整 */ |
|||
.ant-modal-body { |
|||
max-width: 600px; |
|||
margin: 0 auto; |
|||
} |
|||
</style> |
Loading…
Reference in new issue