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.
352 lines
12 KiB
352 lines
12 KiB
// package/subSystem/subSystem.js
|
|
import * as echarts from '../components/ec-canvas/echarts';
|
|
import {
|
|
getSubSystemPatrolAbout
|
|
} from "../../utils/getApiUrl";
|
|
import {
|
|
Request
|
|
} from "../../common";
|
|
const moment = require("../../utils/moment");
|
|
|
|
Page({
|
|
record: [],//巡检记录
|
|
initECharts(option) {
|
|
this.ecComponent.init((canvas, width, height, dpr) => {
|
|
const chart = echarts.init(canvas, null, {
|
|
width: width,
|
|
height: height,
|
|
devicePixelRatio: dpr,
|
|
});
|
|
// 设置图表的配置
|
|
chart.setOption(option);
|
|
// 将 ECharts 实例保存在数据中
|
|
this.chart = chart;
|
|
// 返回 ECharts 实例
|
|
return chart;
|
|
});
|
|
},
|
|
/**
|
|
* 页面的初始数据
|
|
*/
|
|
data: {
|
|
ec: {
|
|
// lazyLoad: true, // 延迟加载 ECharts
|
|
},
|
|
date: '',
|
|
show: true,
|
|
currentPatrolCount: 0, //当月巡检次数
|
|
currentRepairCount: 0, //当月维修次数
|
|
currentDate: new Date().getTime(),
|
|
minDate: 0,
|
|
curSelect: null,//当前选择
|
|
// level1Count: 0, //轻微
|
|
// level2Count: 0, //中度
|
|
// level3Count: 0, //严重
|
|
// dataList:[],//饼图数据
|
|
selectedDate: new Date(), // 设置默认选中的日期为当前日期
|
|
questions: 0,//故障数量
|
|
datePickerShow: false,//选择日期
|
|
formatter(day) {
|
|
|
|
return day;
|
|
},
|
|
|
|
},
|
|
datePickerPopup() {
|
|
this.setData({
|
|
datePickerShow: true
|
|
})
|
|
},
|
|
closeDatePickerPopup() {
|
|
this.setData({
|
|
datePickerShow: false
|
|
})
|
|
},
|
|
onDisplay() {
|
|
this.setData({
|
|
show: true
|
|
});
|
|
},
|
|
onClose() {
|
|
this.setData({
|
|
show: false
|
|
});
|
|
},
|
|
|
|
onConfirm(event) {
|
|
this.setData({
|
|
show: false,
|
|
date: this.formatDate(event.detail),
|
|
});
|
|
},
|
|
|
|
onDateChange(e) {
|
|
const dateObject = new Date(e.detail);
|
|
const firstDay = new Date(dateObject.getFullYear(), dateObject.getMonth(), 1);
|
|
firstDay.setHours(0, 0, 0, 0);
|
|
const firstDayTimestamp = firstDay.getTime();
|
|
const nextMonthFirstDay = new Date(dateObject.getFullYear(), dateObject.getMonth() + 1, 1);
|
|
const lastDayTimestamp = nextMonthFirstDay.getTime() - 1; // 减去1毫秒得到本月最后一天
|
|
const currentYear = dateObject.getFullYear();
|
|
const currentMonth = dateObject.getMonth() + 1;
|
|
this.setData({
|
|
currentYear: currentYear,
|
|
currentMonth: currentMonth,
|
|
lastDay: lastDayTimestamp,
|
|
firstDay: firstDayTimestamp,
|
|
})
|
|
},
|
|
onDateSelect(e) {
|
|
const currentDate = moment(e.detail).format('YYYY-MM-DD')
|
|
const inspectionData = this.record.find(item => currentDate == moment(item.inspectionTime).format('YYYY-MM-DD'));
|
|
if (inspectionData) {
|
|
wx.navigateTo({
|
|
url: `/package/subSystem/dayPatrolInfo/dayPatrolInfo?day=${moment(e.detail).format('YYYY-MM-DD')}&subType=${this.subType}`,
|
|
})
|
|
} else {
|
|
wx.showToast({
|
|
title: '当天没有巡检记录',
|
|
icon: 'none',
|
|
});
|
|
}
|
|
|
|
},
|
|
|
|
/**
|
|
* 生命周期函数--监听页面加载
|
|
*/
|
|
onLoad: function (options) {
|
|
wx.showLoading({
|
|
title: '加载中...',
|
|
})
|
|
this.subType = options.key
|
|
const { windowHeight } = wx.getSystemInfoSync()
|
|
const pageHeight = windowHeight - 48
|
|
const that = this
|
|
wx.showLoading({
|
|
title: '加载中'
|
|
})
|
|
// const that = this;
|
|
wx.setNavigationBarTitle({
|
|
title: options.key,
|
|
});
|
|
//加载初始化数据
|
|
that.getSubSystemPatrolAbout(options)
|
|
//初始化图表的配置项
|
|
// 其他渲染逻辑
|
|
// 创建一个 Date 对象来获取当前日期
|
|
const currentDate = new Date();
|
|
// 获取当前年份
|
|
const currentYear = currentDate.getFullYear();
|
|
// 获取当前月份(注意,月份是从 0 到 11 表示,所以需要加 1)
|
|
const currentMonth = currentDate.getMonth() + 1;
|
|
// 获取当前月份的第一天和最后一天
|
|
const nextMonth = new Date().getMonth() + 1;
|
|
const firstDay = new Date().setDate(1);
|
|
const lastDay = new Date().setMonth(nextMonth, 1) - 86400000;
|
|
// 更新数据,将年份和月份传递给 WXML 页面
|
|
that.setData({
|
|
currentYear: currentYear,
|
|
currentMonth: currentMonth,
|
|
lastDay: lastDay,
|
|
firstDay: firstDay,
|
|
pageHeight: pageHeight + 'px'
|
|
});
|
|
|
|
|
|
// wx.hideLoading()
|
|
|
|
},
|
|
|
|
getSubSystemPatrolAbout: function (options) {
|
|
wx.showLoading({
|
|
title: '加载中...',
|
|
})
|
|
// const userInfo=wx.getStorageSync('userInfo');
|
|
let that = this;
|
|
const STime = moment('1970-01-01').format('YYYY-MM-DD')
|
|
const ETime = moment('2099-12-31').format('YYYY-MM-DD')
|
|
//子系统关键字
|
|
let keywords = options.key
|
|
const maxInspectionTimeByPointId = {};
|
|
// keywords = '管廊'
|
|
const query = { STime, ETime, keywords }
|
|
Request.get(getSubSystemPatrolAbout(query)).then(res => {
|
|
if (res) {
|
|
|
|
//求出最小时间
|
|
const minTimeObject = res.reduce((min, current) => {
|
|
// 比较时间,选择最小的时间
|
|
return !min || new Date(current.inspectionTime) < new Date(min.inspectionTime) ? current : min;
|
|
}, null)
|
|
let inputDate = new Date()
|
|
let firstDayTimestamp = new Date().getTime()
|
|
if (minTimeObject) {
|
|
inputDate = new Date(minTimeObject.inspectionTime)
|
|
inputDate.setDate(1);
|
|
inputDate.setHours(0, 0, 0, 0);
|
|
firstDayTimestamp = inputDate.getTime();
|
|
|
|
}
|
|
this.setData({
|
|
minDate: firstDayTimestamp
|
|
})
|
|
// 遍历数据并更新maxInspectionTimeByPointId
|
|
res.forEach((item) => {
|
|
const { pointId, inspectionTime } = item;
|
|
if (pointId in maxInspectionTimeByPointId) {
|
|
if (inspectionTime > maxInspectionTimeByPointId[pointId]) {
|
|
maxInspectionTimeByPointId[pointId] = inspectionTime;
|
|
}
|
|
} else {
|
|
maxInspectionTimeByPointId[pointId] = inspectionTime;
|
|
}
|
|
});
|
|
// 过滤数据以获取相同pointId中inspectionTime最大的记录
|
|
const filteredData = res.filter((item) => {
|
|
const { pointId, inspectionTime } = item;
|
|
return inspectionTime === maxInspectionTimeByPointId[pointId];
|
|
});
|
|
//巡查内容
|
|
// const list=res?.filter(item=>item?.points?.user.id===userInfo.id)||[]
|
|
// 创建一个对象来存储按设备分类的最低level统计
|
|
const deviceLevelStatistics = {};
|
|
// 初始化一个包含所有level的对象
|
|
const levelValues = { 轻微: 0, 中度: 1, 严重: 2 };
|
|
// 遍历巡检记录
|
|
filteredData.forEach((record) => {
|
|
const points = record.points;
|
|
if (points && points.inspectContent && Array.isArray(points.inspectContent)) {
|
|
points.inspectContent.forEach((content) => {
|
|
const device = content.deviceId;
|
|
content.checkItems.forEach(checkItem => {
|
|
const level = checkItem.level;
|
|
if (!checkItem.isNormal) {
|
|
if (!deviceLevelStatistics[device]) {
|
|
// 如果设备不存在于统计对象中,初始化
|
|
deviceLevelStatistics[device] = {
|
|
deviceName: content.deviceName, // 可能需要设备名称
|
|
level: level
|
|
};
|
|
} else {
|
|
// 如果设备已存在于统计对象中,比较level并更新为最低的level
|
|
deviceLevelStatistics[device].level = levelValues[level] > levelValues[deviceLevelStatistics[device].level] ? level : deviceLevelStatistics[device].level;
|
|
}
|
|
}
|
|
})
|
|
})
|
|
}
|
|
})
|
|
const levelCounts = { 轻微: 0, 中度: 0, 严重: 0 };
|
|
for (const deviceId in deviceLevelStatistics) {
|
|
if (deviceLevelStatistics.hasOwnProperty(deviceId)) {
|
|
const deviceInfo = deviceLevelStatistics[deviceId];
|
|
const level = deviceInfo.level;
|
|
// 增加相应等级的设备数量
|
|
levelCounts[level]++;
|
|
}
|
|
}
|
|
const data1 = Object.entries(levelCounts).map(([name, value]) => ({ name, value }));
|
|
const totalValue = data1.reduce((accumulator, item) => accumulator + item.value, 0);
|
|
this.record=res
|
|
that.setData({
|
|
currentRepairCount: res?.filter(i => i.patrolRecordIssueHandles.length > 0 ? i.patrolRecordIssueHandles[0].state === 6 : false).length || 0,
|
|
currentPatrolCount: res.length,
|
|
questions: totalValue,
|
|
formatter: function (e) {
|
|
const currentDate = moment(e.date).format('YYYY-MM-DD');
|
|
const rs = res.filter(item => currentDate === moment(item.inspectionTime).format('YYYY-MM-DD'))
|
|
if (rs && rs.length) {
|
|
if (rs.some(item => item.patrolRecordIssueHandles.length > 0)) {
|
|
e.bottomInfo = '.';
|
|
e.className = 'yellowClass';
|
|
} else {
|
|
e.bottomInfo = '.';
|
|
e.className = 'greenClass';
|
|
}
|
|
}
|
|
return e
|
|
}
|
|
})
|
|
that.ecComponent = that.selectComponent('#mychart-dom-pie');
|
|
var option = {
|
|
backgroundColor: "#ffffff",
|
|
legend: {
|
|
bottom: 10,
|
|
left: 'center',
|
|
},
|
|
tooltip: {
|
|
trigger: 'item'
|
|
},
|
|
series: [{
|
|
label: {
|
|
normal: {
|
|
fontSize: 14
|
|
}
|
|
},
|
|
type: 'pie',
|
|
center: ['50%', '50%'],
|
|
radius: ['20%', '40%'],
|
|
data: data1
|
|
}]
|
|
};
|
|
that.initECharts(option);
|
|
wx.hideLoading();
|
|
|
|
} else {
|
|
// wx.hideLoading();
|
|
}
|
|
})
|
|
},
|
|
/**
|
|
* 生命周期函数--监听页面初次渲染完成
|
|
*/
|
|
|
|
onReady() {
|
|
|
|
|
|
},
|
|
|
|
/**
|
|
* 生命周期函数--监听页面显示
|
|
*/
|
|
onShow() {
|
|
// wx.hideLoading()
|
|
|
|
},
|
|
|
|
/**
|
|
* 生命周期函数--监听页面隐藏
|
|
*/
|
|
onHide() {
|
|
|
|
},
|
|
|
|
/**
|
|
* 生命周期函数--监听页面卸载
|
|
*/
|
|
onUnload() {
|
|
|
|
},
|
|
|
|
/**
|
|
* 页面相关事件处理函数--监听用户下拉动作
|
|
*/
|
|
onPullDownRefresh() {
|
|
getSubSystemPatrolAbout()
|
|
},
|
|
|
|
/**
|
|
* 页面上拉触底事件的处理函数
|
|
*/
|
|
onReachBottom() {
|
|
|
|
},
|
|
|
|
/**
|
|
* 用户点击右上角分享
|
|
*/
|
|
onShareAppMessage() {
|
|
|
|
}
|
|
})
|