From d9a89d83c2048a964f16ca179feb2b7f21b9d33a Mon Sep 17 00:00:00 2001
From: jiangping <jp@doumee.com>
Date: 星期一, 29 七月 2024 16:28:47 +0800
Subject: [PATCH] 提交

---
 wechat_jiaxuan/components/disCase/index.js |  123 +++++++++++++++++++++++++++++-----------
 1 files changed, 88 insertions(+), 35 deletions(-)

diff --git a/wechat_jiaxuan/components/disCase/index.js b/wechat_jiaxuan/components/disCase/index.js
index f10577b..fe190d4 100644
--- a/wechat_jiaxuan/components/disCase/index.js
+++ b/wechat_jiaxuan/components/disCase/index.js
@@ -4,33 +4,34 @@
    * 缁勪欢鐨勫睘鎬у垪琛�
    */
   properties: {
-
+    menuButtonInfo: Object
   },
   data: {
     activeIndex: -1,
     activeParam: [],
     selParam: '',
     tagCodes: [],
-
+    isLoading :false,
 
     cateList: [],
     dataList: [],
+    total: 0,
     pageNum: 1,
     pageSize: 10,
     query: '',
-    sortType: 'NORMAL',
+    sortType: '',
     catalogCode: 'whole_case'
   },
   attached() {
     this.getCatelist()
   },
   methods: {
-    getCatelist(){
+    getCatelist() {
       const { catalogCode } = this.data
       getCataLogTagList({
         catalogCode
       }).then(res => {
-        if(res.data && res.data.length > 0){
+        if (res.data && res.data.length > 0) {
           this.setData({
             cateList: res.data
           })
@@ -41,21 +42,44 @@
       })
     },
     getList() {
-      const { sortType, query, tagCodes, pageNum, pageSize,catalogCode } = this.data
+      if(this.data.isLoading){
+        return
+      }
+      this.setData({isLoading:true})
+      const { sortType, query, tagCodes, pageNum, pageSize, catalogCode } = this.data
       getZhongTaiWholecasePage({
-        catalogCode,pageNum,pageSize,tagCodes, sortType,query
+        catalogCode, pageNum, pageSize, tagCodes, sortType, query
       }).then(res => {
-        if(res.data){
-          this.setData({ dataList: res.data.records })
-        }  
+        if (res.data) {
+          this.setData({
+            total: res.data.total,
+            dataList: [...this.data.dataList, ...res.data.records],
+          })
+        }
+      }).finally(()=>{
+        this.setData({isLoading:false})
       })
+    },
+    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'
+        })
+      }
     },
     statusChange(e) {
       const sortType = e.currentTarget.dataset.status
-      this.setData({sortType})
+      this.setData({ sortType })
+      this.setData({ pageNum: 1, dataList: [], total: 0 })
       this.getList()
     },
-    handleAction(e){
+    handleAction(e) {
       const actionType = e.currentTarget.dataset.code
       const id = e.currentTarget.dataset.id
       actionDo({
@@ -72,56 +96,85 @@
       })
     },
     tagClick(e) {
+      if(this.data.isLoading){
+        return
+      }
       const code = e.currentTarget.dataset.code
       const paramIndex = e.currentTarget.dataset.index
       const { cateList, tagCodes, activeParam, activeIndex } = this.data
       const index = tagCodes.indexOf(code)
-      
-      if(index === -1){
-        tagCodes.push(code)
-        cateList[activeIndex].paramIndex = paramIndex
-        cateList[activeIndex].paramName = activeParam[paramIndex].labelValueName
-      }else{
-        tagCodes.splice(index, 1)
-        cateList[activeIndex].paramIndex = -1
-        cateList[activeIndex].paramName = ''
+
+      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)
+        cateList[activeIndex].tempParamIndex = paramIndex
+        cateList[activeIndex].tempParamName = activeParam[paramIndex].labelValueName
+        cateList[activeIndex].tempParamCode = code
+      } else {
+        // tagCodes.splice(index, 1)
+        cateList[activeIndex].tempParamIndex = -1
+        cateList[activeIndex].tempParamName = null
+        cateList[activeIndex].tempParamCode = null
       }
-      this.setData({ tagCodes, cateList })
-      console.log('tagCodes', tagCodes);
+      // this.setData({ pageNum: 1, dataList: [], total: 0 })
+      this.setData({cateList })
+      console.log('tagCodes', tagCodes)
     },
     cancelParam() {
+    
       const { cateList } = this.data
       cateList.forEach(item => {
-        item.paramIndex = -1
-        item.paramName = ''
+        item.tempParamIndex =item.paramIndex
+        item.tempParamName =item.paramName 
+        item.tempParamCode =item.paramCode
       })
-      this.setData({ tagCodes: [],activeParam: [],cateList,activeIndex: -1 })
+      this.setData({ activeParam: [],cateList , activeIndex: -1 })
     },
     bindblur() {
+      this.setData({ pageNum: 1, dataList: [], total: 0 })
       this.getList()
     },
-    subParam() {
+    subParam() { 
       this.setData({ activeParam: [] })
+      const { cateList } = this.data
+      var codes = []
+      cateList.forEach(item => {
+        item.paramIndex =item.tempParamIndex
+        item.paramName =item.tempParamName 
+        item.paramCode =item.tempParamCode
+        if(item.paramIndex >-1 && item.paramCode){
+          codes.push(item.paramCode)
+        }
+      })
+      this.setData({tagCodes:codes, pageNum: 1, activeIndex: -1, dataList: [], total: 0 })
       this.getList()
     },
-    changeShowParams(e){
+    changeShowParams(e) {
       const { cateList } = this.data
       const activeIndex = e.currentTarget.dataset.index
-      if(activeIndex === this.data.activeIndex){
+      if (activeIndex === this.data.activeIndex) {
         this.setData({ activeIndex: -1, activeParam: [], selParam: '' })
-      }else{
-        this.setData({ 
+      } else {
+        this.setData({
           activeIndex,
           activeParam: cateList[activeIndex].valueVos
         })
       }
-      
+
       // this.setData({showTwo: false})
     },
-    changeTwo(){
+    changeTwo() {
       const showTwo = !this.data.showTwo
-      this.setData({showTwo})
-      this.setData({showOne: false})
+      this.setData({ showTwo })
+      this.setData({ showOne: false })
     },
   }
 })

--
Gitblit v1.9.3