irc_web/.svn/pristine/55/554bead99957e84160ca5438484...

132 lines
4.3 KiB
Plaintext

<template>
<el-form
ref="hospitalForm"
:model="form"
:rules="rules"
class="demo-ruleForm"
size="small"
label-width="170px"
>
<div class="base-dialog-body">
<el-form-item label="Hospital: " prop="HospitalName">
<el-input v-model="form.HospitalName" />
</el-form-item>
<el-form-item label="Hospital CN: " prop="HospitalNameCN">
<el-input v-model="form.HospitalNameCN" />
</el-form-item>
<el-form-item label="Affiliated University: " prop="UniversityAffiliated">
<el-input v-model="form.UniversityAffiliated" />
</el-form-item>
<el-form-item label="Affiliated University CN: " prop="UniversityAffiliatedCN">
<el-input v-model="form.UniversityAffiliatedCN" />
</el-form-item>
<el-form-item label="Country: " prop="Country">
<el-input v-model="form.Country" />
</el-form-item>
<el-form-item label="Country CN: " prop="CountryCN">
<el-input v-model="form.CountryCN" />
</el-form-item>
<el-form-item label="Province: " prop="Province">
<el-input v-model="form.Province" />
</el-form-item>
<el-form-item label="Province CN: " prop="ProvinceCN">
<el-input v-model="form.ProvinceCN" />
</el-form-item>
<el-form-item label="City: " prop="City">
<el-input v-model="form.City" />
</el-form-item>
<el-form-item label="City CN: " prop="CityCN">
<el-input v-model="form.CityCN" />
</el-form-item>
</div>
<div class="base-dialog-footer" style="text-align:right;margin-top:10px;">
<el-form-item>
<el-button :disabled="btnLoading" size="small" type="primary" @click="handleCancel">Cancel</el-button>
<el-button size="small" type="primary" :loading="btnLoading" @click="handleSave">Save</el-button>
</el-form-item>
</div>
</el-form>
</template>
<script>
import { addOrUpdateHospital } from '@/api/dictionary'
export default {
name: 'HospitalForm',
props: {
data: {
type: Object,
default() {
return {}
}
},
model: {
type: Object,
default() {
return {}
}
}
},
data() {
return {
btnLoading: false,
form: {
Id: '',
HospitalName: '',
HospitalNameCN: '',
UniversityAffiliated: '',
UniversityAffiliatedCN: '',
Country: '',
CountryCN: '',
Province: '',
ProvinceCN: '',
City: '',
CityCN: ''
},
rules: {
HospitalName: [{ required: true, message: 'Please specify', trigger: 'blur' },
{ max: 50, message: 'The maximum length is 50' }],
HospitalNameCN: [{ max: 50, message: 'The maximum length is 50' }],
UniversityAffiliated: [{ max: 100, message: 'The maximum length is 100' }],
UniversityAffiliatedCN: [{ max: 100, message: 'The maximum length is 100' }],
Country: [{ required: true, message: 'Please specify', trigger: 'blur' },
{ max: 50, message: 'The maximum length is 50' }],
CountryCN: [{ max: 50, message: 'The maximum length is 50' }],
Province: [{ required: true, message: 'Please specify', trigger: 'blur' },
{ max: 50, message: 'The maximum length is 50' }],
ProvinceCN: [{ max: 50, message: 'The maximum length is 50' }],
City: [{ required: true, message: 'Please specify', trigger: 'blur' },
{ max: 50, message: 'The maximum length is 50' }],
CityCN: [{ max: 50, message: 'The maximum length is 50' }]
}
}
},
mounted() {
if (Object.keys(this.data).length && this.data.Id) {
this.form = { ...this.data }
}
},
methods: {
handleSave() {
this.$refs.hospitalForm.validate(valid => {
if (!valid) return
this.btnLoading = true
addOrUpdateHospital(this.form).then(res => {
this.btnLoading = false
if (res.IsSuccess) {
this.$message.success('Saved successfully')
this.$refs['hospitalForm'].resetFields()
this.$emit('getList')
this.$emit('close')
}
}).catch(() => {
this.btnLoading = false
})
})
},
handleCancel() {
this.$emit('close')
}
}
}
</script>