search.ts 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361
  1. // pages/search/search.ts
  2. Page({
  3. /**
  4. * 页面的初始数据
  5. */
  6. data: {
  7. /// 底部安全区域
  8. safeBottom: getApp().globalData.safeBottom,
  9. /// tabs
  10. tabs: [{id: 2, name: '单颗裸钻'}, {id: 5, name: '单颗彩钻'}],
  11. /// tab索引
  12. active: 0,
  13. /// 形状
  14. shapes: [{id: 1, name: '圆明亮形', isCheck: true},
  15. {id: 2, name: '公主方形', isCheck: false},
  16. {id: 3, name: '心形', isCheck: false},
  17. {id: 4, name: '马眼形', isCheck: false},
  18. {id: 5, name: '三角形', isCheck: false},
  19. {id: 6, name: '垫形', isCheck: false},
  20. {id: 7, name: '祖母绿形', isCheck: false},
  21. {id: 8, name: '梨形', isCheck: false},
  22. {id: 9, name: '椭圆形', isCheck: false},
  23. {id: 10, name: '长方形', isCheck: false},
  24. {id: 11, name: '雷迪恩形', isCheck: false},
  25. {id: 12, name: '阿斯切形', isCheck: false},
  26. {id: 13, name: '其他', isCheck: false}],
  27. /// 选中形状
  28. shape: 1,
  29. /// 颜色
  30. colors: [{id: 1, name: 'D', isCheck: true},
  31. {id: 2, name: 'E', isCheck: false},
  32. {id: 3, name: 'F', isCheck: false},
  33. {id: 4, name: 'G', isCheck: false},
  34. {id: 5, name: 'H', isCheck: false},
  35. {id: 6, name: 'I', isCheck: false},
  36. {id: 7, name: 'J', isCheck: false},
  37. {id: 8, name: 'K', isCheck: false},
  38. {id: 9, name: 'L', isCheck: false},
  39. {id: 10, name: 'M', isCheck: false},
  40. {id: 11, name: 'N', isCheck: false},
  41. {id: 12, name: 'O', isCheck: false},
  42. {id: 13, name: 'P', isCheck: false},
  43. {id: 14, name: 'Q', isCheck: false},
  44. {id: 15, name: 'R', isCheck: false},
  45. {id: 16, name: 'S', isCheck: false},
  46. {id: 17, name: 'T', isCheck: false},
  47. {id: 18, name: 'U', isCheck: false},
  48. {id: 19, name: 'W', isCheck: false},
  49. {id: 20, name: 'V', isCheck: false},
  50. {id: 21, name: 'X', isCheck: false},
  51. {id: 22, name: 'Y', isCheck: false},
  52. {id: 23, name: 'Z', isCheck: false},
  53. {id: 24, name: '彩色', isCheck: false}],
  54. /// 选中形状
  55. color: 1,
  56. /// 净度
  57. neatness: [{id: 1, name: 'FL', isCheck: true},
  58. {id: 2, name: 'IF', isCheck: false},
  59. {id: 3, name: 'VVS1', isCheck: false},
  60. {id: 4, name: 'VVS2', isCheck: false},
  61. {id: 5, name: 'VS1', isCheck: false},
  62. {id: 6, name: 'VS2', isCheck: false},
  63. {id: 7, name: 'SI1', isCheck: false},
  64. {id: 8, name: 'SI2', isCheck: false},
  65. {id: 9, name: 'SI3', isCheck: false},
  66. {id: 10, name: 'I1', isCheck: false},
  67. {id: 11, name: 'I2', isCheck: false},
  68. {id: 12, name: 'I3', isCheck: false}],
  69. /// 选中净度
  70. neatnes: 1,
  71. /// 切工
  72. qiegongs: [{id: 1, name: 'EX', isCheck: true},
  73. {id: 2, name: 'VG', isCheck: false},
  74. {id: 3, name: 'G', isCheck: false},
  75. {id: 4, name: 'F', isCheck: false},
  76. {id: 5, name: 'P', isCheck: false}],
  77. /// 选中切工
  78. qiegong: 1,
  79. /// 对称
  80. duichengs: [{id: 1, name: 'EX', isCheck: true},
  81. {id: 2, name: 'VG', isCheck: false},
  82. {id: 3, name: 'G', isCheck: false},
  83. {id: 4, name: 'F', isCheck: false},
  84. {id: 5, name: 'P', isCheck: false}],
  85. duicheng: 1,
  86. /// 抛光
  87. paoguangs: [{id: 1, name: 'EX', isCheck: true},
  88. {id: 2, name: 'VG', isCheck: false},
  89. {id: 3, name: 'G', isCheck: false},
  90. {id: 4, name: 'F', isCheck: false},
  91. {id: 5, name: 'P', isCheck: false}],
  92. paoguang: 1,
  93. /// 莹光
  94. yingguangs: [{id: 1, name: '无', isCheck: true},
  95. {id: 2, name: '微弱', isCheck: false},
  96. {id: 3, name: '中等', isCheck: false},
  97. {id: 4, name: '强', isCheck: false},
  98. {id: 5, name: '极强', isCheck: false}],
  99. /// 选中莹光
  100. yingguang: 1,
  101. /// 证书
  102. certificates: [{id: 1, name: 'GIA', isCheck: true},
  103. {id: 2, name: 'NGTC', isCheck: false},
  104. {id: 3, name: 'HRD', isCheck: false},
  105. {id: 4, name: 'IGI', isCheck: false},
  106. {id: 5, name: 'EGL', isCheck: false},
  107. {id: 6, name: 'AGS', isCheck: false},
  108. {id: 7, name: 'NGIC', isCheck: false},
  109. {id: 8, name: 'Others', isCheck: false}],
  110. /// 选中证书
  111. certificate: 1,
  112. /// 币种
  113. currencys: [{id: 1, name: '人民币(¥)', isCheck: true},
  114. {id: 2, name: '美元($)', isCheck: false}],
  115. currency: 1,
  116. /// 最小重量
  117. minweight: 0.00,
  118. /// 最大重量
  119. maxweight: 0.00
  120. },
  121. /**
  122. * tab触发事件
  123. */
  124. onTabChange(e: any) {
  125. /// 设置激活项
  126. this.setData({ active: e.detail.index })
  127. },
  128. /**
  129. * 返回上层视图
  130. */
  131. backToParent() {
  132. /// 返回上层视图
  133. wx.navigateBack()
  134. },
  135. /// 按钮点击事件
  136. onButtonPressed(e: any) {
  137. /// 数据拼接
  138. const ids = (<string> e.target.id).split(' ')
  139. const id = (<string> e.target.id).split(' ')[0]
  140. const index = <number> <unknown>ids[1]
  141. switch (id) {
  142. case 'shape': /// 形状
  143. this.setData({ shapes: this.data.shapes.map(item => {
  144. if (item.id == index) {
  145. item.isCheck = true
  146. /// 赋值
  147. this.setData({ shape: item.id })
  148. } else {
  149. item.isCheck = false
  150. }
  151. return item
  152. }) })
  153. break;
  154. case 'currency':
  155. this.setData({ currencys: this.data.currencys.map(item => {
  156. if (item.id == index) {
  157. item.isCheck = true
  158. /// 赋值
  159. this.setData({ currency: item.id })
  160. } else {
  161. item.isCheck = false
  162. }
  163. return item
  164. }) })
  165. break;
  166. case 'color': /// 颜色
  167. this.setData({ colors: this.data.colors.map(item => {
  168. if (item.id == index) {
  169. item.isCheck = true
  170. /// 赋值
  171. this.setData({ color: item.id })
  172. } else {
  173. item.isCheck = false
  174. }
  175. return item
  176. }) })
  177. break;
  178. case 'neatness': /// 净度
  179. this.setData({ neatness: this.data.neatness.map(item => {
  180. if (item.id == index) {
  181. item.isCheck = true
  182. /// 赋值
  183. this.setData({ neatnes: item.id })
  184. } else {
  185. item.isCheck = false
  186. }
  187. return item
  188. }) })
  189. break;
  190. case 'qiegong': /// 切工
  191. this.setData({ qiegongs: this.data.qiegongs.map(item => {
  192. if (item.id == index) {
  193. item.isCheck = true
  194. /// 赋值
  195. this.setData({ qiegong: item.id })
  196. } else {
  197. item.isCheck = false
  198. }
  199. return item
  200. }) })
  201. break;
  202. case 'duicheng': /// 对称
  203. this.setData({ duichengs: this.data.duichengs.map(item => {
  204. if (item.id == index) {
  205. item.isCheck = true
  206. /// 赋值
  207. this.setData({ duicheng: item.id })
  208. } else {
  209. item.isCheck = false
  210. }
  211. return item
  212. }) })
  213. break;
  214. case 'polishing': /// 抛光
  215. this.setData({ paoguangs: this.data.paoguangs.map(item => {
  216. if (item.id == index) {
  217. item.isCheck = true
  218. /// 赋值
  219. this.setData({ polishing: item.id })
  220. } else {
  221. item.isCheck = false
  222. }
  223. return item
  224. }) })
  225. break;
  226. case 'yingguang': /// 荧光
  227. this.setData({ yingguangs: this.data.yingguangs.map(item => {
  228. if (item.id == index) {
  229. item.isCheck = true
  230. /// 赋值
  231. this.setData({ yingguang: item.id })
  232. } else {
  233. item.isCheck = false
  234. }
  235. return item
  236. }) })
  237. break;
  238. case 'certificate': /// 证书
  239. this.setData({ certificates: this.data.certificates.map(item => {
  240. if (item.id == index) {
  241. item.isCheck = true
  242. /// 赋值
  243. this.setData({ certificate: item.id })
  244. } else {
  245. item.isCheck = false
  246. }
  247. return item
  248. }) })
  249. break;
  250. case 'search': /// 搜索
  251. /// 搜索页面跳转
  252. this.goToSearch()
  253. break;
  254. case 'clear': break;
  255. default: break;
  256. }
  257. },
  258. /// 重量范围值更改
  259. syncNumRange(e: any) {
  260. this.setData({
  261. minweight: e.detail.value[0],
  262. maxweight: e.detail.value[1],
  263. })
  264. },
  265. /// 搜索页面跳转
  266. goToSearch() {
  267. /// 数据拼接
  268. const info = {
  269. category: this.data.tabs[this.data.active].id,
  270. zsshapetype: this.data.shape,
  271. zsclaritytype: this.data.neatnes,
  272. zscuttype: this.data.qiegong,
  273. zssymmetrytype: this.data.duicheng,
  274. zspolishtype: this.data.paoguang,
  275. zsfluorescencetype: this.data.yingguang,
  276. zscurrencytype: this.data.currency,
  277. zscerttype: this.data.certificate,
  278. zscolortype: this.data.color,
  279. weight1: this.data.minweight,
  280. weight2: this.data.maxweight
  281. }
  282. /// 页面跳转
  283. wx.switchTab({
  284. url: '/pages/trade/trade',
  285. /// 加载成功
  286. success: () => {
  287. /// 缓存数据
  288. wx.setStorageSync('TradeParams', JSON.stringify(info))
  289. }
  290. })
  291. },
  292. /**
  293. * 生命周期函数--监听页面加载
  294. */
  295. onLoad() {
  296. },
  297. /**
  298. * 生命周期函数--监听页面初次渲染完成
  299. */
  300. onReady() {
  301. },
  302. /**
  303. * 生命周期函数--监听页面显示
  304. */
  305. onShow() {
  306. },
  307. /**
  308. * 生命周期函数--监听页面隐藏
  309. */
  310. onHide() {
  311. },
  312. /**
  313. * 生命周期函数--监听页面卸载
  314. */
  315. onUnload() {
  316. },
  317. /**
  318. * 页面相关事件处理函数--监听用户下拉动作
  319. */
  320. onPullDownRefresh() {
  321. },
  322. /**
  323. * 页面上拉触底事件的处理函数
  324. */
  325. onReachBottom() {
  326. },
  327. /**
  328. * 用户点击右上角分享
  329. */
  330. onShareAppMessage() {
  331. }
  332. })