add.js 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174
  1. const app = getApp()
  2. import WxValidate from '../../../utils/wxValidate';
  3. Page({
  4. data: {
  5. frameStyle: { useTop: true, name: '学员信息管理', leftArrow: true, useBar: false },
  6. id: '',
  7. form: { icon: [] },
  8. // 性别
  9. genderList: [],
  10. //运动等级
  11. levelList: [],
  12. },
  13. initValidate() {
  14. const rules = { icon: { required: true }, name: { required: true }, age: { required: true }, gender: { required: true }, phone: { required: true, tel: true } }
  15. // 验证字段的提示信息,若不传则调用默认的信息
  16. const messages = { icon: { required: '请选择头像' }, name: { required: '请输入学员姓名' }, age: { required: '请输入年龄' }, gender: { required: '请选择性别' }, phone: { required: '请输入联系电话' } };
  17. this.WxValidate = new WxValidate(rules, messages)
  18. },
  19. // 返回
  20. back: function () {
  21. wx.navigateBack({ delta: 1 })
  22. },
  23. //上传图片
  24. imgUpl: function (e) {
  25. const that = this;
  26. let data = that.data.form.icon;
  27. data.push(e.detail)
  28. that.setData({ 'form.icon': data })
  29. },
  30. // 删除图片
  31. imgDel: function (e) {
  32. const that = this;
  33. let list = that.data.form.icon;
  34. let arr = list.filter((i, index) => index != e.detail.index)
  35. that.setData({ 'form.icon': arr })
  36. },
  37. // 选择性别
  38. genderChange: function (e) {
  39. const that = this;
  40. let data = that.data.genderList[e.detail.value];
  41. if (data) {
  42. that.setData({ 'form.gender': data.value });
  43. that.setData({ 'form.zhGender': data.label });
  44. }
  45. },
  46. // 选择等级
  47. levelChange: function (e) {
  48. const that = this;
  49. let data = that.data.levelList[e.detail.value];
  50. if (data) {
  51. that.setData({ 'form.level': data.value });
  52. that.setData({ 'form.zhLevel': data.label });
  53. }
  54. },
  55. //提交
  56. onSubmit: async function (e) {
  57. const that = this;
  58. const form = that.data.form;
  59. const params = e.detail.value;
  60. params.icon = form.icon;
  61. if (!this.WxValidate.checkForm(params)) {
  62. const error = this.WxValidate.errorList[0];
  63. wx.showToast({ title: `${error.msg}`, icon: 'error', duration: 2000 })
  64. return false
  65. } else {
  66. let arr;
  67. if (form._id) arr = await app.$post(`/student/${form._id}`, params);
  68. else arr = await app.$post(`/student`, params)
  69. if (arr.errcode == '0') { wx.showToast({ title: `维护信息完成`, icon: 'success', duration: 2000 }); that.back(); }
  70. else wx.showToast({ title: `${errmsg}`, icon: 'error', duration: 2000 })
  71. }
  72. },
  73. /**
  74. * 生命周期函数--监听页面加载
  75. */
  76. onLoad: async function (options) {
  77. const that = this;
  78. that.setData({ id: options.id || '' })
  79. //验证规则函数
  80. that.initValidate();
  81. // 查询其他信息
  82. await that.searchOther();
  83. // 监听用户是否登录
  84. await that.watchLogin();
  85. },
  86. searchOther: async function () {
  87. const that = this;
  88. let arr;
  89. // 性别
  90. arr = await app.$get(`/dict`, { code: 'gender' });
  91. if (arr.errcode == '0' && arr.total > 0) {
  92. let list = arr.data[0].list;
  93. that.setData({ genderList: list })
  94. }
  95. // 运动等级
  96. arr = await app.$get(`/dict`, { code: 'student_grade' });
  97. if (arr.errcode == '0' && arr.total > 0) {
  98. let list = arr.data[0].list;
  99. that.setData({ levelList: list })
  100. }
  101. },
  102. // 监听用户是否登录
  103. watchLogin: async function () {
  104. const that = this;
  105. let genderList = that.data.genderList;
  106. let levelList = that.data.levelList;
  107. wx.getStorage({
  108. key: 'user',
  109. success: async res => {
  110. if (that.data.id) {
  111. const arr = await app.$get(`/student/${that.data.id}`);
  112. if (arr.errcode == '0') {
  113. let gender = genderList.find(i => i.value == arr.data.gender)
  114. if (gender) arr.data.zhGender = gender.label;
  115. let level = levelList.find(i => i.value == arr.data.level)
  116. if (level) arr.data.zhLevel = level.label;
  117. that.setData({ form: arr.data });
  118. }
  119. }
  120. },
  121. fail: async res => {
  122. wx.redirectTo({ url: '/pages/index/index' })
  123. }
  124. })
  125. },
  126. /**
  127. * 生命周期函数--监听页面初次渲染完成
  128. */
  129. onReady: function () {
  130. },
  131. /**
  132. * 生命周期函数--监听页面显示
  133. */
  134. onShow: function () {
  135. },
  136. /**
  137. * 生命周期函数--监听页面隐藏
  138. */
  139. onHide: function () {
  140. },
  141. /**
  142. * 生命周期函数--监听页面卸载
  143. */
  144. onUnload: function () {
  145. },
  146. /**
  147. * 页面相关事件处理函数--监听用户下拉动作
  148. */
  149. onPullDownRefresh: function () {
  150. },
  151. /**
  152. * 页面上拉触底事件的处理函数
  153. */
  154. onReachBottom: function () {
  155. },
  156. /**
  157. * 用户点击右上角分享
  158. */
  159. onShareAppMessage: function () {
  160. }
  161. })