This commit is contained in:
2023-06-13 13:40:54 +08:00
parent ead6700f2c
commit ef579def81
208 changed files with 22380 additions and 19469 deletions

View File

@ -1,36 +1,28 @@
<template>
<!--COMPLETE-->
<el-form
ref="formRef"
:label-width="labelWidth + 'px'"
:model="modelValue"
:rules="rules"
ref="formRef"
:label-width="labelWidth + 'px'"
:model="modelValue"
:rules="rules"
>
<div v-if="showTitle" class="form_title">基本信息</div>
<el-row v-if="isAdd">
<el-col :span="24">
<el-form-item label="实验室名称" prop="name">
<!--:disabled="isAdd"-->
<el-input v-model="modelValue.name"></el-input>
</el-form-item>
</el-col>
</el-row>
<el-row v-if="isAdd">
<el-col :span="24">
<el-form-item label="组织机构代码:" prop="code">
<el-row justify="space-between" type="flex">
<el-col :span="20">
<!--:disabled="isAdd"-->
<el-input v-model="modelValue.code"></el-input>
</el-col>
<el-col :span="3">
<el-button type="primary" @click=""
>查找
</el-button
>
</el-col>
</el-row>
</el-form-item>
</el-col>
@ -39,66 +31,70 @@
<el-row v-if="isAdd">
<el-col :span="24">
<el-form-item label="所属院所或单位" prop="school">
<el-input v-model="modelValue.school" placeholder="请输入所属院所或单位"/>
</el-form-item>
</el-col>
</el-row>
<CityOptions ref="cityFormRef" v-model="modelValue" :labelWidth="labelWidth"/>
<el-row>
<el-col :span="24">
<el-form-item label="详细地址:">
<el-input
v-model="modelValue.address"
placeholder="请输入详细地址"
></el-input>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="24">
<el-form-item label="实验室网站:">
<el-input
v-model="modelValue.url"
placeholder="请输入实验室网站"
></el-input>
v-model="modelValue.school"
placeholder="请输入所属院所或单位"
/>
</el-form-item>
</el-col>
</el-row>
<FieldOptions
ref="fieldFormRef"
v-model="modelValue"
:labelWidth="labelWidth"
ref="fieldFormRef"
v-model="modelValue"
:labelWidth="labelWidth"
/>
<InputBoxAdd
ref="keywordsFormRef"
v-model="modelValue"
:labelWidth="labelWidth"
fieldKey="keywords"
placeholder="应用场景关键词+技术产品关键词"
title="关键词"
ref="keywordsFormRef"
v-model="modelValue"
:labelWidth="labelWidth"
fieldKey="keywords"
placeholder="应用场景关键词+技术产品关键词"
title="关键词"
/>
<el-row>
<el-col :span="24">
<el-form-item label="实验室网站:">
<el-input
v-model="modelValue.url"
placeholder="请输入实验室网站"
></el-input>
</el-form-item>
</el-col>
</el-row>
<InputBoxAdd
ref="directionsFormRef"
v-model="modelValue"
:labelWidth="labelWidth"
fieldKey="researchs"
placeholder="请输入研究方向"
title="研究方向"
<CityOptions
ref="cityFormRef"
v-model="modelValue"
:labelWidth="labelWidth"
/>
<el-row>
<el-col :span="24">
<el-form-item label="详细地址:">
<el-input
v-model="modelValue.address"
placeholder="请输入详细地址"
></el-input>
</el-form-item>
</el-col>
</el-row>
<InputBoxAdd
ref="directionsFormRef"
v-model="modelValue"
:labelWidth="labelWidth"
fieldKey="researchs"
placeholder="请输入研究方向"
title="研究方向"
/>
<el-row>
<el-col :span="24">
<el-form-item label="实验室简介" prop="introduction">
<editor
ref="introduceRef"
v-model="modelValue.introduction"
:minHeight="150"
ref="introduceRef"
v-model="modelValue.introduction"
:minHeight="150"
/>
</el-form-item>
</el-col>
@ -106,11 +102,11 @@
</el-form>
</template>
<script setup>
import Editor from '@/components/WangEditor'
import Editor from "@/components/WangEditor";
import CityOptions from "@/views/components/CityOptions";
import FieldOptions from "@/views/components/FieldOptions";
import InputBoxAdd from "@/views/components/InputBoxAdd";
import {reactive, ref, toRefs} from "vue";
import { reactive, ref, toRefs } from "vue";
const props = defineProps({
modelValue: Object,
@ -126,30 +122,41 @@ const props = defineProps({
type: Number,
default: 120,
},
})
});
const formRef = ref()
const cityFormRef = ref()
const fieldFormRef = ref()
const keywordsFormRef = ref()
const directionsFormRef = ref()
const introduceRef = ref()
const formRef = ref();
const cityFormRef = ref();
const fieldFormRef = ref();
const keywordsFormRef = ref();
const directionsFormRef = ref();
const introduceRef = ref();
const data = reactive({
rules: {
product: [{required: true, message: "请输入", trigger: "blur"}],
name: [{required: true, message: "请输入", trigger: "blur"}],
kind: [{required: true, message: "请选择", trigger: "change"}],
code: [{required: true, message: "请输入", trigger: "blur"}],
mobile: [
{required: true, message: "请输入", trigger: "blur"},
name: [{ required: true, message: "请输入实验室名称", trigger: "blur" }],
code: [{ required: true, message: "请输入组织机构代码", trigger: "blur" }],
school: [
{ required: true, message: "请输入所属院所或单位", trigger: "blur" },
],
introduction: [
{
pattern: /^1[3|4|5|6|7|8|9][0-9]\d{8}$/,
required: true,
message: "请输入实验室简介",
trigger: ["change", "blur"],
},
],
/*-----*/
kind: [{ required: true, message: "请选择", trigger: "change" }],
product: [{ required: true, message: "请输入", trigger: "blur" }],
mobile: [
{ required: true, message: "请输入", trigger: "blur" },
{
pattern: /^1[3-9]\d{9}$/,
message: "请输入正确的手机号码",
trigger: "blur",
},
],
researchId: [{required: true, message: "请选择", trigger: "change"}],
researchId: [{ required: true, message: "请选择", trigger: "change" }],
tenantId: [
{
required: true,
@ -157,11 +164,10 @@ const data = reactive({
trigger: ["blur", "change"],
},
],
school: [{required: true, message: "请输入", trigger: "blur"}],
education: [{required: true, message: "请选择", trigger: "change"}],
major: [{required: true, message: "请输入", trigger: "blur"}],
job: [{required: true, message: "请输入", trigger: "blur"}],
title: [{required: true, message: "请输入", trigger: "blur"}],
education: [{ required: true, message: "请选择", trigger: "change" }],
major: [{ required: true, message: "请输入", trigger: "blur" }],
job: [{ required: true, message: "请输入", trigger: "blur" }],
title: [{ required: true, message: "请输入", trigger: "blur" }],
work_at: [
{
required: true,
@ -176,29 +182,9 @@ const data = reactive({
trigger: ["blur", "change"],
},
],
introduction: [
{
required: true,
message: "请输入",
trigger: ["change", "blur"],
},
],
}
},
});
const {rules} = toRefs(data)
const submitForm = () => {
let flag = false;
this.$refs["formRef"].validate((valid) => {
const cityForm = this.$refs.cityForm.submitForm(); // 城市
const fieldForm = this.$refs.fieldForm.submitForm();
const keywordsForm = this.$refs.keywordsForm.submitForm();
const directionsForm = this.$refs.directionsForm.submitForm();
if (valid && cityForm && fieldForm && keywordsForm && directionsForm) {
flag = !flag;
}
});
return flag;
}
const { rules } = toRefs(data);
const validateForm = async () => {
let formValid;
@ -212,22 +198,17 @@ const validateForm = async () => {
const keywordsFormValid = await keywordsFormRef.value.validateForm(); // 关键词表单验证
const directionsFormValid = await directionsFormRef.value.validateForm(); // 研究方向表单验证
return (
formValid &&
cityFormValid &&
fieldFormValid &&
keywordsFormValid &&
directionsFormValid
formValid &&
cityFormValid &&
fieldFormValid &&
keywordsFormValid &&
directionsFormValid
);
};
defineExpose({
validateForm
})
// researchSelect().then(({data}) => {
// researchOptions.value = data;
// });
validateForm,
});
</script>
<style lang="scss" scoped>
@ -236,15 +217,9 @@ defineExpose({
margin-bottom: 30px;
}
// 上传图片框限制
// ::v-deep .el-upload--picture-card {
// width: 120px;
// height: 120px;
// line-height: 120px;
// }
.el-select,
.el-date-editor {
display: block;
width: 100%;
}
</style>
</style>