From 7dc29ed74ebaa8a0e66f68264d9a13f95dc3af21 Mon Sep 17 00:00:00 2001
From: jiangping <jp@doumee.com>
Date: 星期五, 02 八月 2024 11:09:06 +0800
Subject: [PATCH] aa

---
 wechat_staff/components/disRealpic/index.js |  216 ++++++++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 202 insertions(+), 14 deletions(-)

diff --git a/wechat_staff/components/disRealpic/index.js b/wechat_staff/components/disRealpic/index.js
index 17259f9..c05e2e9 100644
--- a/wechat_staff/components/disRealpic/index.js
+++ b/wechat_staff/components/disRealpic/index.js
@@ -1,24 +1,216 @@
-// components/disCase/index.js
+import { getCataLogTagList, getZhongTaiRealcasePage, actionDo } from '../../api/index'
 Component({
   /**
    * 缁勪欢鐨勫睘鎬у垪琛�
    */
   properties: {
-
+    menuButtonInfo: Object
   },
   data: {
-    showParams: false,
-    activeStatus: '0'
+    activeIndex: -1,
+    activeParam: [],
+    selParam: '',
+    tagCodes: [],
+    isLoading:false,
+
+    cateList: [],
+    dataList: [],
+    pageNum: 1,
+    pageSize: 10,
+    query: '',
+    sortType: '',
+    catalogCode: 'real_case'
+  },
+  attached() {
+    this.getCatelist()
   },
   methods: {
-    handleDetail(e) {
-      wx.navigateTo({
-        url: '/pages/detailDis/realpic',
+    refreshCount(){    
+      let  temData = wx.getStorageSync('conentCountTemp')   
+      if(temData && this.data.dataList){  
+          var dataList =this.data.dataList;
+          dataList.forEach(item =>{ 
+              if(item.id+'' == temData.id+'' ){
+                  item.viewCount = (item.viewCount ||0)+1; 
+                  if( item.isCollection != temData.isCollection){ 
+                    if(item.isCollection){
+                        item.collectCount = (item.collectCount || 0)-1
+                        item.collectCount  =   item.collectCount >=0?  item.collectCount :0;
+                    } else{ 
+                        item.collectCount = (item.collectCount || 0)+1
+                    }
+                    item.isCollection = temData.isCollection
+                }
+              }   
+          })
+          this.setData({dataList:dataList})
+           wx.setStorageSync('conentCountTemp',null)
+      }
+    },
+    getCatelist(){
+      const { catalogCode } = this.data
+      getCataLogTagList({
+        catalogCode
+      }).then(res => {
+        if(res.data && res.data.length > 0){
+          this.setData({
+            cateList: res.data
+          })
+          setTimeout(() => {
+            this.getList()
+          }, 300)
+        }
       })
     },
-    changeShowParams(){
-      const showParams = !this.data.showParams
-      this.setData({showParams})
+    getList() {
+      if(this.data.isLoading){
+        return
+      }
+      
+      this.setData({isLoading:true})
+      const { sortType, query, tagCodes, pageNum, pageSize,catalogCode } = this.data
+      getZhongTaiRealcasePage({
+        catalogCode,tagCodes,pageNum,pageSize, sortType,query
+      }).then(res => {
+        this.setData({
+          dataList: [...this.data.dataList, ...res.data.records],
+          total: res.data.total,
+        })
+      }).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'
+        })
+      }
+    },
+    videoClick(e) {
+      const { videourl } = e.currentTarget.dataset
+      let videoPlay = this.selectComponent('.videoPlay'); 
+      if(videoPlay){ 
+        videoPlay.startPlayVideo(videourl,this );
+      } 
+    },
+    priviewFull(e){
+      const item = e.currentTarget.dataset.item
+      console.log('item', item);
+      wx.navigateTo({
+        url: '/pages/webView/index',
+        success: function(res) {
+          // 閫氳繃eventChannel鍚戣鎵撳紑椤甸潰浼犻�佹暟鎹� 
+          res.eventChannel.emit('data',{link:item.openContent} );
+        }
+      })
+    },
+    statusChange(e) {
+      const sortType = e.currentTarget.dataset.status
+      this.setData({sortType})
+      this.setData({ pageNum: 1,dataList: [],total: 0})
+      this.getList()
+    },
+    handleAction(e){
+      const actionType = e.currentTarget.dataset.code
+      const id = e.currentTarget.dataset.id
+      actionDo({
+        actionType,
+        id
+      }).then(res => {
+        this.getList()
+      })
+    },
+    handleDetail(e) {
+      const item = e.currentTarget.dataset.item
+      console.log('item', item);
+      if(item.openType == 'video'){
+        let videoPlay = this.selectComponent('.videoPlay'); 
+        if(videoPlay){ 
+          videoPlay.startPlayVideo(item.openContent,this );
+        } 
+      }
+      if(item.openType == 'link'){
+        wx.navigateTo({
+          url: '/pages/webView/index',
+          success: function(res) {
+            // 閫氳繃eventChannel鍚戣鎵撳紑椤甸潰浼犻�佹暟鎹� 
+            res.eventChannel.emit('data',{link:item.openContent} );
+          }
+        })
+      }
+      if(item.openType == 'page'){
+        wx.navigateTo({
+          url: '/pages/detailDis/realpic?id=' + item.id,
+        })
+      }
+    },
+    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 
+      if(   cateList[activeIndex].tempParamIndex==null ||     cateList[activeIndex].tempParamIndex != paramIndex){ 
+        cateList[activeIndex].tempParamIndex = paramIndex
+        cateList[activeIndex].tempParamName = activeParam[paramIndex].labelValueName
+        cateList[activeIndex].tempParamCode = code
+        console.log(code)
+      }else{
+        cateList[activeIndex].tempParamIndex = -1
+        cateList[activeIndex].tempParamName = null
+        cateList[activeIndex].tempParamCode = null 
+        console.log(1)
+      }
+      this.setData({  cateList }) 
+    },
+    cancelParam() {
+      const { cateList } = this.data
+      cateList.forEach(item => {
+        item.tempParamIndex = item.paramIndex
+        item.tempParamName =   item.paramName 
+        item.tempParamCode =   item.paramCode
+      })
+      this.setData({    activeParam: [],cateList,activeIndex: -1 }) 
+    },
+    bindblur() {
+      this.setData({ pageNum: 1,dataList: [],total: 0})
+      this.getList()
+    },
+    subParam() {
+      const { cateList } = this.data
+      var codes =[]
+      cateList.forEach(item => { 
+        item.paramIndex = item.tempParamIndex
+        item.paramName =   item.tempParamName 
+        item.paramCode =   item.tempParamCode
+        if(item.tempParamIndex >-1 && item.tempParamCode){
+          codes.push(item.tempParamCode)
+        }
+      }) 
+      this.setData({ activeParam: [],tagCodes:codes })
+      this.setData({ pageNum: 1,activeIndex: -1,dataList: [],total: 0})
+      this.getList()
+    },
+    changeShowParams(e){
+      const { cateList } = this.data
+      const activeIndex = e.currentTarget.dataset.index
+      if(activeIndex === this.data.activeIndex){
+        this.setData({ activeIndex: -1, activeParam: [], selParam: '' })
+      }else{
+        this.setData({ 
+          activeIndex,
+          activeParam: cateList[activeIndex].valueVos
+        })
+      }
+      
       // this.setData({showTwo: false})
     },
     changeTwo(){
@@ -26,9 +218,5 @@
       this.setData({showTwo})
       this.setData({showOne: false})
     },
-    statusChange(e) {
-      const activeStatus = e.currentTarget.dataset.status
-      this.setData({activeStatus})
-    }
   }
 })

--
Gitblit v1.9.3