| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179 | <!-- 校验是否完善人才必填信息 --><template>  <scroll-view class="scrollBox" scroll-y="true">    <view class="content">      <!-- <view class="text-center ss-m-b-50 font-size-20 color-primary">学生信息认证</view> -->      <uni-forms        ref="baseInfoRef"        v-model="formData"        :rules="formRules"        validateTrigger="bind"        label-width="131px"        labelAlign="right"      >        <uni-forms-item name="schoolId" label="就读学校" required>          <uni-data-picker v-model="formData.schoolId" :localdata="schools" :clear-icon="false" popup-title="请选择就读学校" @change="getDepartmentList" :map="{ text: 'schoolName', value: 'schoolId' }"></uni-data-picker>        </uni-forms-item>        <uni-forms-item name="schoolDepartmentName" label="所在院系" required>          <uni-data-picker v-model="formData.schoolDepartmentName" :localdata="schoolDepartmentList" :clear-icon="false" popup-title="请选择所在院系" :map="{ text: 'departmentTitle', value: 'departmentTitle' }"></uni-data-picker>        </uni-forms-item>        <uni-forms-item name="majorName" label="所学专业" required>          <uni-easyinput placeholder="请输入所学专业" v-model="formData.majorName" :inputBorder="false" type="text"></uni-easyinput>        </uni-forms-item>        <uni-forms-item name="schoolClassName" label="所在班级" required>          <uni-easyinput placeholder="请填写所在班级" v-model="formData.schoolClassName" :inputBorder="false" type="text"></uni-easyinput>        </uni-forms-item>        <uni-forms-item name="studentNo" label="学号" required>          <uni-easyinput placeholder="请填写学号" v-model="formData.studentNo" :inputBorder="false" type="text"></uni-easyinput>        </uni-forms-item>        <uni-forms-item name="idCardNo" label="身份证号码" required>          <uni-easyinput placeholder="请输入身份证号码" v-model="formData.idCardNo" :inputBorder="false" type="text"></uni-easyinput>        </uni-forms-item>        <uni-forms-item name="emergencyContactName" label="紧急联系人姓名" required>          <uni-easyinput placeholder="请填写紧急联系人姓名" v-model="formData.emergencyContactName" :inputBorder="false" type="text"></uni-easyinput>        </uni-forms-item>        <uni-forms-item name="emergencyContactPhone" label="紧急联系人手机号" required>          <uni-easyinput placeholder="请填写紧急联系人手机号" v-model="formData.emergencyContactPhone" :inputBorder="false" type="number"></uni-easyinput>        </uni-forms-item>      </uni-forms>      <view class="f-horizon-center">        <button type="primary" size="default" class="send-button" @click="submit">保 存</button>      </view>    </view>  </scroll-view></template><script setup>import { ref, unref } from 'vue'import { mobile, isValidIdCard18 } from '@/utils/validate'import { saveStudentSimpleInfo, getStudentInfo } from '@/api/user'// import { userStore } from '@/store/user'; const useUserStore = userStore()import { schoolList, departmentList } from '@/api/pickerData'const baseInfoRef = ref()const formData = ref({ // 必填项目  schoolId: null,  schoolDepartmentName: null,  majorName: null,  schoolClassName: null,  studentNo: null,  idCardNo: null,  emergencyContactName: null,  emergencyContactPhone: null,})// 获取学生基本信息const studentInfoFun = async () => {  const { data } = await getStudentInfo()  // 回显  formData.value = { ...formData.value, ...data }  getDepartmentList()}studentInfoFun()const schools = ref([])// // 学校下拉列表const getSchoolListData = async () => {  const res = await schoolList({current: 1, size: 9999})  schools.value = res?.data?.records?.length ? res.data.records : []}getSchoolListData()const schoolDepartmentList = ref([])const getDepartmentList = async (e) => {  if (!formData.value?.schoolId) return  const query = {    page: { size: 9999,	current: 1	},    entity: { schoolId: formData.value.schoolId }  }  schoolDepartmentList.value = []  if (e) formData.value.schoolDepartmentName = null // 切换学校的时清院系  const res = await departmentList(query)  const list = res?.data?.records?.length ? res.data.records : []  schoolDepartmentList.value = list.map(e => e.entity)}const formRules = {  idCardNo: isValidIdCard18,  phone: mobile,  schoolId:{		rules: [{required: true, errorMessage: '请选择所在院系' }]	},  schoolDepartmentName:{		rules: [{required: true, errorMessage: '请输入所学专业' }]	},  majorName: {		rules: [{required: true, errorMessage: '请填写所在班级' }]	},  schoolClassName: {		rules: [{required: true, errorMessage: '请填写学号' }]	},  studentNo: {		rules: [{required: true, errorMessage: '请填写紧急联系人姓名' }]	},  emergencyContactName: {		rules: [{required: true, errorMessage: '请填写紧急联系人手机号' }]	},  emergencyContactPhone: mobile,}const submit = async () => {  const validate = await unref(baseInfoRef).validate()  if (!validate) return uni.showToast({ title: '请将信息补充完整', icon: 'none' })  // 学校名称  formData.value.schoolName = schools.value.find(e => e.schoolId === formData.value.schoolId)?.schoolName      try {    await saveStudentSimpleInfo(formData.value)    uni.showToast({			icon: 'success',			title: '保存成功'		})		setTimeout(() => {      uni.navigateBack({        delta: 1      })    }, 1000)  } catch (err) {    uni.showToast({ title: err?.msg || '保存失败', icon: 'none' })  }}</script><style lang="scss" scoped>.scrollBox {  width: 100vw;  // height: 100vh;  height: calc(100vh - 30rpx);  margin-bottom: 30rpx;}.content {  padding: 30rpx;}.changeRole {  color: var(--color-666);  font-size: 15px;  line-height: 26px;  margin-bottom: 40rpx;}.upload-img{  position: relative;  width: 200rpx;  height: 200rpx;  border: 1px solid #f1f1f1;  margin: 10rpx;}.upload-file{  width: 200rpx;  height: 200rpx;  border: 1px solid #f1f1f1;  margin: 10rpx;  display: flex;  justify-content: center;  align-items: center;  border-radius: 10rpx;}</style>
 |