edu_info.vue 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369
  1. <template>
  2. <view style="padding: 30rpx;" >
  3. <view style="position: relative;">
  4. <view class="tip">
  5. 请填写真实信息,以便我们后续为您提供完善的 <br>
  6. 个人职业成长定制服务!
  7. </view>
  8. <!-- <view class="btn" style="position: absolute;right: 20rpx;top: 0;">
  9. 编辑
  10. </view> -->
  11. </view>
  12. <view class="form">
  13. <u-form :model="form" ref="uForm">
  14. <u-form-item label="学校名称" :label-width="auto"><u-input v-model="schoolInfo.schoolName" /></u-form-item>
  15. <u-form-item label="全日制" :label-width="auto">
  16. <picker @change="bindPickerChangeFull" :value="index_full" :range="dictObj['full_time_school']">
  17. <view class="picker">
  18. {{dictObj['full_time_school'][index_full]}}
  19. </view>
  20. </picker>
  21. </u-form-item>
  22. <u-form-item label="入学时间" prop="birth" :label-width="auto">
  23. <picker mode="date" :value="admissionTime" @change="bindDateChange">
  24. <view class="picker">
  25. {{admissionTime}}
  26. </view>
  27. </picker>
  28. </u-form-item>
  29. <u-form-item label="毕业时间" prop="birth" :label-width="auto">
  30. <picker mode="date" :value="graduationTime" @change="bindDateChange2">
  31. <view class="picker">
  32. {{graduationTime}}
  33. </view>
  34. </picker>
  35. </u-form-item>
  36. <u-form-item label="学历">
  37. <picker @change="bindPickerChangeLevel" :value="index_level" :range="dictObj['edu_level']">
  38. <view class="picker">
  39. {{index_level?dictObj['edu_level'][index_level]:'未知'}}
  40. </view>
  41. </picker>
  42. </u-form-item>
  43. <u-form-item label="学位">
  44. <picker @change="bindPickerChangeDegree" :value="index_degree" :range="dictObj['academic_degree']">
  45. <view class="picker">
  46. {{dictObj['academic_degree'][index_degree]}}
  47. </view>
  48. </picker>
  49. </u-form-item>
  50. <u-form-item label="学制">
  51. <picker @change="bindPickerChangeSystem" :value="index_system" :range="dictObj['educational_system']">
  52. <view class="picker">
  53. {{dictObj['educational_system'][index_system]}}
  54. </view>
  55. </picker>
  56. </u-form-item>
  57. <u-form-item label="院系">
  58. <picker @change="bindPickerChangeDepartment" :value="index_department" :range="dictObj['department']">
  59. <view class="picker">
  60. {{dictObj['department'][index_department]}}
  61. </view>
  62. </picker>
  63. </u-form-item>
  64. <u-form-item label="专业" :label-width="auto"><u-input v-model="schoolInfo.major" /></u-form-item>
  65. <u-form-item label="班级">
  66. <picker @change="bindPickerChangeGrade" :value="index_grade" :range="dictObj['grade']">
  67. <view class="picker">
  68. {{dictObj['grade'][index_grade]}}
  69. </view>
  70. </picker>
  71. </u-form-item>
  72. <u-form-item label="学信网学籍" :label-width="auto" label-position="top">
  73. <u-upload @on-list-change="changePhotoListHeader" :auto-upload="false" custom-btn="true" :action="action" :file-list="fileList" width="120" height ="120" size-type="['compressed']" max-count="1">
  74. <template v-slot:addBtn >
  75. <image :src="schoolInfo.studentStatusImg ? $method.splitImgHost(schoolInfo.studentStatusImg) : '/static/info_4.png'" style="width: 120rpx; height: 120rpx;"></image>
  76. </template>
  77. </u-upload>
  78. </u-form-item>
  79. </u-form>
  80. </view>
  81. <button @click="submitForm" class="submit_btn">提交</button>
  82. </view>
  83. </template>
  84. <script>
  85. import {mapGetters} from 'vuex';
  86. export default {
  87. data() {
  88. return {
  89. index_degree:0,
  90. index_system:0,
  91. index_department:0,
  92. index_grade:0,
  93. index_level:0,
  94. index_full:0,
  95. action: '33',
  96. fileList: [],
  97. defaultRegionCode:'440112',
  98. form:{
  99. date:'1990-01-01',
  100. region1: ['广东省', '广州市', '天河区'],
  101. region2: ['广东省', '广州市', '天河区'],
  102. },
  103. index_full_day: 0,
  104. full_day: ['男', '女'],
  105. index_sex: 0,
  106. array_sex: ['男', '女'],
  107. index_marry: 0,
  108. array_marry: ['未婚', '已婚'],
  109. index_politic: 0,
  110. array_politic: ['群众', '团员', '党员'],
  111. schoolInfo:{},
  112. admissionTime:'2011-09-01',
  113. graduationTime:'2015-09-01',
  114. studentStatusImg:''
  115. }
  116. },
  117. onLoad(option) {
  118. this.getSchoolInfo()
  119. },
  120. onShow(){
  121. },
  122. computed: {...mapGetters(['dictObj'])},
  123. methods: {
  124. changePhotoListHeader(lists, name) {
  125. this.fileList = lists;
  126. },
  127. submitForm(){
  128. if(!this.schoolInfo.schoolName){
  129. uni.showModal({
  130. title: "提示",
  131. content: '学校名不能为空',
  132. showCancel: false
  133. })
  134. return
  135. }
  136. this.submitImage()
  137. },
  138. async submitImage(){
  139. console.log(this.fileList,33)
  140. if(this.fileList.length > 0&&this.fileList[0].url!=this.$method.splitImgHost(this.schoolInfo.studentStatusImg)){
  141. const waitYS = await this.imageInfos();
  142. }
  143. this.resultForm()
  144. },
  145. imageInfos(){
  146. var self = this
  147. return new Promise((resolve, reject) => {
  148. uni.getImageInfo({
  149. src: self.fileList[0].url,
  150. success: async res => {
  151. let canvasWidth = res.width; //图片原始长宽
  152. let canvasHeight = res.height;
  153. if (canvasWidth > 1000 || canvasHeight > 1000) {
  154. uni.compressImage({
  155. src: self.fileList[0].url,
  156. quality: 75,
  157. width: '50%',
  158. height: '50%',
  159. success: async rest => {
  160. const waitUpload = await self.uploadFile(rest.tempFilePath, 0);
  161. resolve()
  162. }
  163. });
  164. } else {
  165. console.log('无需压缩');
  166. const waitUpload = await self.uploadFile(self.fileList[0].url, 0);
  167. resolve()
  168. }
  169. }
  170. });
  171. });
  172. },
  173. uploadFile(options, int) {
  174. return new Promise((resolve, reject) => {
  175. var self = this;
  176. var data = {
  177. imageStatus: int
  178. };
  179. this.$api.aliyunpolicy(data).then(res => {
  180. var ossToken = res.data.data.resultContent;
  181. uni.uploadFile({
  182. url: ossToken.host,
  183. name: 'file',
  184. filePath: options,
  185. fileType: 'image',
  186. header: {
  187. AuthorizationToken: 'WX ' + uni.getStorageSync('token')
  188. },
  189. formData: {
  190. key: ossToken.dir,
  191. OSSAccessKeyId: ossToken.accessid,
  192. policy: ossToken.policy,
  193. Signature: ossToken.signature,
  194. callback: ossToken.callback,
  195. success_action_status: 200
  196. },
  197. success: result => {
  198. if (result.statusCode === 200) {
  199. self.schoolInfo.studentStatusImg = ossToken.dir;
  200. resolve();
  201. } else {
  202. uni.showToast({
  203. title: '上传失败',
  204. icon: 'none'
  205. });
  206. return;
  207. }
  208. },
  209. fail: error => {
  210. uni.showToast({
  211. title: '上传接口报错',
  212. icon: 'none'
  213. });
  214. return;
  215. }
  216. });
  217. });
  218. });
  219. },
  220. resultForm(){
  221. let that = this
  222. this.schoolInfo.fullTimeSchool = this.dictObj['full_time_school'][this.index_full]
  223. this.schoolInfo.admissionTime = this.admissionTime
  224. this.schoolInfo.graduationTime = this.graduationTime
  225. this.schoolInfo.education = this.dictObj['edu_level'][this.index_level]
  226. this.schoolInfo.academicDegree = this.dictObj['academic_degree'][this.index_degree]
  227. this.schoolInfo.educationalSystem = this.dictObj['educational_system'][this.index_system]
  228. this.schoolInfo.department = this.dictObj['department'][this.index_department]
  229. this.schoolInfo.grade = this.dictObj['grade'][this.index_grade]
  230. this.$api.updateSchoolInfo(this.schoolInfo).then(res => {
  231. if (res.data.code === 200) {
  232. setTimeout(()=>{
  233. uni.showToast({
  234. title: '提交成功',
  235. icon: 'none'
  236. });
  237. },500);
  238. }
  239. });
  240. },
  241. bindPickerChangeDegree(e){
  242. this.index_degree= e.detail.value
  243. },
  244. bindPickerChangeSystem(e){
  245. this.index_system= e.detail.value
  246. },
  247. bindPickerChangeDepartment(e){
  248. this.index_department= e.detail.value
  249. },
  250. bindPickerChangeGrade(e){
  251. this.index_grade= e.detail.value
  252. },
  253. bindPickerChangeFull(e){
  254. this.index_full= e.detail.value
  255. },
  256. bindPickerChangeLevel(e){
  257. this.index_level= e.detail.value
  258. },
  259. getSchoolInfo(){
  260. let that = this
  261. this.$api.getSchoolInfo().then(res => {
  262. if (res.data.code === 200) {
  263. that.schoolInfo = res.data.data
  264. console.log(that.schoolInfo)
  265. if(this.schoolInfo.fullTimeSchool)
  266. this.index_full = this.dictObj['full_time_school'].indexOf((this.schoolInfo.fullTimeSchool))
  267. if(this.schoolInfo.admissionTime)
  268. this.admissionTime = this.schoolInfo.admissionTime
  269. if(this.schoolInfo.graduationTime)
  270. this.graduationTime = this.schoolInfo.graduationTime
  271. if(this.schoolInfo.education)
  272. this.index_level = this.dictObj['edu_level'].indexOf((this.schoolInfo.education))
  273. if(this.schoolInfo.graduationTime)
  274. this.index_degree = this.dictObj['academic_degree'].indexOf((this.schoolInfo.academicDegree))
  275. if(this.schoolInfo.graduationTime)
  276. this.index_system = this.dictObj['educational_system'].indexOf((this.schoolInfo.educationalSystem))
  277. if(this.schoolInfo.graduationTime)
  278. this.index_department = this.dictObj['department'].indexOf((this.schoolInfo.department))
  279. if(this.schoolInfo.graduationTime)
  280. this.index_grade = this.dictObj['grade'].indexOf((this.schoolInfo.grade))
  281. }
  282. });
  283. },
  284. bindPickerChangeSex(e){
  285. this.index_sex= e.detail.value
  286. },
  287. bindPickerChangePolitic(e){
  288. this.index_politic= e.detail.value
  289. },
  290. bindPickerChangeMarry(e){
  291. this.index_marry= e.detail.value
  292. },
  293. handleGetRegion2(region){
  294. let array = []
  295. array.push(region[0].name)
  296. array.push(region[1].name)
  297. array.push(region[2].name)
  298. this.form.region2 = array
  299. },
  300. // 获取选择的地区
  301. handleGetRegion(region){
  302. let array = []
  303. array.push(region[0].name)
  304. array.push(region[1].name)
  305. array.push(region[2].name)
  306. this.form.region1 = array
  307. },
  308. bindDateChange(e){
  309. this.admissionTime=e.detail.value
  310. },
  311. bindDateChange2(e){
  312. this.graduationTime=e.detail.value
  313. },
  314. actionSheetCallback(index) {
  315. uni.hideKeyboard();
  316. this.form.sex_text = this.actionSheetList[index].text;
  317. },
  318. },
  319. }
  320. </script>
  321. <style scope>
  322. .submit_btn{
  323. background-color: #32467B !important;
  324. border-color: #32467B !important;
  325. color: #FFFFFF;
  326. font-size: 30rpx;
  327. padding: 5rpx;
  328. }
  329. .picker{
  330. text-align: right;
  331. }
  332. input{
  333. text-align: right;
  334. }
  335. .form{
  336. background: #FFFFFF;
  337. box-shadow: 0rpx 0rpx 16rpx 4rpx rgba(145, 156, 178, 0.1);
  338. border-radius: 32rpx;
  339. margin: 20rpx 0;
  340. padding: 15rpx;
  341. }
  342. .btn{
  343. width: 96rpx;
  344. height: 48rpx;
  345. background: #32467B;
  346. border-radius: 16rpx;
  347. font-size: 24rpx;
  348. color: #FFFFFF;
  349. line-height: 48rpx;
  350. text-align: center;
  351. }
  352. page {
  353. background: #FDFDFD;
  354. }
  355. .tip{
  356. width: 70%;
  357. font-size: 20rpx;
  358. font-family: PingFang SC;
  359. font-weight: 400;
  360. color: #32467B;
  361. }
  362. </style>