rightsProtection.js 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234
  1. // pages/form/rightsProtection/rightsProtection.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. tortStoreAdinSite:'美国站',
  15. tortType:'发明专利',
  16. tortClassify:'产品侵权',
  17. ifHavePatent:true,
  18. problemDescription:'商品详细页上使用了未经授权的图片'
  19. },
  20. labelWidth:350,
  21. //站点
  22. countrys:[
  23. { text: '美国站', value: '美国站' },
  24. { text: '日本站', value: '日本站' },
  25. { text: '德国站', value: '德国站' },
  26. { text: '英国站', value: '英国站' },
  27. ],
  28. //侵权类型
  29. typeOptions:[
  30. { text: '发明专利', value: '发明专利' },
  31. { text: '外观设计', value: '外观设计' },
  32. { text: '实用新型', value: '实用新型' },
  33. { text: '商标', value: '商标' },
  34. { text: '版权', value: '版权' },
  35. ],
  36. //侵权分类
  37. typeOptions2:[
  38. { text: '产品侵权', value: '产品侵权' },
  39. { text: '图片侵权', value: '图片侵权' },
  40. { text: '背景侵权', value: '背景侵权' },
  41. { text: '文字侵权', value: '文字侵权' },
  42. ],
  43. //问题描述
  44. problemDescriptions:[
  45. { text: '商品详细页上使用了未经授权的图片', value: '商品详细页上使用了未经授权的图片' },
  46. { text: '实际商品或其包装包含非盗版的未授权的内容', value: '实际商品或其包装包含非盗版的未授权的内容' },
  47. { text: '商品详情页面上使用了未经授权的文本', value: '商品详情页面上使用了未经授权的文本' },
  48. { text: '商品或其包装为盗版(全盘复制受版权保护的商品)', value: '商品或其包装为盗版(全盘复制受版权保护的商品)' },
  49. ]
  50. },
  51. /**
  52. * 生命周期函数--监听页面加载
  53. */
  54. onLoad(options) {
  55. },
  56. /**
  57. * 生命周期函数--监听页面初次渲染完成
  58. */
  59. onReady() {
  60. },
  61. /**
  62. * 生命周期函数--监听页面显示
  63. */
  64. onShow() {
  65. },
  66. /**
  67. * 页面方法集合
  68. */
  69. //表单栏位值发生变化时
  70. onValuesChange(e) {
  71. const { changedValues, allValues } = e.detail
  72. // this.setValues(changedValues)
  73. Object.keys(changedValues).forEach((field) => {
  74. this.setData({
  75. ['form.'+field]: changedValues[field],
  76. })
  77. })
  78. },
  79. //手机号校验
  80. checkPhone(rule, value){
  81. if(!value){
  82. return Promise.reject(new Error('手机号不能为空!'))
  83. }
  84. const isTel = (value) => /^1[34578]\d{9}$/.test(value)
  85. if(!isTel(value)){
  86. return Promise.reject(new Error('手机号输入错误!'))
  87. }
  88. return Promise.resolve()
  89. },
  90. //上传文件
  91. uploadFile(){
  92. const that = this;
  93. wx.chooseMessageFile({
  94. count: 1, // 默认9,表示一次最多可以选择的文件个数
  95. type: 'file', // 可以指定是文件
  96. success(res) {
  97. // 返回选定文件的本地文件路径列表,tempFilePath可以作为文件上传的标识
  98. const tempFilePaths = res.tempFilePaths[0];
  99. upload(tempFilePaths).then(res=>{
  100. console.log(res)
  101. })
  102. }
  103. });
  104. },
  105. //输入备注
  106. changRemark(e){
  107. this.setData(
  108. {
  109. ["form.description"]:e.detail.value
  110. }
  111. )
  112. },
  113. //修改是否拥有专利号
  114. onChange(e){
  115. this.setData(
  116. {
  117. ["form.ifHavePatent"]:e.detail
  118. }
  119. )
  120. },
  121. //修改哪一项最能描述您的问题?
  122. onChange1(e){
  123. this.setData(
  124. {
  125. ["form.problemDescription"]:e.detail
  126. }
  127. )
  128. },
  129. //修改下拉菜单值
  130. changeVanDropdownnValue(e){
  131. var label = e.currentTarget.dataset.label
  132. if(label){
  133. var detail = e.detail
  134. this.setData(
  135. {
  136. ["form."+label]:detail
  137. }
  138. )
  139. }
  140. },
  141. //提交工单
  142. submit(){
  143. var key = api.isLogin()
  144. if(!key){
  145. return false
  146. }
  147. const { validateFields } = $wuxForm()
  148. console.log(this.data.form)
  149. validateFields((err, values) => {
  150. console.log(err)
  151. if (!err) {
  152. var params = {
  153. ticketType:2,
  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. protectionAddDTO:this.data.form
  159. }
  160. api.addTicket(params).then(res=>{
  161. if(res.code == 200){
  162. wx.navigateTo({
  163. url: '/pages/successReminder/successReminder?id=2',
  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. })