appeal.js 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238
  1. // pages/form/appeal/appeal.js
  2. const upload = require("../../../utils/upload")
  3. const api = require('../../../api/index')
  4. import { $wuxForm} from '../../../miniprogram_npm/wux-weapp/index'
  5. Page({
  6. /**
  7. * 页面的初始数据
  8. */
  9. data: {
  10. validateMessages: {
  11. required: '%s 字段为必填',
  12. },
  13. form:{
  14. complainAdinSite:'美国站',
  15. complainedAdinSite:'美国站',
  16. isOriginal:true,
  17. complainedType:'商标',
  18. ifTalked:true
  19. },
  20. labelWidth:350,
  21. imageUrl:'',
  22. //站点
  23. countrys:[
  24. { text: '美国站', value: '美国站' },
  25. { text: '日本站', value: '日本站' },
  26. { text: '德国站', value: '德国站' },
  27. { text: '英国站', value: '英国站' },
  28. ],
  29. //被投诉类型
  30. complainedTypes:[
  31. { text: '商标', value: '商标' },
  32. { text: '专利', value: '专利' },
  33. { text: '版权', value: '版权' },
  34. ]
  35. },
  36. /**
  37. * 生命周期函数--监听页面加载
  38. */
  39. onLoad(options) {
  40. },
  41. /**
  42. * 生命周期函数--监听页面初次渲染完成
  43. */
  44. onReady() {
  45. },
  46. /**
  47. * 生命周期函数--监听页面显示
  48. */
  49. onShow() {
  50. },
  51. /**
  52. * 页面方法集合
  53. */
  54. //表单栏位值发生变化时
  55. onValuesChange(e) {
  56. console.log(e)
  57. const { changedValues, allValues } = e.detail
  58. // this.setValues(changedValues)
  59. Object.keys(changedValues).forEach((field) => {
  60. this.setData({
  61. ['form.'+field]: changedValues[field],
  62. })
  63. })
  64. console.log('onValuesChange \n', changedValues, allValues)
  65. },
  66. //手机号校验
  67. checkPhone(rule, value){
  68. if(!value){
  69. return Promise.reject(new Error('手机号不能为空!'))
  70. }
  71. const isTel = (value) => /^1[34578]\d{9}$/.test(value)
  72. if(!isTel(value)){
  73. return Promise.reject(new Error('手机号输入错误!'))
  74. }
  75. return Promise.resolve()
  76. },
  77. //上传文件
  78. beforeUpload(e){
  79. if(e.detail.errMsg=="chooseMedia:ok"){
  80. // var data = [{
  81. // status: 'done',
  82. // url: e.detail.tempFiles[0].tempFilePath,
  83. // }]
  84. var that = this
  85. this.setData({ imageUrl:e.detail.tempFiles[0].tempFilePath })
  86. upload.upload(tempFilePaths).then(res=>{
  87. if(res.code == 200){
  88. var arr = []
  89. arr.push(res.data[0])
  90. that.setData(
  91. {
  92. ["form.fileGuids"]:arr
  93. }
  94. )
  95. }
  96. })
  97. }
  98. },
  99. //输入备注
  100. changRemark(e){
  101. this.setData(
  102. {
  103. ["form.description"]:e.detail.value
  104. }
  105. )
  106. },
  107. //修改商品是否原创
  108. onChange(e){
  109. this.setData(
  110. {
  111. ["form.isOriginal"]:e.detail
  112. }
  113. )
  114. },
  115. //修改被投诉类型
  116. onChange1(e){
  117. this.setData(
  118. {
  119. ["form.complainedType"]:e.detail
  120. }
  121. )
  122. },
  123. //修改是否协商过
  124. onChange3(e){
  125. this.setData(
  126. {
  127. ["form.ifTalked"]:e.detail
  128. }
  129. )
  130. },
  131. //修改下拉菜单值
  132. changeVanDropdownnValue(e){
  133. var label = e.currentTarget.dataset.label
  134. if(label){
  135. var detail = e.detail
  136. this.setData(
  137. {
  138. ["form."+label]:detail
  139. }
  140. )
  141. }
  142. },
  143. //提交工单
  144. submit(){
  145. var key = api.isLogin()
  146. if(!key){
  147. return false
  148. }
  149. const { validateFields } = $wuxForm()
  150. validateFields((err, values) => {
  151. console.log(err)
  152. if (!err) {
  153. var params = {
  154. ticketType:3,
  155. contactPerson:this.data.form.contactPerson,
  156. contactPhone:this.data.form.contactPhone,
  157. contactMail:this.data.form.contactMail,
  158. fileGuids:this.data.form.fileGuids,
  159. respondingAddDTO:this.data.form
  160. }
  161. wx.showLoading({
  162. title: '加载中',
  163. })
  164. api.addTicket(params).then(res=>{
  165. if(res.code == 200){
  166. wx.navigateTo({
  167. url: '/pages/successReminder/successReminder?id=3',
  168. })
  169. }
  170. })
  171. }else{
  172. var error = Object.keys(err)
  173. var key = error[0]
  174. var len = err[key].errors.length
  175. var message = err[key].errors[len-1].message
  176. wx.showModal({
  177. title: '提示',
  178. content: message,
  179. complete: (res) => {
  180. if (res.cancel) {
  181. }
  182. if (res.confirm) {
  183. }
  184. }
  185. })
  186. }
  187. })
  188. },
  189. /**
  190. * 生命周期函数--监听页面隐藏
  191. */
  192. onHide() {
  193. },
  194. /**
  195. * 生命周期函数--监听页面卸载
  196. */
  197. onUnload() {
  198. },
  199. /**
  200. * 页面相关事件处理函数--监听用户下拉动作
  201. */
  202. onPullDownRefresh() {
  203. },
  204. /**
  205. * 页面上拉触底事件的处理函数
  206. */
  207. onReachBottom() {
  208. },
  209. /**
  210. * 用户点击右上角分享
  211. */
  212. onShareAppMessage() {
  213. }
  214. })