add.js 4.6 KB

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