information.vue 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174
  1. <!-- 校验是否完善人才必填信息 -->
  2. <template>
  3. <scroll-view class="scrollBox" scroll-y="true">
  4. <view class="content">
  5. <view class="text-center ss-m-b-50 font-size-20 color-primary">学生信息认证</view>
  6. <uni-forms
  7. ref="baseInfoRef"
  8. v-model="formData"
  9. :rules="formRules"
  10. validateTrigger="bind"
  11. label-width="90px"
  12. labelAlign="center"
  13. >
  14. <uni-forms-item name="schoolId" label="就读学校" required>
  15. <uni-data-picker v-model="formData.schoolId" :localdata="schools" :clear-icon="false" popup-title="请选择就读学校" @change="getDepartmentList" :map="{ text: 'schoolName', value: 'schoolId' }"></uni-data-picker>
  16. </uni-forms-item>
  17. <uni-forms-item name="schoolDepartmentName" label="所在院系" required>
  18. <uni-data-picker v-model="formData.schoolDepartmentName" :localdata="schoolDepartmentList" :clear-icon="false" popup-title="请选择所在院系" :map="{ text: 'departmentTitle', value: 'schoolDepartmentId' }"></uni-data-picker>
  19. </uni-forms-item>
  20. <uni-forms-item name="majorName" label="所学专业" required>
  21. <uni-easyinput placeholder="请输入所学专业" v-model="formData.majorName" :inputBorder="false" type="text"></uni-easyinput>
  22. </uni-forms-item>
  23. <uni-forms-item name="schoolClassName" label="所在班级" required>
  24. <uni-easyinput placeholder="请填写所在班级" v-model="formData.schoolClassName" :inputBorder="false" type="text"></uni-easyinput>
  25. </uni-forms-item>
  26. <uni-forms-item name="studentNo" label="学号" required>
  27. <uni-easyinput placeholder="请填写学号" v-model="formData.studentNo" :inputBorder="false" type="text"></uni-easyinput>
  28. </uni-forms-item>
  29. <uni-forms-item name="idCardNo" label="身份证号码" required>
  30. <uni-easyinput placeholder="请输入身份证号码" v-model="formData.idCardNo" :inputBorder="false" type="text"></uni-easyinput>
  31. </uni-forms-item>
  32. <uni-forms-item name="emergencyContactName" label="紧急联系人姓名" required>
  33. <uni-easyinput placeholder="请填写紧急联系人姓名" v-model="formData.emergencyContactName" :inputBorder="false" type="text"></uni-easyinput>
  34. </uni-forms-item>
  35. <uni-forms-item name="emergencyContactPhone" label="紧急联系人手机号" required>
  36. <uni-easyinput placeholder="请填写紧急联系人手机号" v-model="formData.emergencyContactPhone" :inputBorder="false" type="number"></uni-easyinput>
  37. </uni-forms-item>
  38. </uni-forms>
  39. <view class="f-horizon-center">
  40. <button type="primary" size="default" class="send-button" @click="submit">保 存</button>
  41. </view>
  42. </view>
  43. </scroll-view>
  44. </template>
  45. <script setup>
  46. import { ref, unref } from 'vue'
  47. import { mobile, isValidIdCard18 } from '@/utils/validate'
  48. import { saveStudentSimpleInfo, getStudentInfo } from '@/api/user'
  49. // import { userStore } from '@/store/user'; const useUserStore = userStore()
  50. import { schoolList, departmentList } from '@/api/pickerData'
  51. const baseInfoRef = ref()
  52. const formData = ref({ // 必填项目
  53. schoolId: null,
  54. schoolDepartmentName: null,
  55. majorName: null,
  56. schoolClassName: null,
  57. studentNo: null,
  58. idCardNo: null,
  59. emergencyContactName: null,
  60. emergencyContactPhone: null,
  61. })
  62. // 获取学生基本信息
  63. const studentInfoFun = async () => {
  64. const { data } = await getStudentInfo()
  65. // 回显
  66. formData.value = { ...formData.value, ...data }
  67. getDepartmentList()
  68. }
  69. studentInfoFun()
  70. const schools = ref([])
  71. // // 学校下拉列表
  72. const getSchoolListData = async () => {
  73. const res = await schoolList({current: 1, size: 9999})
  74. schools.value = res?.data?.records?.length ? res.data.records : []
  75. }
  76. getSchoolListData()
  77. const schoolDepartmentList = ref([])
  78. const getDepartmentList = async (e) => {
  79. if (!formData.value?.schoolId) return
  80. const query = {
  81. page: { size: 9999, current: 1 },
  82. entity: { schoolId: formData.value.schoolId }
  83. }
  84. schoolDepartmentList.value = []
  85. if (e) formData.value.schoolDepartmentName = null // 切换学校的时清院系
  86. const res = await departmentList(query)
  87. const list = res?.data?.records?.length ? res.data.records : []
  88. schoolDepartmentList.value = list.map(e => e.entity)
  89. }
  90. const formRules = {
  91. idCardNo: isValidIdCard18,
  92. phone: mobile,
  93. schoolId:{
  94. rules: [{required: true, errorMessage: '请选择所在院系' }]
  95. },
  96. schoolDepartmentName:{
  97. rules: [{required: true, errorMessage: '请输入所学专业' }]
  98. },
  99. majorName: {
  100. rules: [{required: true, errorMessage: '请填写所在班级' }]
  101. },
  102. schoolClassName: {
  103. rules: [{required: true, errorMessage: '请填写学号' }]
  104. },
  105. studentNo: {
  106. rules: [{required: true, errorMessage: '请填写紧急联系人姓名' }]
  107. },
  108. emergencyContactName: {
  109. rules: [{required: true, errorMessage: '请填写紧急联系人手机号' }]
  110. },
  111. emergencyContactPhone: mobile,
  112. }
  113. const submit = async () => {
  114. const validate = await unref(baseInfoRef).validate()
  115. if (!validate) return uni.showToast({ title: '请将信息补充完整', icon: 'none' })
  116. try {
  117. await saveStudentSimpleInfo(formData.value)
  118. uni.showToast({
  119. icon: 'success',
  120. title: '保存成功'
  121. })
  122. // await useUserStore.getInfo()
  123. setTimeout(() => {
  124. uni.navigateBack({
  125. delta: 1
  126. })
  127. }, 1000)
  128. } catch (err) {
  129. uni.showToast({ title: err?.msg || '保存失败', icon: 'none' })
  130. }
  131. }
  132. </script>
  133. <style lang="scss" scoped>
  134. .scrollBox {
  135. width: 100vw;
  136. // height: 100vh;
  137. height: calc(100vh - 30rpx);
  138. margin-bottom: 30rpx;
  139. }
  140. .content {
  141. padding: 30rpx;
  142. }
  143. .changeRole {
  144. color: var(--color-666);
  145. font-size: 15px;
  146. line-height: 26px;
  147. margin-bottom: 40rpx;
  148. }
  149. .upload-img{
  150. position: relative;
  151. width: 200rpx;
  152. height: 200rpx;
  153. border: 1px solid #f1f1f1;
  154. margin: 10rpx;
  155. }
  156. .upload-file{
  157. width: 200rpx;
  158. height: 200rpx;
  159. border: 1px solid #f1f1f1;
  160. margin: 10rpx;
  161. display: flex;
  162. justify-content: center;
  163. align-items: center;
  164. border-radius: 10rpx;
  165. }
  166. </style>