appeal.js 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234
  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. this.setData({ imageUrl:e.detail.tempFiles[0].tempFilePath })
  85. upload.upload(tempFilePaths).then(res=>{
  86. if(res.code == 200){
  87. var arr = []
  88. arr.push(res.data[0])
  89. this.setData(
  90. {
  91. ["form.fileGuids"]:arr
  92. }
  93. )
  94. }
  95. })
  96. }
  97. },
  98. //输入备注
  99. changRemark(e){
  100. this.setData(
  101. {
  102. ["form.description"]:e.detail.value
  103. }
  104. )
  105. },
  106. //修改商品是否原创
  107. onChange(e){
  108. this.setData(
  109. {
  110. ["form.isOriginal"]:e.detail
  111. }
  112. )
  113. },
  114. //修改被投诉类型
  115. onChange1(e){
  116. this.setData(
  117. {
  118. ["form.complainedType"]:e.detail
  119. }
  120. )
  121. },
  122. //修改是否协商过
  123. onChange3(e){
  124. this.setData(
  125. {
  126. ["form.ifTalked"]:e.detail
  127. }
  128. )
  129. },
  130. //修改下拉菜单值
  131. changeVanDropdownnValue(e){
  132. var label = e.currentTarget.dataset.label
  133. if(label){
  134. var detail = e.detail
  135. this.setData(
  136. {
  137. ["form."+label]:detail
  138. }
  139. )
  140. }
  141. },
  142. //提交工单
  143. submit(){
  144. var key = api.isLogin()
  145. if(!key){
  146. return false
  147. }
  148. const { validateFields } = $wuxForm()
  149. validateFields((err, values) => {
  150. console.log(err)
  151. if (!err) {
  152. var params = {
  153. ticketType:3,
  154. contactPerson:this.data.form.contactPerson,
  155. contactPhone:this.data.form.contactPhone,
  156. contactMail:this.data.form.contactMail,
  157. fileGuids:this.data.form.fileGuids,
  158. respondingAddDTO:this.data.form
  159. }
  160. api.addTicket(params).then(res=>{
  161. if(res.code == 200){
  162. wx.navigateTo({
  163. url: '/pages/successReminder/successReminder?id=3',
  164. })
  165. }
  166. })
  167. }else{
  168. var error = Object.keys(err)
  169. var key = error[0]
  170. var len = err[key].errors.length
  171. var message = err[key].errors[len-1].message
  172. wx.showModal({
  173. title: '提示',
  174. content: message,
  175. complete: (res) => {
  176. if (res.cancel) {
  177. }
  178. if (res.confirm) {
  179. }
  180. }
  181. })
  182. }
  183. })
  184. },
  185. /**
  186. * 生命周期函数--监听页面隐藏
  187. */
  188. onHide() {
  189. },
  190. /**
  191. * 生命周期函数--监听页面卸载
  192. */
  193. onUnload() {
  194. },
  195. /**
  196. * 页面相关事件处理函数--监听用户下拉动作
  197. */
  198. onPullDownRefresh() {
  199. },
  200. /**
  201. * 页面上拉触底事件的处理函数
  202. */
  203. onReachBottom() {
  204. },
  205. /**
  206. * 用户点击右上角分享
  207. */
  208. onShareAppMessage() {
  209. }
  210. })