edu_info.vue 11 KB

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