You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							134 lines
						
					
					
						
							2.9 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	
							134 lines
						
					
					
						
							2.9 KiB
						
					
					
				| // package/pointsStatus/pointsStatus.js | |
| import { getProjectGraph, getDeployPoints, getProjectPoints, getdPointCurPatrolRecord } from "../../utils/getApiUrl"; | |
| import { Request } from "../../common"; | |
| 
 | |
| Page({ | |
| 
 | |
|   /** | |
|    * 页面的初始数据 | |
|    */ | |
|   data: { | |
|     imgUrl: getApp().globalData.imgUrl, | |
|     describe: '', | |
|     image: '', | |
|     allPoints: [], | |
|     setedPoints: [], | |
|   }, | |
| 
 | |
|   getData(projectId) { | |
|     const that = this; | |
|     wx.showLoading({ title: '加载中...' }); | |
|     Request.get(getProjectGraph(projectId)).then(res => { | |
|       if (res) { | |
|         Request.get(getDeployPoints(res.id)).then(deployPointsRes => { | |
|           Request.get(getProjectPoints(projectId)).then(allPointRes => { | |
|             wx.hideLoading(); | |
|             that.setData({ | |
|               image: res.graph, | |
|               allPoints: allPointRes, | |
|               setedPoints: deployPointsRes.map(p => ({ | |
|                 ...p, | |
|                 position: JSON.parse(p.position), | |
|                 pointInfo: allPointRes.find(a => a.id === p.pointId), | |
|               })), | |
|             }) | |
|           }) | |
|         }) | |
|       } else { | |
|         wx.hideLoading(); | |
|         // 未布设 | |
|       } | |
|     }) | |
|   }, | |
| 
 | |
|   calcTooltip(e) { | |
|     const that = this; | |
|     const pointNodeId = e.currentTarget.id; | |
|     const { id: pointId, show } = e.currentTarget.dataset; | |
|     const windowWidth = wx.getSystemInfoSync().windowWidth; | |
|     const setTooltip = (status) => { | |
|       const query = that.createSelectorQuery().in(that); | |
|       query.select('#' + pointNodeId).boundingClientRect(data => { | |
|         const sub = windowWidth - data.left < 100 ? 100 - (windowWidth - data.left) : 0; | |
|         const nextSetedPoints = that.data.setedPoints.map(p => { | |
|           if (p.pointId == pointId) { | |
|             p.sub = sub; | |
|             p.show = !p.show; | |
|             if (status) { | |
|               p.status = status; | |
|             } | |
|           } | |
|           return p; | |
|         }) | |
|         that.setData({ setedPoints: nextSetedPoints }) | |
|       }).exec() | |
|     } | |
|     if (!show) { | |
|       wx.showLoading({ title: '加载中...' }); | |
|       Request.get(getdPointCurPatrolRecord(pointId)).then(res => { | |
|         wx.hideLoading(); | |
|         setTooltip(res.length ? res[0].alarm ? '异常' : '正常' : '--'); | |
|       }) | |
|     } else { | |
|       setTooltip(); | |
|     } | |
|   }, | |
| 
 | |
|   /** | |
|    * 生命周期函数--监听页面加载 | |
|    */ | |
|   onLoad(options) { | |
|     const { projectId, describe } = options; | |
|     this.setData({ describe }); | |
|     this.getData(projectId); | |
|   }, | |
| 
 | |
|   /** | |
|    * 生命周期函数--监听页面初次渲染完成 | |
|    */ | |
|   onReady() { | |
| 
 | |
|   }, | |
| 
 | |
|   /** | |
|    * 生命周期函数--监听页面显示 | |
|    */ | |
|   onShow() { | |
| 
 | |
|   }, | |
| 
 | |
|   /** | |
|    * 生命周期函数--监听页面隐藏 | |
|    */ | |
|   onHide() { | |
| 
 | |
|   }, | |
| 
 | |
|   /** | |
|    * 生命周期函数--监听页面卸载 | |
|    */ | |
|   onUnload() { | |
| 
 | |
|   }, | |
| 
 | |
|   /** | |
|    * 页面相关事件处理函数--监听用户下拉动作 | |
|    */ | |
|   onPullDownRefresh() { | |
| 
 | |
|   }, | |
| 
 | |
|   /** | |
|    * 页面上拉触底事件的处理函数 | |
|    */ | |
|   onReachBottom() { | |
| 
 | |
|   }, | |
| 
 | |
|   /** | |
|    * 用户点击右上角分享 | |
|    */ | |
|   onShareAppMessage() { | |
| 
 | |
|   } | |
| }) |