index.ts 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357
  1. // pages/search/index.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) { item.isCheck = !item.isCheck }
  145. return item
  146. }) })
  147. /// 赋值
  148. this.setData({ shape: this.data.shapes.map(item => {
  149. return item.id.toString()
  150. }) })
  151. break;
  152. case 'currency':
  153. this.setData({ currencys: this.data.currencys.map(item => {
  154. if (item.id == index) {
  155. item.isCheck = true
  156. /// 赋值
  157. this.setData({ currency: item.id })
  158. } else {
  159. item.isCheck = false
  160. }
  161. return item
  162. }) })
  163. break;
  164. case 'color': /// 颜色
  165. this.setData({ colors: this.data.colors.map(item => {
  166. if (item.id == index) { item.isCheck = !item.isCheck }
  167. return item
  168. }) })
  169. /// 赋值
  170. this.setData({ color: this.data.colors.map(item => {
  171. return item.id.toString()
  172. }) })
  173. break;
  174. case 'neatness': /// 净度
  175. this.setData({ neatness: this.data.neatness.map(item => {
  176. if (item.id == index) {
  177. item.isCheck = true
  178. /// 赋值
  179. this.setData({ neatnes: item.id })
  180. } else {
  181. item.isCheck = false
  182. }
  183. return item
  184. }) })
  185. break;
  186. case 'qiegong': /// 切工
  187. this.setData({ qiegongs: this.data.qiegongs.map(item => {
  188. if (item.id == index) {
  189. item.isCheck = true
  190. /// 赋值
  191. this.setData({ qiegong: item.id })
  192. } else {
  193. item.isCheck = false
  194. }
  195. return item
  196. }) })
  197. break;
  198. case 'duicheng': /// 对称
  199. this.setData({ duichengs: this.data.duichengs.map(item => {
  200. if (item.id == index) {
  201. item.isCheck = true
  202. /// 赋值
  203. this.setData({ duicheng: item.id })
  204. } else {
  205. item.isCheck = false
  206. }
  207. return item
  208. }) })
  209. break;
  210. case 'polishing': /// 抛光
  211. this.setData({ paoguangs: this.data.paoguangs.map(item => {
  212. if (item.id == index) {
  213. item.isCheck = true
  214. /// 赋值
  215. this.setData({ polishing: item.id })
  216. } else {
  217. item.isCheck = false
  218. }
  219. return item
  220. }) })
  221. break;
  222. case 'yingguang': /// 荧光
  223. this.setData({ yingguangs: this.data.yingguangs.map(item => {
  224. if (item.id == index) {
  225. item.isCheck = true
  226. /// 赋值
  227. this.setData({ yingguang: item.id })
  228. } else {
  229. item.isCheck = false
  230. }
  231. return item
  232. }) })
  233. break;
  234. case 'certificate': /// 证书
  235. this.setData({ certificates: this.data.certificates.map(item => {
  236. if (item.id == index) {
  237. item.isCheck = true
  238. /// 赋值
  239. this.setData({ certificate: item.id })
  240. } else {
  241. item.isCheck = false
  242. }
  243. return item
  244. }) })
  245. break;
  246. case 'search': /// 搜索
  247. /// 搜索页面跳转
  248. this.goToSearch()
  249. break;
  250. case 'clear': break;
  251. default: break;
  252. }
  253. },
  254. /// 重量范围值更改
  255. syncNumRange(e: any) {
  256. this.setData({
  257. minweight: e.detail.value[0],
  258. maxweight: e.detail.value[1],
  259. })
  260. },
  261. /// 搜索页面跳转
  262. goToSearch() {
  263. /// 数据拼接
  264. const info = {
  265. category: this.data.tabs[this.data.active].id,
  266. zsshapetype: this.data.shape,
  267. zsclaritytype: this.data.neatnes,
  268. zscuttype: this.data.qiegong,
  269. zssymmetrytype: this.data.duicheng,
  270. zspolishtype: this.data.paoguang,
  271. zsfluorescencetype: this.data.yingguang,
  272. zscurrencytype: this.data.currency,
  273. zscerttype: this.data.certificate,
  274. zscolortype: this.data.color,
  275. weight1: this.data.minweight,
  276. weight2: this.data.maxweight
  277. }
  278. /// 页面跳转
  279. wx.switchTab({
  280. url: '/pages/trade/index',
  281. /// 加载成功
  282. success: () => {
  283. /// 缓存数据
  284. wx.setStorageSync('TradeParams', JSON.stringify(info))
  285. }
  286. })
  287. },
  288. /**
  289. * 生命周期函数--监听页面加载
  290. */
  291. onLoad() {
  292. },
  293. /**
  294. * 生命周期函数--监听页面初次渲染完成
  295. */
  296. onReady() {
  297. },
  298. /**
  299. * 生命周期函数--监听页面显示
  300. */
  301. onShow() {
  302. },
  303. /**
  304. * 生命周期函数--监听页面隐藏
  305. */
  306. onHide() {
  307. },
  308. /**
  309. * 生命周期函数--监听页面卸载
  310. */
  311. onUnload() {
  312. },
  313. /**
  314. * 页面相关事件处理函数--监听用户下拉动作
  315. */
  316. onPullDownRefresh() {
  317. },
  318. /**
  319. * 页面上拉触底事件的处理函数
  320. */
  321. onReachBottom() {
  322. },
  323. /**
  324. * 用户点击右上角分享
  325. */
  326. onShareAppMessage() {
  327. }
  328. })