From d50a3ed44e2edab2a7a661c43491c3aa42c57794 Mon Sep 17 00:00:00 2001
From: peng <peng.com>
Date: 星期四, 25 九月 2025 14:17:05 +0800
Subject: [PATCH] 用户行为分享基础埋点

---
 pages/kitchen/KitchenVideo.vue |  181 ++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 163 insertions(+), 18 deletions(-)

diff --git a/pages/kitchen/KitchenVideo.vue b/pages/kitchen/KitchenVideo.vue
index ccecf6a..a2b54e4 100644
--- a/pages/kitchen/KitchenVideo.vue
+++ b/pages/kitchen/KitchenVideo.vue
@@ -283,6 +283,9 @@
 import {
   changeCollect
 } from "@/api/collect.js";
+import { saveShare, saveShareClickRecord } from "@/api/share.js";
+import storage from "@/utils/storage.js";
+import { getSessionId, userAction } from "@/api/userAction.js";
 export default {
   computed: {
     hasPlayTime() {
@@ -367,6 +370,7 @@
       },
       loading: false, // 鏄惁姝e湪鍔犺浇
       videoQuery: {
+		source: 'system',
         pageNumber: 1,
         pageSize: 6,
         videoFrom: 'recommend',
@@ -383,10 +387,28 @@
 	  similarlyNomore: false, // 鏄惁杩樻湁鏇村鐩镐技瑙嗛
 	  similaryVideoIndex: 0, // 鐩镐技瑙嗛鐨勬挱鏀句綅缃�
 	  similarlyLoading: false, // 鐩镐技瑙嗛鍔犺浇
-	  marginBottom: 0 // 搴曢儴瀹夊叏鍖哄煙
+	  marginBottom: 0 ,// 搴曢儴瀹夊叏鍖哄煙
+	  pageSessionNo:"",
+	  actionParam:{
+		sessionId:'',
+		actionType:"PAGE",
+		joinType:"SELF",
+		pageCode:"KITCHEN_VIDEO",
+		pageParams:"{}",
+		pageStatus:"JOIN",
+		pageType:"LIST"
+		}
     }
   },
   onShow() {
+	  getSessionId().then(res=>{
+	  		this.pageSessionNo = res.data.data
+	  		if(this.pageSessionNo){
+	  		let	param = this.actionParam;
+	  			param.sessionId = this.pageSessionNo
+	  			userAction(param)
+	  		}
+	  })	
     // this.showDrawer('showLeft')
     this.loadVideos()
     // 濡傛灉瑙嗛鎸変笅鏆傚仠鍚庡垏鎹㈤〉闈㈠啀鍥炲埌椤甸潰鏃讹紝鍙畻鏆傚仠鏃堕棿锛堝洜涓烘殏鍋滄椂闂村拰绂诲紑椤甸潰鏃堕棿鏄噸澶嶇殑锛屽彧绠椾竴涓級
@@ -395,26 +417,114 @@
       this.totalHidenTime += duration
     }
   },
+  onUnload() {
+    let	param = this.actionParam;
+    if (this.sendOnShow)return
+    param.pageStatus = "LEAVE"
+    userAction(param)
+  },
   onHide() {
     this.startHidenTime = Date.now()
+    let	param = this.actionParam;
+    this.sendOnShow = true;
+    param.pageStatus = "LEAVE"
+    userAction(param)
   },
-  onLoad() {
-	  this.marginBottom = uni.getSystemInfoSync().safeAreaInsets.bottom
-	  // 鑾峰彇鐘舵�佹爮楂樺害
-	  const systemInfo = uni.getSystemInfoSync();
-	  console.log('systemInfo------------------------>',systemInfo.windowHeight)
-	  const menuButtonInfo =  uni.getMenuButtonBoundingClientRect()
-	  console.log('menuButtonInfo--------------------------->',menuButtonInfo)
-	  const {top,height} = menuButtonInfo
-	  this.buttonHeight = systemInfo.statusBarHeight+height;
-	  this.menueButton = top;
-	  console.log('systemInfo.safeAreaInsets.bottom>',systemInfo.safeAreaInsets.bottom)
-	  this.leftHeight = systemInfo.windowHeight - top -50 - systemInfo.safeAreaInsets.bottom -22;
-	  console.log('-------------leftHeight------------------------>',this.leftHeight)
-	this.getKitchenTypeList();
-	this.loadVideos();
+  onLoad(option) {
+		this.marginBottom = uni.getSystemInfoSync().safeAreaInsets.bottom;
+		// 鑾峰彇鐘舵�佹爮楂樺害
+	    const systemInfo = uni.getSystemInfoSync();
+	    console.log('systemInfo------------------------>',systemInfo.windowHeight)
+	    const menuButtonInfo =  uni.getMenuButtonBoundingClientRect()
+	    console.log('menuButtonInfo--------------------------->',menuButtonInfo)
+	    const {top,height} = menuButtonInfo
+	    this.buttonHeight = systemInfo.statusBarHeight+height;
+	    this.menueButton = top;
+	    console.log('systemInfo.safeAreaInsets.bottom>',systemInfo.safeAreaInsets.bottom)
+	    this.leftHeight = systemInfo.windowHeight - top -50 - systemInfo.safeAreaInsets.bottom -22;
+	    console.log('-------------leftHeight------------------------>',this.leftHeight)
+		let queryParam = this.videoQuery;
+		if(option.q){
+			const decodedUrl = decodeURIComponent(decodeURIComponent(option.q));
+			console.log('鍘熷URL:', decodedUrl);
+			
+			// 瑙f瀽URL涓殑鏌ヨ鍙傛暟
+			const params = this.parseUrlParams(decodedUrl);
+			const shareType = params.shareType; 
+			const videoId = params.videoId;  
+			const source = params.source;
+			queryParam.videoId = videoId
+			queryParam.shareType = shareType
+			queryParam.source = source
+			console.log('瑙f瀽鍙傛暟:', { shareType, videoId,source });
+			this.actionParam.pageParams = JSON.stringify(params)
+			this.actionParam.joinType = 'SHARE'
+		}
+		const token = storage.getAccessToken();
+		if(!token){
+			this.wxSilentLogin(() => {
+				// 鍒ゆ柇鏄笉鏄偣鍑诲垎浜摼鎺ヨ繘鏉ョ殑
+				if (option.userId && option.videoId) {
+					this.actionParam.pageParams = JSON.stringify(option)
+					this.actionParam.joinType = 'SCAN'
+					queryParam.videoId = option.videoId
+					// 淇濆瓨鍒嗕韩鐐瑰嚮璁板綍
+					saveShareClickRecord({refId: option.videoId, shareUserId: option.userId})
+				}
+					this.getKitchenTypeList();
+					this.loadVideos(queryParam);
+					
+			})
+		}else{
+			if (option.userId && option.videoId) {
+				queryParam.videoId = option.videoId
+				// 淇濆瓨鍒嗕韩鐐瑰嚮璁板綍
+				saveShareClickRecord({refId: option.videoId, shareUserId: option.userId})
+		}
+		this.getKitchenTypeList();
+		this.loadVideos(queryParam);
+	}
+	
+  }, 
+   onShareAppMessage(e) {
+	const userInfo = storage.getUserInfo();
+	if(!userInfo) {
+		console.log("鏈櫥褰曚笉鑳藉垎浜�");
+		return
+	}
+	const videoInfo = e.target.dataset.obj;
+	// 淇濆瓨鍒嗕韩璁板綍
+	const data = {
+		shareType: 'video',
+		refId: videoInfo.id,
+		shareUser: userInfo.id
+	}
+	saveShare(data)
+  	return {
+  		title: videoInfo.title,
+  		path: `/pages/tabbar/index/home?videoId=${videoInfo.id}&userId=${userInfo.id}`,
+  		imageUrl: videoInfo.coverUrl
+  	}
   },
   methods: {
+	  // 瑙f瀽URL鍙傛暟
+	  parseUrlParams(url) {
+	    const params = {};
+	    // 澶勭悊鍙兘瀛樺湪鐨刪ash锛堝鏋滄湁鐨勮瘽锛�
+	    const cleanUrl = url.split('#')[0];
+	    const queryStr = cleanUrl.split('?')[1] || '';
+	    
+	    queryStr.split('&').forEach(pair => {
+	      const [key, value] = pair.split('=');
+	      if (key) {
+	        // 濡傛灉鍊煎瓨鍦紝鍒欒В鐮侊紝鍚﹀垯璁句负绌哄瓧绗︿覆
+	        params[key] = value ? decodeURIComponent(value) : '';
+	      }
+	    });
+	    
+	    return params;
+	  },
+	  
 	// 鏌ヨ褰撳墠瑙嗛鐨勫叧鑱旇棰戯紙鎸備簡鍚屼竴鍟嗗搧鐨勶級
 	async getGoodsSimilarly() {
 			  if (this.similarlyLoading || this.similarlyNomore) return Promise.resolve();;
@@ -724,14 +834,48 @@
       })
     },
     // 鍔犺浇瑙嗛鏁版嵁
-    async loadVideos() {
+    async loadVideos(param) {
       console.log(this.loading, this.videoNoMore,this.videoQuery)
       if (this.videoQuery.pageNumber == 1) {
 
       } else if (this.loading || this.videoNoMore) return;
       this.loading = true;
-
+		if(param){
+			console.log("浜岀淮鐮佹壂鐮佹暟鎹墽琛屽湪姝ゅ1")
+			console.log(this.videoQuery)
+			getkitchenVideoList(this.videoQuery).then(res => {
+				console.log(res)
+			  // 鏂板涓�涓瓧娈电敤浜庡惊鐜椂鐨刱ey
+			  const data = res.data.data.map(item => {
+			  	return {
+			  		...item,
+			  		updateKey: item.id
+			  	}
+			  })
+			  if (this.videoQuery.pageNumber === 1) {
+			    this.videoList = data;
+			  } else {
+			    this.videoList = [
+			      ...this.videoList,
+			      ...data.filter(
+			          (newItem) => !this.videoList.some((oldItem) => oldItem.id === newItem.id)
+			      ),
+			    ];
+			  }
+			  this.loading = false;
+			  if (data.length < this.videoQuery.pageSize) {
+			    this.videoNoMore = true;
+			    return;
+			  }
+			  this.videoQuery.pageNumber++;
+			
+			})
+		}else{
+			
+		console.log("浜岀淮鐮佹壂鐮佹暟鎹墽琛屽湪姝ゅ2")
+		console.log(this.videoQuery)
       getkitchenVideoList(this.videoQuery).then(res => {
+		  console.log(res)
         // 鏂板涓�涓瓧娈电敤浜庡惊鐜椂鐨刱ey
         const data = res.data.data.map(item => {
         	return {
@@ -757,6 +901,7 @@
         this.videoQuery.pageNumber++;
 
       })
+	  }
     },
 
     // 婊戝姩鍒囨崲瑙嗛

--
Gitblit v1.8.0