<template>
|
<Card>
|
<el-form
|
:model="form"
|
:rules="rules"
|
ref="strainForm"
|
label-position="top"
|
class="strain-form"
|
>
|
<div class="form-grid">
|
<el-form-item label="菌种编号" prop="strainNo" required>
|
<el-input v-model="form.strainNo" placeholder="请输入"></el-input>
|
</el-form-item>
|
<el-form-item label="菌种名称" prop="strainName" required>
|
<el-input v-model="form.strainName" placeholder="请输入"></el-input>
|
</el-form-item>
|
<el-form-item label="菌种来源" prop="source" required>
|
<el-input v-model="form.source" placeholder="请输入"></el-input>
|
</el-form-item>
|
<el-form-item label="鉴定方法" prop="identificationMethod" required>
|
<el-input v-model="form.identificationMethod" placeholder="请输入"></el-input>
|
</el-form-item>
|
<el-form-item label="特征描述" prop="characteristics" required>
|
<el-input v-model="form.characteristics" placeholder="请输入"></el-input>
|
</el-form-item>
|
<el-form-item label="菌种保存方法" prop="preservationMethod" required>
|
<el-input v-model="form.preservationMethod" placeholder="请输入"></el-input>
|
</el-form-item>
|
<el-form-item label="保存位置" prop="storageLocation" required>
|
<el-input v-model="form.storageLocation" placeholder="请输入"></el-input>
|
</el-form-item>
|
</div>
|
|
<div class="form-row">
|
<el-form-item label="备注" prop="remarks" class="full-width">
|
<el-input
|
type="textarea"
|
v-model="form.remarks"
|
:rows="4"
|
placeholder="请输入"
|
></el-input>
|
</el-form-item>
|
</div>
|
<div class="end-btn" style="margin-top: 38px">
|
<el-button type="primary" @click="handleSubmit">提交</el-button>
|
<el-button @click="handleDraft">存草稿</el-button>
|
</div>
|
</el-form>
|
|
<!-- 签字确认组件 -->
|
<SignatureCanvas
|
:visible.sync="signatureVisible"
|
@confirm="handleSignatureConfirm"
|
/>
|
</Card>
|
</template>
|
|
<script>
|
import SignatureCanvas from '@/components/SignatureCanvas.vue'
|
|
export default {
|
name: 'AddMainCell',
|
components: {
|
SignatureCanvas
|
},
|
data() {
|
return {
|
signatureVisible: false,
|
form: {
|
strainNo: '',
|
strainName: '',
|
source: '',
|
identificationMethod: '',
|
characteristics: '',
|
storageLocation: '',
|
preservationMethod: '',
|
remarks: ''
|
},
|
rules: {
|
strainNo: [{ required: true, message: '请输入菌种编号', trigger: 'blur' }],
|
strainName: [{ required: true, message: '请输入菌种名称', trigger: 'blur' }],
|
source: [{ required: true, message: '请输入菌种来源', trigger: 'blur' }],
|
identificationMethod: [{ required: true, message: '请输入鉴定方法', trigger: 'blur' }],
|
characteristics: [{ required: true, message: '请输入特征描述', trigger: 'blur' }],
|
storageLocation: [{ required: true, message: '请输入保存位置', trigger: 'blur' }],
|
preservationMethod: [{ required: true, message: '请输入菌种保存方法', trigger: 'blur' }]
|
}
|
}
|
},
|
methods: {
|
handleSubmit() {
|
this.$refs.strainForm.validate((valid) => {
|
if (valid) {
|
this.signatureVisible = true
|
}
|
})
|
},
|
handleDraft() {
|
// 实现存草稿逻辑
|
console.log('save draft', this.form)
|
this.$message.success('草稿保存成功')
|
},
|
handleSignatureConfirm(signatureImage) {
|
this.signatureVisible = false
|
// 处理提交逻辑
|
console.log('submit form with signature:', this.form, signatureImage)
|
this.$message.success('提交成功')
|
this.$router.back()
|
}
|
}
|
}
|
</script>
|
|
<style scoped lang="less">
|
.strain-form {
|
padding: 0 40px;
|
|
.form-grid {
|
display: grid;
|
grid-template-columns: repeat(3, 1fr);
|
gap: 24px;
|
margin-bottom: 24px;
|
|
@media screen and (max-width: 1200px) {
|
grid-template-columns: repeat(2, 1fr);
|
}
|
|
@media screen and (max-width: 768px) {
|
grid-template-columns: 1fr;
|
}
|
}
|
|
.form-row {
|
display: flex;
|
flex-wrap: wrap;
|
gap: 24px;
|
margin-bottom: 24px;
|
|
.el-form-item {
|
margin-bottom: 0;
|
|
&.full-width {
|
width: 100%;
|
}
|
}
|
}
|
|
:deep(.el-form-item__label) {
|
font-weight: normal;
|
color: #606266;
|
padding-bottom: 8px;
|
line-height: 20px;
|
}
|
|
:deep(.el-form-item__content) {
|
line-height: unset;
|
}
|
|
:deep(.el-input__inner) {
|
border-radius: 4px;
|
height: 36px;
|
line-height: 36px;
|
}
|
|
:deep(.el-textarea__inner) {
|
border-radius: 4px;
|
padding: 8px 12px;
|
min-height: 120px;
|
}
|
}
|
|
.end-btn {
|
display: flex;
|
align-items: center;
|
justify-content: center;
|
gap: 10px;
|
|
:deep(.el-button) {
|
width: 180px;
|
height: 36px;
|
padding: 0;
|
display: flex;
|
align-items: center;
|
justify-content: center;
|
font-size: 14px;
|
border-radius: 4px;
|
margin: 0;
|
}
|
}
|
</style>
|