| @ -0,0 +1,32 @@ | |||||
|  | Component({ | ||||
|  |     data: { | ||||
|  |         selected: 0, | ||||
|  |         color: "#7A7E83", | ||||
|  |         selectedColor: "#1070E8", | ||||
|  |         list: [] | ||||
|  |     }, | ||||
|  |     attached () { | ||||
|  |         let userRole = wx.getStorageSync('userRole'); | ||||
|  |         // 0 表示普通用户 1表示管理员
 | ||||
|  |         console.log('userRole', userRole); | ||||
|  |         if (userRole && userRole.includes('管理')) { | ||||
|  |             this.setData({ | ||||
|  |                 list: getApp().globalData.managerList | ||||
|  |             }) | ||||
|  |         } else { | ||||
|  |             this.setData({ | ||||
|  |                 list: getApp().globalData.inspecterList | ||||
|  |             }) | ||||
|  |         } | ||||
|  |     }, | ||||
|  |     methods: { | ||||
|  |         switchTab (e) { | ||||
|  |             const data = e.currentTarget.dataset | ||||
|  |             const url = data.path | ||||
|  |             // this.setData({
 | ||||
|  |             //     selected: data.index
 | ||||
|  |             // })
 | ||||
|  |             wx.switchTab({ url }) | ||||
|  |         } | ||||
|  |     } | ||||
|  | }) | ||||
| @ -0,0 +1,3 @@ | |||||
|  | { | ||||
|  |     "component": true | ||||
|  | } | ||||
| @ -0,0 +1,8 @@ | |||||
|  | <!-- miniprogram/custom-tab-bar/index.wxml --> | ||||
|  | <view class="tab-bar"> | ||||
|  |     <view class="tab-bar-border"></view> | ||||
|  |     <view wx:for="{{list}}" wx:key="index" class="tab-bar-item" data-path="{{item.pagePath}}" data-index="{{index}}" bindtap="switchTab"> | ||||
|  |         <image src="{{selected === index ? item.selectedIconPath : item.iconPath}}"></image> | ||||
|  |         <view style="color: {{selected === index ? selectedColor : color}}">{{item.text}}</view> | ||||
|  |     </view> | ||||
|  | </view> | ||||
| @ -0,0 +1,38 @@ | |||||
|  | .tab-bar { | ||||
|  |     position: fixed; | ||||
|  |     bottom: 0; | ||||
|  |     left: 0; | ||||
|  |     right: 0; | ||||
|  |     height: 48px; | ||||
|  |     background: white; | ||||
|  |     display: flex; | ||||
|  |     padding-bottom: env(safe-area-inset-bottom); | ||||
|  | } | ||||
|  | 
 | ||||
|  | .tab-bar-border { | ||||
|  |     background-color: rgba(0, 0, 0, 0.33); | ||||
|  |     position: absolute; | ||||
|  |     left: 0; | ||||
|  |     top: 0; | ||||
|  |     width: 100%; | ||||
|  |     height: 1px; | ||||
|  |     transform: scaleY(0.5); | ||||
|  | } | ||||
|  | 
 | ||||
|  | .tab-bar-item { | ||||
|  |     flex: 1; | ||||
|  |     text-align: center; | ||||
|  |     display: flex; | ||||
|  |     justify-content: center; | ||||
|  |     align-items: center; | ||||
|  |     flex-direction: column; | ||||
|  | } | ||||
|  | 
 | ||||
|  | .tab-bar-item image { | ||||
|  |     width: 27px; | ||||
|  |     height: 27px; | ||||
|  | } | ||||
|  | 
 | ||||
|  | .tab-bar-item view { | ||||
|  |     font-size: 10px; | ||||
|  | } | ||||
| After Width: | Height: | Size: 1.2 KiB | 
| Before Width: | Height: | Size: 1.1 KiB After Width: | Height: | Size: 1.1 KiB | 
| After Width: | Height: | Size: 24 KiB | 
| After Width: | Height: | Size: 2.6 KiB | 
| After Width: | Height: | Size: 517 B | 
| After Width: | Height: | Size: 2.3 KiB | 
| After Width: | Height: | Size: 1.7 KiB | 
| After Width: | Height: | Size: 1.7 KiB | 
| After Width: | Height: | Size: 21 KiB | 
| @ -0,0 +1,284 @@ | |||||
|  | import WxCanvas from './wx-canvas'; | ||||
|  | import * as echarts from './echarts'; | ||||
|  | 
 | ||||
|  | let ctx; | ||||
|  | 
 | ||||
|  | function compareVersion(v1, v2) { | ||||
|  |   v1 = v1.split('.') | ||||
|  |   v2 = v2.split('.') | ||||
|  |   const len = Math.max(v1.length, v2.length) | ||||
|  | 
 | ||||
|  |   while (v1.length < len) { | ||||
|  |     v1.push('0') | ||||
|  |   } | ||||
|  |   while (v2.length < len) { | ||||
|  |     v2.push('0') | ||||
|  |   } | ||||
|  | 
 | ||||
|  |   for (let i = 0; i < len; i++) { | ||||
|  |     const num1 = parseInt(v1[i]) | ||||
|  |     const num2 = parseInt(v2[i]) | ||||
|  | 
 | ||||
|  |     if (num1 > num2) { | ||||
|  |       return 1 | ||||
|  |     } else if (num1 < num2) { | ||||
|  |       return -1 | ||||
|  |     } | ||||
|  |   } | ||||
|  |   return 0 | ||||
|  | } | ||||
|  | 
 | ||||
|  | Component({ | ||||
|  |   properties: { | ||||
|  |     canvasId: { | ||||
|  |       type: String, | ||||
|  |       value: 'ec-canvas' | ||||
|  |     }, | ||||
|  | 
 | ||||
|  |     ec: { | ||||
|  |       type: Object | ||||
|  |     }, | ||||
|  | 
 | ||||
|  |     forceUseOldCanvas: { | ||||
|  |       type: Boolean, | ||||
|  |       value: false | ||||
|  |     } | ||||
|  |   }, | ||||
|  | 
 | ||||
|  |   data: { | ||||
|  |     isUseNewCanvas: false | ||||
|  |   }, | ||||
|  | 
 | ||||
|  |   ready: function () { | ||||
|  |     // Disable prograssive because drawImage doesn't support DOM as parameter
 | ||||
|  |     // See https://developers.weixin.qq.com/miniprogram/dev/api/canvas/CanvasContext.drawImage.html
 | ||||
|  |     echarts.registerPreprocessor(option => { | ||||
|  |       if (option && option.series) { | ||||
|  |         if (option.series.length > 0) { | ||||
|  |           option.series.forEach(series => { | ||||
|  |             series.progressive = 0; | ||||
|  |           }); | ||||
|  |         } | ||||
|  |         else if (typeof option.series === 'object') { | ||||
|  |           option.series.progressive = 0; | ||||
|  |         } | ||||
|  |       } | ||||
|  |     }); | ||||
|  | 
 | ||||
|  |     if (!this.data.ec) { | ||||
|  |       console.warn('组件需绑定 ec 变量,例:<ec-canvas id="mychart-dom-bar" ' | ||||
|  |         + 'canvas-id="mychart-bar" ec="{{ ec }}"></ec-canvas>'); | ||||
|  |       return; | ||||
|  |     } | ||||
|  | 
 | ||||
|  |     if (!this.data.ec.lazyLoad) { | ||||
|  |       this.init(); | ||||
|  |     } | ||||
|  |   }, | ||||
|  | 
 | ||||
|  |   methods: { | ||||
|  |     init: function (callback) { | ||||
|  |       const version = wx.getSystemInfoSync().SDKVersion | ||||
|  | 
 | ||||
|  |       const canUseNewCanvas = compareVersion(version, '2.9.0') >= 0; | ||||
|  |       const forceUseOldCanvas = this.data.forceUseOldCanvas; | ||||
|  |       const isUseNewCanvas = canUseNewCanvas && !forceUseOldCanvas; | ||||
|  |       this.setData({ isUseNewCanvas }); | ||||
|  | 
 | ||||
|  |       if (forceUseOldCanvas && canUseNewCanvas) { | ||||
|  |         console.warn('开发者强制使用旧canvas,建议关闭'); | ||||
|  |       } | ||||
|  | 
 | ||||
|  |       if (isUseNewCanvas) { | ||||
|  |         // console.log('微信基础库版本大于2.9.0,开始使用<canvas type="2d"/>');
 | ||||
|  |         // 2.9.0 可以使用 <canvas type="2d"></canvas>
 | ||||
|  |         this.initByNewWay(callback); | ||||
|  |       } else { | ||||
|  |         const isValid = compareVersion(version, '1.9.91') >= 0 | ||||
|  |         if (!isValid) { | ||||
|  |           console.error('微信基础库版本过低,需大于等于 1.9.91。' | ||||
|  |             + '参见:https://github.com/ecomfe/echarts-for-weixin' | ||||
|  |             + '#%E5%BE%AE%E4%BF%A1%E7%89%88%E6%9C%AC%E8%A6%81%E6%B1%82'); | ||||
|  |           return; | ||||
|  |         } else { | ||||
|  |           console.warn('建议将微信基础库调整大于等于2.9.0版本。升级后绘图将有更好性能'); | ||||
|  |           this.initByOldWay(callback); | ||||
|  |         } | ||||
|  |       } | ||||
|  |     }, | ||||
|  | 
 | ||||
|  |     initByOldWay(callback) { | ||||
|  |       // 1.9.91 <= version < 2.9.0:原来的方式初始化
 | ||||
|  |       ctx = wx.createCanvasContext(this.data.canvasId, this); | ||||
|  |       const canvas = new WxCanvas(ctx, this.data.canvasId, false); | ||||
|  | 
 | ||||
|  |       if (echarts.setPlatformAPI) { | ||||
|  |         echarts.setPlatformAPI({ | ||||
|  |           createCanvas: () => canvas, | ||||
|  |         }); | ||||
|  |       } else { | ||||
|  |         echarts.setCanvasCreator(() => canvas); | ||||
|  |       }; | ||||
|  |       // const canvasDpr = wx.getSystemInfoSync().pixelRatio // 微信旧的canvas不能传入dpr
 | ||||
|  |       const canvasDpr = 1 | ||||
|  |       var query = wx.createSelectorQuery().in(this); | ||||
|  |       query.select('.ec-canvas').boundingClientRect(res => { | ||||
|  |         if (typeof callback === 'function') { | ||||
|  |           this.chart = callback(canvas, res.width, res.height, canvasDpr); | ||||
|  |         } | ||||
|  |         else if (this.data.ec && typeof this.data.ec.onInit === 'function') { | ||||
|  |           this.chart = this.data.ec.onInit(canvas, res.width, res.height, canvasDpr); | ||||
|  |         } | ||||
|  |         else { | ||||
|  |           this.triggerEvent('init', { | ||||
|  |             canvas: canvas, | ||||
|  |             width: res.width, | ||||
|  |             height: res.height, | ||||
|  |             canvasDpr: canvasDpr // 增加了dpr,可方便外面echarts.init
 | ||||
|  |           }); | ||||
|  |         } | ||||
|  |       }).exec(); | ||||
|  |     }, | ||||
|  | 
 | ||||
|  |     initByNewWay(callback) { | ||||
|  |       // version >= 2.9.0:使用新的方式初始化
 | ||||
|  |       const query = wx.createSelectorQuery().in(this) | ||||
|  |       query | ||||
|  |         .select('.ec-canvas') | ||||
|  |         .fields({ node: true, size: true }) | ||||
|  |         .exec(res => { | ||||
|  |           const canvasNode = res[0].node | ||||
|  |           this.canvasNode = canvasNode | ||||
|  | 
 | ||||
|  |           const canvasDpr = wx.getSystemInfoSync().pixelRatio | ||||
|  |           const canvasWidth = res[0].width | ||||
|  |           const canvasHeight = res[0].height | ||||
|  | 
 | ||||
|  |           const ctx = canvasNode.getContext('2d') | ||||
|  | 
 | ||||
|  |           const canvas = new WxCanvas(ctx, this.data.canvasId, true, canvasNode) | ||||
|  |           if (echarts.setPlatformAPI) { | ||||
|  |             echarts.setPlatformAPI({ | ||||
|  |               createCanvas: () => canvas, | ||||
|  |               loadImage: (src, onload, onerror) => { | ||||
|  |                 if (canvasNode.createImage) { | ||||
|  |                   const image = canvasNode.createImage(); | ||||
|  |                   image.onload = onload; | ||||
|  |                   image.onerror = onerror; | ||||
|  |                   image.src = src; | ||||
|  |                   return image; | ||||
|  |                 } | ||||
|  |                 console.error('加载图片依赖 `Canvas.createImage()` API,要求小程序基础库版本在 2.7.0 及以上。'); | ||||
|  |                 // PENDING fallback?
 | ||||
|  |               } | ||||
|  |             }) | ||||
|  |           } else { | ||||
|  |             echarts.setCanvasCreator(() => canvas) | ||||
|  |           } | ||||
|  | 
 | ||||
|  |           if (typeof callback === 'function') { | ||||
|  |             this.chart = callback(canvas, canvasWidth, canvasHeight, canvasDpr) | ||||
|  |           } else if (this.data.ec && typeof this.data.ec.onInit === 'function') { | ||||
|  |             this.chart = this.data.ec.onInit(canvas, canvasWidth, canvasHeight, canvasDpr) | ||||
|  |           } else { | ||||
|  |             this.triggerEvent('init', { | ||||
|  |               canvas: canvas, | ||||
|  |               width: canvasWidth, | ||||
|  |               height: canvasHeight, | ||||
|  |               dpr: canvasDpr | ||||
|  |             }) | ||||
|  |           } | ||||
|  |         }) | ||||
|  |     }, | ||||
|  |     canvasToTempFilePath(opt) { | ||||
|  |       if (this.data.isUseNewCanvas) { | ||||
|  |         // 新版
 | ||||
|  |         const query = wx.createSelectorQuery().in(this) | ||||
|  |         query | ||||
|  |           .select('.ec-canvas') | ||||
|  |           .fields({ node: true, size: true }) | ||||
|  |           .exec(res => { | ||||
|  |             const canvasNode = res[0].node | ||||
|  |             opt.canvas = canvasNode | ||||
|  |             wx.canvasToTempFilePath(opt) | ||||
|  |           }) | ||||
|  |       } else { | ||||
|  |         // 旧的
 | ||||
|  |         if (!opt.canvasId) { | ||||
|  |           opt.canvasId = this.data.canvasId; | ||||
|  |         } | ||||
|  |         ctx.draw(true, () => { | ||||
|  |           wx.canvasToTempFilePath(opt, this); | ||||
|  |         }); | ||||
|  |       } | ||||
|  |     }, | ||||
|  | 
 | ||||
|  |     touchStart(e) { | ||||
|  |       if (this.chart && e.touches.length > 0) { | ||||
|  |         var touch = e.touches[0]; | ||||
|  |         var handler = this.chart.getZr().handler; | ||||
|  |         handler.dispatch('mousedown', { | ||||
|  |           zrX: touch.x, | ||||
|  |           zrY: touch.y, | ||||
|  |           preventDefault: () => {}, | ||||
|  |           stopImmediatePropagation: () => {}, | ||||
|  |           stopPropagation: () => {} | ||||
|  |         }); | ||||
|  |         handler.dispatch('mousemove', { | ||||
|  |           zrX: touch.x, | ||||
|  |           zrY: touch.y, | ||||
|  |           preventDefault: () => {}, | ||||
|  |           stopImmediatePropagation: () => {}, | ||||
|  |           stopPropagation: () => {} | ||||
|  |         }); | ||||
|  |         handler.processGesture(wrapTouch(e), 'start'); | ||||
|  |       } | ||||
|  |     }, | ||||
|  | 
 | ||||
|  |     touchMove(e) { | ||||
|  |       if (this.chart && e.touches.length > 0) { | ||||
|  |         var touch = e.touches[0]; | ||||
|  |         var handler = this.chart.getZr().handler; | ||||
|  |         handler.dispatch('mousemove', { | ||||
|  |           zrX: touch.x, | ||||
|  |           zrY: touch.y, | ||||
|  |           preventDefault: () => {}, | ||||
|  |           stopImmediatePropagation: () => {}, | ||||
|  |           stopPropagation: () => {} | ||||
|  |         }); | ||||
|  |         handler.processGesture(wrapTouch(e), 'change'); | ||||
|  |       } | ||||
|  |     }, | ||||
|  | 
 | ||||
|  |     touchEnd(e) { | ||||
|  |       if (this.chart) { | ||||
|  |         const touch = e.changedTouches ? e.changedTouches[0] : {}; | ||||
|  |         var handler = this.chart.getZr().handler; | ||||
|  |         handler.dispatch('mouseup', { | ||||
|  |           zrX: touch.x, | ||||
|  |           zrY: touch.y, | ||||
|  |           preventDefault: () => {}, | ||||
|  |           stopImmediatePropagation: () => {}, | ||||
|  |           stopPropagation: () => {} | ||||
|  |         }); | ||||
|  |         handler.dispatch('click', { | ||||
|  |           zrX: touch.x, | ||||
|  |           zrY: touch.y, | ||||
|  |           preventDefault: () => {}, | ||||
|  |           stopImmediatePropagation: () => {}, | ||||
|  |           stopPropagation: () => {} | ||||
|  |         }); | ||||
|  |         handler.processGesture(wrapTouch(e), 'end'); | ||||
|  |       } | ||||
|  |     } | ||||
|  |   } | ||||
|  | }); | ||||
|  | 
 | ||||
|  | function wrapTouch(event) { | ||||
|  |   for (let i = 0; i < event.touches.length; ++i) { | ||||
|  |     const touch = event.touches[i]; | ||||
|  |     touch.offsetX = touch.x; | ||||
|  |     touch.offsetY = touch.y; | ||||
|  |   } | ||||
|  |   return event; | ||||
|  | } | ||||
| @ -1,3 +1,4 @@ | |||||
| { | { | ||||
|  |   "component": true, | ||||
|   "usingComponents": {} |   "usingComponents": {} | ||||
| } | } | ||||
| @ -0,0 +1,4 @@ | |||||
|  | <!-- 新的:接口对其了H5 --> | ||||
|  | <canvas wx:if="{{isUseNewCanvas}}" type="2d" class="ec-canvas" canvas-id="{{ canvasId }}" bindinit="init" bindtouchstart="{{ ec.disableTouch ? '' : 'touchStart' }}" bindtouchmove="{{ ec.disableTouch ? '' : 'touchMove' }}" bindtouchend="{{ ec.disableTouch ? '' : 'touchEnd' }}"></canvas> | ||||
|  | <!-- 旧的 --> | ||||
|  | <canvas wx:else class="ec-canvas" canvas-id="{{ canvasId }}" bindinit="init" bindtouchstart="{{ ec.disableTouch ? '' : 'touchStart' }}" bindtouchmove="{{ ec.disableTouch ? '' : 'touchMove' }}" bindtouchend="{{ ec.disableTouch ? '' : 'touchEnd' }}"></canvas> | ||||
| @ -0,0 +1,4 @@ | |||||
|  | .ec-canvas { | ||||
|  |   width: 100%; | ||||
|  |   height: 100%; | ||||
|  | } | ||||
| @ -0,0 +1,111 @@ | |||||
|  | export default class WxCanvas { | ||||
|  |   constructor(ctx, canvasId, isNew, canvasNode) { | ||||
|  |     this.ctx = ctx; | ||||
|  |     this.canvasId = canvasId; | ||||
|  |     this.chart = null; | ||||
|  |     this.isNew = isNew | ||||
|  |     if (isNew) { | ||||
|  |       this.canvasNode = canvasNode; | ||||
|  |     } | ||||
|  |     else { | ||||
|  |       this._initStyle(ctx); | ||||
|  |     } | ||||
|  | 
 | ||||
|  |     // this._initCanvas(zrender, ctx);
 | ||||
|  | 
 | ||||
|  |     this._initEvent(); | ||||
|  |   } | ||||
|  | 
 | ||||
|  |   getContext(contextType) { | ||||
|  |     if (contextType === '2d') { | ||||
|  |       return this.ctx; | ||||
|  |     } | ||||
|  |   } | ||||
|  | 
 | ||||
|  |   // canvasToTempFilePath(opt) {
 | ||||
|  |   //   if (!opt.canvasId) {
 | ||||
|  |   //     opt.canvasId = this.canvasId;
 | ||||
|  |   //   }
 | ||||
|  |   //   return wx.canvasToTempFilePath(opt, this);
 | ||||
|  |   // }
 | ||||
|  | 
 | ||||
|  |   setChart(chart) { | ||||
|  |     this.chart = chart; | ||||
|  |   } | ||||
|  | 
 | ||||
|  |   addEventListener() { | ||||
|  |     // noop
 | ||||
|  |   } | ||||
|  | 
 | ||||
|  |   attachEvent() { | ||||
|  |     // noop
 | ||||
|  |   } | ||||
|  | 
 | ||||
|  |   detachEvent() { | ||||
|  |     // noop
 | ||||
|  |   } | ||||
|  | 
 | ||||
|  |   _initCanvas(zrender, ctx) { | ||||
|  |     zrender.util.getContext = function () { | ||||
|  |       return ctx; | ||||
|  |     }; | ||||
|  | 
 | ||||
|  |     zrender.util.$override('measureText', function (text, font) { | ||||
|  |       ctx.font = font || '12px sans-serif'; | ||||
|  |       return ctx.measureText(text); | ||||
|  |     }); | ||||
|  |   } | ||||
|  | 
 | ||||
|  |   _initStyle(ctx) { | ||||
|  |     ctx.createRadialGradient = () => { | ||||
|  |       return ctx.createCircularGradient(arguments); | ||||
|  |     }; | ||||
|  |   } | ||||
|  | 
 | ||||
|  |   _initEvent() { | ||||
|  |     this.event = {}; | ||||
|  |     const eventNames = [{ | ||||
|  |       wxName: 'touchStart', | ||||
|  |       ecName: 'mousedown' | ||||
|  |     }, { | ||||
|  |       wxName: 'touchMove', | ||||
|  |       ecName: 'mousemove' | ||||
|  |     }, { | ||||
|  |       wxName: 'touchEnd', | ||||
|  |       ecName: 'mouseup' | ||||
|  |     }, { | ||||
|  |       wxName: 'touchEnd', | ||||
|  |       ecName: 'click' | ||||
|  |     }]; | ||||
|  |     eventNames.forEach(name => { | ||||
|  |       this.event[name.wxName] = e => { | ||||
|  |         const touch = e.touches[0]; | ||||
|  |         this.chart.getZr().handler.dispatch(name.ecName, { | ||||
|  |           zrX: name.wxName === 'tap' ? touch.clientX : touch.x, | ||||
|  |           zrY: name.wxName === 'tap' ? touch.clientY : touch.y, | ||||
|  |           preventDefault: () => {}, | ||||
|  |           stopImmediatePropagation: () => {}, | ||||
|  |           stopPropagation: () => {} | ||||
|  |         }); | ||||
|  |       }; | ||||
|  |     }); | ||||
|  |   } | ||||
|  | 
 | ||||
|  |   set width(w) { | ||||
|  |     if (this.canvasNode) this.canvasNode.width = w | ||||
|  |   } | ||||
|  |   set height(h) { | ||||
|  |     if (this.canvasNode) this.canvasNode.height = h | ||||
|  |   } | ||||
|  | 
 | ||||
|  |   get width() { | ||||
|  |     if (this.canvasNode) | ||||
|  |       return this.canvasNode.width | ||||
|  |     return 0 | ||||
|  |   } | ||||
|  |   get height() { | ||||
|  |     if (this.canvasNode) | ||||
|  |       return this.canvasNode.height | ||||
|  |     return 0 | ||||
|  |   } | ||||
|  | } | ||||
| @ -1,2 +0,0 @@ | |||||
| <!--package/homePage/homePage.wxml--> |  | ||||
| <text>package/homePage/homePage.wxml</text> |  | ||||
| @ -1 +0,0 @@ | |||||
| /* package/homePage/homePage.wxss */ |  | ||||
| @ -1,4 +1,4 @@ | |||||
| // package/homePage/homePage.js
 | // package/riskManagement/riskCalendar/riskCalendar.js
 | ||||
| Page({ | Page({ | ||||
| 
 | 
 | ||||
|   /** |   /** | ||||
| @ -0,0 +1,9 @@ | |||||
|  | { | ||||
|  |   "navigationBarBackgroundColor": "#1979ff", | ||||
|  |   "navigationBarTextStyle": "white", | ||||
|  |   "navigationBarTitleText": "故障日历", | ||||
|  |   "enablePullDownRefresh": false, | ||||
|  |   "usingComponents": { | ||||
|  |     "ec-canvas": "../../components/ec-canvas/ec-canvas" | ||||
|  |   } | ||||
|  | } | ||||
| @ -0,0 +1,2 @@ | |||||
|  | <!--package/riskManagement/riskCalendar/riskCalendar.wxml--> | ||||
|  | <text>package/riskManagement/riskCalendar/riskCalendar.wxml</text> | ||||
| @ -0,0 +1 @@ | |||||
|  | /* package/riskManagement/riskCalendar/riskCalendar.wxss */ | ||||
| @ -0,0 +1,126 @@ | |||||
|  | // package/riskManagement/riskManagement.js
 | ||||
|  | import * as echarts from '../components/ec-canvas/echarts'; | ||||
|  | 
 | ||||
|  | function setOption(chart, data) { | ||||
|  |   const option = { | ||||
|  |     grid: { | ||||
|  |       top: '5%', | ||||
|  |       left: '3%', | ||||
|  |       right: '4%', | ||||
|  |       bottom: '3%', | ||||
|  |       containLabel: true | ||||
|  |     }, | ||||
|  |     xAxis: { | ||||
|  |       type: 'category', | ||||
|  |       data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'] | ||||
|  |     }, | ||||
|  |     yAxis: { | ||||
|  |       type: 'value' | ||||
|  |     }, | ||||
|  |     series: [ | ||||
|  |       { | ||||
|  |         data: data, | ||||
|  |         type: 'line' | ||||
|  |       } | ||||
|  |     ] | ||||
|  |   }; | ||||
|  |   chart.setOption(option); | ||||
|  | } | ||||
|  | 
 | ||||
|  | Page({ | ||||
|  | 
 | ||||
|  |   /** | ||||
|  |    * 页面的初始数据 | ||||
|  |    */ | ||||
|  |   data: { | ||||
|  |     ec: { | ||||
|  |       // onInit: initChart,
 | ||||
|  |       lazyLoad: true, // 将 lazyLoad 设为 true 后,需要手动初始化图表
 | ||||
|  |     }, | ||||
|  |     isLoaded: false, | ||||
|  |     list: [1,2,3] | ||||
|  |   }, | ||||
|  | 
 | ||||
|  |   // 初始化图表
 | ||||
|  |   initChart: function (data) { | ||||
|  |     this.ecComponent.init((canvas, width, height, dpr) => { | ||||
|  |       // 获取组件的 canvas、width、height 后的回调函数
 | ||||
|  |       // 在这里初始化图表
 | ||||
|  |       const chart = echarts.init(canvas, null, { | ||||
|  |         width: width, | ||||
|  |         height: height, | ||||
|  |         devicePixelRatio: dpr // new
 | ||||
|  |       }); | ||||
|  |       setOption(chart, data); | ||||
|  | 
 | ||||
|  |       // 将图表实例绑定到 this 上,可以在其他成员函数中访问
 | ||||
|  |       this.chart = chart; | ||||
|  | 
 | ||||
|  |       this.setData({ | ||||
|  |         isLoaded: true, | ||||
|  |       }); | ||||
|  | 
 | ||||
|  |       // 注意这里一定要返回 chart 实例,否则会影响事件处理等
 | ||||
|  |       return chart; | ||||
|  |     }); | ||||
|  |   }, | ||||
|  | 
 | ||||
|  |   /** | ||||
|  |    * 生命周期函数--监听页面加载 | ||||
|  |    */ | ||||
|  |   onLoad(options) { | ||||
|  |     // 请求数据
 | ||||
|  |     setTimeout(() => { | ||||
|  |       this.initChart([250, 300, 100, 147, 260, 123, 311]) | ||||
|  |     }, 1000) | ||||
|  |   }, | ||||
|  | 
 | ||||
|  |   /** | ||||
|  |    * 生命周期函数--监听页面初次渲染完成 | ||||
|  |    */ | ||||
|  |   onReady() { | ||||
|  |     this.ecComponent = this.selectComponent('#risk-trend-chart'); | ||||
|  |   }, | ||||
|  | 
 | ||||
|  |   /** | ||||
|  |    * 生命周期函数--监听页面显示 | ||||
|  |    */ | ||||
|  |   onShow() { | ||||
|  | 
 | ||||
|  |   }, | ||||
|  | 
 | ||||
|  |   /** | ||||
|  |    * 生命周期函数--监听页面隐藏 | ||||
|  |    */ | ||||
|  |   onHide() { | ||||
|  | 
 | ||||
|  |   }, | ||||
|  | 
 | ||||
|  |   /** | ||||
|  |    * 生命周期函数--监听页面卸载 | ||||
|  |    */ | ||||
|  |   onUnload() { | ||||
|  | 
 | ||||
|  |   }, | ||||
|  | 
 | ||||
|  |   /** | ||||
|  |    * 页面相关事件处理函数--监听用户下拉动作 | ||||
|  |    */ | ||||
|  |   onPullDownRefresh() { | ||||
|  | 
 | ||||
|  |   }, | ||||
|  | 
 | ||||
|  |   /** | ||||
|  |    * 页面上拉触底事件的处理函数 | ||||
|  |    */ | ||||
|  |   onReachBottom() { | ||||
|  | 
 | ||||
|  |   }, | ||||
|  | 
 | ||||
|  |   /** | ||||
|  |    * 用户点击右上角分享 | ||||
|  |    */ | ||||
|  |   onShareAppMessage() { | ||||
|  | 
 | ||||
|  |   } | ||||
|  | }) | ||||
| @ -0,0 +1,9 @@ | |||||
|  | { | ||||
|  |   "navigationBarBackgroundColor": "#006BE3", | ||||
|  |   "navigationBarTextStyle": "white", | ||||
|  |   "navigationBarTitleText": "故障风险管理", | ||||
|  |   "enablePullDownRefresh": false, | ||||
|  |   "usingComponents": { | ||||
|  |     "ec-canvas": "../components/ec-canvas/ec-canvas" | ||||
|  |   } | ||||
|  | } | ||||
| @ -0,0 +1,41 @@ | |||||
|  | <!-- package / riskManagement / riskManagement.wxml --> | ||||
|  | <view class="risk-management"> | ||||
|  |   <view class="icon"><text class="icon-text">故障统计</text></view> | ||||
|  | 
 | ||||
|  |   <view class="flex flex-between"> | ||||
|  |     <view class="title-item flex flex-col"> | ||||
|  |       <view>本月上报风险</view> | ||||
|  |       <view><text class="title-num">{{86}}</text><text class="title-unit">个</text></view> | ||||
|  |     </view> | ||||
|  |     <view class="title-item flex flex-col"> | ||||
|  |       <view>故障风险管理</view> | ||||
|  |       <view><text class="title-num">{{300}}</text><text class="title-unit">个</text></view> | ||||
|  |     </view> | ||||
|  |   </view> | ||||
|  | 
 | ||||
|  |   <view class="card"> | ||||
|  |     <view class="flex flex-start"> | ||||
|  |       <!-- <image src="" class="card-img" /> --> | ||||
|  |       <view class="card-img" style="background: blue;"></view> | ||||
|  |       <view class="card-title">历史风险趋势</view> | ||||
|  |     </view> | ||||
|  |     <view class="chart"> | ||||
|  |       <ec-canvas id="risk-trend-chart" canvas-id="risk-trend-chart" ec="{{ ec }}"></ec-canvas> | ||||
|  |     </view> | ||||
|  |   </view> | ||||
|  | 
 | ||||
|  |   <view class="card"> | ||||
|  |     <view class="flex flex-between"> | ||||
|  |       <!-- <image src="" class="card-img" /> --> | ||||
|  |       <view class="flex"> | ||||
|  |         <view class="card-img" style="background: blue;"></view> | ||||
|  |         <view class="card-title">故障排行榜</view> | ||||
|  |       </view> | ||||
|  |       <view class="card-link">查看详情 ></view> | ||||
|  |     </view> | ||||
|  |     <view>【故障次数统计】</view> | ||||
|  |     <view class="list" wx:for="{{list}}"> | ||||
|  |       <view class="list-title">设备{{item}}</view> | ||||
|  |     </view> | ||||
|  |   </view> | ||||
|  | </view> | ||||
| @ -0,0 +1,76 @@ | |||||
|  | /* package/riskManagement/riskManagement.wxss */ | ||||
|  | .risk-management { | ||||
|  |   height: 100vh; | ||||
|  |   background-image: linear-gradient(179deg, #006BE3 0%, #4E87FF 16%, #4e87ff00 93%); | ||||
|  |   padding: 0 15px; | ||||
|  | } | ||||
|  | 
 | ||||
|  | .icon { | ||||
|  |   width: 61px; | ||||
|  |   height: 31.86px; | ||||
|  |   background-image: linear-gradient(0deg, #EAF2FF 5%, #2578F0 100%); | ||||
|  |   box-shadow: 0 3px 4px 1px #bfdbfa4f; | ||||
|  | } | ||||
|  | 
 | ||||
|  | .icon-text { | ||||
|  |   width: 48px; | ||||
|  |   height: 17px; | ||||
|  |   font-family: PingFangSC-Medium; | ||||
|  |   font-weight: 500; | ||||
|  |   font-size: 12px; | ||||
|  |   color: #FFFFFF; | ||||
|  | } | ||||
|  | 
 | ||||
|  | .title-item { | ||||
|  |   width: 150px; | ||||
|  |   color: #ffffffd9; | ||||
|  | } | ||||
|  | 
 | ||||
|  | .title-num { | ||||
|  |   font-size: 20px; | ||||
|  |   color: #FFFFFF; | ||||
|  | } | ||||
|  | 
 | ||||
|  | .title-unit { | ||||
|  |   font-size: 10px; | ||||
|  |   color: #FFFFFE; | ||||
|  |   margin-left: 10px; | ||||
|  | } | ||||
|  | 
 | ||||
|  | .card { | ||||
|  |   background: #FFFFFF; | ||||
|  |   box-shadow: 2px 2px 11px 0 #00000008, 0 0 4px 0 #00000012; | ||||
|  |   border-radius: 4px; | ||||
|  |   padding: 12px; | ||||
|  |   margin-top: 12px; | ||||
|  | } | ||||
|  | 
 | ||||
|  | .card-img { | ||||
|  |   width: 18px; | ||||
|  |   height: 18px; | ||||
|  |   margin-right: 13px; | ||||
|  | } | ||||
|  | 
 | ||||
|  | .card-title { | ||||
|  |   font-weight: 500; | ||||
|  |   font-size: 16px; | ||||
|  |   color: #383A3B; | ||||
|  | } | ||||
|  | 
 | ||||
|  | .card-link { | ||||
|  |   font-weight: 500; | ||||
|  |   font-size: 14px; | ||||
|  |   color: #1684FF; | ||||
|  | } | ||||
|  | 
 | ||||
|  | .chart { | ||||
|  |   width: 100%; | ||||
|  |   height: 195px; | ||||
|  |   margin-top: 20px; | ||||
|  | } | ||||
|  | 
 | ||||
|  | .list { | ||||
|  |   margin-top: 10px; | ||||
|  |   padding: 10px 7px; | ||||
|  |   background-color: #F1F7FF; | ||||
|  | } | ||||
| @ -0,0 +1,242 @@ | |||||
|  | // 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({ | ||||
|  |     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, //当月维修次数
 | ||||
|  |         level1Count: 0, //轻微
 | ||||
|  |         level2Count: 0, //中度
 | ||||
|  |         level3Count: 0, //严重
 | ||||
|  |         selectedDate: new Date(), // 设置默认选中的日期为当前日期
 | ||||
|  |         formatter(day) { | ||||
|  | 
 | ||||
|  |             return day; | ||||
|  |         }, | ||||
|  | 
 | ||||
|  |     }, | ||||
|  | 
 | ||||
|  |     onDisplay() { | ||||
|  |         this.setData({ | ||||
|  |             show: true | ||||
|  |         }); | ||||
|  |     }, | ||||
|  |     onClose() { | ||||
|  |         this.setData({ | ||||
|  |             show: false | ||||
|  |         }); | ||||
|  |     }, | ||||
|  | 
 | ||||
|  |     onConfirm(event) { | ||||
|  |         this.setData({ | ||||
|  |             show: false, | ||||
|  |             date: this.formatDate(event.detail), | ||||
|  |         }); | ||||
|  |     }, | ||||
|  | 
 | ||||
|  |     /** | ||||
|  |      * 生命周期函数--监听页面加载 | ||||
|  |      */ | ||||
|  |     onLoad: function (options) { | ||||
|  |         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() | ||||
|  | 
 | ||||
|  |     }, | ||||
|  |     //过滤轻微,中度,重度的巡检个数
 | ||||
|  |     filterLevelCount:function(list,level){ | ||||
|  |      return   list?.filter(i => { | ||||
|  |             const content = i?.points?.inspectContent | ||||
|  |             if (content) { | ||||
|  |                 for (let key in content) { | ||||
|  |                     if (content.hasOwnProperty(key)) { | ||||
|  |                         const subObject = content[key]; | ||||
|  |                         return subObject.level===level | ||||
|  |                     } | ||||
|  |                 } | ||||
|  |             } | ||||
|  |         })?.length | ||||
|  |     }, | ||||
|  |     getSubSystemPatrolAbout: function (options) { | ||||
|  |         let that = this; | ||||
|  |         //当月开始时间
 | ||||
|  |         const STime = moment().startOf('month').format('YYYY-MM-DD') | ||||
|  |         //当月结束时间
 | ||||
|  |         const ETime = moment().endOf('month').format('YYYY-MM-DD') | ||||
|  |         //子系统关键字
 | ||||
|  |         let keywords = options.key | ||||
|  |         // keywords = '管廊'
 | ||||
|  |         const query = { | ||||
|  |             STime, | ||||
|  |             ETime, | ||||
|  |             keywords | ||||
|  |         } | ||||
|  |         Request.get(getSubSystemPatrolAbout(query)).then(res => { | ||||
|  |             if (res) { | ||||
|  |                 //巡查内容
 | ||||
|  |                 that.setData({ | ||||
|  |                     currentRepairCount: res?.filter(i => i?.patrolRecordIssueHandles[0]?.yanshoushijian && parseInt(moment(i?.patrolRecordIssueHandles[0]?.yanshoushijian).format('YYYYMMDD')) === parseInt(moment().format('YYYYMMDD'))).length || 0, | ||||
|  |                     currentPatrolCount: res.length, | ||||
|  |                     level1Count: that.filterLevelCount(res,'轻微')||0, | ||||
|  |                     level2Count: that.filterLevelCount(res,'中度')||0, | ||||
|  |                     level3Count: that.filterLevelCount(res,'严重')||0, | ||||
|  |                     formatter:function(e){ | ||||
|  |                         res?.map(i=>{ | ||||
|  |                             if(moment(i.inspectionTime).format('YYYY-MM-DD')==moment(e.date).format('YYYY-MM-DD')){ | ||||
|  |                                 if( i.patrolRecordIssueHandles.length==0){ | ||||
|  |                                     e.bottomInfo = '.';e.className = 'greenClass' | ||||
|  |                                 }else if( i.patrolRecordIssueHandles.length&& i?.patrolRecordIssueHandles[0]?.yanshoushijian && parseInt(moment(i?.patrolRecordIssueHandles[0]?.yanshoushijian).format('YYYYMMDD')) === parseInt(moment().format('YYYYMMDD'))){ | ||||
|  |                                     e.bottomInfo = '.';e.className = 'yellowClass' | ||||
|  |                                 } | ||||
|  |                             } | ||||
|  |                         }) | ||||
|  |                         return e | ||||
|  |                     } | ||||
|  |                 }) | ||||
|  |                 that.ecComponent = that.selectComponent('#mychart-dom-pie'); | ||||
|  |                 console.log('that.level1Count',this.data.level2Count) | ||||
|  |                 var option = { | ||||
|  |                     backgroundColor: "#ffffff", | ||||
|  |                     legend: { | ||||
|  |                         bottom: 10, | ||||
|  |                         left: 'center', | ||||
|  |                     }, | ||||
|  |                     series: [{ | ||||
|  |                         label: { | ||||
|  |                             normal: { | ||||
|  |                                 fontSize: 14 | ||||
|  |                             } | ||||
|  |                         }, | ||||
|  |                         type: 'pie', | ||||
|  |                         center: ['50%', '50%'], | ||||
|  |                         radius: ['20%', '40%'], | ||||
|  |                         data:[ {name:'轻微',value:that.data.level1Count}, | ||||
|  |                         {name:'中度',value:that.data.level2Count}, | ||||
|  |                         {name:'重度',value:that.data.level3Count}] | ||||
|  |                     }] | ||||
|  |                 }; | ||||
|  |                 that.initECharts(option); | ||||
|  |                 | ||||
|  |                 wx.hideLoading() | ||||
|  |             } else { | ||||
|  |                 wx.hideLoading(); | ||||
|  |             } | ||||
|  |         }) | ||||
|  |     }, | ||||
|  |     /** | ||||
|  |      * 生命周期函数--监听页面初次渲染完成 | ||||
|  |      */ | ||||
|  | 
 | ||||
|  |     onReady() { | ||||
|  |         | ||||
|  | 
 | ||||
|  |     }, | ||||
|  | 
 | ||||
|  |     /** | ||||
|  |      * 生命周期函数--监听页面显示 | ||||
|  |      */ | ||||
|  |     onShow() { | ||||
|  | 
 | ||||
|  |     }, | ||||
|  | 
 | ||||
|  |     /** | ||||
|  |      * 生命周期函数--监听页面隐藏 | ||||
|  |      */ | ||||
|  |     onHide() { | ||||
|  | 
 | ||||
|  |     }, | ||||
|  | 
 | ||||
|  |     /** | ||||
|  |      * 生命周期函数--监听页面卸载 | ||||
|  |      */ | ||||
|  |     onUnload() { | ||||
|  | 
 | ||||
|  |     }, | ||||
|  | 
 | ||||
|  |     /** | ||||
|  |      * 页面相关事件处理函数--监听用户下拉动作 | ||||
|  |      */ | ||||
|  |     onPullDownRefresh() { | ||||
|  |         getSubSystemPatrolAbout() | ||||
|  |     }, | ||||
|  | 
 | ||||
|  |     /** | ||||
|  |      * 页面上拉触底事件的处理函数 | ||||
|  |      */ | ||||
|  |     onReachBottom() { | ||||
|  | 
 | ||||
|  |     }, | ||||
|  | 
 | ||||
|  |     /** | ||||
|  |      * 用户点击右上角分享 | ||||
|  |      */ | ||||
|  |     onShareAppMessage() { | ||||
|  | 
 | ||||
|  |     } | ||||
|  | }) | ||||
| @ -0,0 +1,8 @@ | |||||
|  | { | ||||
|  |    | ||||
|  |   "usingComponents": {   | ||||
|  |         "ec-canvas": "../components/ec-canvas/ec-canvas", | ||||
|  |         "van-calendar": "@vant/weapp/calendar/index" | ||||
|  | 
 | ||||
|  |   } | ||||
|  | } | ||||
| @ -0,0 +1,35 @@ | |||||
|  | <!--package/subSystem/subSystem.wxml--> | ||||
|  | <!--总览图--> | ||||
|  | <view style="display: flex;justify-content: space-around;margin-bottom: 10px; padding-top: 10px; background-image: linear-gradient(179deg, #006BE3 0%, #4E87FF 16%, #4e87ff00 93%);"> | ||||
|  |     <view> | ||||
|  |         <view>本月巡检次数</view> | ||||
|  |         <view class="number">{{currentPatrolCount}}</view> | ||||
|  |     </view> | ||||
|  |     <view> | ||||
|  |         <view>本月维修次数</view> | ||||
|  |         <view class="number">{{currentRepairCount}}</view> | ||||
|  |     </view> | ||||
|  | </view> | ||||
|  | <!--饼图--> | ||||
|  | <view class="card" > | ||||
|  |     <ec-canvas id="mychart-dom-pie" canvas-id="mychart-pie" ec="{{ ec }}"></ec-canvas> | ||||
|  | </view> | ||||
|  | <!--巡检日历--> | ||||
|  | <view class="card heightStyle"> | ||||
|  |     <view class="header"> | ||||
|  |         <view class="xunjian">巡检日历</view> | ||||
|  |         <view class="yearMonth">{{currentYear+'年'+currentMonth+'月'}}</view> | ||||
|  |     </view> | ||||
|  |     <van-calendar | ||||
|  |      max-date="{{lastDay}}" | ||||
|  |     v-model="selectedDate" | ||||
|  |         readonly 	  | ||||
|  |     show-title="{{false}}"  | ||||
|  |     show-subtitle="{{false}}"  | ||||
|  |      poppable="{{ false }}"  | ||||
|  |      show-confirm="{{ false }}" | ||||
|  |      default-date="{{selectedDate}}" | ||||
|  |      formatter="{{formatter}}" | ||||
|  |      color="#0000FF" | ||||
|  |       class="calendar" /> | ||||
|  | </view> | ||||
| @ -0,0 +1,70 @@ | |||||
|  | /* package/subSystem/subSystem.wxss */ | ||||
|  | .number{ | ||||
|  |     width: 40px; | ||||
|  |     height: 26px; | ||||
|  |     font-family: D-DINExp; | ||||
|  |     font-weight: DINExp; | ||||
|  |     font-size: 24px; | ||||
|  |     color: #FFFFFF; | ||||
|  |     letter-spacing: 0; | ||||
|  | } | ||||
|  | 
 | ||||
|  | .card { | ||||
|  |     font-family: PingFangSC-Medium; | ||||
|  |     font-weight: 500; | ||||
|  |     font-size: 16px; | ||||
|  |     color: #333333; | ||||
|  |     background-color: #fff; | ||||
|  |     border: 1px solid #ddd; | ||||
|  |     border-radius: 8px; | ||||
|  |     /* padding: 10px 10px; */ | ||||
|  |     margin: 5px 5px; | ||||
|  |     box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2); | ||||
|  |     /* width: 300px; */ | ||||
|  |     height: 300px; | ||||
|  |   } | ||||
|  |   .heightStyle{ | ||||
|  |     height: auto; | ||||
|  |   } | ||||
|  |    | ||||
|  |   .xunjian{ | ||||
|  |     width: 64px; | ||||
|  |     height: 22px; | ||||
|  |     font-family: PingFangSC-Medium; | ||||
|  |     font-weight: 500; | ||||
|  |     font-size: 16px; | ||||
|  |     color: #000000d9; | ||||
|  |     letter-spacing: 0; | ||||
|  |   } | ||||
|  |   .yearMonth{ | ||||
|  |     width: 85px; | ||||
|  |     height: 20px; | ||||
|  |     font-family: PingFangSC-Medium; | ||||
|  |     font-weight: 500; | ||||
|  |     font-size: 14px; | ||||
|  |     color: #1684FF; | ||||
|  |     letter-spacing: 0; | ||||
|  |     text-align: right; | ||||
|  |   } | ||||
|  |   .header{ | ||||
|  |     display: flex; | ||||
|  |     justify-content: space-around; | ||||
|  |     margin-bottom: 10px; | ||||
|  |     margin-top:10px; | ||||
|  |   } | ||||
|  | 
 | ||||
|  |   .yellowClass .van-calendar__bottom-info{ | ||||
|  |     font-size: 50px; | ||||
|  |     color:yellow; | ||||
|  | 
 | ||||
|  |   } | ||||
|  |   .greenClass .van-calendar__bottom-info{ | ||||
|  |     font-size: 50px; | ||||
|  |     color:green; | ||||
|  |   } | ||||
|  |    | ||||
|  | 
 | ||||
|  |   | ||||
|  | 
 | ||||
|  |    | ||||
|  | 
 | ||||
| @ -1 +1,25 @@ | |||||
| /* pages/home/home.wxss */ | /* pages/home/home.wxss */ | ||||
|  | .list { | ||||
|  |     font-family: PingFangSC-Regular; | ||||
|  |     font-weight: 400; | ||||
|  |     font-size: 12px; | ||||
|  |     color: #333333; | ||||
|  |     letter-spacing: 0; | ||||
|  | } | ||||
|  | .card { | ||||
|  |     background-color: #fff; | ||||
|  |     border: 1px solid #ddd; | ||||
|  |     border-radius: 8px; | ||||
|  |     /* padding: 10px; */ | ||||
|  |     box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2); | ||||
|  |     margin: 10px; | ||||
|  |   } | ||||
|  |   .home-swiper { | ||||
|  |     width: 95%; | ||||
|  |     /* height: 360rpx; */ | ||||
|  |   } | ||||
|  | 
 | ||||
|  |   /* .slide-image { | ||||
|  |     width: 100%; | ||||
|  |     height: 100%; | ||||
|  |   } */ | ||||
| @ -0,0 +1,107 @@ | |||||
|  | // pages/workbench/workbench.js
 | ||||
|  | Page({ | ||||
|  | 
 | ||||
|  |   /** | ||||
|  |    * 页面的初始数据 | ||||
|  |    */ | ||||
|  |   data: { | ||||
|  |     itemList: [ | ||||
|  |       { | ||||
|  |         iconPath: '/images/workbench/report.png', | ||||
|  |         text: '故障及风险管理', | ||||
|  |         page: '/package/riskManagement/riskManagement' | ||||
|  |       }, | ||||
|  |       { | ||||
|  |         iconPath: '/images/workbench/report.png', | ||||
|  |         text: '设备大数据图谱', | ||||
|  |         page: '/package/riskManagement/riskCalendar/riskCalendar' | ||||
|  |       }, | ||||
|  |       { | ||||
|  |         iconPath: '/images/workbench/report.png', | ||||
|  |         text: '智能诊断', | ||||
|  |         page: '/package/riskManagement/riskManagement' | ||||
|  |       }, | ||||
|  |       { | ||||
|  |         iconPath: '/images/workbench/expert_systems.png', | ||||
|  |         text: '专家系统', | ||||
|  |         page: '/package/riskManagement/riskManagement' | ||||
|  |       }, | ||||
|  |       { | ||||
|  |         iconPath: '/images/workbench/report.png', | ||||
|  |         text: '巡检报告', | ||||
|  |         page: '/package/riskManagement/riskManagement' | ||||
|  |       }, | ||||
|  |       { | ||||
|  |         iconPath: '/images/workbench/issues.png', | ||||
|  |         text: '发现问题', | ||||
|  |         page: '/package/riskManagement/riskManagement' | ||||
|  |       }, | ||||
|  |     ] | ||||
|  |   }, | ||||
|  | 
 | ||||
|  |   navigator(e) { | ||||
|  |     wx.navigateTo({ | ||||
|  |       url: e.currentTarget.dataset.page, | ||||
|  |     }) | ||||
|  |   }, | ||||
|  | 
 | ||||
|  |   /** | ||||
|  |    * 生命周期函数--监听页面加载 | ||||
|  |    */ | ||||
|  |   onLoad(options) { | ||||
|  | 
 | ||||
|  |   }, | ||||
|  | 
 | ||||
|  |   /** | ||||
|  |    * 生命周期函数--监听页面初次渲染完成 | ||||
|  |    */ | ||||
|  |   onReady() { | ||||
|  | 
 | ||||
|  |   }, | ||||
|  | 
 | ||||
|  |   /** | ||||
|  |    * 生命周期函数--监听页面显示 | ||||
|  |    */ | ||||
|  |   onShow() { | ||||
|  |     if (typeof this.getTabBar === 'function' && this.getTabBar()) { | ||||
|  |       this.getTabBar().setData({ | ||||
|  |         selected: 1 | ||||
|  |       }) | ||||
|  |     } | ||||
|  |   }, | ||||
|  | 
 | ||||
|  |   /** | ||||
|  |    * 生命周期函数--监听页面隐藏 | ||||
|  |    */ | ||||
|  |   onHide() { | ||||
|  | 
 | ||||
|  |   }, | ||||
|  | 
 | ||||
|  |   /** | ||||
|  |    * 生命周期函数--监听页面卸载 | ||||
|  |    */ | ||||
|  |   onUnload() { | ||||
|  | 
 | ||||
|  |   }, | ||||
|  | 
 | ||||
|  |   /** | ||||
|  |    * 页面相关事件处理函数--监听用户下拉动作 | ||||
|  |    */ | ||||
|  |   onPullDownRefresh() { | ||||
|  | 
 | ||||
|  |   }, | ||||
|  | 
 | ||||
|  |   /** | ||||
|  |    * 页面上拉触底事件的处理函数 | ||||
|  |    */ | ||||
|  |   onReachBottom() { | ||||
|  | 
 | ||||
|  |   }, | ||||
|  | 
 | ||||
|  |   /** | ||||
|  |    * 用户点击右上角分享 | ||||
|  |    */ | ||||
|  |   onShareAppMessage() { | ||||
|  | 
 | ||||
|  |   } | ||||
|  | }) | ||||
| @ -0,0 +1,6 @@ | |||||
|  | { | ||||
|  |   "navigationBarBackgroundColor": "#1979ff", | ||||
|  |   "navigationBarTextStyle": "white", | ||||
|  |   "navigationBarTitleText": "控制台", | ||||
|  |   "enablePullDownRefresh": false | ||||
|  | } | ||||
| @ -0,0 +1,9 @@ | |||||
|  | <!-- pages/workbench/workbench.wxml --> | ||||
|  | <view class="workbench-page"> | ||||
|  |     <view class="workbench"> | ||||
|  |         <view class="workbench-item" wx:for="{{itemList}}" data-page="{{item.page}}" bindtap="navigator"> | ||||
|  |             <image src="{{item.iconPath}}" class="item-img" /> | ||||
|  |             <View class="item-text">{{item.text}}</View> | ||||
|  |         </view> | ||||
|  |     </view> | ||||
|  | </view> | ||||
| @ -0,0 +1,33 @@ | |||||
|  | /* pages/workbench/workbench.wxss */ | ||||
|  | .workbench-page { | ||||
|  |     width: 100vw; | ||||
|  |     height: 100vh; | ||||
|  |     background-color: #EDF1F8; | ||||
|  | } | ||||
|  | 
 | ||||
|  | .workbench { | ||||
|  |     display: flex; | ||||
|  |     flex-wrap: wrap; | ||||
|  |     justify-content: space-evenly; | ||||
|  |     align-items: flex-start; | ||||
|  | } | ||||
|  | 
 | ||||
|  | .workbench-item { | ||||
|  |     width: 166px; | ||||
|  |     height: 138px; | ||||
|  |     background: #FFFFFF; | ||||
|  |     border-radius: 8px; | ||||
|  |     margin-top: 12px; | ||||
|  | } | ||||
|  | 
 | ||||
|  | .item-img { | ||||
|  |     width: 40px; | ||||
|  |     height: 40px; | ||||
|  |     margin: 16px 0px 44px 12px; | ||||
|  | } | ||||
|  | 
 | ||||
|  | .item-text { | ||||
|  |     font-size: 16px; | ||||
|  |     color: #333333; | ||||
|  |     margin-left: 12px; | ||||
|  | } | ||||