technological-brain-admin/src/views/admin/tech-resources/talent-unit-form.vue

337 lines
10 KiB
Vue

<template>
<div class="talent-unit-form-container">
<el-card>
<template #header>
<div class="card-header">
<span>{{ isView ? '查看' : (formData.id ? '编辑' : '新增') }}工作单位</span>
<el-button @click="handleBack">返回</el-button>
</div>
</template>
<el-form
ref="formRef"
:model="formData"
:rules="rules"
label-width="140px"
:disabled="isView"
>
<!-- 基本信息 -->
<el-divider content-position="left">基本信息</el-divider>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="机构名称" prop="orgName">
<el-input v-model="formData.orgName" placeholder="请输入机构名称" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="组织类型" prop="orgType">
<el-select v-model="formData.orgType" placeholder="请选择组织类型" style="width: 100%">
<el-option label="高校" value="SCHOOL" />
<el-option label="企业" value="ENTERPRISE" />
<el-option label="科研院所" value="RESEARCH_INSTITUTE" />
<el-option label="政府机关" value="GOVERNMENT" />
<el-option label="其他" value="OTHER" />
</el-select>
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="机构代码" prop="orgCode">
<el-input v-model="formData.orgCode" placeholder="请输入统一社会信用代码" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="法定代表人" prop="legalRepresentative">
<el-input v-model="formData.legalRepresentative" placeholder="请输入法定代表人" />
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="成立日期" prop="establishmentDate">
<el-date-picker
v-model="formData.establishmentDate"
type="date"
placeholder="请选择成立日期"
style="width: 100%"
value-format="YYYY-MM-DD"
/>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="员工人数" prop="employeeCount">
<el-input-number v-model="formData.employeeCount" :min="0" style="width: 100%" />
</el-form-item>
</el-col>
</el-row>
<!-- 联系信息 -->
<el-divider content-position="left">联系信息</el-divider>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="联系电话" prop="contactPhone">
<el-input v-model="formData.contactPhone" placeholder="请输入联系电话" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="联系邮箱" prop="contactEmail">
<el-input v-model="formData.contactEmail" placeholder="请输入联系邮箱" />
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="官方网址" prop="website">
<el-input v-model="formData.website" placeholder="请输入官方网址" />
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="8">
<el-form-item label="所属省份" prop="province">
<el-input v-model="formData.province" placeholder="请输入省份" />
</el-form-item>
</el-col>
<el-col :span="8">
<el-form-item label="所属城市" prop="city">
<el-input v-model="formData.city" placeholder="请输入城市" />
</el-form-item>
</el-col>
<el-col :span="8">
<el-form-item label="所属区域" prop="district">
<el-input v-model="formData.district" placeholder="请输入区域" />
</el-form-item>
</el-col>
</el-row>
<el-form-item label="详细地址" prop="address">
<el-input v-model="formData.address" placeholder="请输入详细地址" />
</el-form-item>
<!-- 企业信息 -->
<template v-if="formData.orgType === 'ENTERPRISE'">
<el-divider content-position="left">企业信息</el-divider>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="注册资本" prop="registeredCapital">
<el-input v-model="formData.registeredCapital" placeholder="请输入注册资本" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="所属行业" prop="industry">
<el-input v-model="formData.industry" placeholder="请输入所属行业" />
</el-form-item>
</el-col>
</el-row>
<el-form-item label="是否高新技术企业" prop="isHighTech">
<el-radio-group v-model="formData.isHighTech">
<el-radio :label="0">否</el-radio>
<el-radio :label="1">是</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item label="经营范围" prop="businessScope">
<el-input
v-model="formData.businessScope"
type="textarea"
:rows="3"
placeholder="请输入经营范围"
/>
</el-form-item>
</template>
<!-- 高校信息 -->
<template v-if="formData.orgType === 'SCHOOL'">
<el-divider content-position="left">高校信息</el-divider>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="高校类型" prop="schoolType">
<el-select v-model="formData.schoolType" placeholder="请选择高校类型" style="width: 100%">
<el-option label="985" value="985" />
<el-option label="211" value="211" />
<el-option label="双一流" value="双一流" />
<el-option label="普通本科" value="普通本科" />
<el-option label="其他" value="其他" />
</el-select>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="办学层次" prop="schoolLevel">
<el-select v-model="formData.schoolLevel" placeholder="请选择办学层次" style="width: 100%">
<el-option label="本科" value="本科" />
<el-option label="专科" value="专科" />
<el-option label="本专科" value="本专科" />
</el-select>
</el-form-item>
</el-col>
</el-row>
</template>
<!-- 其他信息 -->
<el-divider content-position="left">其他信息</el-divider>
<el-form-item label="机构简介" prop="introduction">
<el-input
v-model="formData.introduction"
type="textarea"
:rows="4"
placeholder="请输入机构简介"
/>
</el-form-item>
<!-- 操作按钮 -->
<el-form-item v-if="!isView">
<el-button type="primary" @click="handleSubmit" :loading="submitting">提交</el-button>
<el-button @click="handleBack">取消</el-button>
</el-form-item>
</el-form>
</el-card>
</div>
</template>
<script setup lang="ts">
import { ref, reactive, onMounted } from 'vue'
import { useRoute, useRouter } from 'vue-router'
defineOptions({
name: 'TalentUnitForm'
})
import { ElMessage } from 'element-plus'
import type { FormInstance, FormRules } from 'element-plus'
import {
getOrganizationDetail,
addOrganization,
updateOrganization,
type OrganizationFormData
} from '@/api/organization'
const router = useRouter()
const route = useRoute()
const formRef = ref<FormInstance>()
const submitting = ref(false)
const isView = ref(false)
// 表单数据
const formData = reactive<OrganizationFormData>({
orgName: '',
orgType: 'ENTERPRISE',
orgCode: '',
legalRepresentative: '',
establishmentDate: '',
province: '',
city: '',
district: '',
address: '',
contactPhone: '',
contactEmail: '',
website: '',
employeeCount: undefined,
introduction: '',
registeredCapital: '',
businessScope: '',
industry: '',
isHighTech: 0,
schoolType: '',
schoolLevel: ''
})
// 表单验证规则
const rules: FormRules = {
orgName: [
{ required: true, message: '请输入机构名称', trigger: 'blur' }
],
orgType: [
{ required: true, message: '请选择组织类型', trigger: 'change' }
],
contactEmail: [
{ type: 'email', message: '请输入正确的邮箱地址', trigger: 'blur' }
],
website: [
{ type: 'url', message: '请输入正确的网址', trigger: 'blur' }
]
}
// 加载详情
const loadDetail = async (id: string) => {
try {
const { data } = await getOrganizationDetail(id)
if (data.code === 200) {
Object.assign(formData, data.data)
} else {
ElMessage.error(data.message || '加载数据失败')
}
} catch (error) {
ElMessage.error('加载数据失败')
console.error(error)
}
}
// 提交表单
const handleSubmit = async () => {
if (!formRef.value) return
await formRef.value.validate(async (valid) => {
if (valid) {
submitting.value = true
try {
const apiFunc = formData.id ? updateOrganization : addOrganization
const { data } = await apiFunc(formData)
if (data.code === 200) {
ElMessage.success(formData.id ? '修改成功' : '新增成功')
handleBack()
} else {
ElMessage.error(data.message || '操作失败')
}
} catch (error) {
ElMessage.error('操作失败')
console.error(error)
} finally {
submitting.value = false
}
}
})
}
// 返回
const handleBack = () => {
router.push('/admin/talent-unit')
}
onMounted(() => {
const id = route.params.id as string
isView.value = route.path.includes('/view/')
if (id) {
loadDetail(id)
}
})
</script>
<style scoped>
.talent-unit-form-container {
padding: 20px;
}
.card-header {
display: flex;
justify-content: space-between;
align-items: center;
}
:deep(.el-divider__text) {
font-weight: bold;
color: #409eff;
}
</style>