gerenZiliao.vue 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391
  1. <template>
  2. <view class="jz-content-box">
  3. <view class="upload-img-box">
  4. <jiazhengUpload @getFileUrl="getFileUrl" changjingType="shenfenzheng"></jiazhengUpload>
  5. </view>
  6. <view class="form-label-input">
  7. <view class="phone-form-label"><text class="form-label-require">*</text>手机号</view>
  8. <uni-easyinput type="number" v-model="formData.userName" placeholder="请输入手机号" maxlength="11" />
  9. </view>
  10. <view class="form-label-input">
  11. <view class="phone-form-label"><text class="form-label-require">*</text>姓名</view>
  12. <uni-easyinput v-model="formData.realName" placeholder="请输入姓名" />
  13. </view>
  14. <view class="form-label-input">
  15. <view class="phone-form-label"><text class="form-label-require">*</text>身份证号</view>
  16. <uni-easyinput v-model="formData.idCard" placeholder="请输入身份证号" maxlength="18" />
  17. </view>
  18. <view class="form-label-input">
  19. <view class="phone-form-label"><text class="form-label-require">*</text>生日</view>
  20. <uni-datetime-picker type="line" v-model="formData.birthday">
  21. <view class="form-radio-select">
  22. <view v-if="!formData.birthday">请选择出生日期</view>
  23. <view v-else>{{formData.birthday}}</view>
  24. <icon></icon>
  25. </view>
  26. </uni-datetime-picker>
  27. </view>
  28. <view class="form-label-input">
  29. <view class="phone-form-label"><text class="form-label-require">*</text>籍贯</view>
  30. <picker mode="multiSelector" :range="pickerData" :range-key="'label'" @change="onPickerChange">
  31. <view class="picker">
  32. 当前选择:{{ selectedProvince }} - {{ selectedCity }}
  33. </view>
  34. </picker>
  35. </view>
  36. <view class="form-label-input">
  37. <view class="phone-form-label"><text class="form-label-require">*</text>身份证地址</view>
  38. <uni-easyinput v-model="formData.hujiDizhi" placeholder="请输入身份证地址" />
  39. </view>
  40. <view class="form-label-input">
  41. <view class="phone-form-label"><text class="form-label-require">*</text>民族</view>
  42. <picker :range="minzuList" mode='selector' :value="formData.minzuIndex" range-key="name"
  43. @change="minzuChange" @cancel="minzuCancel">
  44. <view class="form-radio-select">
  45. <view>{{ formData.minzu.name || '请选择民族' }}</view>
  46. <icon></icon>
  47. </view>
  48. </picker>
  49. </view>
  50. <view class="form-label-radio">
  51. <view class="phone-form-label"><text class="form-label-require">*</text>性别</view>
  52. <view class="form-radio-group">
  53. <view class="form-radio-item" :class="{genderActive: formData.gender===1}" @click="genderSelect(1)">
  54. 男</view>
  55. <view class="form-radio-item" :class="{genderActive: formData.gender===2}" @click="genderSelect(2)">
  56. 女</view>
  57. </view>
  58. </view>
  59. <view class="form-label-radio form-top-margin flex-start-row">
  60. <view class="phone-form-label"><text class="form-label-require"></text>学历</view>
  61. <dataChecked :list="xueliList" mode="single" :showAdd="false" @change="selectChangeXueliList" />
  62. </view>
  63. <view class="form-label-radio flex-start-row">
  64. <view class="phone-form-label"><text></text>婚姻 </view>
  65. <dataChecked :list="hunyinList" mode="single" :showAdd="false" @change="selectChangeHunyinList" />
  66. </view>
  67. <view class="form-label-input form-top-margin flex-start-row">
  68. <view class="phone-form-label"><text></text>通讯地址</view>
  69. <textarea v-model="formData.juzhuDizhi" placeholder="请输入通讯地址" class="form-textarea-box" />
  70. </view>
  71. <view class="form-label-select">
  72. <view class="phone-form-label"><text></text>星座</view>
  73. <picker :range="xingzuoList" mode='selector' :value="formData.xingzuoIndex" range-key="name"
  74. @change="xingzuoChange" @cancel="xingzuoCancel">
  75. <view class="form-radio-select">
  76. <view>{{ formData.xingzuo.name || '请选择星座' }}</view>
  77. <icon></icon>
  78. </view>
  79. </picker>
  80. </view>
  81. <view class="form-label-select">
  82. <view class="phone-form-label"><text></text>属相</view>
  83. <picker :range="shuxiangList" mode='selector' :value="formData.shuxiangIndex" range-key="name"
  84. @change="shuxiangChange" @cancel="shuxiangCancel">
  85. <view class="form-radio-select">
  86. <view>{{ formData.shuxiang.name || '请选择属相' }}</view>
  87. <icon></icon>
  88. </view>
  89. </picker>
  90. </view>
  91. <view class="form-label-switch">
  92. <view class="phone-form-label"> <text class="form-label-require"></text>星座属相展示到简历 </view>
  93. <view>展示
  94. <switch @change="switchXingzuoChange" :checked="formData.xingzuoFlag" color="#3fd2a1"
  95. style="transform:scale(0.7)" />
  96. </view>
  97. </view>
  98. <view class="agree-section-box form-top-margin">
  99. <checkbox-group @change="handleAgree">
  100. <label class="checkbox">
  101. <checkbox :checked="formData.agree" color="#3fd2a1" style="transform:scale(0.65)" />
  102. <text>已征得本人同意,将其个人资料信息录入平台</text>
  103. </label>
  104. </checkbox-group>
  105. <button type="default" @click="goNext" class="phone-green-btn">下一步</button>
  106. </view>
  107. </view>
  108. </template>
  109. <script>
  110. import dataChecked from './common/dataChecked.vue';
  111. import jiazhengUpload from "./common/jiazhengUpload.vue"
  112. import {
  113. getJiazhengXueli,
  114. getJiazhengHunyin,
  115. getJiazhengMinzu,
  116. getJiazhengShuxiang,
  117. getJiazhengXingzuo,
  118. getJiazhengJiguan
  119. } from "@/api/jiazheng.js";
  120. export default {
  121. components: {
  122. dataChecked,
  123. jiazhengUpload
  124. },
  125. data() {
  126. return {
  127. formData: {
  128. userName: '',
  129. realName: '',
  130. idCard: '',
  131. birthday: '',
  132. hometown: [],
  133. hujiDizhi: '',
  134. gender: '',
  135. juzhuDizhi: '',
  136. minzu: {},
  137. shuxiang: {},
  138. xingzuo: {},
  139. hunyin: {},
  140. xueli: {},
  141. agree: false,
  142. xingzuoIndex: 0,
  143. minzuIndex: 0,
  144. shuxiangIndex: 0,
  145. xingzuoFlag: false
  146. },
  147. xueliList: [],
  148. hunyinList: [],
  149. shuxiangList: [],
  150. xingzuoList: [],
  151. minzuList: [],
  152. // areaTree: [],
  153. pickerData: [],
  154. selectedProvince: '',
  155. selectedCity: ''
  156. }
  157. },
  158. created() {
  159. this.getXueli()
  160. this.getHunyin()
  161. this.getMinzu()
  162. this.getXingzuo()
  163. this.getShuxiang()
  164. this.getJiguan()
  165. },
  166. methods: {
  167. formatData(data) {
  168. const provinces = data.map(province => {
  169. return {
  170. label: province.lable,
  171. value: province.id,
  172. children: province.children.map(city => {
  173. return {
  174. label: city.lable,
  175. value: city.id
  176. };
  177. })
  178. };
  179. });
  180. return provinces;
  181. },
  182. onPickerChange(e) {
  183. const [provinceIndex, cityIndex] = e.detail.value;
  184. const selectedProvince = this.pickerData[provinceIndex];
  185. const selectedCity = selectedProvince.children[cityIndex];
  186. this.selectedProvince = selectedProvince.label;
  187. this.selectedCity = selectedCity.label;
  188. },
  189. checkAllFields() {
  190. const requiredFields = [{
  191. key: 'userName',
  192. name: '手机号'
  193. },
  194. {
  195. key: 'realName',
  196. name: '姓名'
  197. },
  198. {
  199. key: 'idCard',
  200. name: '身份证号'
  201. },
  202. {
  203. key: 'birthday',
  204. name: '生日'
  205. },
  206. // {
  207. // key: 'hometown',
  208. // name: '家乡',
  209. // type: 'array'
  210. // },
  211. {
  212. key: 'hujiDizhi',
  213. name: '身份证地址'
  214. },
  215. {
  216. key: 'gender',
  217. name: '性别'
  218. },
  219. {
  220. key: 'juzhuDizhi',
  221. name: '通讯地址'
  222. },
  223. {
  224. key: 'minzu',
  225. name: '民族',
  226. type: 'object'
  227. },
  228. {
  229. key: 'shuxiang',
  230. name: '属相',
  231. type: 'object'
  232. },
  233. {
  234. key: 'xingzuo',
  235. name: '星座',
  236. type: 'object'
  237. },
  238. ]
  239. for (const field of requiredFields) {
  240. const value = this.formData[field.key]
  241. // 根据不同类型进行存在验证
  242. if (field.type === 'array' && !value?.length) {
  243. this.showAlert(field.name)
  244. return false
  245. }
  246. if (field.type === 'object' && !Object.keys(value).length) {
  247. this.showAlert(field.name)
  248. return false
  249. }
  250. if (field.type === 'boolean' && value !== true) {
  251. this.showAlert(field.name)
  252. return false
  253. }
  254. if (!field.type && !value?.toString().trim()) {
  255. this.showAlert(field.name)
  256. return false
  257. }
  258. }
  259. return true
  260. },
  261. showAlert(fieldName) {
  262. uni.showToast({
  263. title: `${fieldName}不能为空`,
  264. icon: 'none',
  265. duration: 2000
  266. })
  267. },
  268. getJiguan() {
  269. getJiazhengJiguan({}).then(res => {
  270. // this.areaTree = res.data
  271. this.pickerData = this.formatData(res.data);
  272. console.log('this.pickerData',this.pickerData);
  273. }).catch(error => {
  274. console.error('获取技能类型失败:', error);
  275. });
  276. },
  277. getXueli() {
  278. getJiazhengXueli({}).then(res => {
  279. this.xueliList = res.data
  280. // console.log('xueliList', this.xueliList);
  281. }).catch(error => {
  282. console.error('获取技能类型失败:', error);
  283. });
  284. },
  285. getXingzuo() {
  286. getJiazhengXingzuo({}).then(res => {
  287. this.xingzuoList = res.data
  288. // console.log('xingzuoList', this.xingzuoList);
  289. }).catch(error => {
  290. console.error('获取技能类型失败:', error);
  291. });
  292. },
  293. getShuxiang() {
  294. getJiazhengShuxiang({}).then(res => {
  295. this.shuxiangList = res.data
  296. // console.log('shuxiangList', this.shuxiangList);
  297. }).catch(error => {
  298. console.error('获取技能类型失败:', error);
  299. });
  300. },
  301. getHunyin() {
  302. getJiazhengHunyin({}).then(res => {
  303. this.hunyinList = res.data
  304. // console.log('hunyinList', this.hunyinList);
  305. }).catch(error => {
  306. console.error('获取技能类型失败:', error);
  307. });
  308. },
  309. getMinzu() {
  310. getJiazhengMinzu({}).then(res => {
  311. this.minzuList = res.data
  312. // console.log('minzuList', this.minzuList);
  313. }).catch(error => {
  314. console.error('获取技能类型失败:', error);
  315. });
  316. },
  317. getFileUrl(data) {
  318. this.formData.icon = data
  319. console.log('data', data);
  320. },
  321. minzuChange(e) {
  322. const index = e.detail.value
  323. this.formData.minzu = this.minzuList[index]
  324. //console.log('this.formData.minzu', this.formData.minzu);
  325. },
  326. minzuCancel() {
  327. this.formData.minzuIndex = 0
  328. },
  329. xingzuoChange(e) {
  330. const index = e.detail.value
  331. this.formData.xingzuo = this.xingzuoList[index]
  332. // console.log('this.formData.xingzuo', this.formData.xingzuo);
  333. },
  334. xingzuoCancel() {
  335. this.formData.xingzuoIndex = 0
  336. },
  337. shuxiangChange(e) {
  338. const index = e.detail.value
  339. this.formData.shuxiang = this.shuxiangList[index]
  340. //console.log('this.formData.shuxiang', this.formData.shuxiang);
  341. },
  342. shuxiangCancel() {
  343. this.formData.shuxiangIndex = 0
  344. },
  345. selectChangeXueliList(data) {
  346. console.log('data', data);
  347. },
  348. genderSelect(data) {
  349. this.formData.gender = data
  350. },
  351. selectChangeHunyinList(data) {
  352. this.formData.hunyin = data
  353. },
  354. switchXingzuoChange(e) {
  355. this.formData.xingzuoFlag = e.detail.value
  356. },
  357. goNext() {
  358. console.log('formData', this.formData);
  359. if (!this.checkAllFields()) return
  360. this.$emit('goNext', 0);
  361. },
  362. handleAgree(e) {
  363. this.formData.agree = e.detail.value.length > 0
  364. },
  365. }
  366. }
  367. </script>