From a75b18a4157ab486e0b51c438ac165ab3a08e3e0 Mon Sep 17 00:00:00 2001
From: k94314517 <8417338+k94314517@user.noreply.gitee.com>
Date: 星期四, 25 七月 2024 18:10:00 +0800
Subject: [PATCH] 代码提交

---
 wechat_jiaxuan/components/disProduct/index.js |  102 +++++++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 87 insertions(+), 15 deletions(-)

diff --git a/wechat_jiaxuan/components/disProduct/index.js b/wechat_jiaxuan/components/disProduct/index.js
index e932f66..d1d3649 100644
--- a/wechat_jiaxuan/components/disProduct/index.js
+++ b/wechat_jiaxuan/components/disProduct/index.js
@@ -1,22 +1,26 @@
-import { getCatalogList, getZhongTaiProductPage } from '../../api/index'
+import { getCatalogList,getCataLogTagList, getZhongTaiProductPage } from '../../api/index'
 Component({
   /**
    * 缁勪欢鐨勫睘鎬у垪琛�
    */
   properties: {
+    menuButtonInfo: Object
   },
 
   /**
    * 缁勪欢鐨勫垵濮嬫暟鎹�
    */
   data: {
-    showOne: false,
-    showTwo: false,
+    activeIndex: -1,
+    activeParam: [],
+    tagCodes: [],
 
     cateList: [],
+    secondCateList: [],
     datalist: [],
     pageNum: 1,
     pageSize: 10,
+    total: 0,
     query: '',
     sortType: 'NORMAL',
     catalogCode: ""
@@ -52,17 +56,24 @@
     },
     getTag() {
       const catalogCode = this.data.catalogCode
-      getCatalogList({
+      getCataLogTagList({
         catalogCode
+      }).then(res => {
+        this.setData({
+          secondCateList: res.data || [],
+          activeParam: []
+        })
       })
     },
     bindblur() {
+      console.log('澶卞幓鐒︾偣');
+      this.setData({ pageNum: 1,datalist: [],total: 0})
       this.getList()
     },
     getList() {
-      const { catalogCode, pageNum, pageSize, sortType, query } = this.data
+      const { catalogCode,tagCodes, pageNum, pageSize, sortType, query } = this.data
       getZhongTaiProductPage({
-        catalogCode,pageNum,pageSize,sortType,query
+        catalogCode,pageNum,pageSize,sortType,query,tagCodes
       }).then(res => {
         this.setData({
           datalist: [...this.data.datalist, ...res.data.records],
@@ -70,14 +81,30 @@
         })
       })
     },
+    scrolltolower() {
+      console.log('瑙﹀簳浜嬩欢');
+      const { total, datalist, pageNum } = this.data
+      if(total > datalist.length){
+        this.setData({ pageNum: pageNum + 1 })
+        this.getList()
+      }else{
+        wx.showToast({
+          title: '鏆傛棤鏇村鏁版嵁',
+          icon: 'none'
+        })
+      }
+    },
     cateClick(e) {
       const catalogCode = e.currentTarget.dataset.code
-      this.setData({ catalogCode })
+      this.setData({ catalogCode, tagCodes: [] })
+      this.setData({ pageNum: 1,datalist: [],total: 0})
+      this.getTag()
       this.getList()
     },
     statusChange(e) {
       const sortType = e.currentTarget.dataset.status
       this.setData({sortType})
+      this.setData({ pageNum: 1,datalist: [],total: 0})
       this.getList()
     },
     handleDetail(e) {
@@ -86,15 +113,60 @@
         url: '/pages/detailDis/product?id=' + id,
       })
     },
-    changeOne(){
-      const showOne = !this.data.showOne
-      this.setData({showOne})
-      this.setData({showTwo: false})
+    tagClick(e) {
+      const code = e.currentTarget.dataset.code
+      const paramIndex = e.currentTarget.dataset.index
+      const { secondCateList, tagCodes, activeParam, activeIndex } = this.data
+      const index = tagCodes.indexOf(code)
+      console.log('code', code);
+      console.log('tagCodes', tagCodes);
+      if(index === -1){
+        // 鍚宲aram閲宑ode閲嶅
+        if(activeParam && activeParam.length > 0){
+          activeParam.forEach(item => {
+            const indexTemp = tagCodes.indexOf(item.labelValueCode)
+            if(indexTemp > -1){
+              tagCodes.splice(indexTemp, 1)
+            }
+          })
+        }
+        tagCodes.push(code)
+        secondCateList[activeIndex].paramIndex = paramIndex
+        secondCateList[activeIndex].paramName = activeParam[paramIndex].labelValueName
+      }else{
+        tagCodes.splice(index, 1)
+        secondCateList[activeIndex].paramIndex = -1
+        secondCateList[activeIndex].paramName = ''
+      }
+      this.setData({ tagCodes, secondCateList })
     },
-    changeTwo(){
-      const showTwo = !this.data.showTwo
-      this.setData({showTwo})
-      this.setData({showOne: false})
+    changeShowParams(e){
+      const { secondCateList } = this.data
+      const activeIndex = e.currentTarget.dataset.index
+      console.log('activeIndex', activeIndex);
+      console.log('secondCateList', secondCateList);
+      if(activeIndex === this.data.activeIndex){
+        this.setData({ activeIndex: -1, activeParam: [] })
+      }else{
+        this.setData({ 
+          activeIndex,
+          activeParam: secondCateList[activeIndex].valueVos
+        })
+      }
+      // this.setData({showTwo: false})
+    },
+    cancelParam() {
+      const { secondCateList } = this.data
+      secondCateList.forEach(item => {
+        item.paramIndex = -1
+        item.paramName = ''
+      })
+      this.setData({ tagCodes: [],activeParam: [],secondCateList,activeIndex: -1 })
+    },
+    subParam() {
+      this.setData({ activeParam: [] })
+      this.setData({ pageNum: 1,datalist: [],total: 0})
+      this.getList()
     },
   }
 })

--
Gitblit v1.9.3